这是原厂英文文档的翻译页面. 欢迎帮助我们 完善文档.

创建触发器

描述

object trigger.create(object/array triggers)

此方法允许创建新的触发器.

此方法只适用于AdminSuper admin用户类型,调用该方法的权限可以在用户角色设置中被撤销. 前往 用户角色 以查看并了解更多信息.

参数

(object/array) 要创建的触发器.

除了 标准触发器属性 之外,该方法还接受以下参数.

参数 类型 描述
dependencies array 目的触发器.

目的触发器必须存在且已定义triggerid属性.
tags array 触发器标签 标签.

触发器表达式必须以扩展形式给出.

返回值

(object) 返回一个对象,该对象包含在 triggerids 属性下创建的触发器 ID,返回 的ID 顺序与传递的触发器的顺序相匹配.

示例

创建触发器

创建具有单个触发依赖关系的触发器.

请求:

{
           "jsonrpc": "2.0",
           "method": "trigger.create",
           "params": [
               {
                   "description": "Processor load is too high on {HOST.NAME}",
                   "expression": "last(/Linux server/system.cpu.load[percpu,avg1])>5",
                   "dependencies": [
                       {
                           "triggerid": "17367"
                       }
                   ]
               },
               {
                   "description": "Service status",
                   "expression": "length(last(/Linux server/log[/var/log/system,Service .* has stopped]))<>0",
                   "dependencies": [
                       {
                           "triggerid": "17368"
                       }
                   ],
                   "tags": [
                       {
                           "tag": "service",
                           "value": "{{ITEM.VALUE}.regsub(\"Service (.*) has stopped\", \"\\1\")}"
                       },
                       {
                           "tag": "error",
                           "value": ""
                       }
                   ]
               }
           ],
           "auth": "038e1d7b1735c6a5436ee9eae095879e",
           "id": 1
       }

响应:

{
           "jsonrpc": "2.0",
           "result": {
               "triggerids": [
                   "17369",
                   "17370"
               ]
           },
           "id": 1
       }

源码

CTrigger::create() in ui/include/classes/api/services/CTrigger.php.