CatalogItemVariableSet - スコープ対象
CatalogItemVariableSet API を使用すると、スクリプトを使用してサービスカタログアイテムの変数セットを作成および変更できます。
CatalogItemVariableSet - create(ブール standardUpdate)
定義されたカタログアイテム変数セットを挿入します。
| 名前 | タイプ | 説明 |
|---|---|---|
| standardUpdate | ブーリアン | エンジンとワークフローの実行を有効にするかどうかを示すフラグです。 有効な値:
|
| タイプ | 説明 |
|---|---|
| 文字列 | 挿入された変数レコードの sys_id です。 |
// Given an existing catalog item
var catItemSysId = "e0d08b13c3330100c8b837659bba8fb4";
addVariableSets(catItemSysId);
function addVariableSets(catItemSysId) {
// List of all variable sets to attach
var myVarSets = [];
// Create variable set
var myVarSetAttrs = {"name": "Requester details", "order": "100"};
var myVarSet = new sn_sc.CatalogItemVariableSet();
myVarSet.setAttributes(myVarSetAttrs);
var myVarSetId = myVarSet.create(true);
myVarSets.push(myVarSetId);
}
CatalogItemVariableSet - deleteRecord(ブール standardUpdate)
変数セットを削除します。
| 名前 | タイプ | 説明 |
|---|---|---|
| standardUpdate | ブーリアン | エンジンとワークフローの実行を有効にするかどうかを示すフラグです。 有効な値:
|
| タイプ | 説明 |
|---|---|
| なし |
この例は、My Variable Set を使用しているすべてのカタログアイテムから My Variable Set を削除して、My Variable Set レコードを削除します。
// Get the sys_id of the variable set you want to delete
var vSet = new GlideRecord('item_option_new_set');
vSet.addEncodedQuery('title=My Variable Set'); // find My Variable Set
vSet.query();
if (vSet.next()) {
// first remove the variable set from all catalog items
var catItemVset = new GlideRecord('io_set_item'); // M2M table linking variable set and catalog item
catItemVset.addQuery('variable_set', vSet.getUniqueValue); // find all catalog items using My Variable Set
catItemVset.query();
while (catItemVset.next()) {
var vsetM2M = new sn_sc.CatalogItemVariableSetM2M(catItemVset.getUniqueValue()); // io_set_item M2M record sys_id
vsetM2M.deleteRecord(true); // delete M2M record
}
// then delete the variable set record
var varset = new sn_sc.CatalogItemVariableSet(vSet.getUniqueValue());
varset.deleteRecord(true);
}
CatalogItemVariableSet - read(オブジェクト columns, ブール standardUpdate)
カタログアイテム変数セットの属性値のマッピングを返します。
| 名前 | タイプ | 説明 |
|---|---|---|
| 列 | オブジェクト | 値を希望する列のセットを指定します。 |
| standardUpdate | ブーリアン | エンジンとワークフローの実行を有効にするかどうかを示すフラグです。 有効な値:
|
| タイプ | 説明 |
|---|---|
| オブジェクト | 列名を値にマッピングするオブジェクトです。 |
CatalogItemVariableSet - setAttributes(オブジェクト attributes)
変数セットの属性を設定します。
| 名前 | タイプ | 説明 |
|---|---|---|
| 属性 | オブジェクト | 列名を値にマッピングするオブジェクト |
| タイプ | 説明 |
|---|---|
| なし |
この例は、変数セットを作成して、新しい変数セットに変数を追加します。
createVariableSet('My Variable Set', 'This is my test variable set', '100', 'one_to_one');
function createVariableSet(name, description, order, type) {
var myVarSet = new sn_sc.CatalogItemVariableSet();
// fields used in object are from table item_option_new_set
var myVarSetAttrs = {
"name": name,
"description": description,
"order": order,
"type": type
};
myVarSet.setAttributes(myVarSetAttrs);
var myVarSetId = myVarSet.create(true); // returns the sys_id of the created variable set
gs.info('Variable set created in table item_option_new_set with sys_id ' + myVarSetId);
// add a variable to the newly created variable set
var myVar = new sn_sc.CatalogItemVariable();
var myVarAttrs = {
"type": "6", // type 6 is single line text
"variable_set": myVarSetId.toString(),
"question_text": "Example question",
"name": "example_question",
"order": 200
};
myVar.setAttributes(myVarAttrs);
myVar.create(true);
}
出力:
Variable set created in table item_option_new_set with sys_id e21df65a1bff7c10593876a61a4bcbc4
CatalogItemVariableSet - update(オブジェクト columnValues, ブール standardUpdate)
変数セットを更新します。
| 名前 | タイプ | 説明 |
|---|---|---|
| columnValues | オブジェクト | 列名を値にマッピングするオブジェクト |
| standardUpdate | ブーリアン | エンジンとワークフローの実行を有効にするかどうかを示すフラグです。 有効な値:
|
| タイプ | 説明 |
|---|---|
| なし |
この例は、Standard Employee Questions 変数セットの説明と順序を更新します。
// Get the sys_id of the variable set you want to update
var vSet = new GlideRecord('item_option_new_set');
vSet.addEncodedQuery('title=Standard Employee Questions'); // find the Standard Employee Questions variable set
vSet.query();
if (vSet.next()) {
var varset = new sn_sc.CatalogItemVariableSet(vSet.getUniqueValue());
var attr = {
'description': 'This should be used for all end user requests such as phones, tablets, etc. \n My description line',
'order': '500'
};
varset.update(attr, true);
}