Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.
Comment: Migrated to Confluence 5.3

Table of Contents

You can perform a filter on objects for use with the GET method to reduce API calls and improve performance.

To perform a filter, use the POST method to indicate the object type (the elements, groups, and monitors endpoints), and provide JSON-compliant object IDs:

Code Block
POST https://youruptime/api/v1/<endPoint>/filter
  
{ ids : [a,b,c] }

The response will include a newly created filter ID for the collection of endpoints:

Code Block
{"id":n}

Use the ID with a GET method to return an array of elements in the standard element listing format:

Code Block
GET https://youruptime/api/v1/<endPoint>/filter/<n>/

You can also return an array of element statuses:

Code Block
GET https://youruptime/api/v1/<endPoint>/filter/<n>/status

Object IDs

For "monitor" and "group" object types, the IDs provided in the POST request correspond to the id field for the objects being filtered. The object ID provided must match the object type declared in the request.

Similarly, element IDs can be provided for "element" object types:

Code Block
{ 
ids : [14,6,9],
}

However, for this object type, groups can also be provided. This can be helpful in cases where you want to output element listings, but are using groups as a way to declare the elements. In the request, the group id field is denoted as groupIDs:

Code Block
{ 
  groupIds : [2,3]
}

With this call, both elements and groups can also be filtered together:

Code Block
{ 
  ids : [14,6,9],
  groupIds : [2,3]
}

Monitors Filter Example

Request:

Code Block
POST https://youruptime:9997/api/v1/monitors/filter

{ ids : [21801,21802] }

Returned:

Code Block
{"id":1}

Next request:

Code Block
GET https://youruptime:9997/api/v1/monitors/filter/1/status

Returned:

Code Block
    [
        {
        "acknowledgedComment": null,
        "elementId": 556,
        "elementStatus": {
            "id": 556,
            "isMonitored": true,
            "lastCheckTime": "2014-01-15T10:36:40",
            "lastTransitionTime": "2012-10-01T08:35:16",
            "message": null,
            "name": "Aetos",
            "powerState": null,
            "status": "OK"
        },
        "id": 21801,
        "isAcknowledged": false,
        "isHidden": false,
        "isHostCheck": false,
        "isMonitored": true,
        "lastCheckTime": "2014-01-15T10:31:58",
        "lastTransitionTime": "2014-01-15T10:02:15",
        "message": " Unable to contact Agent (Aetos on port 3333)",
        "name": "UPTIME-Aetos",
        "status": "CRIT"
        },
        {
        "acknowledgedComment": null,
        "elementId": 556,
        "elementStatus": {
            "id": 556,
            "isMonitored": true,
            "lastCheckTime": "2014-01-15T10:36:40",
            "lastTransitionTime": "2012-10-01T08:35:16",
            "message": null,
            "name": "Aetos",
            "powerState": null,
            "status": "OK"
        },
        "id": 21802,
        "isAcknowledged": false,
        "isHidden": false,
        "isHostCheck": true,
        "isMonitored": true,
        "lastCheckTime": "2014-01-15T10:36:40",
        "lastTransitionTime": "2012-10-01T08:35:16",
        "message": "Ping completed: 5 sent, 0.0% loss, 0.6ms average round trip time",
        "name": "PING-Aetos",
        "status": "OK"
        }
    ]

Elements Filter Example

Request:

Code Block
POST https://youruptime:9997/api/v1/elements/filter

{ ids : [14,6,9] }

Returned:

Code Block
{"id":2}

Next request:

Code Block
GET https://youruptime:9997/api/v1/elements/filter/2/status  

Groups Filter Example

Request:

Code Block
POST https://youruptime:9997/api/v1/groups/filter

{ ids : [2,3] }

Returned:

Code Block
{"id":3} 

Next request:

Code Block
GET https://youruptime:9997/api/v1/groups/filter/3/status

Filter Persistence

By default, a filter created from a POST request persists for 5 minutes, and are designed to be used immediately after creation. The GET method can use the filter until expiry, after which a 410 Gone status code will be returned.

Only the up.time user who created the filter will be able to see and use it.