创建

描述

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.