Difference between revisions of "Automatically Set Assignee to Closing Analyst"

From SDU
Jump to: navigation, search
(New page: Category:Customizations This article provides instructions for having system generated Activities set to ''Internal'' so it cannot be viewed by users of the Employee or Customer Interf...)
 
m
 
(34 intermediate revisions by 3 users not shown)
Line 1: Line 1:
 +
__NOTOC__
 
[[Category:Customizations]]
 
[[Category:Customizations]]
This article provides instructions for having system generated Activities set to ''Internal'' so it cannot be viewed by users of the Employee or Customer Interfaces.
+
{{Global Header}}
 +
{{Global Announcement}}
  
== Step 1. Create the script ==
+
== Overview ==
A script is created as an .spl file and placed in the [[NX_ROOT]]/site/mods/majic directory. When the Service Desk service starts, the contents of the majic directory are processed and cached. You can use any naming scheme you like for your .spl file, but it is recommended that the file be preceded with a 'z' for easy identification as a custom file (eg zMyCompany.spl, zcr_scripts.spl, zMyScripts.spl).
+
This article provides instructions for having system generated [[Activities]] set to ''Internal'' so it cannot be viewed by users of the Employee or Customer Interfaces.
  
<!--c1--><div class='codetop'>CODE</div><div class='codemain'><!--ec1-->// User &#39;cr&#39; for Requests, Incidents &amp; Problems, &#39;chg&#39; for Changes, and &#39;iss&#39; for Issues<br>cr&#58;&#58;zmyscript&#40;...&#41;{<br>object group_leader1;<br>object attached_events_table_record1;<br>send_wait&#40;0, top_object&#40;&#41;, "get_co_group"&#41;;<br>if &#40;msg_error&#40;&#41;&#41; {<br>logf&#40;ERROR, "%s - %s", ref_num, msg&#91;0&#93;&#41;;<br>}<br>group_leader1 = msg&#91;0&#93;;<br>send_wait&#40; 0, top_object&#40;&#41;, "call_attr", "atev", "get_new_dob", NULL, NULL, group_leader1&#41;;<br>if &#40;msg_error&#40;&#41;&#41; {<br>logf&#40;ERROR, "%s - %s", ref_num, msg&#91;0&#93;&#41;;<br>}<br>attached_events_table_record1 = msg&#91;0&#93;;<br>attached_events_table_record1.obj_id = persistent_id;<br>// Enter the persid of the event<br>attached_events_table_record1.event_tmpl = "evt&#58;400001";<br>send_wait&#40;0, group_leader1, "checkin"&#41;;<br>if &#40;msg_error&#40;&#41;&#41; {<br>logf&#40;ERROR, "%s - %s", ref_num, msg&#91;0&#93;&#41;;<br>}<br>}<!--c2--></div><!--ec2-->
+
== Procedures ==
 +
=== Step 1. Create the script ===
 +
A script is created as an [[.spl file]] and placed in the [[$NX_ROOT]]/site/mods/majic directory. When the Service Desk service starts, the contents of the majic directory are processed and cached. You can use any naming scheme you like for your [[.spl file]], but it is recommended that the file be preceded with a 'z' for easy identification as a custom file (eg zMyCompany.spl, zcr_scripts.spl, zMyScripts.spl).
  
The trigger that will be created in step 2 is the first level filtering. If you need further filtering then utilize an [[if statement]] in the spel code above.
+
<source lang="javascript">// Use 'cr' for Requests, Incidents & Problems, 'chg' for Changes, and 'iss' for Issues
<br>
+
cr::zmyscript(...){
 +
if(is_null(assignee)){
 +
// Use 'int' in place of 'uuid' in the line below if for pre-r11 releases
 +
uuid userid;
 +
send_wait(0, top_object(), "call_attr", "cr", "current_user_id");
 +
userid = msg[0];
 +
assignee = userid;
 +
}
 +
}</source>
  
== Step 2. Create the trigger ==
+
The trigger that will be created in step 2 is the first level filtering. If you need further filtering then utilize an [[If|if statement]] in the [[spel code]] above.
This step is to create the trigger that will initiate the script. The methods used to implement the trigger vary based on the Service Desk release.  In the examples to follow, the trigger is designed to fire if the Status is being changed to 'Resolved'. Use whatever filter you like for attaching your event.
+
  
<font color="blue">For r11.x releases</font> triggers are created via the Schema Designer utility. Simply add the following code as a Site-Defined Trigger to the '''cr (Request)''', '''chg (Change Order)''', or '''iss (Issue)''' table.
+
=== Step 2. Create the trigger ===
<!--c1--><div class='codetop'>CODE</div><div class='codemain'><!--ec1-->POST_VALIDATE zmyscript&#40;&#41; 113 FILTER &#40;status { -&#62; &#39;RE&#39; } &#41;&#59;<!--c2--></div><!--ec2-->
+
This step is to create the trigger that will initiate the script. The methods used to implement the trigger vary based on the Service Desk release.  In the examples to follow, the trigger is designed to fire if the Status is being changed to 'Resolved'. Use whatever filter you like for attaching your [[Events and Macros|event]].
  
<font color="blue">For older releases</font> triggers are made by creating a .mod file and placing it in the [[NX_ROOT]]/site/mods/majic directory. Name the .mod anything you like, but it is recommended that it be preceded with a 'z'.
+
''For r11.x releases'' triggers are created via the [[Schema Designer]] utility. Simply add the following code as a [[Site-Defined Trigger]] to the '''[[Call Req Table|cr (Request)]]''', '''[[Change Request Table|chg (Change Order)]]''', or '''[[Issue Table|iss (Issue)]]''' table.
 +
POST_VALIDATE zmyscript() 111 FILTER(EVENT("UPDATE") && status{->'CL'});
  
<!--c1--><div class='codetop'>CODE</div><div class='codemain'><!--ec1-->MODIFY cr POST_VALIDATE zmyscript&#40;&#41; 113 FILTER &#40;status { -&#62; &#39;RE&#39; } &#41;;<br><br>MODIFY chg POST_VALIDATE zmyscript&#40;&#41; 113 FILTER &#40;status { -&#62; &#39;RE&#39; } &#41;;<br><br>MODIFY iss POST_VALIDATE zmyscript&#40;&#41; 113 FILTER &#40;status { -&#62; &#39;RE&#39; } &#41;;<!--c2--></div><!--ec2-->
+
''For older releases'' triggers are made by creating a [[.mod file]] and placing it in the [[$NX_ROOT]]/site/mods/majic directory. Name the [[.mod file|.mod]] anything you like, but it is recommended that it be preceded with a 'z'.
<br>
+
  
== Step 3. Publish the Schema changes ==
+
<source lang="javascript">// Use OBJECT cr for Requests, Incidents & Problems
 +
// Use OBJECT chg for Change Orders
 +
// Use OBJECT iss for Issues
 +
OBJECT cr {
 +
  TRIGGERS {
 +
    POST_VALIDATE zmyscript() 111 FILTER(EVENT("UPDATE") && status{->'CL'});
 +
  };
 +
};</source>
 +
 
 +
=== Step 3. Publish the Schema changes ===
 
The methods used to publish schema changes vary based on the Service Desk release.
 
The methods used to publish schema changes vary based on the Service Desk release.
  
<font color="blue">For r11.x releases</font>, follow these steps:
+
''For r11.x releases'', follow these steps:
#Save your Schema changes
+
#Save and Publish your Schema changes (under File menu of Schema Designer)
 
#Stop the Service Desk service
 
#Stop the Service Desk service
#Run pdm_publish from a command line
+
#Run [[pdm_publish]] from a command line
 
#Start the Service Desk service
 
#Start the Service Desk service
  
<font color="blue">For older release</font> recycle the Service Desk service.
+
''For older releases'' recycle the Service Desk service.
<br>
+

Latest revision as of 04:10, 27 July 2008

To make corrections or additions to this article, select the edit tab above.
To discuss or ask questions about this article, select the discussion tab above.

Overview

This article provides instructions for having system generated Activities set to Internal so it cannot be viewed by users of the Employee or Customer Interfaces.

Procedures

Step 1. Create the script

A script is created as an .spl file and placed in the $NX_ROOT/site/mods/majic directory. When the Service Desk service starts, the contents of the majic directory are processed and cached. You can use any naming scheme you like for your .spl file, but it is recommended that the file be preceded with a 'z' for easy identification as a custom file (eg zMyCompany.spl, zcr_scripts.spl, zMyScripts.spl).

<source lang="javascript">// Use 'cr' for Requests, Incidents & Problems, 'chg' for Changes, and 'iss' for Issues cr::zmyscript(...){ if(is_null(assignee)){ // Use 'int' in place of 'uuid' in the line below if for pre-r11 releases uuid userid; send_wait(0, top_object(), "call_attr", "cr", "current_user_id"); userid = msg[0]; assignee = userid; } }</source>

The trigger that will be created in step 2 is the first level filtering. If you need further filtering then utilize an if statement in the spel code above.

Step 2. Create the trigger

This step is to create the trigger that will initiate the script. The methods used to implement the trigger vary based on the Service Desk release. In the examples to follow, the trigger is designed to fire if the Status is being changed to 'Resolved'. Use whatever filter you like for attaching your event.

For r11.x releases triggers are created via the Schema Designer utility. Simply add the following code as a Site-Defined Trigger to the cr (Request), chg (Change Order), or iss (Issue) table.

POST_VALIDATE zmyscript() 111 FILTER(EVENT("UPDATE") && status{->'CL'});

For older releases triggers are made by creating a .mod file and placing it in the $NX_ROOT/site/mods/majic directory. Name the .mod anything you like, but it is recommended that it be preceded with a 'z'.

<source lang="javascript">// Use OBJECT cr for Requests, Incidents & Problems // Use OBJECT chg for Change Orders // Use OBJECT iss for Issues OBJECT cr {

 TRIGGERS {
   POST_VALIDATE zmyscript() 111 FILTER(EVENT("UPDATE") && status{->'CL'});
 };

};</source>

Step 3. Publish the Schema changes

The methods used to publish schema changes vary based on the Service Desk release.

For r11.x releases, follow these steps:

  1. Save and Publish your Schema changes (under File menu of Schema Designer)
  2. Stop the Service Desk service
  3. Run pdm_publish from a command line
  4. Start the Service Desk service

For older releases recycle the Service Desk service.