|
|
- <h1>Management API</h1>
- <p>SITE_NAME Management API supports listing, creating, updating, pausing and deleting
- checks in user's account.</p>
- <h2>API Endpoints</h2>
- <table>
- <thead>
- <tr>
- <th>Endpoint Name</th>
- <th>Endpoint Address</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td><a href="#list-checks">Get a list of existing checks</a></td>
- <td><code>GET SITE_ROOT/api/v1/checks/</code></td>
- </tr>
- <tr>
- <td><a href="#get-check">Get a single check</a></td>
- <td><code>GET SITE_ROOT/api/v1/checks/<uuid></code><br><code>GET SITE_ROOT/api/v1/checks/<unique_key></code></td>
- </tr>
- <tr>
- <td><a href="#create-check">Create a new check</a></td>
- <td><code>POST SITE_ROOT/api/v1/checks/</code></td>
- </tr>
- <tr>
- <td><a href="#update-check">Update an existing check</a></td>
- <td><code>POST SITE_ROOT/api/v1/checks/<uuid></code></td>
- </tr>
- <tr>
- <td><a href="#pause-check">Pause monitoring of a check</a></td>
- <td><code>POST SITE_ROOT/api/v1/checks/<uuid>/pause</code></td>
- </tr>
- <tr>
- <td><a href="#delete-check">Delete check</a></td>
- <td><code>DELETE SITE_ROOT/api/v1/checks/<uuid></code></td>
- </tr>
- <tr>
- <td><a href="#list-pings">Get a list of check's logged pings</a></td>
- <td><code>GET SITE_ROOT/api/v1/checks/<uuid>/pings/</code></td>
- </tr>
- <tr>
- <td><a href="#list-flips">Get a list of check's status changes</a></td>
- <td><code>GET SITE_ROOT/api/v1/checks/<uuid>/flips/</code><br><code>GET SITE_ROOT/api/v1/checks/<unique_key>/flips/</code></td>
- </tr>
- <tr>
- <td><a href="#list-channels">Get a list of existing integrations</a></td>
- <td><code>GET SITE_ROOT/api/v1/channels/</code></td>
- </tr>
- </tbody>
- </table>
- <h2>Authentication</h2>
- <p>Your requests to SITE_NAME Management API must authenticate using an
- API key. API keys are project-specific, there are no account-wide API keys.
- By default, a project on SITE_NAME doesn't have an API key. You can create read-write
- and read-only API keys in the <strong>Project Settings</strong> page.</p>
- <dl>
- <dt>read-write key</dt>
- <dd>Has full access to all documented API endpoints.</dd>
- <dt>read-only key</dt>
- <dd>
- <p>Only works with the following API endpoints:</p>
- <ul>
- <li><a href="#list-checks">Get a list of existing checks</a></li>
- <li><a href="#get-check">Get a single check</a></li>
- <li><a href="#list-flips">Get a list of check's status changes</a></li>
- </ul>
- <p>Omits sensitive information from the API responses. See the documentation of
- individual API endpoints for details.</p>
- </dd>
- </dl>
- <p>The client can authenticate itself by including an <code>X-Api-Key: <your-api-key></code>
- header in a HTTP request. Alternatively, for POST requests with a JSON request body,
- the client can include an <code>api_key</code> field in the JSON document.
- See the <a href="#create-check">Create a new check</a> section for an example.</p>
- <h2>API Requests</h2>
- <p>For POST requests, the SITE_NAME API expects request body to be
- a JSON document (<em>not</em> a <code>multipart/form-data</code> encoded form data).</p>
- <h2>API Responses</h2>
- <p>SITE_NAME uses HTTP status codes wherever possible.
- In general, 2xx class indicates success, 4xx indicates an client error,
- and 5xx indicates a server error.</p>
- <p>The response may contain a JSON document with additional data.</p>
- <h2 class="rule" id="list-checks">Get a List of Existing Checks</h2>
- <p><code>GET SITE_ROOT/api/v1/checks/</code></p>
- <p>Returns a list of checks belonging to the user, optionally filtered by
- one or more tags.</p>
- <h3>Query String Parameters</h3>
- <dl>
- <dt>tag=<value></dt>
- <dd>
- <p>Filters the checks, and returns only the checks that are tagged with the
- specified value.</p>
- <p>This parameter can be repeated multiple times.</p>
- <p>Example:</p>
- <p><code>SITE_ROOT/api/v1/checks/?tag=foo&tag=bar</code></p>
- </dd>
- </dl>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The request succeeded.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl --header <span class="s2">"X-Api-Key: your-api-key"</span> SITE_ROOT/api/v1/checks/
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"checks"</span><span class="p">:</span> <span class="p">[</span>
- <span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Filesystem Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"backup fs"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs incremental backup every hour"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">600</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">1</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"up"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-24T14:02:03+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="s2">"2020-03-24T15:02:03+00:00"</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINT31365bce-8da9-4729-8ff3-aaa71d56b712"</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/31365bce-8da9-4729-8ff3-aaa71d56b712"</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/31365bce-8da9-4729-8ff3-aaa71d56b712/pause"</span><span class="p">,</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">"1bdea468-03bf-47b8-ab27-29a9dd0e4b94,51c6eb2b-2ae1-456b-99fe-6f1e0a36cd3c"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Database Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"production db"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs ~/db-backup.sh"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">1200</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">7</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"down"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:19:32+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINT803f680d-e89b-492b-82ef-2be7b774a92d"</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/803f680d-e89b-492b-82ef-2be7b774a92d"</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/803f680d-e89b-492b-82ef-2be7b774a92d/pause"</span><span class="p">,</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">"1bdea468-03bf-47b8-ab27-29a9dd0e4b94,51c6eb2b-2ae1-456b-99fe-6f1e0a36cd3c"</span><span class="p">,</span>
- <span class="nt">"schedule"</span><span class="p">:</span> <span class="s2">"15 5 * * *"</span><span class="p">,</span>
- <span class="nt">"tz"</span><span class="p">:</span> <span class="s2">"UTC"</span>
- <span class="p">}</span>
- <span class="p">]</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <p>When using the read-only API key, the following fields are omitted:
- <code>ping_url</code>, <code>update_url</code>, <code>pause_url</code>, <code>channels</code>. An extra <code>unique_key</code> field
- is added which can be used <a href="#get-check">to <code>GET</code> a check</a> in place of the <code>UUID</code>. The <code>unique_key</code> identifier is stable across API calls. Example:</p>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"checks"</span><span class="p">:</span> <span class="p">[</span>
- <span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Filesystem Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"backup fs"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs incremental backup every hour"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">600</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">1</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"up"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-24T14:02:03+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="s2">"2020-03-24T15:02:03+00:00"</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"unique_key"</span><span class="p">:</span> <span class="s2">"a6c7b0a8a66bed0df66abfdab3c77736861703ee"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Database Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"production db"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs ~/db-backup.sh"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">1200</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">7</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"down"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:19:32+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"unique_key"</span><span class="p">:</span> <span class="s2">"124f983e0e3dcaeba921cfcef46efd084576e783"</span><span class="p">,</span>
- <span class="nt">"schedule"</span><span class="p">:</span> <span class="s2">"15 5 * * *"</span><span class="p">,</span>
- <span class="nt">"tz"</span><span class="p">:</span> <span class="s2">"UTC"</span>
- <span class="p">}</span>
- <span class="p">]</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="get-check">Get a Single Check</h2>
- <p><code>GET SITE_ROOT/api/v1/checks/<uuid></code><br>
- <code>GET SITE_ROOT/api/v1/checks/<unique_key></code></p>
- <p>Returns a JSON representation of a single check. Accepts either check's UUID or
- the <code>unique_key</code> (a field derived from UUID, and returned by API responses when
- using the read-only API key) as an identifier.</p>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The request succeeded.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl --header <span class="s2">"X-Api-Key: your-api-key"</span> SITE_ROOT/api/v1/checks/<uuid>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Database Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"production db"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs ~/db-backup.sh"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">1200</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">7</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"down"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:19:32+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINT803f680d-e89b-492b-82ef-2be7b774a92d"</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/803f680d-e89b-492b-82ef-2be7b774a92d"</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/803f680d-e89b-492b-82ef-2be7b774a92d/pause"</span><span class="p">,</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">"1bdea468-03bf-47b8-ab27-29a9dd0e4b94,51c6eb2b-2ae1-456b-99fe-6f1e0a36cd3c"</span><span class="p">,</span>
- <span class="nt">"schedule"</span><span class="p">:</span> <span class="s2">"15 5 * * *"</span><span class="p">,</span>
- <span class="nt">"tz"</span><span class="p">:</span> <span class="s2">"UTC"</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h3>Example Read-Only Response</h3>
- <p>When using the read-only API key, the following fields are omitted:
- <code>ping_url</code>, <code>update_url</code>, <code>pause_url</code>, <code>channels</code>. An extra <code>unique_key</code> field is
- added. This identifier is stable across API calls.</p>
- <p>Note: the <code>ping_url</code>, <code>update_url</code> and <code>pause_url</code> fields, although omitted, are not
- really secret. The client already knows the check's unique UUID and so can easily
- construct these URLs by itself.</p>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Database Backup"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"production db"</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">"Runs ~/db-backup.sh"</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">1200</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">7</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"down"</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:19:32+00:00"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"unique_key"</span><span class="p">:</span> <span class="s2">"124f983e0e3dcaeba921cfcef46efd084576e783"</span><span class="p">,</span>
- <span class="nt">"schedule"</span><span class="p">:</span> <span class="s2">"15 5 * * *"</span><span class="p">,</span>
- <span class="nt">"tz"</span><span class="p">:</span> <span class="s2">"UTC"</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="create-check">Create a Check</h2>
- <p><code>POST SITE_ROOT/api/v1/checks/</code></p>
- <p>Creates a new check and returns its ping URL.
- All request parameters are optional and will use their default
- values if omitted.</p>
- <p>This API call can be used to create both "simple" and "cron" checks.
- To create a "simple" check, specify the "timeout" parameter.
- To create a "cron" check, specify the "schedule" and "tz" parameters.</p>
- <h3>Request Parameters</h3>
- <dl>
- <dt>name</dt>
- <dd>
- <p>string, optional, default value: ""</p>
- <p>Name for the new check.</p>
- </dd>
- <dt>tags</dt>
- <dd>
- <p>string, optional, default value: ""</p>
- <p>A space-delimited list of tags for the new check.
- Example:</p>
- <p><pre>{"tags": "reports staging"}</pre></p>
- </dd>
- <dt>desc</dt>
- <dd>
- <p>string, optional.</p>
- <p>Description for the check.</p>
- </dd>
- <dt>timeout</dt>
- <dd>
- <p>number, optional, default value: {{ default_timeout }}.</p>
- <p>A number of seconds, the expected period of this check.</p>
- <p>Minimum: 60 (one minute), maximum: 2592000 (30 days).</p>
- <p>Example for 5 minute timeout:</p>
- <p><pre>{"kind": "simple", "timeout": 300}</pre></p>
- </dd>
- <dt>grace</dt>
- <dd>
- <p>number, optional, default value: {{ default_grace }}.</p>
- <p>A number of seconds, the grace period for this check.</p>
- <p>Minimum: 60 (one minute), maximum: 2592000 (30 days).</p>
- </dd>
- <dt>schedule</dt>
- <dd>
- <p>string, optional, default value: "<em> * </em> * *".</p>
- <p>A cron expression defining this check's schedule.</p>
- <p>If you specify both "timeout" and "schedule" parameters, "timeout" will be
- ignored and "schedule" will be used.</p>
- <p>Example for a check running every half-hour:</p>
- <p><pre>{"schedule": "0,30 * <em> * </em>"}</pre></p>
- </dd>
- <dt>tz</dt>
- <dd>
- <p>string, optional, default value: "UTC".</p>
- <p>Server's timezone. This setting only has effect in combination with the
- "schedule" parameter.</p>
- <p>Example:</p>
- <p><pre>{"tz": "Europe/Riga"}</pre></p>
- </dd>
- <dt>manual_resume</dt>
- <dd>
- <p>boolean, optional, default value: false.</p>
- <p>Controls whether a paused ping resumes automatically when pinged (the default),
- or not. If set to false, a paused check will leave the paused state when it receives
- a ping. If set to true, a paused check will ignore pings and stay paused until it is
- either manually resumed from the web dashboard or the <code>manual_resume</code> flag is
- changed.</p>
- </dd>
- <dt>channels</dt>
- <dd>
- <p>string, optional</p>
- <p>By default, if a check is created through API, no notification channels
- (integrations) are assigned to it. So, when the check goes up or down, no
- notifications will get sent.</p>
- <p>Set this field to a special value "*" to automatically assign all existing
- integrations.</p>
- <p>To assign specific integrations, use a comma-separated list of integration
- identifiers. Use the <a href="#list-channels">Get a List of Existing Integrations</a> call to
- look up integration identifiers.</p>
- </dd>
- <dt>unique</dt>
- <dd>
- <p>array of string values, optional, default value: [].</p>
- <p>Before creating a check, look for existing checks, filtered by fields listed
- in <code>unique</code>. If a matching check is found, return it with HTTP status code 200.
- If no matching check is found, proceed as normal: create a check and return it
- with HTTP status code 201.</p>
- <p>The accepted values are: <code>name</code>, <code>tags</code>, <code>timeout</code> and <code>grace</code>.</p>
- <p>Example:</p>
- <p><pre>{"name": "Backups", unique: ["name"]}</pre></p>
- <p>In this example, if a check named "Backups" exists, it will be returned.
- Otherwise, a new check will be created and returned.</p>
- </dd>
- </dl>
- <h3>Response Codes</h3>
- <dl>
- <dt>201 Created</dt>
- <dd>The check was successfully created.</dd>
- <dt>200 OK</dt>
- <dd>The <code>unique</code> parameter was used and an existing check was matched.</dd>
- <dt>400 Bad Request</dt>
- <dd>The request is not well-formed, violates schema, or uses invalid
- field values.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>The account's check limit has been reached. For free accounts,
- the limit is 20 checks per account.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/ <span class="se">\</span>
- --header <span class="s2">"X-Api-Key: your-api-key"</span> <span class="se">\</span>
- --data <span class="s1">'{"name": "Backups", "tags": "prod www", "timeout": 3600, "grace": 60}'</span>
- </code></pre></div>
-
-
- <p>Or, alternatively:</p>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/ <span class="se">\</span>
- --data <span class="s1">'{"api_key": "your-api-key", "name": "Backups", "tags": "prod www", "timeout": 3600, "grace": 60}'</span>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">60</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">0</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Backups"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/pause"</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINTf618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"new"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"prod www"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="update-check">Update an Existing Check</h2>
- <p><code>POST SITE_ROOT/api/v1/checks/<uuid></code></p>
- <p>Updates an existing check. All request parameters are optional. The check is
- updated only with the supplied request parameters. If any parameter is omitted,
- its value is left unchanged.</p>
- <h3>Request Parameters</h3>
- <dl>
- <dt>name</dt>
- <dd>
- <p>string, optional.</p>
- <p>Name for the check.</p>
- </dd>
- <dt>tags</dt>
- <dd>
- <p>string, optional.</p>
- <p>A space-delimited list of tags for the check.</p>
- <p>Example:</p>
- <p><pre>{"tags": "reports staging"}</pre></p>
- </dd>
- <dt>desc</dt>
- <dd>
- <p>string, optional.</p>
- <p>Description for the check.</p>
- </dd>
- <dt>timeout</dt>
- <dd>
- <p>number, optional.</p>
- <p>A number of seconds, the expected period of this check.</p>
- <p>Minimum: 60 (one minute), maximum: 2592000 (30 days).</p>
- <p>Example for 5 minute timeout:</p>
- <p><pre>{"kind": "simple", "timeout": 300}</pre></p>
- </dd>
- <dt>grace</dt>
- <dd>
- <p>number, optional.</p>
- <p>A number of seconds, the grace period for this check.</p>
- <p>Minimum: 60 (one minute), maximum: 2592000 (30 days).</p>
- </dd>
- <dt>schedule</dt>
- <dd>
- <p>string, optional.</p>
- <p>A cron expression defining this check's schedule.</p>
- <p>If you specify both "timeout" and "schedule" parameters, "timeout" will be
- ignored and "schedule" will be used.</p>
- <p>Example for a check running every half-hour:</p>
- <p><pre>{"schedule": "0,30 * <em> * </em>"}</pre></p>
- </dd>
- <dt>tz</dt>
- <dd>
- <p>string, optional.</p>
- <p>Server's timezone. This setting only has effect in combination with the
- "schedule" parameter.</p>
- <p>Example:</p>
- <p><pre>{"tz": "Europe/Riga"}</pre></p>
- </dd>
- <dt>manual_resume</dt>
- <dd>
- <p>boolean, optional, default value: false.</p>
- <p>Controls whether a paused ping resumes automatically when pinged (the default),
- or not. If set to false, a paused check will leave the paused state when it receives
- a ping. If set to true, a paused check will ignore pings and stay paused until it is
- either manually resumed from the web dashboard or the <code>manual_resume</code> flag is
- changed.</p>
- </dd>
- <dt>channels</dt>
- <dd>
- <p>string, optional.</p>
- <p>Set this field to a special value "*" to automatically assign all existing
- notification channels.</p>
- <p>Set this field to a special value "" (empty string) to automatically <em>unassign</em>
- all notification channels.</p>
- <p>Set this field to a comma-separated list of channel identifiers to assign
- specific notification channels.</p>
- <p>Example:</p>
- <p><pre>{"channels": "4ec5a071-2d08-4baa-898a-eb4eb3cd6941,746a083e-f542-4554-be1a-707ce16d3acc"}</pre></p>
- </dd>
- </dl>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The check was successfully updated.</dd>
- <dt>400 Bad Request</dt>
- <dd>The request is not well-formed, violates schema, or uses invalid
- field values.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc <span class="se">\</span>
- --header <span class="s2">"X-Api-Key: your-api-key"</span> <span class="se">\</span>
- --data <span class="s1">'{"name": "Backups", "tags": "prod www", "timeout": 3600, "grace": 60}'</span>
- </code></pre></div>
-
-
- <p>Or, alternatively:</p>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc <span class="se">\</span>
- --data <span class="s1">'{"api_key": "your-api-key", "name": "Backups", "tags": "prod www", "timeout": 3600, "grace": 60}'</span>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">60</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">0</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Backups"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/pause"</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINTf618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"new"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"prod www"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="pause-check">Pause Monitoring of a Check</h2>
- <p><code>POST SITE_ROOT/api/v1/checks/<uuid>/pause</code></p>
- <p>Disables monitoring for a check, without removing it. The check goes into a "paused"
- state. You can resume monitoring of the check by pinging it.</p>
- <p>This API call has no request parameters.</p>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The check was successfully paused.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/0c8983c9-9d73-446f-adb5-0641fdacc9d4/pause <span class="se">\</span>
- --request POST --header <span class="s2">"X-Api-Key: your-api-key"</span> --data <span class="s2">""</span>
- </code></pre></div>
-
-
- <p>Note: the <code>--data ""</code> argument forces curl to send a <code>Content-Length</code> request header
- even though the request body is empty. For HTTP POST requests, the <code>Content-Length</code>
- header is sometimes required by some network proxies and web servers.</p>
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">60</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">0</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Backups"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/pause"</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINTf618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"paused"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"prod www"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc"</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="delete-check">Delete Check</h2>
- <p><code>DELETE SITE_ROOT/api/v1/checks/<uuid></code></p>
- <p>Permanently deletes the check from user's account. Returns JSON representation of the
- check that was just deleted.</p>
- <p>This API call has no request parameters.</p>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The check was successfully deleted.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc <span class="se">\</span>
- --request DELETE --header <span class="s2">"X-Api-Key: your-api-key"</span>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"desc"</span><span class="p">:</span> <span class="s2">""</span><span class="p">,</span>
- <span class="nt">"grace"</span><span class="p">:</span> <span class="mi">60</span><span class="p">,</span>
- <span class="nt">"last_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"n_pings"</span><span class="p">:</span> <span class="mi">0</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"Backups"</span><span class="p">,</span>
- <span class="nt">"next_ping"</span><span class="p">:</span> <span class="kc">null</span><span class="p">,</span>
- <span class="nt">"manual_resume"</span><span class="p">:</span> <span class="kc">false</span><span class="p">,</span>
- <span class="nt">"pause_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/pause"</span><span class="p">,</span>
- <span class="nt">"ping_url"</span><span class="p">:</span> <span class="s2">"PING_ENDPOINTf618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="nt">"status"</span><span class="p">:</span> <span class="s2">"new"</span><span class="p">,</span>
- <span class="nt">"tags"</span><span class="p">:</span> <span class="s2">"prod www"</span><span class="p">,</span>
- <span class="nt">"timeout"</span><span class="p">:</span> <span class="mi">3600</span><span class="p">,</span>
- <span class="nt">"update_url"</span><span class="p">:</span> <span class="s2">"SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc"</span><span class="p">,</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="list-pings">Get a list of check's logged pings</h2>
- <p><code>GET SITE_ROOT/api/v1/checks/<uuid>/pings/</code></p>
- <p>Returns a list of pings this check has received.</p>
- <p>This endpoint returns pings in reverse order (most recent first), and the total
- number of returned pings depends on account's billing plan: 100 for free accounts,
- 1000 for paid accounts.</p>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The request succeeded.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/pings/ <span class="se">\</span>
- --header <span class="s2">"X-Api-Key: your-api-key"</span>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"pings"</span><span class="p">:</span> <span class="p">[</span>
- <span class="p">{</span>
- <span class="nt">"type"</span><span class="p">:</span> <span class="s2">"success"</span><span class="p">,</span>
- <span class="nt">"date"</span><span class="p">:</span> <span class="s2">"2020-06-09T14:51:06.113073+00:00"</span><span class="p">,</span>
- <span class="nt">"n"</span><span class="p">:</span> <span class="mi">4</span><span class="p">,</span>
- <span class="nt">"scheme"</span><span class="p">:</span> <span class="s2">"http"</span><span class="p">,</span>
- <span class="nt">"remote_addr"</span><span class="p">:</span> <span class="s2">"192.0.2.0"</span><span class="p">,</span>
- <span class="nt">"method"</span><span class="p">:</span> <span class="s2">"GET"</span><span class="p">,</span>
- <span class="nt">"ua"</span><span class="p">:</span> <span class="s2">"curl/7.68.0"</span><span class="p">,</span>
- <span class="nt">"duration"</span><span class="p">:</span> <span class="mf">2.896736</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"type"</span><span class="p">:</span> <span class="s2">"start"</span><span class="p">,</span>
- <span class="nt">"date"</span><span class="p">:</span> <span class="s2">"2020-06-09T14:51:03.216337+00:00"</span><span class="p">,</span>
- <span class="nt">"n"</span><span class="p">:</span> <span class="mi">3</span><span class="p">,</span>
- <span class="nt">"scheme"</span><span class="p">:</span> <span class="s2">"http"</span><span class="p">,</span>
- <span class="nt">"remote_addr"</span><span class="p">:</span> <span class="s2">"192.0.2.0"</span><span class="p">,</span>
- <span class="nt">"method"</span><span class="p">:</span> <span class="s2">"GET"</span><span class="p">,</span>
- <span class="nt">"ua"</span><span class="p">:</span> <span class="s2">"curl/7.68.0"</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"type"</span><span class="p">:</span> <span class="s2">"success"</span><span class="p">,</span>
- <span class="nt">"date"</span><span class="p">:</span> <span class="s2">"2020-06-09T14:50:59.633577+00:00"</span><span class="p">,</span>
- <span class="nt">"n"</span><span class="p">:</span> <span class="mi">2</span><span class="p">,</span>
- <span class="nt">"scheme"</span><span class="p">:</span> <span class="s2">"http"</span><span class="p">,</span>
- <span class="nt">"remote_addr"</span><span class="p">:</span> <span class="s2">"192.0.2.0"</span><span class="p">,</span>
- <span class="nt">"method"</span><span class="p">:</span> <span class="s2">"GET"</span><span class="p">,</span>
- <span class="nt">"ua"</span><span class="p">:</span> <span class="s2">"curl/7.68.0"</span><span class="p">,</span>
- <span class="nt">"duration"</span><span class="p">:</span> <span class="mf">2.997976</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"type"</span><span class="p">:</span> <span class="s2">"start"</span><span class="p">,</span>
- <span class="nt">"date"</span><span class="p">:</span> <span class="s2">"2020-06-09T14:50:56.635601+00:00"</span><span class="p">,</span>
- <span class="nt">"n"</span><span class="p">:</span> <span class="mi">1</span><span class="p">,</span>
- <span class="nt">"scheme"</span><span class="p">:</span> <span class="s2">"http"</span><span class="p">,</span>
- <span class="nt">"remote_addr"</span><span class="p">:</span> <span class="s2">"192.0.2.0"</span><span class="p">,</span>
- <span class="nt">"method"</span><span class="p">:</span> <span class="s2">"GET"</span><span class="p">,</span>
- <span class="nt">"ua"</span><span class="p">:</span> <span class="s2">"curl/7.68.0"</span>
- <span class="p">}</span>
- <span class="p">]</span>
- <span class="p">}</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="list-flips">Get a list of check's status changes</h2>
- <p><code>GET SITE_ROOT/api/v1/checks/<uuid>/flips/</code><br>
- <code>GET SITE_ROOT/api/v1/checks/<unique_key>/flips/</code></p>
- <p>Returns a list of "flips" this check has experienced. A flip is a change of status
- (from "down" to "up", or from "up" to "down").</p>
- <h3>Query String Parameters</h3>
- <dl>
- <dt>seconds=<value></dt>
- <dd>
- <p>Returns the flips from the last <code>value</code> seconds</p>
- <p>Example:</p>
- <p><code>SITE_ROOT/api/v1/checks/<uuid|unique_key>/flips/?seconds=3600</code></p>
- </dd>
- <dt>start=<value></dt>
- <dd>
- <p>Returns flips that are newer than the specified UNIX timestamp.</p>
- <p>Example:</p>
- <p><code>SITE_ROOT/api/v1/checks/<uuid|unique_key>/flips/?start=1592214380</code></p>
- </dd>
- <dt>end=<value></dt>
- <dd>
- <p>Returns flips that are older than the specified UNIX timestamp.</p>
- <p>Example:</p>
- <p><code>SITE_ROOT/api/v1/checks/<uuid|unique_key>/flips/?end=1592217980</code></p>
- </dd>
- </dl>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The request succeeded.</dd>
- <dt>400 Bad Request</dt>
- <dd>Invalid query parameters.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- <dt>403 Forbidden</dt>
- <dd>Access denied, wrong API key.</dd>
- <dt>404 Not Found</dt>
- <dd>The specified check does not exist.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl SITE_ROOT/api/v1/checks/f618072a-7bde-4eee-af63-71a77c5723bc/flips/ <span class="se">\</span>
- --header <span class="s2">"X-Api-Key: your-api-key"</span>
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">[</span>
- <span class="p">{</span>
- <span class="nt">"timestamp"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:18:23+00:00"</span><span class="p">,</span>
- <span class="nt">"up"</span><span class="p">:</span> <span class="mi">1</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"timestamp"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:17:15+00:00"</span><span class="p">,</span>
- <span class="nt">"up"</span><span class="p">:</span> <span class="mi">0</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"timestamp"</span><span class="p">:</span> <span class="s2">"2020-03-23T10:16:18+00:00"</span><span class="p">,</span>
- <span class="nt">"up"</span><span class="p">:</span> <span class="mi">1</span>
- <span class="p">}</span>
- <span class="p">]</span>
- </code></pre></div>
-
-
- <h2 class="rule" id="list-channels">Get a List of Existing Integrations</h2>
- <p><code>GET SITE_ROOT/api/v1/channels/</code></p>
- <p>Returns a list of integrations belonging to the project.</p>
- <h3>Response Codes</h3>
- <dl>
- <dt>200 OK</dt>
- <dd>The request succeeded.</dd>
- <dt>401 Unauthorized</dt>
- <dd>The API key is either missing or invalid.</dd>
- </dl>
- <h3>Example Request</h3>
- <div class="bash highlight"><pre><span></span><code>curl --header <span class="s2">"X-Api-Key: your-api-key"</span> SITE_ROOT/api/v1/channels/
- </code></pre></div>
-
-
- <h3>Example Response</h3>
- <div class="json highlight"><pre><span></span><code><span class="p">{</span>
- <span class="nt">"channels"</span><span class="p">:</span> <span class="p">[</span>
- <span class="p">{</span>
- <span class="nt">"id"</span><span class="p">:</span> <span class="s2">"4ec5a071-2d08-4baa-898a-eb4eb3cd6941"</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"My Work Email"</span><span class="p">,</span>
- <span class="nt">"kind"</span><span class="p">:</span> <span class="s2">"email"</span>
- <span class="p">},</span>
- <span class="p">{</span>
- <span class="nt">"id"</span><span class="p">:</span> <span class="s2">"746a083e-f542-4554-be1a-707ce16d3acc"</span><span class="p">,</span>
- <span class="nt">"name"</span><span class="p">:</span> <span class="s2">"My Phone"</span><span class="p">,</span>
- <span class="nt">"kind"</span><span class="p">:</span> <span class="s2">"sms"</span>
- <span class="p">}</span>
- <span class="p">]</span>
- <span class="p">}</span>
- </code></pre></div>
|