获取

描述

integer/array maintenance.get(object parameters)

此方法用于根据给定参数获取维护模式。

任何类型的用户都可以使用此方法。权限可以在用户角色设置中撤消调用该方法。了解更多信息可以参见用户角色

参数

(object) 定义所需输出的参数。

该方法支持以下参数。

参数 类型 描述
groupids ID/数组 仅返回分配给指定主机组的维护。
hostids ID/数组 仅返回分配给指定主机的维护。
maintenanceids ID/数组 仅返回具有指定ID的维护。
selectHostGroups 查询 返回一个包含分配给维护的主机组的[主机组](../api/reference/hostgroup/object)属性。
selectHosts 查询 返回一个包含分配给维护的主机的[主机](../api/reference/host/object)属性。
selectTags 查询 返回一个包含维护的问题标签的[标签](../api/reference/maintenance/object#problem_tag)属性。
selectTimeperiods 查询 返回一个包含维护的时间段的[时间周期](../api/reference/maintenance/object#time_period)属性。
sortfield 字符串/数组 根据给定属性对结果进行排序。

可能的值:maintenanceidnamemaintenance_type
countOutput 布尔值 这些参数在参考说明中进行了描述。
editable 布尔值
excludeSearch 布尔值
filter 对象
limit 整数
output 查询
preservekeys 布尔值
search 对象
searchByAny 布尔值
searchWildcardsEnabled 布尔值
sortorder 字符串/数组
startSearch 布尔值
selectGroups
(已废弃)
查询 此参数已废弃,请改用selectHostGroups
返回一个包含分配给维护的主机组的[组](../api/reference/hostgroup/object)属性。

返回值

(整型/数组) 返回其中之一: - 一个对象数组; - 如果使用countOutput参数,被检索对象的数量。

案例

检索维护周期

检索所有已配置的维护,以及有关分配的主机组、定义的时间段和问题标签的数据。

请求

{
           "jsonrpc": "2.0",
           "method": "maintenance.get",
           "params": {
               "output": "extend",
               "selectHostGroups": "extend",
               "selectTimeperiods": "extend",
               "selectTags": "extend"
           },
           "id": 1
       }

响应:

{
           "jsonrpc": "2.0",
           "result": [
               {
                   "maintenanceid": "3",
                   "name": "Sunday maintenance",
                   "maintenance_type": "0",
                   "description": "",
                   "active_since": "1358844540",
                   "active_till": "1390466940",
                   "tags_evaltype": "0",
                   "hostgroups": [
                       {
                           "groupid": "4",
                           "name": "Zabbix servers",
                           "flags": "0",
                           "uuid": "6f6799aa69e844b4b3918f779f2abf08"
                       }
                   ],
                   "timeperiods": [
                       {
                           "timeperiod_type": "3",
                           "every": "1",
                           "month": "0",
                           "dayofweek": "1",
                           "day": "0",
                           "start_time": "64800",
                           "period": "3600",
                           "start_date": "2147483647"
                       }
                   ],
                   "tags": [
                       {
                           "tag": "service",
                           "operator": "0",
                           "value": "mysqld",
                       },
                       {
                           "tag": "error",
                           "operator": "2",
                           "value": ""
                       }
                   ]
               }
           ],
           "id": 1
       }

参见

来源

CMaintenance::get() 在 ui/include/classes/api/services/CMaintenance.php.