DecisionTableAPI - Scoped, Global
The DecisionTableAPI class enables you to access Decision Tables data in scoped and global server-side scripts.
To access DecisionTableAPI methods, use the sn_dt
namespace. You must have the decision_table_crud_api role to use this API. To learn more about
Decision Tables, see Decision Tables.
DecisionTableAPI - DecisionTableAPI()
Instantiates a DecisionTableAPI object.
| Name | Type | Description |
|---|---|---|
| None |
var dt = new sn_dt.DecisionTableAPI();
DecisionTableAPI - createAnswerElementChoices(String decisionID, Array questions)
Creates multiple records in the Choices [sys_choice] table that are linked to answer elements.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| choices | Array | Array of objects used to create records in the Choices [sys_choice] table. Each object creates one choice record. |
| choices.answerElementID | String | Sys_id of the answer element to associate with the choice. Table: Result [sys_decision_multi_result_element] |
| choices.label | String | Label of the choice. |
| choices.order | Number | Optional. Order of the choice. |
| choices.value | String | Value of the choice. |
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each choice. Data type: Array |
| <Object>.results.errors | Error information for the choice. Data type: Array |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the choice created in the Choices [sys_choice]
table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the choice record was successfully created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two choices for an answer element.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var answerElementID = '99d197c83d0b9910f8776a598af912df';
var choices = [
{
label: 'Hyderabad',
value: 'hyd',
answerElementId: answerElementID,
order: 20
},
{
label: 'Mumbai',
value: 'mum',
answerElementId: answerElementID,
order: 40
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createAnswerElementChoices(decisionID, choices);
gs.info('Status - ' + response.status);
gs.info('First choice sys id - ' + response.results[0].record.getValue('sys_id'));
gs.info('Second choice sys id - ' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First choice sys id - 6bc0d3c03d0b9910f8776a598af912c6
Second choice sys id - 6fc0d3c03d0b9910f8776a598af912c9
DecisionTableAPI - createAnswerElements(String decisionID, Array answerElements)
Creates multiple records in the Result [sys_decision_multi_result_element] table that are related to the specified decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| answerElements | Array | Array of objects used to create records in the Result Elements [sys_decision_multi_result_element] table. Each object creates one answer element record. |
| answerElements.label | String | Label of the answer element record. |
| answerElements.maxsize | Number | Optional. Maximum number of characters allowed in the answer element field. Use this property only if answerElements.type is Default value: 250 |
| answerElements.order | Number | Optional. Order of the answer element. |
| answerElements.reference | String | Required if the value of answerElements.type is Reference. Name of the reference table used by the answer element. |
| answerElements.type | String | Answer element input type. Valid values:
|
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each answer element. Data type: Array |
| <Object>.results.errors | Error information for the answer element. Data type: Array |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the answer element created in the Result Elements [sys_decision_multi_result_element] table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the answer element record was successfully created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two answer elements for a decision table.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var answerElements = [
{
label: 'City name',
name: 'city',
type: 'choice',
comments: 'City name',
},
{
label: 'Assigned To',
name: 'assigned_to',
type: 'reference',
reference: 'sys_user'
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createAnswerElements(decisionID, answerElements);
gs.info('Status - ' + response.status);
gs.info('First answer element sys id - ' + response.results[0].record.getValue('sys_id'));
gs.info('Second answer element sys id - ' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First answer element sys id - 41c707803d0b9910f8776a598af91201
Second answer element sys id - 51c707803d0b9910f8776a598af91217
DecisionTableAPI - createConditions(String decisionID, Array conditions)
Creates multiple records in the Decision Conditions [sn_decision_table_decision_condition] table that are related to the specified decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| conditions | Array | Array of objects used to create records in the Decision Conditions [sn_decision_table_decision_condition] table. Each object creates one decision condition record. |
| conditions.decisionInput | String | Sys_id of the decision input to associate with the condition. Table: Decision Inputs [sys_decision_input] |
| conditions.defaultOperator | String | Optional. Default operator for the condition. For a list of valid operators, see Operators available for filters and queries. |
| conditions.label | String | Label of the decision condition record. |
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each decision condition. Data type: Array of Objects |
| <Object>.results.errors | Error information for the decision condition. Data type: Array of Objects |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the decision condition created in the Decision
Conditions [sn_decision_table_decision_condition] table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the decision condition record was successfully created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two decision conditions for a decision table.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var conditions = [
{
label: 'Total count',
decisionInput: '22bde5003dc39910f8776a598af91292',
defaultOperator: '!='
},
{
label: 'Is Incident Active',
decisionInput: '6abde5003dc39910f8776a598af9127e',
default_operator: 'ISEMPTY',
order: 10,
field: 'u_incident.active'
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createConditions(decisionID, conditions);
gs.info('Status - ' + response.status);
gs.info('First condition sys id - ' + response.results[0].record.getValue('sys_id'));
gs.info('Second condition sys id - ' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First condition sys id - c1530f4c3dc79910f8776a598af912ef
Second condition sys id - c9530f4c3dc79910f8776a598af912f1
DecisionTableAPI - createDecisionTable(Object decisionTable)
Creates a decision table record in the Decision Tables [sys_decision] table.
| Name | Type | Description |
|---|---|---|
| decisionTable | Object | Key-value pairs of the field names and values to use to create a decision table
record. |
| decisionTable.accessibleFrom | String | Optional. Scopes that have access to the decision table record. Valid
values:
|
| decisionTable.name | String | Name of the decision table. |
| decisionTable.scope | String | Scope of the decision table record. |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the decision table created in the Decision Tables
[sys_decision] table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates an Emergency Change Policy decision table.
var decisionTable = {
name: 'Emergency Change Policy',
scope: 'global',
accessibleFrom: 'public'
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createDecisionTable(decisionTable);
gs.info('Status -' + response.status);
gs.info('Decision Table sys id - ' + response.record.getValue('sys_id'));
Output:
Status - Success
Decision Table sys id - 665569083d839910f8776a598af91223
DecisionTableAPI - createInputChoices(String decisionID, Array choices)
Creates multiple records in the Choices [sys_choice] table that are linked to decision inputs.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| choices | Array | Array of objects used to create records in the Choices [sys_choice] table. Each object creates one choice record. |
| choices.inputID | String | Sys_id of the decision input to associate with the choice. Table: Decision Inputs [sys_decision_input] |
| choices.label | String | Label of the choice. |
| choices.order | Number | Optional. Order of the choice. |
| choices.value | String | Value of the choice. |
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each choice. Data type: Array of Objects |
| <Object>.results.errors | Error information for the choice. Data type: Array of Objects |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the choice created in the Choices [sys_choice]
table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the choice record was successfully created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two choices for a decision input.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var inputID = '4d1f8f083d0b9910f8776a598af91274';
var choices = [
{
label: 'Hyderabad',
value: 'hyd',
inputId: inputID,
order: 20
},
{
label: 'Mumbai',
value: 'mum',
inputId: inputID,
order: 40
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createInputChoices(decisionID, choices);
gs.info(JSON.stringify(response));
gs.info('Status - ' + response.status);
gs.info('First choice sys id - ' + response.results[0].record.getValue('sys_id'));
gs.info('Second choice sys id - ' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First choice sys id - 6bc0d3c03d0b9910f8776a598af912c6
Second choice sys id - 6fc0d3c03d0b9910f8776a598af912c9
DecisionTableAPI - createInputs(String decisionID, Array inputs)
Creates multiple records in the Decision Inputs [sys_decision_input] table that are related to the specified decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| inputs | Array | Array of objects used to create records in the Decision Input
[sys_decision_input] table. Each object creates one decision input
record. |
| inputs.label | String | Label of the decision input record. |
| inputs.maxsize | Number | Optional. Maximum number of characters allowed in the input field. Use this
property only if inputs.type is
Default value: 250 |
| inputs.order | Number | Optional. Order of the input. |
| inputs.reference | String | Required if the value of inputs.type is
Reference. Name of the reference table used by the decision
input. |
| inputs.type | String | Decision input type. Valid values:
|
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each decision input. Data type: Array |
| <Object>.results.errors | Error information for the decision input. Data type: Array |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the decision input created in the Decision Inputs
[sys_decision_input] table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the decision input record was successfully
created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two inputs for a decision table.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var inputs = [
{
label: 'Incident',
type: 'reference',
reference: 'incident',
ref_qual: 'active=true^EQ'
},
{
label: 'Total count',
type: 'integer'
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createInputs(decisionID,inputs);
gs.info('Status - ' + response.status);
gs.info('First input id –' + response.results[0].record.getValue('sys_id'));
gs.info('Second input id –' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First input id - 5dbfa58c3d839910f8776a598af91219
Second input id - 95bfe1803dc39910f8776a598af912fa
DecisionTableAPI - createQuestions(String decisionID, Array questions)
Creates multiple records in the Decisions [sys_decision_question] table that are related to the specified decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| questions | Array | Array of objects used to create records in the Decisions [sys_decision_question] table. Each object creates one question record. |
| questions.active | Boolean | Flag that indicates whether the question record is active. Valid values:
|
| questions.answer | Array | List of possible answers to the question. For a single result table, the array can only have one object. For a multi-result table, the array can have multiple objects. |
| questions.answer.name | String | Name of the answer element. Table: Result [sys_decision_multi_result_element] |
| questions.answer.value | String | Value of the answer element. Table: Result [sys_decision_multi_result_element] |
| questions.condition | String | Conditions required to reach this question. The fields available for the conditions are the decision inputs that are associated with the decision table. For more information about creating conditions, see Operators available for filters and queries. |
| questions.defaultAnswer | Boolean | Flag that indicates whether this question is the default question for the decision table. Valid values:
|
| questions.order | Number | Order of the question. |
| Type | Description |
|---|---|
| Object | Object with information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results | Array with information about the status of each question. Data type: Array of Objects |
| <Object>.results.errors | Error information for the question. Data type: Array of Objects |
| <Object>.results.errors.message | Error message. Data type: String |
| <Object>.results.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.results.record | GlideRecord reference to the question created in the Decisions
[sys_decision_question] table. Data type: GlideRecord |
| <Object>.results.status | Status that indicates whether the question record was successfully created. Possible values:
Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example creates two questions for a decision table.
var decisionID = 'a45be18c3d839910f8776a598af91269';
var questions = [
{
condition: 'u_item=Phone^u_price=500^EQ',
answer:[
{
name: 'u_seller',
value: '02826bf03710200044e0bfc8bcbe5d64'
},
{
name: 'u_discount',
value: '5'
}
],
active: true,
defaultAnswer: true,
order: 300
},
{
condition: 'u_item=Laptop^u_price>800^EQ',
answer:[
{
name: 'u_discount',
value: '20'
}
],
active: true,
defaultAnswer: false,
order: 150
}
];
var dt = new sn_dt.DecisionTableAPI();
var response = dt.createQuestions(decisionID, questions);
gs.info(JSON.stringify(response));
gs.info('Status - ' + response.status);
gs.info('First decision sys id - ' + response.results[0].record.getValue('sys_id'));
gs.info('Second decision sys id - ' + response.results[1].record.getValue('sys_id'));
Output:
Status - Success
First decision sys id - 21c8d3003d4b9910f8776a598af91213
Second decision sys id - e9c8d3003d4b9910f8776a598af91218
DecisionTableAPI - deleteAnswerElement(String answerElementID)
Deletes a record in the Result [sys_decision_multi_result_element] table.
| Name | Type | Description |
|---|---|---|
| answerElementID | String | Sys_id of the answer element record. Table: Result Elements [sys_decision_multi_result_element] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes an answer element.
var answerElementID = '51c707803d0b9910f8776a598af91217';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteAnswerElement(answerElementID);
gs.info('Status - ' + response.status);
Output:
Status - Success
DecisionTableAPI - deleteChoice(String choiceID)
Deletes a record in the Choices [sys_choice] table.
| Name | Type | Description |
|---|---|---|
| choiceID | String | Sys_id of the choice record. Table: Choices [sys_choice] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes a choice.
var choiceID = '4532db883d0b9910f8776a598af912e7';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteChoice(choiceID);
gs.info('Status - ' + response.status);
Output:
Status - Success
DecisionTableAPI - deleteCondition(String conditionID)
Deletes a record in the Decision Conditions [sn_decision_table_decision_condition] table.
| Name | Type | Description |
|---|---|---|
| conditionID | String | Sys_id of the decision condition record. Table: Decision Conditions [sn_decision_table_decision_condition] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes a decision condition.
var conditionID = 'c9530f4c3dc79910f8776a598af912f1';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteCondition(conditionID);
gs.info('Status - ' + response.status);
Output:
Status - Success
DecisionTableAPI - deleteDecisionTable(String decisionID)
Deletes a record in the Decision Tables [sys_decision] table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes a decision table.
var decisionID = 'a1f6e14c3d039910f8776a598af9129d';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteDecisionTable(decisionID);
gs.info('Status -' + response.status);
Output:
Status - Success
DecisionTableAPI - deleteInput(String inputID)
Deletes a record in the Decision Inputs [sys_decision_input] table.
| Name | Type | Description |
|---|---|---|
| inputID | String | Sys_id of the decision input record. Table: Decision Inputs [sys_decision_input] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes a decision input.
var inputID = 'a1f6e14c3d039910f8776a598af9129d';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteInput(inputID);
gs.info('Status -' + response.status);
Output:
Status - Success
DecisionTableAPI - deleteQuestion(String questionID)
Deletes a record in the Decisions [sys_decision_question] table.
| Name | Type | Description |
|---|---|---|
| questionID | String | Sys_id of the question record. Table: Decisions [sys_decision_question] |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example deletes a question.
var questionId = '700602fe81d21110f87735acbca2c610';
var dt = new sn_dt.DecisionTableAPI();
var response = dt.deleteQuestion(questionId);
gs.info('Status - ' + response.status);
Output:
Status - Success
DecisionTableAPI - getAll()
Returns all decision tables from the Decision Tables [sys_decision] table.
| Name | Type | Description |
|---|---|---|
| None |
| Type | Description |
|---|---|
| Object | All decision tables and their fields from the Decision Tables [sys_decision]
table. Each decision table contains these key-value pairs:
Format: JSON |
var dt = new sn_dt.DecisionTableAPI();
var response = dt.getAll();
gs.info(JSON.stringify(response));
Output:
{"result": [
{
"distinctAnswers": [{
"valid": true,
"label": "Assignment Group Manager Approval",
"value": "5684821db701230034d1da23ee11a94d",
"table": "chg_approval_def"
}],
"referenceQualifier": "",
"inputs": [
{
"searchField": null,
"defaultValue": "0",
"show_ref_finder": false,
"use_dependent": false,
"type": "integer",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "eca52ca7b701230034d1da23ee11a95a",
"type_label": "Integer",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "",
"choiceOption": "",
"label": "CI Count",
"hint": "",
"name": "ci_count",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 40,
"columnName": ""
},
{
"searchField": "number",
"defaultValue": "",
"show_ref_finder": false,
"use_dependent": false,
"type": "reference",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "change_request",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "1395e8a7b701230034d1da23ee11a9b6",
"type_label": "Reference",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "Change Request",
"choiceOption": "",
"label": "Change request",
"hint": "",
"name": "change_request",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 32,
"columnName": ""
}
],
"domain": "global",
"answerType": "reference",
"questions": [{
"defaultAnswer": false,
"condition": "ci_count>=1000^EQ",
"answer": {
"valid": true,
"label": "Assignment Group Manager Approval",
"value": "5684821db701230034d1da23ee11a94d",
"table": "chg_approval_def"
},
"decisionTable": "e49568a7b701230034d1da23ee11a913",
"domain": "global",
"active": true,
"state": null,
"id": "2a36eca7b701230034d1da23ee11a961",
"label": "Mandatory Approval if 1000 CIs or more",
"order": 0
}],
"accessibleFrom": "public",
"name": "Example Standard Change Policy",
"active": true,
"id": "e49568a7b701230034d1da23ee11a913",
"label": "",
"answerTable": {
"displayValue": "Change Approval Definition",
"value": "chg_approval_def"
}
},
{
"distinctAnswers": [
{
"valid": true,
"label": "CAB Approval",
"value": "45358a5db701230034d1da23ee11a938",
"table": "chg_approval_def"
},
{
"valid": true,
"label": "Assignment Group Manager Approval",
"value": "5684821db701230034d1da23ee11a94d",
"table": "chg_approval_def"
},
{
"valid": true,
"label": "Assignment Group Approval",
"value": "dc95ca5db701230034d1da23ee11a9e9",
"table": "chg_approval_def"
}
],
"referenceQualifier": "",
"inputs": [
{
"searchField": null,
"defaultValue": "false",
"show_ref_finder": false,
"use_dependent": false,
"type": "boolean",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "c0a7869db701230034d1da23ee11a9e7",
"type_label": "True/False",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "",
"choiceOption": "",
"label": "Manager approved",
"hint": "",
"name": "manager_approved",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 40,
"columnName": ""
},
{
"searchField": "number",
"defaultValue": "",
"show_ref_finder": false,
"use_dependent": false,
"type": "reference",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "change_request",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "23164e5db701230034d1da23ee11a9c5",
"type_label": "Reference",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "Change Request",
"choiceOption": "",
"label": "Change request",
"hint": "",
"name": "change_request",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 32,
"columnName": ""
}
],
"domain": "global",
"answerType": "reference",
"questions": [
{
"defaultAnswer": false,
"condition": "change_request.state=-3^change_request.riskIN2,3^NQchange_request.state=-3^change_request.assignment_group.managerISEMPTY^EQ",
"answer": {
"valid": true,
"label": "CAB Approval",
"value": "45358a5db701230034d1da23ee11a938",
"table": "chg_approval_def"
},
"decisionTable": "5b06ce5db701230034d1da23ee11a965",
"domain": "global",
"active": true,
"state": null,
"id": "10284a9db701230034d1da23ee11a9c1",
"label": "Requires CAB Approval",
"order": 0
},
{
"defaultAnswer": false,
"condition": "change_request.state=-3^change_request.risk=4^manager_approved=false^EQ",
"answer": {
"valid": true,
"label": "Assignment Group Manager Approval",
"value": "5684821db701230034d1da23ee11a94d",
"table": "chg_approval_def"
},
"decisionTable": "5b06ce5db701230034d1da23ee11a965",
"domain": "global",
"active": true,
"state": null,
"id": "88e6829db701230034d1da23ee11a9a9",
"label": "Low Risk Manager approval",
"order": 0
},
{
"defaultAnswer": false,
"condition": "change_request.state=-4^EQ",
"answer": {
"valid": true,
"label": "Assignment Group Approval",
"value": "dc95ca5db701230034d1da23ee11a9e9",
"table": "chg_approval_def"
},
"decisionTable": "5b06ce5db701230034d1da23ee11a965",
"domain": "global",
"active": true,
"state": null,
"id": "a436029db701230034d1da23ee11a989",
"label": "Assess Technical Approvals",
"order": 0
}
],
"accessibleFrom": "public",
"name": "Normal Change Policy",
"active": true,
"id": "5b06ce5db701230034d1da23ee11a965",
"label": "",
"answerTable": {
"displayValue": "Change Approval Definition",
"value": "chg_approval_def"
}
},
]}
DecisionTableAPI - getAnswers(String decisionID)
Returns the answers associated with the specified decision table. An answer is a record on any table associated with a Decision [sys_decision_question] record.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| Type | Description |
|---|---|
| Object | Answer records associated with the decision table. Each record contains these
key-value pairs:
Format: JSON |
var dt = new sn_dt.DecisionTableAPI();
var response = dt.getAnswers("3c4464a7b701230034d1da23ee11a993");
gs.info(JSON.stringify(response));
Output:
{
"result": [
{
"answerElementValues": [
{
"valid": true,
"answerElementName": "u_user",
"label": "Abel Tuter",
"value": "62826bf03710200044e0bfc8bcbe5df1",
"table": "sys_user"
}],
"valid": true,
"multipleAnswerRecord": true,
"label": "User: Abel Tuter",
"value": "76e19cd953d7011097a3ddeeff7b122c",
"table": "sys_decision_multi_result"
},
]
}
DecisionTableAPI - getDecision(String decisionID, Map inputs)
Evaluates a decision table based on the provided inputs and returns an answer. If no inputs are provided, returns the first default answer found.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| inputs | Map | Optional. Input values for the Decision Inputs [sys_decision_input] table associated with the provided decision table. Use the value of the Column name field as the key. The data type of
the value must match the Decision Input Type field. If no inputs are provided, returns the first default answer found. Remarque : All inputs and column names must follow the following format:
For example,
For more information, see Make Decisions from JavaScript with the DecisionTableAPI - Workflow Automation CoE |
| Type | Description |
|---|---|
| GlideRecord | The correctly evaluated Answer record associated with the decision table. An answer record is a record from the table defined in the Decision [sys_decision_question] record Answer table
field.
|
var dt = new sn_dt.DecisionTableAPI();
var inputs = new Object();
inputs['u_age'] = 25;
var response = dt.getDecision('26eea7a9dba07300efc65404ce961961', inputs);
var user = response.result_elements.u_user;
DecisionTableAPI - getDecisions(String decisionID, Map inputs)
Evaluates a decision table based on the provided inputs and returns all correctly evaluated answers. If no inputs are provided, returns all default answers.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| inputs | Map | Optional. Input values for the Decision Inputs [sys_decision_input] table associated with the provided decision table. If no inputs are provided, returns all default answers. Remarque : All inputs and column names must
follow the following format:
For example,
For more information, see Make Decisions from JavaScript with the DecisionTableAPI - Workflow Automation CoE |
| Type | Description |
|---|---|
| Array | List of answer records in GlideRecord format. An answer record is a record on
any table associated with a Decision [sys_decision_question] record.
|
var dt = new sn_dt.DecisionTableAPI();
var input = new Object();
input['u_age'] = 25;
var response = dt.getDecisions('5b06ce5db701230034d1da23ee11a965', input);
var firstRecord = response[0];
var user = firstRecord.result_elements.u_user;
DecisionTableAPI - getDecisionTable(String decisionID)
Returns a single decision table from the Decision Tables [sys_decision] table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| Type | Description |
|---|---|
| Object | Decision table from the Decision Tables [sys_decision] table. Each decision
table contains these key-value pairs.
Format: JSON |
var dt = new sn_dt.DecisionTableAPI();
var response = dt.getDecisionTable("3c4464a7b701230034d1da23ee11a993");
gs.info(JSON.stringify(response));
Output:
"distinctAnswers": [{
"valid": true,
"label": "CAB Approval",
"value": "45358a5db701230034d1da23ee11a938",
"table": "chg_approval_def"
}],
"referenceQualifier": "",
"inputs": [{
"searchField": "number",
"defaultValue": "",
"show_ref_finder": false,
"use_dependent": false,
"type": "reference",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "change_request",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "634420a7b701230034d1da23ee11a94f",
"type_label": "Reference",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "Change Request",
"choiceOption": "",
"label": "Change request",
"hint": "",
"name": "change_request",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 32,
"columnName": ""
}],
"domain": "global",
"answerType": "reference",
"questions": [{
"defaultAnswer": true,
"condition": "change_request.state=-3^EQ",
"answer": {
"valid": true,
"label": "CAB Approval",
"value": "45358a5db701230034d1da23ee11a938",
"table": "chg_approval_def"
},
"decisionTable": "3c4464a7b701230034d1da23ee11a993",
"domain": "global",
"active": true,
"state": null,
"id": "2764a4a7b701230034d1da23ee11a989",
"label": "Requires CAB Approval",
"order": 0
}],
"accessibleFrom": "public",
"name": "Emergency Change Policy",
"active": true,
"id": "3c4464a7b701230034d1da23ee11a993",
"label": "",
"answerTable": {
"displayValue": "Change Approval Definition",
"value": "chg_approval_def"
}
}
DecisionTableAPI - getInputs(String decisionID)
Returns the decision inputs from the Decision Inputs [sys_decision_input] table associated with the passed in decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| Type | Description |
|---|---|
| Object | Decision inputs from the Decision Inputs [sys_decision_input] table associated
with the decision table. You can find the inputs associated with a decision table
using the Decision Inputs related list in the Decision Tables [sys_decision] table.
Inputs contain these key-value pairs.
Format: JSON |
var dt = new sn_dt.DecisionTableAPI();
var response = dt.getInputs("3c4464a7b701230034d1da23ee11a993");
gs.info(JSON.stringify(response));
Output:
{"result": [{
"searchField": "number",
"defaultValue": "",
"show_ref_finder": false,
"use_dependent": false,
"type": "reference",
"mandatory": false,
"extended": false,
"local": false,
"sys_class_name": "",
"reference": "change_request",
"dependent_on": "",
"data_structure": "",
"readonly": false,
"id": "634420a7b701230034d1da23ee11a94f",
"type_label": "Reference",
"table": "",
"order": 100,
"ref_qual": "",
"reference_display": "Change Request",
"choiceOption": "",
"label": "Change request",
"hint": "",
"name": "change_request",
"attributes": {"element_mapping_provider": "com.glide.decision_table.data.DecisionTableVariableMapper"},
"maxsize": 32,
"columnName": ""
}]}
DecisionTableAPI - getQuestions(String decisionID)
Returns the decisions from the Decision [sys_decision_question] table associated with the passed in decision table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the Decision Table record from the Decision Tables [sys_decision] table. |
| Type | Description |
|---|---|
| Object | Decisions from the Decision [sys_decision_question] table associated with the
decision table. You can find the decisions associated with a decision table using
the Decisions related list in the Decision Tables [sys_decision] table. Decision
records contain these key-value pairs.
Format: JSON |
var dt = new sn_dt.DecisionTableAPI();
var response = dt.getQuestions("3c4464a7b701230034d1da23ee11a993");
gs.info(JSON.stringify(response));
Output:
{"result": [{
"defaultAnswer": true,
"condition": "change_request.state=-3^EQ",
"answer": {
"valid": true,
"label": "CAB Approval",
"value": "45358a5db701230034d1da23ee11a938",
"table": "chg_approval_def"
},
"decisionTable": "3c4464a7b701230034d1da23ee11a993",
"domain": "global",
"active": true,
"state": null,
"id": "2764a4a7b701230034d1da23ee11a989",
"label": "Requires CAB Approval",
"order": 0
}]}
DecisionTableAPI - updateAnswerElement(String answerElementID, Object answerElement)
Updates a record in the Result [sys_decision_multi_result_element] table.
| Name | Type | Description |
|---|---|---|
| answerElementID | String | Sys_id of the answer element record. Table: Result Elements [sys_decision_multi_result_element] |
| answerElement | Object | Key-value pairs to update the answer element record. |
| answerElement.comments | String | Optional. Description of the answer element. |
| answerElement.label | String | Optional. Label of the answer element record. |
| answerElement.maxsize | Number | Optional. Maximum number of characters allowed in the answer element field.
Use this property only if answerElement.type is
|
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the answer element updated in the Result Elements
[sys_decision_multi_result_element] table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates the label and comments for an answer element.
var answerElementID = '51c707803d0b9910f8776a598af91217';
var answerElement = {
label: 'Product',
comments: 'hello'
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateAnswerElement(answerElementID, answerElement);
gs.info('Status - ' + response.status);
gs.info('Result Element label changed to - ' + response.record.getValue('label'));
Output:
Status - Success
Result Element label changed to - Product
DecisionTableAPI - updateChoice (String choiceID, Object choice)
Updates a record in the Choices [sys_choice] table.
| Name | Type | Description |
|---|---|---|
| choiceID | String | Sys_id of the choice record. Table: Choices [sys_choice] |
| choice | Object | Key-value pairs to update the choice record. |
| choice.label | String | Optional. Label of the choice. |
| choice.order | Number | Optional. Order of the choice. |
| choice.value | String | Optional. Value of the choice. |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the choice updated in the Choices [sys_choice]
table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates the label, value, and order for a choice.
var choiceID = '4532db883d0b9910f8776a598af912e7';
var choices = {
label: 'Delhi',
value: 'del',
order: 50
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateChoice(choiceID, choices);
gs.info('Status - ' + response.status);
Output:
Status - Success
DecisionTableAPI - updateCondition(String conditionID, Object condition)
Updates a record in the Decision Conditions [sn_decision_table_decision_condition] table.
| Name | Type | Description |
|---|---|---|
| conditionID | String | Sys_id of the decision condition record. Table: Decision Conditions [sn_decision_table_decision_condition] |
| condition | Object | Key-value pairs to update the decision condition record. |
| condition.defaultOperator | String | Optional. Default operator for the condition. For a list of valid operators, see Operators available for filters and queries. |
| condition.description | String | Optional. Description of the condition. |
| condition.label | String | Optional. Label of the decision condition record. |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the decision condition updated in the Decision
Conditions [sn_decision_table_decision_condition] table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates a decision condition.
var conditionID = 'c9530f4c3dc79910f8776a598af912f1';
var condition = {
defaultOperator: '!=',
label: 'Active Incident',
description: 'Check if the incident is active'
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateCondition(conditionID, condition);
gs.info('Status - ' + response.status);
gs.info('Condition label changed to - ' + response.record.getValue('label'));
Output:
Status - Success
Condition label changed to - Active Incident
DecisionTableAPI - updateDecisionTable(String decisionID, Object decisionTable)
Updates a record in the Decision Tables [sys_decision] table.
| Name | Type | Description |
|---|---|---|
| decisionID | String | Sys_id of the decision table record. Table: Decision Tables [sys_decision] |
| decisionTable | Object | Key-value pairs to update the decision table record. |
| decisionTable.accessibleFrom | String | Optional. Scopes that have access to the decision table record. Valid
values:
|
| decisionTable.name | String | Optional. Name of the decision table. |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the decision table. Data type: GlideRecord Table: Decision Tables [sys_decision] |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates a decision table.
var decisionID = 'a1f6e14c3d039910f8776a598af9129d';
var decisionTable = {
name: 'Emergency Change Request',
accessibleFrom: 'public',
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateDecisionTable(decisionID, decisionTable);
gs.info('Status -' + response.status);
gs.info('Decision Table sys id - ' + response.record.getValue('sys_id'));
Output:
Status - Success
Decision Table sys id - a1f6e14c3d039910f8776a598af9129d
DecisionTableAPI - updateInput(String inputID, Object input)
Updates a record in the Decision Inputs [sys_decision_input] table.
| Name | Type | Description |
|---|---|---|
| inputID | String | Sys_id of the decision input record. Table: Decision Inputs [sys_decision_input] |
| input | Object | Key-value pairs to update a decision input record. |
| input.active | Boolean | Optional. Flag that indicates whether the decision input record is active. Valid values:
|
| input.defaultValue | String | Optional. Default value for the input. |
| input.label | String | Optional. Label of the decision input record. |
| input.mandatory | Boolean | Optional. Flag that indicates whether the input is mandatory. Valid values:
|
| input.maxsize | Number | Optional. Maximum number of characters allowed in the input field. Use this
property only if input.type is
|
| input.order | Number | Optional. Order of the input. |
| input.readonly | Boolean | Optional. Flag that indicates whether the input is read-only. Valid values:
|
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the decision input updated in the Decision Inputs
[sys_decision_input] table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates a decision input.
var inputID = 'e862f1803dc39910f8776a598af912da';
var input = {
label: 'Item name',
defaultValue: 'Apple',
maxsize: 100,
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateInput(inputID, input);
gs.info(JSON.stringify(response));
gs.info('Status - ' + response.status);
gs.info('Input label changed to - ' + response.record.getValue('label'));
Output:
Status - Success
Input label changed to - Item name
DecisionTableAPI - updateQuestion(String questionID, Object question)
Updates a record in the Decisions [sys_decision_question] table.
| Name | Type | Description |
|---|---|---|
| questionID | String | Sys_id of the question record. Table: Decisions [sys_decision_question] |
| question | Object | Key-value pairs to update the question record. |
| question.active | Boolean | Optional. Flag that indicates whether the question record is active. Valid values:
|
| question.answer | Array | Optional. List of possible answers to the question. For a single result table, the array can only have one object. For a multi-result table, the array can have multiple objects. |
| question.answer.name | String | Optional. Name of the answer element. Table: Result Elements [sys_decision_multi_result_element] |
| question.answer.value | String | Optional. Value of the answer element. Table: Result Elements [sys_decision_multi_result_element] |
| question.condition | String | Optional. Conditions required to reach this question. The fields available for the conditions are the decision inputs that are associated with the decision table. For more information about creating conditions, see Operators available for filters and queries. |
| question.defaultAnswer | Boolean | Optional. Flag that indicates whether this question is the default question for the decision table. Valid values:
|
| question.label | String | Optional. Label of the question record. |
| question.order | Number | Optional. Order of the question. |
| Type | Description |
|---|---|
| Object | Information about the status of the API request. |
| <Object>.errors | Error information. Data type: Array of Objects |
| <Object>.errors.message | Error message. Data type: String |
| <Object>.errors.type | Type of error. Possible value: INTERNAL_ERROR Data type: String |
| <Object>.record | GlideRecord reference to the question updated in the Decisions
[sys_decision_question] table. Data type: GlideRecord |
| <Object>.status | Status of the API request. Possible values:
Data type: String |
This example updates a question record.
var questionId = '70381fcc3d0b9910f8776a598af91219';
var questions = {
condition: 'u_item=Laptop^u_price>1800^EQ',
answer:[
{
name: 'u_discount',
value: '40',
},
{
name: 'u_seller',
value: '02826bf03710200044e0bfc8bcbe5d64',
},
],
active: true,
order: 3000
};
var dt = new sn_dt.DecisionTableAPI();
var response = dt.updateQuestion(questionId, questions);
gs.info('Status - ' + response.status);
Output:
Status - Success