Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Docs/Reporting] More information about HTTP / script stuff #41200

Merged
merged 12 commits into from
Jul 18, 2019
7 changes: 6 additions & 1 deletion docs/reporting/automating-report-generation.asciidoc
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
[[automating-report-generation]]
== Automating Report Generation
You can automatically generate reports with {watcher}, or by submitting
HTTP POST requests from a script.
HTTP `POST` requests from a script.
tsullivan marked this conversation as resolved.
Show resolved Hide resolved

include::report-intervals.asciidoc[]

Expand Down Expand Up @@ -38,6 +38,11 @@ include::watch-example.asciidoc[]

include::script-example.asciidoc[]

[float]
=== HTTP Response Codes

include::response-codes.asciidoc[]

[float]
== Deprecated Report URLs

Expand Down
23 changes: 23 additions & 0 deletions docs/reporting/response-codes.asciidoc
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
The Reporting APIs use HTTP response codes to indicate to give feedback. In automation,
tsullivan marked this conversation as resolved.
Show resolved Hide resolved
this helps external systems track the various possible job states:

- **`200` (OK)**: As expected, Kibana returns `200` status in the response for
successful requests to queue or download reports.
+
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

note: easy-to-miss soft line break here

NOTE: Kibana will send a `200` response status for successfully queuing a Reporting job via
the POST URL. This is true even if the job somehow fails later, since execution happens
asynchronously from queuing.

- **`400` (Bad Request)**: When sending requests to the POST URL, if you don't use
`POST` as the HTTP method, or if your request is missing the `kbn-version` header,
Kibana will return a code `400` status response for the request.

- **`503` (Service Unavailable)**: When using the `path` to request the download, you will get
a `503` status response if report generation hasn't completed yet. In that case,
retry after the number of seconds in the `Retry-After` header in the download API
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This sentence is confusing:

In that case, retry after the number of seconds in the Retry-After header in the download API response until the report is complete.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I see what you mean. How about:

When using the path to request the download, you will get a 503 status response if report generation hasn't completed yet. A 503 response comes with a Retry-After header. Before trying again to download the report, you can have your script wait the suggested number of seconds found in the Retry-After header until the report is complete.

response until the report is complete.

- **`500` (Internal Server Error)**: If there was an error in generating the report,
the download URL will return a `500` status response. More information will be
available in the Reporting management page in Kibana: *Management > Kibana >
Reporting*
31 changes: 10 additions & 21 deletions docs/reporting/script-example.asciidoc
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
To automatically generate reports from a script, you'll make a request to the POST URL.
To automatically generate reports from a script, you'll make a request to the `POST` URL.
The response from this request will be JSON, and will contain a `path` property with a
URL to use to download the generated report when it is complete.
URL to use to download the generated report. Use the `GET` method in the HTTP request to
download the report.

The request method must be POST and it must include a `kbn-version` header for Kibana
The request method must be `POST` and it must include a `kbn-version` header for Kibana
to allow the request.

The following example queues CSV report generation using the POST URL with cURL:
The following example queues CSV report generation using the `POST` URL with cURL:

[source,shell]
---------------------------------------------------------
Expand All @@ -17,12 +18,13 @@ curl \
---------------------------------------------------------
// CONSOLE

<1> POST method is required.
<1> `POST` method is required.
<2> Provide user credentials for a user with permission to access Kibana and X-Pack reporting.
<3> The `kbn-version` header is required for all POST requests to Kibana.
<4> The POST URL. You can copy and paste the URL for any report from the Kibana UI.
<3> The `kbn-version` header is required for all `POST` requests to Kibana.
**The value must match the dotted-numeral version of the Kibana instance.**
tsullivan marked this conversation as resolved.
Show resolved Hide resolved
<4> The `POST` URL. You can copy and paste the URL for any report from the Kibana UI.

Here is an example response:
Here is an example response for a successfully queued report:

[source,json]
---------------------------------------------------------
Expand All @@ -45,16 +47,3 @@ Here is an example response:
<1> The relative path on the Kibana host for downloading the report.
<2> (Not included in the example) Internal representation of the reporting job, as
found in the `.reporting-*` index.

[IMPORTANT]
===================
When using the `path` to request the download, you will get a 503 (Service Unavailable)
response if report generation hasn't completed yet. In that case, retry after the
number of seconds in the `Retry-After` header in the download API response until the
report is complete.

If there was an error in generating the report, the download URL will return a 500
(Internal Server Error) response. More information is available in the
Reporting management page in Kibana: *Management > Kibana > Reporting*
Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

All this is moved to a standalone section, because it grew pretty large

===================