Difference between revisions of "Automatically Attach an Event"

From SDU
Jump to: navigation, search
(Step 1. Create the script)
Line 6: Line 6:
 
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).
 
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).
  
<!--c1--><div class='codetop'>CODE</div><div class='codemain'><!--ec1-->alg&#58;&#58;zmyscript&#40;...&#41; {<br> send_wait&#40;0, this, "call_attr", "internal", "set_val", "1", "SURE_SET"&#41;;<br> &nbsp;if &#40;msg_error&#40;&#41;&#41; { <br> &nbsp; logf&#40;ERROR, "error updating alg internal with 1&#58; &#39;%s&#39;", msg&#91;0&#93;&#41;; <br> &nbsp;}<br>}<!--c2--></div><!--ec2-->
+
cr::zmyscript(...){
 +
object group_leader1;  
 +
object attached_events_table_record1;
 +
send_wait(0, top_object(), "get_co_group");
 +
if (msg_error()) {
 +
logf(ERROR, "%s - %s", ref_num, msg[0]);
 +
}
 +
group_leader1 = msg[0];
 +
send_wait( 0, top_object(), "call_attr", "atev", "get_new_dob", NULL, NULL, group_leader1);  
 +
if (msg_error()) {  
 +
logf(ERROR, "%s - %s", ref_num, msg[0]);  
 +
}
 +
attached_events_table_record1 = msg[0];  
 +
attached_events_table_record1.obj_id = persistent_id;  
 +
attached_events_table_record1.event_tmpl = "<color=red>evt:400001</color>"; //Identify Event Here
 +
send_wait(0, group_leader1, "checkin");
 +
if (msg_error()) {
 +
logf(ERROR, "%s - %s", ref_num, msg[0]);
 +
}
 +
}
  
''Note: The example script works for Requests, Incidents, and Problems. Change the 'alg' in the first line of the script to 'chgalg' for Change Orders or 'issalg' for Issues.''
+
''Note: The example script works for Requests, Incidents, and Problems. Change the 'cr' in the first line of the script to 'chg' for Change Orders or 'iss' for Issues.''
 
<br><br>
 
<br><br>
  

Revision as of 18:45, 13 January 2008

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.

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).

cr::zmyscript(...){ object group_leader1; object attached_events_table_record1; send_wait(0, top_object(), "get_co_group"); if (msg_error()) { logf(ERROR, "%s - %s", ref_num, msg[0]); } group_leader1 = msg[0]; send_wait( 0, top_object(), "call_attr", "atev", "get_new_dob", NULL, NULL, group_leader1); if (msg_error()) { logf(ERROR, "%s - %s", ref_num, msg[0]); } attached_events_table_record1 = msg[0]; attached_events_table_record1.obj_id = persistent_id; attached_events_table_record1.event_tmpl = "<color=red>evt:400001</color>"; //Identify Event Here send_wait(0, group_leader1, "checkin"); if (msg_error()) { logf(ERROR, "%s - %s", ref_num, msg[0]); } }

Note: The example script works for Requests, Incidents, and Problems. Change the 'cr' in the first line of the script to 'chg' for Change Orders or 'iss' for Issues.

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.

For r11.x releases triggers are created via the Schema Designer utility. Simply add the following code as a Site-Defined Trigger to the desired table.

CODE
POST_VALIDATE zmyscript() 100 FILTER (type { -> 'EVT' } );

Note: This code will work for all ticket types.

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

CODE
MODIFY alg POST_VALIDATE zmyscript() 100 FILTER (type { -> 'EVT' } );

Note: This code works for Requests, Incidents, and Problems. Change the 'alg' to 'chgalg' for Change Orders or 'issalg' for Issues.

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 your Schema changes
  2. Stop the Service Desk service
  3. Run pdm_publish from a command line
  4. Start the Service Desk service

For older release recycle the Service Desk service.