Toggle menu
862
3.8K
30.2K
279.1K
Catglobe Wiki
Toggle personal menu
Not logged in
Your IP address will be publicly visible if you make any edits.

WorkflowScript class: Difference between revisions

From Catglobe Wiki
Tungocman (talk | contribs)
No edit summary
No edit summary
 
(10 intermediate revisions by 3 users not shown)
Line 2: Line 2:
|Name=<nowiki>WorkflowScript</nowiki>
|Name=<nowiki>WorkflowScript</nowiki>
|Description=<nowiki>Class to manipulate workflows.</nowiki>
|Description=<nowiki>Class to manipulate workflows.</nowiki>
|Constructors=
|InheritsFrom=object|Constructors=
{{CGscriptConstructors_Template|Parameters=
{{CGscriptConstructors_Template|Parameters=
{{CGscriptParameters_Template|Type=number|Name=<nowiki>resourceId</nowiki>|Description=<nowiki>Resource id of the script to load</nowiki>}}
{{CGscriptParameters_Template|Type=int|Name=<nowiki>resourceId</nowiki>|Description=<nowiki>Resource id of the script to load</nowiki>}}
|Description=<nowiki>Load existing workflow</nowiki>}}
|Description=<nowiki>Load existing workflow</nowiki>}}
{{CGscriptConstructors_Template|Parameters=
{{CGscriptConstructors_Template|Parameters=
Line 10: Line 10:
|Description=<nowiki>Make new workflow</nowiki>}}
|Description=<nowiki>Make new workflow</nowiki>}}
|Methods=
|Methods=
{{CGscriptMethods_Template|ReturnType=AnyType|Name=<nowiki>Call</nowiki>|Parameters={{CGscriptParameters_Template|Type=params AnyType|Name=params AnyType|Description=}}
{{CGscriptMethods_Template|ReturnType=object|Name=<nowiki>Call</nowiki>|Parameters={{CGscriptParameters_Template|Type=params AnyType|Name=params AnyType|Description=}}
|Description=<nowiki>Run the script with the given arguments</nowiki>}}
|Description=<nowiki>Run the script with the given arguments</nowiki>}}
{{CGscriptMethods_Template|ReturnType=AnyType|Name=<nowiki>Invoke</nowiki>|Parameters=
{{CGscriptMethods_Template|ReturnType=object|Name=<nowiki>Invoke</nowiki>|Parameters=
{{CGscriptParameters_Template|Type=array|Name=<nowiki>arguments</nowiki>|Description=<nowiki>The arguments to the script</nowiki>}}
{{CGscriptParameters_Template|Type=array|Name=<nowiki>arguments</nowiki>|Description=<nowiki>The arguments to the script</nowiki>}}
|Description=<nowiki>Run the script with the given arguments</nowiki>}}
|Description=<nowiki>Run the script with the given arguments</nowiki>}}
{{CGscriptMethods_Template|ReturnType=Empty|Name=<nowiki>Save</nowiki>|Parameters=
{{CGscriptMethods_Template|ReturnType=Empty|Name=<nowiki>Save</nowiki>|Parameters=
{{CGscriptParameters_Template|Type=string|Name=<nowiki>name</nowiki>|Description=<nowiki>Name of the resource. If empty it will not change the existing name. Required for new scripts.</nowiki>|Comma=,}}{{CGscriptParameters_Template|Type=number|Name=<nowiki>parentResourceId</nowiki>|Description=<nowiki>Parent of the resource. If 0 it will not change the existing. Required for new scripts.</nowiki>}}
{{CGscriptParameters_Template|Type=string|Name=<nowiki>name</nowiki>|Description=<nowiki>Name of the resource. If empty it will not change the existing name. Required for new scripts.</nowiki>|Comma=,}}{{CGscriptParameters_Template|Type=int|Name=<nowiki>parentResourceId</nowiki>|Description=<nowiki>Parent of the resource. If 0 it will not change the existing. Required for new scripts.</nowiki>}}
|Description=<nowiki>Save the current workflowscript.</nowiki>}}
|Description=<nowiki>Save the current workflowscript.</nowiki>}}
{{CGscriptMethods_Template|ReturnType=Empty|Name=<nowiki>Save</nowiki>|Description=<nowiki>Save the current workflowscript using the existing name and parent.</nowiki>}}
{{CGscriptMethods_Template|ReturnType=Empty|Name=<nowiki>Save</nowiki>|Description=<nowiki>Save the current workflowscript using the existing name and parent.</nowiki>}}
{{CGscriptMethods_Template|ReturnType=string|Name=<nowiki>ToString</nowiki>|Description=<nowiki>The string representation of the object.</nowiki>}}
{{CGscriptMethods_Template|ReturnType=int|Name=<nowiki>Schedule</nowiki>|Parameters=
{{CGscriptParameters_Template|Type=CatTaskSchedule|Name=<nowiki>schedule</nowiki>|Description=<nowiki>When to run</nowiki>|Comma=,}}{{CGscriptParameters_Template|Type=bool|Name=<nowiki>informMe</nowiki>|Description=<nowiki>Send mail when finished task</nowiki>|Comma=,}}{{CGscriptParameters_Template|Type=array|Name=<nowiki>parameters</nowiki>|Description=<nowiki>Send mail when finished task</nowiki>}}
|Description=<nowiki>Schedule workflow to run at a given schedule. Returns CatTask instance id</nowiki>}}
{{CGscriptMethods_Template|ReturnType=string|Name=<nowiki>ToString</nowiki>|Inherited=object|Description=<nowiki>The string representation of the object.</nowiki>}}
|Properties=
|Properties=
{{CGscriptProperties_Template|ReturnType=bool|Name=<nowiki>BatchMode</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the if the non-tabulation script should run in batch mode.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=bool|Name=<nowiki>BatchMode</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the if the non-tabulation script should run in batch mode.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=string|Name=<nowiki>CgScript</nowiki>|HasGetter=1|Description=<nowiki>The script.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=string|Name=<nowiki>CgScript</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>The script.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=number|Name=<nowiki>DataCache</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the DataCache under which to run the script under. 0 means clear setting. Only for tabulation scripts.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=int|Name=<nowiki>DataCache</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the DataCache under which to run the script under. 0 means clear setting. Only for tabulation scripts.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=number|Name=<nowiki>ImpersonatedUser</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the user under which to run the script under. Must have Full access to the user to set as impersonation. 0 means clear impersonation.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=bool|Name=<nowiki>EnableProfiling</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Set to true to enable profiling.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=int|Name=<nowiki>ImpersonatedUser</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the user under which to run the script under. Must have Full access to the user to set as impersonation. 0 means clear impersonation.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=string|Name=<nowiki>ObjectTypeName</nowiki>|HasGetter=1|Description=<nowiki>The name of the type of object.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=string|Name=<nowiki>ObjectTypeName</nowiki>|HasGetter=1|Description=<nowiki>The name of the type of object.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=number|Name=<nowiki>Questionnaire</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the Questionnaire under which to run the script under. 0 means clear setting. Only for non-tabulation scripts.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=ProfilingResult|Name=<nowiki>ProfilingResult</nowiki>|HasGetter=1|Description=<nowiki>Returns the result of the Profiling.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=TypeInformation|Name=<nowiki>TypeInformation</nowiki>|HasGetter=1|Description=<nowiki>Get information about this class.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=int|Name=<nowiki>Questionnaire</nowiki>|HasGetter=1|HasSetter=1|Description=<nowiki>Get/Set the Questionnaire under which to run the script under. 0 means clear setting. Only for non-tabulation scripts.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=number|Name=<nowiki>UniqueId</nowiki>|HasGetter=1|Description=<nowiki>The resource id of the workflow.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=TypeInformation|Name=<nowiki>TypeInformation</nowiki>|HasGetter=1|Inherited=object|Description=<nowiki>Get information about this class.</nowiki>}}
{{CGscriptProperties_Template|ReturnType=int|Name=<nowiki>UniqueId</nowiki>|HasGetter=1|Description=<nowiki>The resource id of the workflow.</nowiki>}}
}}
}}


==== <span style="color:#a52a2a;">'''Examples'''</span>  ====
=== '''Notes''' ===
<source lang=javascript>
To be able to run the dynamic scripts, means using the second constructor of this class. Users must have this special navigation access in both module "Workflow Module" and "Tabulation Script Module": '''Able to create scripts that can dynamically create scripts'''. This special navigation access just can be seen and set by user '''Administrator'''.
 
 
=== '''Examples''' ===
 
'''Ex 1:''' <source lang="javascript">
/*
/*
  *   MAKE A COPY OF A SPECIFIED WORKFLOW
  * MAKE A COPY OF A SPECIFIED WORKFLOW
  */
  */


/* Input Parameters for this workflow */
/* Input Parameters for this workflow */
// Required - Set values here
// Required - Set values here
number inputWorkflow_RID;
number sourceWorkflowRID;
string nameOfTheCopy;
string nameOfCopy;
number parentResourceId;
number parentResourceId;  


/* Other variables */
/* Other variables */
Line 47: Line 57:
string CgScript;
string CgScript;
bool BatchMode;
bool BatchMode;
number ImpersonatedUser_RID;
number ImpersonatedUser;
number Questionnaire_RID;
number Questionnaire;
number DataCache_RID;
number DataCache;
object error;
object error;


/* Checking the required parameters */
/* Checking the required parameters */
if(inputWorkflow_RID == empty) {
if(sourceWorkflowRID == empty) {
print("Please set value for parameter: inputWorkflow_RID. Workflow failed.");
print("Please set value for parameter: sourceWorkflowRID. Workflow failed.");
return;
return;
}
}
if(nameOfTheCopy == empty) {
if(nameOfCopy == empty) {
print("Please set value for parameter: nameOfTheCopy. Workflow failed.");
print("Please set value for parameter: nameOfCopy. Workflow failed.");
return;
return;
}
}
if(parentResourceId == empty) {
if(parentResourceId == empty) {
print("Please set value for parameter: parentResourceId. Workflow failed.");
print("Please set value for parameter: parentResourceId. Workflow failed.");
return;
return;
}
}


/* Now doing the job: Making the copy */
/* Now doing the job: Making the copy */
object source = new WorkflowScript(inputWorkflow_RID);
object source = new WorkflowScript(sourceWorkflowRID);
object dest;
object dest;


// Check that the source is Tabulation Script or non-Tabulation Script
// Check that the source is Tabulation Script or non-Tabulation Script
try {
try {
if(source.DataCache != empty) // if throw error then the source is non-tabulation script
if(source.DataCache != empty) // if throw error then the source is non-tabulation script
isTabulation = true;
isTabulation = true;
}
}
catch(error){
catch(error){
// so the source is non-tabulation script
// so the source is non-tabulation script
isTabulation = false;
isTabulation = false;
}
}


Line 83: Line 93:
// The source is Tabulation Script
// The source is Tabulation Script
{
{
// Get all properties of this Tabulation Script
// Get all properties of this Tabulation Script
CgScript = source.CgScript;
CgScript = source.CgScript;
DataCache_RID = source.DataCache;
DataCache = source.DataCache;
 
    dest = new WorkflowScript(CgScript, true);
try
dest.DataCache = DataCache_RID;
// because this property is not available for Tabulation Script in 581 version
ImpersonatedUser = source.ImpersonatedUser;
// Save the copied one
catch(error) {}
dest.Save(nameOfTheCopy, parentResourceId);
 
print("Completed! The resource if of new copyied one: " + dest.UniqueId);
dest = new WorkflowScript(CgScript, true);
dest.DataCache = DataCache;
return dest;
try
// because this property is not available for Tabulation Script in 581 version
dest.ImpersonatedUser = ImpersonatedUser;
catch(error) {}
// Save the copied one
dest.Save(nameOfCopy, parentResourceId);
print("Completed! The resource id of new copied one: " + dest.UniqueId);  
return dest;
}  
}  
// The source is non-Tabulation Script
// The source is non-Tabulation Script
else {
else {
// Get all properties of this non-Tabulation Script
// Get all properties of this non-Tabulation Script
CgScript = source.CgScript;
CgScript = source.CgScript;
Questionnaire_RID = source.Questionnaire;
Questionnaire = source.Questionnaire;
BatchMode = source.BatchMode;
BatchMode = source.BatchMode;
ImpersonatedUser = source.ImpersonatedUser;
    dest = new WorkflowScript(CgScript, false);
dest.Questionnaire = Questionnaire_RID;
dest = new WorkflowScript(CgScript, false);
dest.BatchMode = BatchMode;
dest.Questionnaire = Questionnaire;
dest.BatchMode = BatchMode;
dest.ImpersonatedUser = ImpersonatedUser;


// Save the copied one
// Save the copied one
dest.Save(nameOfTheCopy, parentResourceId);
dest.Save(nameOfCopy, parentResourceId);
print("Completed! The resource if of new copyied one: " + dest.UniqueId);
print("Completed! The resource id of new copied one: " + dest.UniqueId);  
return dest;
return dest;
}
}
</source>
<br />'''Ex 2:''' <source lang="javascript">
ProfilingResult pr;
WorkflowScript wf = new WorkflowScript(11951195);
pr = wf.ProfilingResult;
pr.EnableProfiling = true;
wf.Call();
print(pr.Script); // {print("hello world");}
print(pr.CompileTime); // 0.0595
print(pr.CountResult); // {"1": {"4": 1}}
print(pr.DependencyGraphTime); // 0
print(pr.TimeResult); // {"1": {"-1": 0.0034, "4": 0.0034}}
print(pr.WhereExpTime); // 0
</source>
'''Example for schedule a workflow '''
<source lang="javascript">
//wS.Schedule(schedule, informMe, parameters)
number workflowRId = 15562503;
WorkflowScript wS = new WorkflowScript(workflowRId);
DateTime dt = new DateTime("2017/05/31 03:10");
CatTaskSpecificTimeSchedule schedule  = new CatTaskSpecificTimeSchedule(dt);
//CatTaskInstantSchedule schedule  = new CatTaskInstantSchedule();
bool informMe = false;
array parameters={};
wS.Schedule(schedule, informMe, parameters);//Returns CatTask instance id: 104700 (CatTaskMetaDataId: 54183)
</source>
</source>

Latest revision as of 06:33, 2 July 2020

WorkflowScript



Class to manipulate workflows.

Parent class

Inherits from object

Constructors

  • (int resourceId "Resource id of the script to load") - Load existing workflow
  • (string script "The script to use.", bool isTabulation "Set if this is a tabulation script or not") - Make new workflow

Methods

  • object Call(params AnyType) - Run the script with the given arguments
  • object Invoke(array arguments "The arguments to the script") - Run the script with the given arguments
  • Empty Save(string name "Name of the resource. If empty it will not change the existing name. Required for new scripts.", int parentResourceId "Parent of the resource. If 0 it will not change the existing. Required for new scripts.") - Save the current workflowscript.
  • Empty Save() - Save the current workflowscript using the existing name and parent.
  • int Schedule(CatTaskSchedule schedule "When to run", bool informMe "Send mail when finished task", array parameters "Send mail when finished task") - Schedule workflow to run at a given schedule. Returns CatTask instance id
  • (From object) string ToString() - The string representation of the object.

Properties

  • bool BatchMode { get; set; } - Get/Set the if the non-tabulation script should run in batch mode.
  • string CgScript { get; set; } - The script.
  • int DataCache { get; set; } - Get/Set the DataCache under which to run the script under. 0 means clear setting. Only for tabulation scripts.
  • bool EnableProfiling { get; set; } - Set to true to enable profiling.
  • int ImpersonatedUser { get; set; } - Get/Set the user under which to run the script under. Must have Full access to the user to set as impersonation. 0 means clear impersonation.
  • string ObjectTypeName { get; } - The name of the type of object.
  • ProfilingResult ProfilingResult { get; } - Returns the result of the Profiling.
  • int Questionnaire { get; set; } - Get/Set the Questionnaire under which to run the script under. 0 means clear setting. Only for non-tabulation scripts.
  • (From object) TypeInformation TypeInformation { get; } - Get information about this class.
  • int UniqueId { get; } - The resource id of the workflow.


Notes

To be able to run the dynamic scripts, means using the second constructor of this class. Users must have this special navigation access in both module "Workflow Module" and "Tabulation Script Module": Able to create scripts that can dynamically create scripts. This special navigation access just can be seen and set by user Administrator.


Examples

Ex 1:

/*
 * MAKE A COPY OF A SPECIFIED WORKFLOW
 */

/* Input Parameters for this workflow */
// Required - Set values here
number sourceWorkflowRID;
string nameOfCopy;
number parentResourceId; 

/* Other variables */
bool isTabulation;
string CgScript;
bool BatchMode;
number ImpersonatedUser;
number Questionnaire;
number DataCache;
object error;

/* Checking the required parameters */
if(sourceWorkflowRID == empty) {
 print("Please set value for parameter: sourceWorkflowRID. Workflow failed.");
 return;
}
if(nameOfCopy == empty) {
 print("Please set value for parameter: nameOfCopy. Workflow failed.");
 return;
}
if(parentResourceId == empty) {
 print("Please set value for parameter: parentResourceId. Workflow failed.");
 return;
}

/* Now doing the job: Making the copy */
object source = new WorkflowScript(sourceWorkflowRID);
object dest;

// Check that the source is Tabulation Script or non-Tabulation Script
try {
 if(source.DataCache != empty) // if throw error then the source is non-tabulation script
 isTabulation = true;
}
catch(error){
 // so the source is non-tabulation script
 isTabulation = false;
}

if(isTabulation == true) 
// The source is Tabulation Script
{
 // Get all properties of this Tabulation Script
 CgScript = source.CgScript;
 DataCache = source.DataCache;

 try 
 // because this property is not available for Tabulation Script in 581 version
 ImpersonatedUser = source.ImpersonatedUser;
 catch(error) {}
 

 dest = new WorkflowScript(CgScript, true);
 dest.DataCache = DataCache;
 
 try 
 // because this property is not available for Tabulation Script in 581 version
 dest.ImpersonatedUser = ImpersonatedUser;
 catch(error) {}
 
 // Save the copied one
 dest.Save(nameOfCopy, parentResourceId);
 
 print("Completed! The resource id of new copied one: " + dest.UniqueId); 
 
 return dest;
} 
// The source is non-Tabulation Script
else {
 // Get all properties of this non-Tabulation Script
 CgScript = source.CgScript;
 Questionnaire = source.Questionnaire;
 BatchMode = source.BatchMode;
 ImpersonatedUser = source.ImpersonatedUser;
 
 dest = new WorkflowScript(CgScript, false);
 dest.Questionnaire = Questionnaire;
 dest.BatchMode = BatchMode;
 dest.ImpersonatedUser = ImpersonatedUser;

 // Save the copied one
 dest.Save(nameOfCopy, parentResourceId);
 
 print("Completed! The resource id of new copied one: " + dest.UniqueId); 
 
 return dest;
}


Ex 2:

ProfilingResult pr;
WorkflowScript wf = new WorkflowScript(11951195);
pr = wf.ProfilingResult;
pr.EnableProfiling = true;
wf.Call();

print(pr.Script); // {print("hello world");}
print(pr.CompileTime); // 0.0595
print(pr.CountResult); // {"1": {"4": 1}} 
print(pr.DependencyGraphTime); // 0
print(pr.TimeResult); // {"1": {"-1": 0.0034, "4": 0.0034}}
print(pr.WhereExpTime); // 0

Example for schedule a workflow

//wS.Schedule(schedule, informMe, parameters)
number workflowRId = 15562503;
WorkflowScript wS = new WorkflowScript(workflowRId);
DateTime dt = new DateTime("2017/05/31 03:10");
CatTaskSpecificTimeSchedule schedule  = new CatTaskSpecificTimeSchedule(dt);
//CatTaskInstantSchedule schedule  = new CatTaskInstantSchedule();
bool informMe = false;
array parameters={};
wS.Schedule(schedule, informMe, parameters);//Returns CatTask instance id: 104700 (CatTaskMetaDataId: 54183)