Skip to content

Latest commit

 

History

History
215 lines (184 loc) · 9.86 KB

servercheck_extensions.rst

File metadata and controls

215 lines (184 loc) · 9.86 KB

servercheck/extensions

.. seealso:: :ref:`admin-to-ext-script`

GET

Retrieves the list of Traffic Ops extensions.

Auth. Required:Yes
Roles Required:None
Permissions Required:SERVER-CHECK:READ, SERVER:READ
Response Type:Array

Request Structure

Request Query Parameters
Name Required Description
id no Filter TO Extensions by the integral, unique identifier of an Extension
name no Filter TO Extensions by the name of an Extension
script_file no Filter TO Extensions by the base filename of the script that runs for the Extension
isactive no Boolean used to return either only active (1) or inactive(0) TO Extensions
type no Filter TO Extensions by the type of Extension
sortOrder no Changes the order of sorting. Either ascending (default or "asc") or descending ("desc")
limit no Choose the maximum number of results to return
offset no The number of results to skip before beginning to return results. Must use in conjunction with limit.
page no Return the nth page of results, where "n" is the value of this parameter, pages are limit long and the first page is 1. If offset was defined, this query parameter has no effect. limit must be defined to make use of page.
GET /api/5.0/servercheck/extensions HTTP/1.1
Host: trafficops.infra.ciab.test
User-Agent: curl/7.47.0
Accept: */*
Cookie: mojolicious=...

Response Structure

additional_config_json:

A string containing a JSON-encoded object with extra configuration options... inside a JSON object...

description:

A short description of the extension

Note

This is, unfortunately, null for all default extensions

id:

An integral, unique identifier for this extension definition

info_url:

A URL where info about this extension may be found

isactive:

An integer describing the boolean notion of whether or not the extension is active; one of:

0

disabled

1

enabled

name:

The name of the extension

script_file:

The base filename of the script that runs for the extension

servercheck_shortname:

The name of the column in the table at 'Monitor' -> 'Cache Checks' in Traffic Portal, where "Check Extension" output is displayed

type:

The Check :term:`Type` of the extension. This will always be a CHECK_EXTENSION type with the naming convention of CHECK_EXTENSION_*.

version:

A (hopefully) semantic version number describing the version of the plugin

HTTP/1.1 200 OK
Access-Control-Allow-Credentials: true
Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept
Access-Control-Allow-Methods: POST,GET,OPTIONS,PUT,DELETE
Access-Control-Allow-Origin: *
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Content-Type: application/json
Date: Tue, 11 Dec 2018 20:51:48 GMT
X-Server-Name: traffic_ops_golang/
Set-Cookie: mojolicious=...; Path=/; Expires=Mon, 18 Nov 2019 17:40:54 GMT; Max-Age=3600; HttpOnly
Vary: Accept-Encoding
Whole-Content-Sha512: n73jg9XR4V5Cwqq56Rf3wuIi99k3mM5u2NAjcZ/gQBu8jvAFymDlnZqKeJ+wTll1vjIsHpXCOVXV7+5UGakLgA==
Transfer-Encoding: chunked

{ "response": [
        {
                "script_file": "ToPingCheck.pl",
                "version": "1.0.0",
                "name": "ILO_PING",
                "description": null,
                "info_url": "-",
                "additional_config_json": "{ check_name: \"ILO\", \"base_url\": \"https://localhost\", \"select\": \"ilo_ip_address\", \"cron\": \"9 * * * *\" }",
                "isactive": 1,
                "type": "CHECK_EXTENSION_BOOL",
                "id": 1,
                "servercheck_short_name": "ILO"
        },
        {
                "script_file": "ToPingCheck.pl",
                "version": "1.0.0",
                "name": "10G_PING",
                "description": null,
                "info_url": "-",
                "additional_config_json": "{ check_name: \"10G\", \"base_url\": \"https://localhost\", \"select\": \"ip_address\", \"cron\": \"18 * * * *\" }",
                "isactive": 1,
                "type": "CHECK_EXTENSION_BOOL",
                "id": 2,
                "servercheck_short_name": "10G"
        }
]}

POST

Creates a new Traffic Ops check extension.

Auth. Required:Yes
Roles Required:None[1]
Permissions Required:SERVER-CHECK:CREATE, SERVER-CHECK:READ, SERVER:READ
Response Type:undefined

Request Structure

additional_config_json:

An optional string containing a JSON-encoded object with extra configuration options... inside a JSON object...

description:

A short description of the extension

info_url:

A URL where info about this extension may be found

isactive:

An integer describing the boolean notion of whether or not the extension is active; one of:

0

disabled

1

enabled

name:

The name of the extension

script_file:

The base filename of the script that runs for the extension

.. seealso:: :ref:`admin-to-ext-script` for details on where the script should be located on the Traffic Ops server

servercheck_shortname:

The name of the column in the table at 'Monitor' -> 'Cache Checks' in Traffic Portal, where "Check Extension" output is displayed

type:

The :term:`Type` of extension. Must be CHECK_EXTENSION type with the naming convention of CHECK_EXTENSION_*.

version:

A (hopefully) semantic version number describing the version of the plugin

POST /api/5.0/servercheck/extensions HTTP/1.1
Host: cache1.example.com:6443
User-Agent: curl/7.47.0
Accept: */*
Cookie: mojolicious=...
Content-Length: 208
Content-Type: application/json

{
        "name": "test",
        "version": "0.0.1-1",
        "info_url": "",
        "script_file": "",
        "isactive": 0,
        "description": "A test extension for API examples",
        "servercheck_short_name": "test",
        "type": "CHECK_EXTENSION_NUM"
}

Response Structure

HTTP/1.1 200 OK
Access-Control-Allow-Credentials: true
Access-Control-Allow-Headers: Origin, X-Requested-With, Content-Type, Accept
Access-Control-Allow-Methods: POST,GET,OPTIONS,PUT,DELETE
Access-Control-Allow-Origin: *
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Content-Type: application/json
Date: Wed, 12 Dec 2018 16:37:44 GMT
X-Server-Name: traffic_ops_golang/
Set-Cookie: mojolicious=...; Path=/; Expires=Mon, 18 Nov 2019 17:40:54 GMT; Max-Age=3600; HttpOnly
Vary: Accept-Encoding
Whole-Content-Sha512: 7M67PYnli6WzGQFS3g8Gh1SOyq6VENZMqm/kUffOTLLFfuWSEuSLA65R5R+VyJiNjdqOG5Bp78mk+JYcqhtVGw==
Content-Length: 89

{ "supplemental":
        {
                "id": 5
        },
"alerts": [{
        "level": "success",
        "text": "Check Extension Loaded."
}]}
[1]No roles are required to use this endpoint, however access is controlled by username. Only the reserved user extension is permitted the use of this endpoint.