action.create

描述

object action.create(object/array actions)

此方法允许 create 新动作。

此方法仅对 管理员超级管理员 用户类型可用。 可以在用户角色设置中撤销调用该方法的权限。更多信息请参见 User roles

参数

(object/array) 要创建的操作。

除了 动作 外, 该方法还接受以下参数。

参数 数据类型 说明
filter object 该操作的 操作过滤器 object。
operations array 该操作的 action-操作,用于 create。
recovery_operations array 该操作的 action-恢复操作,用于 create。
update_operations array 该操作的 Action update operations,用于 create。

返回值

(object) 返回一个object,其中包含在actionids属性下列出的已创建动作的ID。返回的ID顺序与传入的动作顺序一致。

示例

创建触发器动作

创建一个触发器动作,当来自主机"10084"的触发器(名称中包含单词"memory")进入PROBLEM状态时,该动作将开始执行。 此动作将配置4操作。 第一个即时操作将通过媒介类型"1"向用户组"7"中的所有用户发送消息。 如果事件在30分钟内未解决,则第二个操作将在属于"2"组的所有主机上run 配置全局脚本"5"(作用域为"Action operation"的脚本)。 如果事件得到解决,恢复操作将通知所有收到过有关此问题消息的用户。 如果事件被更新,确认/update操作将向所有收到过有关此问题消息的用户发送通知(使用自定义主题和消息)。

执行请求:

{  "jsonrpc": "2.0",  "method": "action.create",  "params": {  "name": "Trigger action",  "eventsource": 0,  "esc_period": "30m",  "filter": {  "evaltype": 0,  "conditions": [  {  "conditiontype": 1,  "operator": 0,  "value": "10084"  },  {  "conditiontype": 3,  "operator": 2,  "value": "memory"  }  ]  },  "operations": [  {  "operationtype": 0,  "esc_step_from": 1,  "esc_step_to": 1,  "opmessage_grp": [  {  "usrgrpid": "7"  }  ],  "opmessage": {  "default_msg": 1,  "mediatypeid": "1"  }  },  {  "operationtype": 1,  "esc_step_from": 2,  "esc_step_to": 2,  "opconditions": [  {  "conditiontype": 14,  "operator": 0,  "value": "0"  }  ],  "opcommand_grp": [  {  "groupid": "2"  }  ],  "opcommand": {  "scriptid": "5"  }  }  ],  "recovery_operations": [  {  "operationtype": "11",  "opmessage": {  "default_msg": 1  }  }  ],  "update_operations": [  {  "operationtype": "12",  "opmessage": {  "default_msg": 0,  "message": "Custom update operation message body",  "subject": "Custom update operation message subject"  }  }  ]  },  "id": 1 }

响应:

{  "jsonrpc": "2.0",  "result": {  "actionids": [  "17"  ]  },  "id": 1 }

创建发现动作

创建一个发现动作,将模板“10001”链接到已发现的 主机。

执行请求:

{  "jsonrpc": "2.0",  "method": "action.create",  "params": {  "name": "Discovery action",  "eventsource": 1,  "filter": {  "evaltype": 0,  "conditions": [  {  "conditiontype": 21,  "operator": 0,  "value": "1"  },  {  "conditiontype": 10,  "operator": 0,  "value": "2"  }  ]  },  "operations": [  {  "operationtype": 6,  "optemplate": [  {  "templateid": "10001"  }  ]  }  ]  },  "id": 1 }

响应:

{  "jsonrpc": "2.0",  "result": {  "actionids": [  "18"  ]  },  "id": 1 }

使用自定义表达式过滤器

创建一个使用自定义表达式"A and (B or C)"来评估操作条件的触发器动作。 当来自主机"10084"或主机"10106"且严重性大于等于"警告"的触发器进入问题状态时, 该动作将通过媒介类型"1"向用户组"7"中的所有用户发送消息。 公式ID"A"、"B"和"C"是任意选择的。

执行请求:

{  "jsonrpc": "2.0",  "method": "action.create",  "params": {  "name": "Trigger action",  "eventsource": 0,  "esc_period": "15m",  "filter": {  "evaltype": 3,  "formula": "A and (B or C)",  "conditions": [  {  "conditiontype": 4,  "operator": 5,  "value": "2",  "formulaid": "A"  },  {  "conditiontype": 1,  "operator": 0,  "value": "10084",  "formulaid": "B"  },  {  "conditiontype": 1,  "operator": 0,  "value": "10106",  "formulaid": "C"  }  ]  },  "operations": [  {  "operationtype": 0,  "esc_step_from": 1,  "esc_step_to": 1,  "opmessage_grp": [  {  "usrgrpid": "7"  }  ],  "opmessage": {  "default_msg": 1,  "mediatypeid": "1"  }  }  ]  },  "id": 1 }

响应:

{  "jsonrpc": "2.0",  "result": {  "actionids": [  "18"  ]  },  "id": 1 }

创建 agent 自动注册规则

创建一个自动注册动作,当主机名称包含"SRV"或元数据包含"AlmaLinux"时,将一个主机添加到主机组"2"。

执行请求:

{  "jsonrpc": "2.0",  "method": "action.create",  "params": {  "name": "Register Linux servers",  "eventsource": "2",  "filter": {  "evaltype": "2",  "conditions": [  {  "conditiontype": "22",  "operator": "2",  "value": "SRV"  },  {  "conditiontype": "24",  "operator": "2",  "value": "AlmaLinux"  }  ]  },  "operations": [  {  "operationtype": "4",  "opgroup": [  {  "groupid": "2"  }  ]  }  ]  },  "id": 1 }

响应:

{  "jsonrpc": "2.0",  "result": {  "actionids": [  19  ]  },  "id": 1 }

创建带主机标签的Agent自动注册规则

创建一个自动注册动作,将 一个主机 添加到 主机组 "2",并添加两个 主机 标签。

执行请求:

{  "jsonrpc": "2.0",  "method": "action.create",  "params": {  "name": "Register Linux servers with tags",  "eventsource": "2",  "operations": [  {  "operationtype": "4",  "opgroup": [  {  "groupid": "2"  }  ]  },  {  "operationtype": "13",  "optag": [  {  "tag": "location",  "value": "office"  },  {  "tag": "city",  "value": "Riga"  }  ]  }  ]  },  "id": 1 }

响应:

{  "jsonrpc": "2.0",  "result": {  "actionids": [  20  ]  },  "id": 1 }

另请参阅

来源

CAction::create() 在 ui/include/classes/api/services/CAction.php 中。