AutoreplyOrCorrespondence: Difference between revisions

From Request Tracker Wiki
Jump to navigation Jump to search
(Created page with "When creating a ticket on someone's behalf this template code will choose to use the Autoreply or Correspondence templates. If the ticket creator is not a requestor or there is m...")
 
mNo edit summary
 
(3 intermediate revisions by 2 users not shown)
Line 1: Line 1:
When creating a ticket on someone's behalf this template code will choose to use the Autoreply or Correspondence templates. If the ticket creator is not a requestor or there is more than one requestor the Correspondence template is used, otherwise an Autoreply template is used.
This template code checks to see if the creator is the same as one of the requestors on ticket creation. If so it loads and processes the Autoreply template searching first in the current queue and if there isn't one there resorting to the global version.


If the requestor is not the creator then it processes the Correspondence template instead doing the same search as above.
The effect of using this template is that if a ticket is created on behalf of a customer they receive the message you create (on ticket creation) as if it is a reply rather than the default cryptic auto-reply.
It assumes there are at least global templates 'Autoreply' and 'Correspondence'.




<nowiki>
  {
    use RT::Template;
    my $creator_name = $Ticket->CreatorObj->Name;
    my $requestors = $Ticket->Requestors->UserMembersObj;
    my ( $c_requestor, $r_count ) = ( 0, 0 );
    while ( my $r = $requestors->Next() ) {
        if ( $r->Name eq $creator_name ) {
            $c_requestor++;
        }
        else {
            $r_count++;
        }
    }
    my $template = new RT::Template($RT::SystemUser);
    my $template_name;
   
    #if the creator is not a requestor or
    #there is more than one requestor ( who's not the creator )
    #use the Correspondence template
    if ( ! $c_requestor || $r_count ) {
        $template_name = 'Correspondence';
    }
    else {
        #otherwise use the Autoreply template
        $template_name = 'Autoreply';
    }


     #Load the Queue Template
<pre>
    $template->LoadQueueTemplate(  
     {
        Queue => $Ticket->Queue,  
      use RT::Template;
        Name => $template_name,
      my $creator_name = $Ticket->CreatorObj->Name;
    );
      my $requestors = $Ticket->Requestors->UserMembersObj;
    #if there's no Queue Template attempt to find a Global one.
      my ( $c_requestor, $r_count ) = ( 0, 0 );
    unless ( $template->id ) {
      while ( my $r = $requestors->Next() ) {
        $template->LoadGlobalTemplate( $template_name );
          if ( $r->Name eq $creator_name ) {
        unless ( $template->id ) {  
              $c_requestor++;
            $RT::Logger->error("Could not load template : $template_name")
          }
        }
          else {
              $r_count++;
          }
      }
      my $template = new RT::Template($RT::SystemUser);
      my $template_name;
     
      #if the creator is not a requestor or
      #there is more than one requestor ( who's not the creator )
      #use the Correspondence template
      if ( ! $c_requestor || $r_count ) {
          $template_name = 'Correspondence';
      }
      else {
          #otherwise use the Autoreply template
          $template_name = 'Autoreply';
      }
 
      #Load the Queue Template
      $template->LoadQueueTemplate(  
          Queue => $Ticket->Queue,  
          Name => $template_name,
      );
      #if there's no Queue Template attempt to find a Global one.
      unless ( $template->id ) {
          $template->LoadGlobalTemplate( $template_name );
          unless ( $template->id ) {  
              $RT::Logger->error("Could not load template : $template_name")
          }
      }
      #Process embedded fields & expressions of true templates;
      #note that we can only meaningfully use the body
      my($ret, $msg) = $template->Parse(
                          TicketObj => $Ticket,
                          TransactionObj => $Transaction,
                      );
      $ret ? $template->MIMEObj->stringify : $msg;
     }
     }
    #Process embedded fields & expressions of true templates;
  </pre>
    #note that we can only meaningfully use the body
    my($ret, $msg) = $template->Parse(
                        TicketObj => $Ticket,
                        TransactionObj => $Transaction,
                    );
    $ret ? $template->MIMEObj->stringify : $msg;
  }
</nowiki>

Latest revision as of 07:53, 16 August 2016

This template code checks to see if the creator is the same as one of the requestors on ticket creation. If so it loads and processes the Autoreply template searching first in the current queue and if there isn't one there resorting to the global version.

If the requestor is not the creator then it processes the Correspondence template instead doing the same search as above.

The effect of using this template is that if a ticket is created on behalf of a customer they receive the message you create (on ticket creation) as if it is a reply rather than the default cryptic auto-reply.

It assumes there are at least global templates 'Autoreply' and 'Correspondence'.


    {
      use RT::Template;
      my $creator_name = $Ticket->CreatorObj->Name;
      my $requestors = $Ticket->Requestors->UserMembersObj;
      my ( $c_requestor, $r_count ) = ( 0, 0 );
      while ( my $r = $requestors->Next() ) {
          if ( $r->Name eq $creator_name ) {
              $c_requestor++;
          }
          else {
              $r_count++;
          }
      }
      my $template = new RT::Template($RT::SystemUser);
      my $template_name;
      
      #if the creator is not a requestor or 
      #there is more than one requestor ( who's not the creator )
      #use the Correspondence template
      if ( ! $c_requestor || $r_count ) {
          $template_name = 'Correspondence';
      }
      else {
          #otherwise use the Autoreply template
          $template_name = 'Autoreply';
      }
  
      #Load the Queue Template
      $template->LoadQueueTemplate( 
          Queue => $Ticket->Queue, 
          Name => $template_name,
      );
      #if there's no Queue Template attempt to find a Global one.
      unless ( $template->id ) {
          $template->LoadGlobalTemplate( $template_name );
          unless ( $template->id ) { 
              $RT::Logger->error("Could not load template : $template_name")
          }
      }
      #Process embedded fields & expressions of true templates;
      #note that we can only meaningfully use the body
      my($ret, $msg) = $template->Parse(
                           TicketObj => $Ticket, 
                           TransactionObj => $Transaction,
                       );
      $ret ? $template->MIMEObj->stringify : $msg;
    }