Chilkat Online Tools

C++ / Datadog API Collection / Get an SLO's history

Back to Collection Items

#include <CkHttp.h>
#include <CkJsonObject.h>
#include <CkHttpResponse.h>
#include <CkStringBuilder.h>

void ChilkatSample(void)
    {
    // This example assumes the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    CkHttp http;
    bool success;

    CkJsonObject queryParams;
    queryParams.UpdateInt("from_ts",-62147425);
    queryParams.UpdateInt("to_ts",-62147425);
    queryParams.UpdateString("target","49.34019051965387");
    queryParams.UpdateString("apply_correction","true");

    http.SetRequestHeader("Accept","application/json");

    CkHttpResponse *resp = http.QuickRequestParams("GET","https://api.app.ddog-gov.com/api/v1/slo/:slo_id/history",queryParams);
    if (http.get_LastMethodSuccess() == false) {
        std::cout << http.lastErrorText() << "\r\n";
        return;
    }

    CkStringBuilder sbResponseBody;
    resp->GetBodySb(sbResponseBody);

    CkJsonObject jResp;
    jResp.LoadSb(sbResponseBody);
    jResp.put_EmitCompact(false);

    std::cout << "Response Body:" << "\r\n";
    std::cout << jResp.emit() << "\r\n";

    int respStatusCode = resp->get_StatusCode();
    std::cout << "Response Status Code = " << respStatusCode << "\r\n";
    if (respStatusCode >= 400) {
        std::cout << "Response Header:" << "\r\n";
        std::cout << resp->header() << "\r\n";
        std::cout << "Failed." << "\r\n";
        delete resp;
        return;
    }

    delete resp;

    // Sample JSON response:
    // (Sample code for parsing the JSON response is shown below)

    // {
    //   "data": {
    //     "from_ts": 1615323990,
    //     "group_by": [
    //       "aliqua pariatur",
    //       "labor"
    //     ],
    //     "groups": [
    //       {
    //         "error_budget_remaining": {
    //           "7d": 100
    //         },
    //         "errors": [
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           },
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           }
    //         ],
    //         "group": "name",
    //         "history": [
    //           [
    //             1579212382,
    //             0
    //           ]
    //         ],
    //         "monitor_modified": 1615867200,
    //         "monitor_type": "string",
    //         "name": "string",
    //         "precision": 2,
    //         "preview": true,
    //         "sli_value": 99.99,
    //         "span_precision": 2,
    //         "uptime": 99.99
    //       },
    //       {
    //         "error_budget_remaining": {
    //           "7d": 100
    //         },
    //         "errors": [
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           },
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           }
    //         ],
    //         "group": "name",
    //         "history": [
    //           [
    //             1579212382,
    //             0
    //           ]
    //         ],
    //         "monitor_modified": 1615867200,
    //         "monitor_type": "string",
    //         "name": "string",
    //         "precision": 2,
    //         "preview": true,
    //         "sli_value": 99.99,
    //         "span_precision": 2,
    //         "uptime": 99.99
    //       }
    //     ],
    //     "monitors": [
    //       {
    //         "error_budget_remaining": {
    //           "7d": 100
    //         },
    //         "errors": [
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           },
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           }
    //         ],
    //         "group": "name",
    //         "history": [
    //           [
    //             1579212382,
    //             0
    //           ]
    //         ],
    //         "monitor_modified": 1615867200,
    //         "monitor_type": "string",
    //         "name": "string",
    //         "precision": 2,
    //         "preview": true,
    //         "sli_value": 99.99,
    //         "span_precision": 2,
    //         "uptime": 99.99
    //       },
    //       {
    //         "error_budget_remaining": {
    //           "7d": 100
    //         },
    //         "errors": [
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           },
    //           {
    //             "error_type": "",
    //             "error_message": ""
    //           }
    //         ],
    //         "group": "name",
    //         "history": [
    //           [
    //             1579212382,
    //             0
    //           ]
    //         ],
    //         "monitor_modified": 1615867200,
    //         "monitor_type": "string",
    //         "name": "string",
    //         "precision": 2,
    //         "preview": true,
    //         "sli_value": 99.99,
    //         "span_precision": 2,
    //         "uptime": 99.99
    //       }
    //     ],
    //     "overall": {
    //       "error_budget_remaining": {
    //         "7d": 100
    //       },
    //       "errors": [
    //         {
    //           "error_type": "",
    //           "error_message": ""
    //         },
    //         {
    //           "error_type": "",
    //           "error_message": ""
    //         }
    //       ],
    //       "group": "name",
    //       "history": [
    //         [
    //           1579212382,
    //           0
    //         ]
    //       ],
    //       "monitor_modified": 1615867200,
    //       "monitor_type": "string",
    //       "name": "string",
    //       "precision": {
    //         "30d": 1,
    //         "7d": 2
    //       },
    //       "preview": true,
    //       "sli_value": 99.99,
    //       "span_precision": 2,
    //       "uptime": 99.99
    //     },
    //     "series": {
    //       "res_type": "",
    //       "interval": 0,
    //       "resp_version": 0,
    //       "query": "",
    //       "times": [
    //       ],
    //       "numerator": {
    //         "count": 0,
    //         "sum": 0,
    //         "metadata": {}
    //       },
    //       "denominator": {
    //         "count": 0,
    //         "sum": 0,
    //         "metadata": {}
    //       },
    //       "message": ""
    //     },
    //     "thresholds": {
    //       "my_service": {
    //         "target": 95,
    //         "timeframe": "7d"
    //       }
    //     },
    //     "to_ts": 1615928790,
    //     "type": "metric",
    //     "type_id": 0
    //   },
    //   "errors": [
    //     {
    //       "error": "ullamco pariatur"
    //     },
    //     {
    //       "error": "aliquip anim do laborum commodo"
    //     }
    //   ]
    // }

    // Sample code for parsing the JSON response...
    // Use this online tool to generate parsing code from sample JSON: Generate JSON Parsing Code

    // Chilkat functions returning "const char *" return a pointer to temporary internal memory owned and managed by Chilkat.

    const char *strVal = 0;
    int error_budget_remaining7d;
    const char *group = 0;
    int monitor_modified;
    const char *monitor_type = 0;
    const char *name = 0;
    int precision;
    bool preview;
    const char *sli_value = 0;
    int span_precision;
    const char *uptime = 0;
    int j;
    int count_j;
    const char *error_type = 0;
    const char *error_message = 0;
    int k;
    int count_k;
    int intVal;
    const char *error = 0;

    int From_ts = jResp.IntOf("data.from_ts");
    int v_7d = jResp.IntOf("data.overall.error_budget_remaining.7d");
    const char *Group = jResp.stringOf("data.overall.group");
    int Monitor_modified = jResp.IntOf("data.overall.monitor_modified");
    const char *Monitor_type = jResp.stringOf("data.overall.monitor_type");
    const char *Name = jResp.stringOf("data.overall.name");
    int v_30d = jResp.IntOf("data.overall.precision.30d");
    int Precision7d = jResp.IntOf("data.overall.precision.7d");
    bool Preview = jResp.BoolOf("data.overall.preview");
    const char *Sli_value = jResp.stringOf("data.overall.sli_value");
    int Span_precision = jResp.IntOf("data.overall.span_precision");
    const char *Uptime = jResp.stringOf("data.overall.uptime");
    const char *Res_type = jResp.stringOf("data.series.res_type");
    int Interval = jResp.IntOf("data.series.interval");
    int Resp_version = jResp.IntOf("data.series.resp_version");
    const char *Query = jResp.stringOf("data.series.query");
    int Count = jResp.IntOf("data.series.numerator.count");
    int Sum = jResp.IntOf("data.series.numerator.sum");
    int DenominatorCount = jResp.IntOf("data.series.denominator.count");
    int DenominatorSum = jResp.IntOf("data.series.denominator.sum");
    const char *Message = jResp.stringOf("data.series.message");
    int Target = jResp.IntOf("data.thresholds.my_service.target");
    const char *Timeframe = jResp.stringOf("data.thresholds.my_service.timeframe");
    int To_ts = jResp.IntOf("data.to_ts");
    const char *v_Type = jResp.stringOf("data.type");
    int Type_id = jResp.IntOf("data.type_id");
    int i = 0;
    int count_i = jResp.SizeOfArray("data.group_by");
    while (i < count_i) {
        jResp.put_I(i);
        strVal = jResp.stringOf("data.group_by[i]");
        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("data.groups");
    while (i < count_i) {
        jResp.put_I(i);
        error_budget_remaining7d = jResp.IntOf("data.groups[i].error_budget_remaining.7d");
        group = jResp.stringOf("data.groups[i].group");
        monitor_modified = jResp.IntOf("data.groups[i].monitor_modified");
        monitor_type = jResp.stringOf("data.groups[i].monitor_type");
        name = jResp.stringOf("data.groups[i].name");
        precision = jResp.IntOf("data.groups[i].precision");
        preview = jResp.BoolOf("data.groups[i].preview");
        sli_value = jResp.stringOf("data.groups[i].sli_value");
        span_precision = jResp.IntOf("data.groups[i].span_precision");
        uptime = jResp.stringOf("data.groups[i].uptime");
        j = 0;
        count_j = jResp.SizeOfArray("data.groups[i].errors");
        while (j < count_j) {
            jResp.put_J(j);
            error_type = jResp.stringOf("data.groups[i].errors[j].error_type");
            error_message = jResp.stringOf("data.groups[i].errors[j].error_message");
            j = j + 1;
        }

        j = 0;
        count_j = jResp.SizeOfArray("data.groups[i].history");
        while (j < count_j) {
            jResp.put_J(j);
            k = 0;
            count_k = jResp.SizeOfArray("data.groups[i].history[j]");
            while (k < count_k) {
                jResp.put_K(k);
                intVal = jResp.IntOf("data.groups[i].history[j][k]");
                k = k + 1;
            }

            j = j + 1;
        }

        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("data.monitors");
    while (i < count_i) {
        jResp.put_I(i);
        error_budget_remaining7d = jResp.IntOf("data.monitors[i].error_budget_remaining.7d");
        group = jResp.stringOf("data.monitors[i].group");
        monitor_modified = jResp.IntOf("data.monitors[i].monitor_modified");
        monitor_type = jResp.stringOf("data.monitors[i].monitor_type");
        name = jResp.stringOf("data.monitors[i].name");
        precision = jResp.IntOf("data.monitors[i].precision");
        preview = jResp.BoolOf("data.monitors[i].preview");
        sli_value = jResp.stringOf("data.monitors[i].sli_value");
        span_precision = jResp.IntOf("data.monitors[i].span_precision");
        uptime = jResp.stringOf("data.monitors[i].uptime");
        j = 0;
        count_j = jResp.SizeOfArray("data.monitors[i].errors");
        while (j < count_j) {
            jResp.put_J(j);
            error_type = jResp.stringOf("data.monitors[i].errors[j].error_type");
            error_message = jResp.stringOf("data.monitors[i].errors[j].error_message");
            j = j + 1;
        }

        j = 0;
        count_j = jResp.SizeOfArray("data.monitors[i].history");
        while (j < count_j) {
            jResp.put_J(j);
            k = 0;
            count_k = jResp.SizeOfArray("data.monitors[i].history[j]");
            while (k < count_k) {
                jResp.put_K(k);
                intVal = jResp.IntOf("data.monitors[i].history[j][k]");
                k = k + 1;
            }

            j = j + 1;
        }

        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("data.overall.errors");
    while (i < count_i) {
        jResp.put_I(i);
        error_type = jResp.stringOf("data.overall.errors[i].error_type");
        error_message = jResp.stringOf("data.overall.errors[i].error_message");
        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("data.overall.history");
    while (i < count_i) {
        jResp.put_I(i);
        j = 0;
        count_j = jResp.SizeOfArray("data.overall.history[i]");
        while (j < count_j) {
            jResp.put_J(j);
            intVal = jResp.IntOf("data.overall.history[i][j]");
            j = j + 1;
        }

        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("data.series.times");
    while (i < count_i) {
        jResp.put_I(i);
        i = i + 1;
    }

    i = 0;
    count_i = jResp.SizeOfArray("errors");
    while (i < count_i) {
        jResp.put_I(i);
        error = jResp.stringOf("errors[i].error");
        i = i + 1;
    }
    }

Curl Command

curl -G -d "from_ts=-62147425"
	-d "to_ts=-62147425"
	-d "target=49.34019051965387"
	-d "apply_correction=true"
	-H "Accept: application/json"
https://api.app.ddog-gov.com/api/v1/slo/:slo_id/history

Postman Collection Item JSON

{
  "name": "Get an SLO's history",
  "request": {
    "method": "GET",
    "header": [
      {
        "key": "Accept",
        "value": "application/json"
      }
    ],
    "url": {
      "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
      "host": [
        "{{baseUrl}}"
      ],
      "path": [
        "api",
        "v1",
        "slo",
        ":slo_id",
        "history"
      ],
      "query": [
        {
          "key": "from_ts",
          "value": "-62147425",
          "description": "(Required) The `from` timestamp for the query window in epoch seconds."
        },
        {
          "key": "to_ts",
          "value": "-62147425",
          "description": "(Required) The `to` timestamp for the query window in epoch seconds."
        },
        {
          "key": "target",
          "value": "49.34019051965387",
          "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
        },
        {
          "key": "apply_correction",
          "value": "true",
          "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
        }
      ],
      "variable": [
        {
          "key": "slo_id",
          "value": "tempor Ut sed velit"
        }
      ]
    },
    "description": "Get a specific SLO’s history, regardless of its SLO type.\n\nThe detailed history data is structured according to the source data type.\nFor example, metric data is included for event SLOs that use\nthe metric source, and monitor SLO types include the monitor transition history.\n\n**Note:** There are different response formats for event based and time based SLOs.\nExamples of both are shown."
  },
  "response": [
    {
      "name": "OK",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "DD-API-KEY",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "v1",
            "slo",
            ":slo_id",
            "history"
          ],
          "query": [
            {
              "key": "from_ts",
              "value": "-62147425",
              "description": "(Required) The `from` timestamp for the query window in epoch seconds."
            },
            {
              "key": "to_ts",
              "value": "-62147425",
              "description": "(Required) The `to` timestamp for the query window in epoch seconds."
            },
            {
              "key": "target",
              "value": "49.34019051965387",
              "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
            },
            {
              "key": "apply_correction",
              "value": "true",
              "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
            }
          ],
          "variable": [
            {
              "key": "slo_id"
            }
          ]
        }
      },
      "status": "OK",
      "code": 200,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"data\": {\n    \"from_ts\": 1615323990,\n    \"group_by\": [\n      \"aliqua pariatur\",\n      \"labor\"\n    ],\n    \"groups\": [\n      {\n        \"error_budget_remaining\": {\n          \"7d\": 100\n        },\n        \"errors\": [\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          },\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          }\n        ],\n        \"group\": \"name\",\n        \"history\": [\n          [\n            1579212382,\n            0\n          ]\n        ],\n        \"monitor_modified\": 1615867200,\n        \"monitor_type\": \"string\",\n        \"name\": \"string\",\n        \"precision\": 2,\n        \"preview\": true,\n        \"sli_value\": 99.99,\n        \"span_precision\": 2,\n        \"uptime\": 99.99\n      },\n      {\n        \"error_budget_remaining\": {\n          \"7d\": 100\n        },\n        \"errors\": [\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          },\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          }\n        ],\n        \"group\": \"name\",\n        \"history\": [\n          [\n            1579212382,\n            0\n          ]\n        ],\n        \"monitor_modified\": 1615867200,\n        \"monitor_type\": \"string\",\n        \"name\": \"string\",\n        \"precision\": 2,\n        \"preview\": true,\n        \"sli_value\": 99.99,\n        \"span_precision\": 2,\n        \"uptime\": 99.99\n      }\n    ],\n    \"monitors\": [\n      {\n        \"error_budget_remaining\": {\n          \"7d\": 100\n        },\n        \"errors\": [\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          },\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          }\n        ],\n        \"group\": \"name\",\n        \"history\": [\n          [\n            1579212382,\n            0\n          ]\n        ],\n        \"monitor_modified\": 1615867200,\n        \"monitor_type\": \"string\",\n        \"name\": \"string\",\n        \"precision\": 2,\n        \"preview\": true,\n        \"sli_value\": 99.99,\n        \"span_precision\": 2,\n        \"uptime\": 99.99\n      },\n      {\n        \"error_budget_remaining\": {\n          \"7d\": 100\n        },\n        \"errors\": [\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          },\n          {\n            \"error_type\": \"\",\n            \"error_message\": \"\"\n          }\n        ],\n        \"group\": \"name\",\n        \"history\": [\n          [\n            1579212382,\n            0\n          ]\n        ],\n        \"monitor_modified\": 1615867200,\n        \"monitor_type\": \"string\",\n        \"name\": \"string\",\n        \"precision\": 2,\n        \"preview\": true,\n        \"sli_value\": 99.99,\n        \"span_precision\": 2,\n        \"uptime\": 99.99\n      }\n    ],\n    \"overall\": {\n      \"error_budget_remaining\": {\n        \"7d\": 100\n      },\n      \"errors\": [\n        {\n          \"error_type\": \"\",\n          \"error_message\": \"\"\n        },\n        {\n          \"error_type\": \"\",\n          \"error_message\": \"\"\n        }\n      ],\n      \"group\": \"name\",\n      \"history\": [\n        [\n          1579212382,\n          0\n        ]\n      ],\n      \"monitor_modified\": 1615867200,\n      \"monitor_type\": \"string\",\n      \"name\": \"string\",\n      \"precision\": {\n        \"30d\": 1,\n        \"7d\": 2\n      },\n      \"preview\": true,\n      \"sli_value\": 99.99,\n      \"span_precision\": 2,\n      \"uptime\": 99.99\n    },\n    \"series\": {\n      \"res_type\": \"\",\n      \"interval\": 0,\n      \"resp_version\": 0,\n      \"query\": \"\",\n      \"times\": [],\n      \"numerator\": {\n        \"count\": 0,\n        \"sum\": 0,\n        \"metadata\": {}\n      },\n      \"denominator\": {\n        \"count\": 0,\n        \"sum\": 0,\n        \"metadata\": {}\n      },\n      \"message\": \"\"\n    },\n    \"thresholds\": {\n      \"my_service\": {\n        \"target\": 95,\n        \"timeframe\": \"7d\"\n      }\n    },\n    \"to_ts\": 1615928790,\n    \"type\": \"metric\",\n    \"type_id\": 0\n  },\n  \"errors\": [\n    {\n      \"error\": \"ullamco pariatur\"\n    },\n    {\n      \"error\": \"aliquip anim do laborum commodo\"\n    }\n  ]\n}"
    },
    {
      "name": "Bad Request",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "DD-API-KEY",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "v1",
            "slo",
            ":slo_id",
            "history"
          ],
          "query": [
            {
              "key": "from_ts",
              "value": "-62147425",
              "description": "(Required) The `from` timestamp for the query window in epoch seconds."
            },
            {
              "key": "to_ts",
              "value": "-62147425",
              "description": "(Required) The `to` timestamp for the query window in epoch seconds."
            },
            {
              "key": "target",
              "value": "49.34019051965387",
              "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
            },
            {
              "key": "apply_correction",
              "value": "true",
              "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
            }
          ],
          "variable": [
            {
              "key": "slo_id"
            }
          ]
        }
      },
      "status": "Bad Request",
      "code": 400,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    \"Bad Request\",\n    \"Bad Request\"\n  ]\n}"
    },
    {
      "name": "Forbidden",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "DD-API-KEY",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "v1",
            "slo",
            ":slo_id",
            "history"
          ],
          "query": [
            {
              "key": "from_ts",
              "value": "-62147425",
              "description": "(Required) The `from` timestamp for the query window in epoch seconds."
            },
            {
              "key": "to_ts",
              "value": "-62147425",
              "description": "(Required) The `to` timestamp for the query window in epoch seconds."
            },
            {
              "key": "target",
              "value": "49.34019051965387",
              "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
            },
            {
              "key": "apply_correction",
              "value": "true",
              "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
            }
          ],
          "variable": [
            {
              "key": "slo_id"
            }
          ]
        }
      },
      "status": "Forbidden",
      "code": 403,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    \"Bad Request\",\n    \"Bad Request\"\n  ]\n}"
    },
    {
      "name": "Not Found",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "DD-API-KEY",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "v1",
            "slo",
            ":slo_id",
            "history"
          ],
          "query": [
            {
              "key": "from_ts",
              "value": "-62147425",
              "description": "(Required) The `from` timestamp for the query window in epoch seconds."
            },
            {
              "key": "to_ts",
              "value": "-62147425",
              "description": "(Required) The `to` timestamp for the query window in epoch seconds."
            },
            {
              "key": "target",
              "value": "49.34019051965387",
              "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
            },
            {
              "key": "apply_correction",
              "value": "true",
              "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
            }
          ],
          "variable": [
            {
              "key": "slo_id"
            }
          ]
        }
      },
      "status": "Not Found",
      "code": 404,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    \"Bad Request\",\n    \"Bad Request\"\n  ]\n}"
    },
    {
      "name": "Too many requests",
      "originalRequest": {
        "method": "GET",
        "header": [
          {
            "key": "Accept",
            "value": "application/json"
          },
          {
            "description": "Added as a part of security scheme: apikey",
            "key": "DD-API-KEY",
            "value": "<API Key>"
          }
        ],
        "url": {
          "raw": "{{baseUrl}}/api/v1/slo/:slo_id/history?from_ts=-62147425&to_ts=-62147425&target=49.34019051965387&apply_correction=true",
          "host": [
            "{{baseUrl}}"
          ],
          "path": [
            "api",
            "v1",
            "slo",
            ":slo_id",
            "history"
          ],
          "query": [
            {
              "key": "from_ts",
              "value": "-62147425",
              "description": "(Required) The `from` timestamp for the query window in epoch seconds."
            },
            {
              "key": "to_ts",
              "value": "-62147425",
              "description": "(Required) The `to` timestamp for the query window in epoch seconds."
            },
            {
              "key": "target",
              "value": "49.34019051965387",
              "description": "The SLO target. If `target` is passed in, the response will include the remaining error budget and a timeframe value of `custom`."
            },
            {
              "key": "apply_correction",
              "value": "true",
              "description": "Defaults to `true`. If any SLO corrections are applied and this parameter is set to `false`,\nthen the corrections will not be applied and the SLI values will not be affected."
            }
          ],
          "variable": [
            {
              "key": "slo_id"
            }
          ]
        }
      },
      "status": "Too Many Requests",
      "code": 429,
      "_postman_previewlanguage": "json",
      "header": [
        {
          "key": "Content-Type",
          "value": "application/json"
        }
      ],
      "cookie": [
      ],
      "body": "{\n  \"errors\": [\n    \"Bad Request\",\n    \"Bad Request\"\n  ]\n}"
    }
  ]
}