From 75e6df5b5b13bd59a4e136810f9f5140987610d8 Mon Sep 17 00:00:00 2001 From: Thomas Heartman Date: Mon, 9 May 2022 09:24:48 +0200 Subject: [PATCH] docs: document Proxy openAPI integration (#1571) * docs: document the new OpenAPI functionality * docs: add availability note for openapi integration * docs: rewrite openapi section --- website/docs/sdks/unleash-proxy.md | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/website/docs/sdks/unleash-proxy.md b/website/docs/sdks/unleash-proxy.md index 018a0b5624..71eaeb27c5 100644 --- a/website/docs/sdks/unleash-proxy.md +++ b/website/docs/sdks/unleash-proxy.md @@ -42,6 +42,7 @@ The Proxy has a large number of configuration options that you can use to adjust | | | | | | | `clientKeysHeaderName` | `CLIENT_KEY_HEADER_NAME` | `"authorization"` | no | The name of the HTTP header to use for client keys. Incoming requests must set the value of this header to one of the Proxy's `clientKeys` to be authorized successfully. | | `customStrategies` | `UNLEASH_CUSTOM_STRATEGIES_FILE` | `[]` | no | Use this option to inject implementation of custom activation strategies. If you are using `UNLEASH_CUSTOM_STRATEGIES_FILE`: provide a valid path to a JavaScript file which exports an array of custom activation strategies. | +| `enableOAS` | `ENABLE_OAS` | `false` | no | Set to `true` to expose the proxy's OpenAPI spec at `/docs/openapi.json` and an interactive Swagger interface at `/docs/openapi`. Read more in the [OpenAPI section](#openapi).| | `environment` | `UNLEASH_ENVIRONMENT` | `undefined` | no | If set this will be the `environment` used by the proxy in the Unleash Context. It will not be possible for proxy SDKs to override the environment if set. | | `logLevel` | `LOG_LEVEL ` | `"warn"` | no | Used to set `logLevel`. Supported options: `"debug"`, `"info"`, `"warn"`, `"error"` and `"fatal"` | | `logger` | n/a | `SimpleLogger` | no | Register a custom logger. | @@ -123,6 +124,18 @@ The Unleash Proxy has a very simple API. It takes the [Unleash Context](../user_ ![The Unleash Proxy](/img/The-Unleash-Proxy-API.png) +### OpenAPI integration and API documentation {#openapi} + +:::info Availability +The OpenAPI integration is available in versions 0.9 and later of the Unleash proxy. +::: + +The proxy can optionally expose a runtime-generated OpenAPI JSON spec and a corresponding OpenAPI UI for its API. The OpenAPI UI page is an interactive page where you can discover and test the API endpoints the proxy exposes. The JSON spec can be used to generate an OpenAPI client with OpenAPI tooling such as the [OpenAPI generator](https://openapi-generator.tech/). + +To enable the JSON spec and UI, set `ENABLE_OAS` (environment variable) or `enableOAS` (in-code configuration variable) to `true`. + +The spec and UI can then be found at `/docs/openapi.json` and `/docs/openapi` respectively. + ### Payload The `proxy` endpoint returns information about toggles enabled for the current user. The payload is a JSON object with a `toggles` property, which contains a list of toggles.