Modify¶
POST /api/v1/aggs_to_metric/{rule_uuid}/modify
Overview¶
Modify an aggregation-to-metric rule.
Route Parameters¶
| Parameter Name | Type | Required | Description |
|---|---|---|---|
| rule_uuid | string | Y | The ID of the aggregation-to-metric rule. |
Body Request Parameters¶
| Parameter Name | Type | Required | Description |
|---|---|---|---|
| extend | json | Y | Additional information. Allow empty: False |
| jsonScript | json | Y | Rule configuration. Allow empty: False |
| jsonScript.type | string | Y | Type. Example: rumToMetric Allow empty: False Allow empty string: False Allowed values: ['logToMetric', 'rumToMetric', 'apmToMetric', 'metricToMetric', 'securityToMetric', 'dialingToMetric'] |
| jsonScript.query | json | Y | DQL query related information. Allow empty: False |
| jsonScript.metricInfo | json | Y | Metric configuration information. Allow empty: False |
| jsonScript.metricInfo.every | string | Y | Frequency. Example: 5m Allow empty string: False |
| jsonScript.metricInfo.metric | string | Y | Measurement name. Example: cpu Allow empty string: False |
| jsonScript.metricInfo.metricField | string | Y | Metric name. Example: load5s Allow empty string: False |
| jsonScript.metricInfo.unit | string | Unit. Example: load5s Allow empty string: True |
|
| jsonScript.metricInfo.desc | string | Description. Example: xxx Allow empty string: True |
|
| skipRepeatNameCheck | boolean | Whether to skip duplicate name detection for measurement and metric. Default is false. false performs duplicate detection, true skips it. Example: false Allow empty: False |
Parameter Supplementary Description¶
Data Description.
1. Parameter Description in jsonScript
| Parameter Name | type | Required | Description |
|---|---|---|---|
| type | String | Required | Data source type, enumeration. |
| query | Json | Required | Query information. |
| metricInfo | Json | Required | Measurement configuration information. |
2. Description of Check Type jsonScript.type
| key | Description |
|---|---|
| rumToMetric | RUM to metric. |
| apmToMetric | APM to metric. |
| logToMetric | Logging to metric. |
| metricToMetric | Metric to metric. |
| securityToMetric | Security Check to metric. |
3. Description of Check Type jsonScript.metricInfo
| Parameter Name | type | Required | Description |
|---|---|---|---|
| every | String | Required | Frequency, options: 1m, 5m, 15m, unit is (minutes/m). |
| metric | String | Required | Measurement name. |
| metricField | String | Required | Metric name. |
| unit | String | Unit. | |
| desc | String | Description. |
3.1 Description of Unit jsonScript.metricInfo.unit
Unit format: custom/["unit type","unit"], example: custom/["time","ms"]
Custom unit format: custom/["custom","custom unit"], example: custom/["custom","tt"]
Standard unit types, refer to Unit Description
4. Description of Check Type jsonScript.query
| Parameter Name | type | Required | Description |
|---|---|---|---|
| q | String | Required | Query statement. |
| qtype | String | Query syntax type, dql/promql. | |
| qmode | String | Query type, dropdown: selectorQuery, manual: customQuery. This field affects the frontend query display style. |
5. Parameter Description in extend
| Parameter Name | type | Required | Description |
|---|---|---|---|
| filters | Array[dict] | Filter condition list for non-log types. | |
| groupBy | Array[str] | Grouping information. | |
| funcName | string | Required | Aggregation function, enumeration values ("count", "avg", "max", "sum", "min", "count_distinct", "p75", "p95", "p99"). |
| fieldKey | string | Required | Aggregation field. |
| index | string | Index name for log type. | |
| source | string | This field has different meanings for different types: Log type: source, APM type: service, RUM type: app_id, Metric type: measurement, Security Check: category. | |
| filterString | string | Filter condition for log type, original filter string, example: 'host:hangzhou123 -service:coredns internal:true'. |
Note:
All fields in the extend field are only used for frontend display purposes. The actual metric generation query statement is based on the query information configured in jsonScript.query.
6. Main Structure Description of extend.filters
| Parameter Name | type | Required | Description |
|---|---|---|---|
| condition | string | Relationship with the previous filter condition, allowed values:and, or; default: and. |
|
| name | string | Field name to filter. | |
| op | string | Operator, allowed values: =, !=, match, not match. |
|
| values | array | Value list. | |
| values[#] | string/int/boolean | Can be string/numeric/boolean type. During data comparison, specific elements from values will be taken based on the operation characteristic, e.g., when operation is =, only values[0] participates in the operation. |
6.1 Example of extend.filters:
[
{
"name": "A",
"condition": "and",
"op": "match",
"values": ["error"]
},
{
"name": "tagC",
"condition": "and",
"op": "=",
"values": ["ok"]
}
]
7. Overall Structure Example:
{
"extend": {
"filters": [],
"groupBy": ["host_ip"],
"funcName": "count",
"fieldKey": "*",
"index": "default",
"source": "*",
"filterString": "host:hangzhou123 region:guanzhou"
},
"jsonScript": {
"type": "logToMetric",
"metricInfo": {
"every": "1m",
"metric": "test",
"metricField": "001-test",
"unit": "custom/[\"timeStamp\",\"ms\"]",
"desc": ""
},
"query": {
"q": "L('default')::RE(`.*`):(count(`*`)) { `host`='hangzhou123' and `region`='guanzhou' } BY `host_ip`",
"qtype": "dql"
}
}
}
Request Example¶
curl 'https://openapi.truewatch.com/api/v1/objc_cfg/rul_xxxx/create' \
-H 'DF-API-KEY: <DF-API-KEY>' \
-H 'Content-Type: application/json;charset=UTF-8' \
--data-raw '{"extend":{"filters":[],"groupBy":["host_ip"],"funcName":"count","fieldKey":"*","index":"default","source":"*","filterString":"host:hangzhou123 region:guanzhou"},"jsonScript":{"type":"logToMetric","metricInfo":{"every":"1m","metric":"test","metricField":"001-test","unit":"custom/[\"timeStamp\",\"ms\"]","desc":""},"query":{"q":"L('default')::RE(`.*`):(count(`*`)) { `host`='hangzhou123' and `region`='guanzhou' } BY `host_ip`","qtype":"dql"}}}' \
--compressed
Response¶
{
"code": 200,
"content": {
"workspaceUUID": "wksp_xxxx",
"monitorUUID": "",
"updator": null,
"type": "aggs",
"refKey": "",
"secret": null,
"jsonScript": {
"type": "logToMetric",
"metricInfo": {
"every": "1m",
"metric": "test",
"metricField": "001-test",
"unit": "custom/[\"timeStamp\",\"ms\"]",
"desc": ""
},
"query": {
"q": "L('default')::RE(`.*`):(count(`*`)) { `host`='hangzhou123' and `region`='guanzhou' } BY `host_ip`",
"qtype": "dql"
}
},
"crontabInfo": {
"id": "cron-4VdviPep3oHc",
"crontab": null
},
"extend": {
"filters": [],
"groupBy": [
"host_ip"
],
"funcName": "count",
"fieldKey": "*",
"index": "default",
"source": "*",
"filterString": "host:hangzhou123 region:guanzhou"
},
"createdWay": "manual",
"isLocked": false,
"openPermissionSet": false,
"permissionSet": [],
"id": null,
"uuid": "rul_xxxx",
"status": 0,
"creator": "acnt_xxxx",
"createAt": 1734594428,
"deleteAt": -1,
"updateAt": null,
"__operation_info": {
"uuid": "rul_xxxx"
}
},
"errorCode": "",
"message": "",
"success": true,
"traceId": "1111139030457458757"
}