1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-20 00:08:02 +01:00

Docs: update API access for new token type (#1958)

* refactor how-to guide for creating a token

* fix token links

* update SDK reference

* beginning of direct api guide

* refactored frontend api guide

* lint staged breaking notes

* update docs - cors for frontend

* update token guide images

* update after review

* Apply suggestions from code review

`website/docs/user_guide/token.mdx`

Co-authored-by: Thomas Heartman <thomas@getunleash.ai>

* Apply suggestions from code review

`website/docs/topics/frontend-api.md`

Co-authored-by: Thomas Heartman <thomas@getunleash.ai>

* Apply suggestions from code review

Co-authored-by: Thomas Heartman <thomas@getunleash.ai>

* Apply suggestions from code review

Co-authored-by: Thomas Heartman <thomas@getunleash.ai>

* pr review

* docs: Add info about front-end tokens + formatting

* docs: add info about token anatomy

* docs: link to correct  place in doc

* docs: replace "direct access API" -> "front-end API"

* docs: rename file frontend-api -> front-end-api

Co-authored-by: Thomas Heartman <thomas@getunleash.ai>
This commit is contained in:
Tymoteusz Czech 2022-09-15 09:02:10 +02:00 committed by GitHub
parent 6778d347cd
commit 2cd5028125
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
33 changed files with 243 additions and 133 deletions

View File

@ -97,14 +97,14 @@ const ApiTokenForm: React.FC<IApiTokenFormProps> = ({
<form onSubmit={handleSubmit} className={styles.form}> <form onSubmit={handleSubmit} className={styles.form}>
<div className={styles.container}> <div className={styles.container}>
<p className={styles.inputDescription}> <p className={styles.inputDescription}>
Who are you generating the token for? What would you like to call this token?
</p> </p>
<Input <Input
className={styles.input} className={styles.input}
value={username} value={username}
name="username" name="username"
onChange={e => setUsername(e.target.value)} onChange={e => setUsername(e.target.value)}
label="Username" label="Token name"
error={errors.username !== undefined} error={errors.username !== undefined}
errorText={errors.username} errorText={errors.username}
onFocus={() => clearErrors('username')} onFocus={() => clearErrors('username')}

View File

@ -83,7 +83,7 @@ export const CreateApiToken = () => {
<FormTemplate <FormTemplate
loading={loading} loading={loading}
title={pageTitle} title={pageTitle}
description="In order to connect to Unleash clients will need an API token to grant access. A client SDK will need to token with 'client privileges', which allows them to fetch feature toggle configuration and post usage metrics back." description="Unleash SDKs use API tokens to authenticate to the Unleash API. Client SDKs need a token with 'client privileges', which allows them to fetch feature toggle configurations and post usage metrics."
documentationLink="https://docs.getunleash.io/reference/api-tokens-and-client-keys" documentationLink="https://docs.getunleash.io/reference/api-tokens-and-client-keys"
documentationLinkLabel="API tokens documentation" documentationLinkLabel="API tokens documentation"
formatApiCode={formatApiCode} formatApiCode={formatApiCode}

View File

@ -34,8 +34,8 @@ export const CorsForm = ({ frontendApiOrigins }: ICorsFormProps) => {
<form onSubmit={onSubmit}> <form onSubmit={onSubmit}>
<Box sx={{ display: 'grid', gap: 1 }}> <Box sx={{ display: 'grid', gap: 1 }}>
<label htmlFor={inputFieldId}> <label htmlFor={inputFieldId}>
Which origins should be allowed to call the Frontend API Which origins should be allowed to call the Frontend API?
(one per line)? Add only one origin per line.
</label> </label>
<TextField <TextField
id={inputFieldId} id={inputFieldId}

View File

@ -12,7 +12,7 @@ Segments are available to Unleash Pro and Unleash Enterprise users since **Unlea
:::note :::note
To use the admin API, you'll need to [create and use an admin API token](../../user_guide/token.md). To use the admin API, you'll need to [create and use an admin API token](../../user_guide/token.mdx).
::: :::

View File

@ -2,56 +2,98 @@
title: API tokens and client keys title: API tokens and client keys
--- ---
For Unleash to be of any use, it requires at least a server and a [consuming client](../sdks/index.md). For Unleash to be of any use, it requires at least a server and a [consuming client](../sdks/index.md). More advanced use cases may call for multiple clients, automated feature toggle updates, the [Unleash proxy](../sdks/unleash-proxy.md) and [Unleash proxy clients](../sdks/index.md#front-end-sdks), and more. To facilitate communication between all these moving parts, Unleash uses a system of API tokens and client keys, all with a specific purpose in mind.
More advanced use cases may call for multiple clients, automated feature toggle updates, the [Unleash proxy](../sdks/unleash-proxy.md) and [Unleash proxy clients](../sdks/index.md#front-end-sdks), and more. To facilitate communication between all these moving parts, Unleash uses a system of API tokens and client keys, all with a specific purpose in mind.
This document details the three kinds of tokens and keys that you will need to fully connect any Unleash system: This document details the three kinds of tokens and keys that you will need to fully connect any Unleash system:
- [Admin tokens](#admin-tokens) for updating resources in Unleash
- [Client tokens](#client-tokens) for connecting server-side client SDKs and the Unleash proxy to the Unleash server - [Admin tokens](#admin-tokens) for updating resources in Unleash
- [Proxy client keys](#proxy-client-keys) for connecting proxy client SDKs to the Unleash proxy. - [Client tokens](#client-tokens) for connecting server-side client SDKs and the Unleash proxy to the Unleash server
- [Proxy client keys](#proxy-client-keys) for connecting proxy client SDKs to the Unleash proxy.
## API tokens ## API tokens
:::tip :::tip
This section describes what API tokens are. For information on how to create them, refer to the [how-to guide for creating API tokens](../user_guide/token.md).
This section describes what API tokens are. For information on how to create them, refer to the [how-to guide for creating API tokens](../user_guide/token.mdx).
::: :::
Use API tokens to connect to the Unleash server API. API tokens come in two distinct types: Use API tokens to connect to the Unleash server API. API tokens come in three distinct types:
- [Admin tokens](#admin-tokens)
- [Client tokens](#client-tokens)
Both types use [the same format](#format) but have different intended uses. API tokens are considered to be *secrets* and should _not_ be exposed to end users. - [Admin tokens](#admin-tokens)
- [Client tokens](#client-tokens)
- [Front-end tokens](#front-end-tokens)
All types use [the same format](#format) but have different intended uses. Admin and client tokens are _secrets_ and should _not_ be exposed to end users. Front-end tokens, on the other hand, are not secret.
### The parts of an API token {#token-data}
An API token contains the following pieces of information:
| Name | Description |
| --- | --- |
| Token name (sometimes called "username") | The token's name. Names or **not** required to be unique. |
| Type | What kind of token it is: admin, client, or front-end. |
| Projects | What projects a token has access to. |
| Environment | What environment the token has access to. |
### Admin tokens ### Admin tokens
**Admin tokens** grant *full read and write access* to all resources in the Unleash server API. Admin tokens have access to all projects, all environments, and all global resources (find out more about [resources in the RBAC document](../user_guide/rbac.md#core-principles)). **Admin tokens** grant _full read and write access_ to all resources in the Unleash server API. Admin tokens have access to all projects, all environments, and all global resources (find out more about [resources in the RBAC document](../user_guide/rbac.md#core-principles)).
Use admin tokens to: Use admin tokens to:
- Automate Unleash behavior such as creating feature toggles, projects, etc.
- Write custom Unleash UIs to replace the default Unleash admin UI. - Automate Unleash behavior such as creating feature toggles, projects, etc.
- Write custom Unleash UIs to replace the default Unleash admin UI.
Do **not** use admin tokens for: Do **not** use admin tokens for:
- [Client SDKs](../sdks/index.md): You will _not_ be able to read toggle data from multiple environments. Use [client tokens](#client-tokens) instead.
- [Client SDKs](../sdks/index.md): You will _not_ be able to read toggle data from multiple environments. Use [client tokens](#client-tokens) instead.
Support for scoped admin tokens with more fine-grained permissions is currently in the planning stage. Support for scoped admin tokens with more fine-grained permissions is currently in the planning stage.
### Client tokens ### Client tokens
**Client tokens** are intended for use in [server-side client SDKs](../sdks/index.md#server-side-sdks) (including the Unleash Proxy) and grant the user permissions to: **Client tokens** are intended for use in [server-side client SDKs](../sdks/index.md#server-side-sdks) (including the Unleash Proxy) and grant the user permissions to:
- Read feature toggle information
- Register applications with the Unleash server
- Send usage metrics
When creating a client token, you can choose which projects it should be able to read data from. You can give it access to a specific list of projects or to all projects (including projects that don't exist yet). Prior to Unleash 4.10, a token could be valid only for a *single project* or *all projects*. - Read feature toggle information
- Register applications with the Unleash server
- Send usage metrics
When creating a client token, you can choose which projects it should be able to read data from. You can give it access to a specific list of projects or to all projects (including projects that don't exist yet). Prior to Unleash 4.10, a token could be valid only for a _single project_ or _all projects_.
Each client token is only **valid for a single environment**. Each client token is only **valid for a single environment**.
Use client tokens: Use client tokens:
- In [server-side client SDKs](../sdks/index.md#server-side-sdks)
- To connect [the Unleash Proxy](../sdks/unleash-proxy.md) to the Unleash API - In [server-side client SDKs](../sdks/index.md#server-side-sdks)
- To connect [the Unleash Proxy](../sdks/unleash-proxy.md) to the Unleash API
Do **not** use client tokens in: Do **not** use client tokens in:
- [Front-end SDKs](../sdks/index.md#front-end-sdks). You will _not_ be able to connect to the Unleash server due to CORS restrictions. Configure an [Unleash Proxy](../sdks/unleash-proxy.md) and use [Proxy client keys](#proxy-client-keys) instead.
- [Front-end SDKs](../sdks/index.md#front-end-sdks). You will _not_ be able to connect to the Unleash server due to CORS restrictions. To connect front-end SDKs, choose one of the following options:
- Enable the [Unleash front-end API](./front-end-api.md) and create a [front-end token](#front-end-tokens).
- Configure an [Unleash Proxy](../sdks/unleash-proxy.md) and use [Proxy client keys](#proxy-client-keys).
### Front-end tokens
**Front-end tokens** are used with [front-end SDKs](../sdks/index.md#front-end-sdks) when used with the [Unleash front-end API](./front-end-api.md). They grant the user permission to:
- Read the enabled toggled for a given context
- Register applications with the Unleash server
- Send usage metrics
As with [client tokens](#client-tokens), front-end tokens can read data from one, multiple, or all existing projects.
Each front-end token is only **valid for a single environment**.
Use front-end tokens in:
- [Front-end SDKs (also known as _proxy clients_)](../sdks/index.md#front-end-sdks).
Do **not** use front-end tokens in:
- [Server-side SDKs](../sdks/index.md#server-side-sdks). The format is different, so they won't work correctly.
### Format ### Format
@ -65,7 +107,6 @@ The first version of API tokens was a 64 character long hexadecimal string. Exam
be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178 be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178
``` ```
#### Version 2 #### Version 2
API tokens consist of three parts: API tokens consist of three parts:
@ -77,37 +118,49 @@ API tokens consist of three parts:
The parts are separated by two different separators: A colon (`:`) between the project(s) and the environment, and a full stop (`.`) between the environment and the hash. The parts are separated by two different separators: A colon (`:`) between the project(s) and the environment, and a full stop (`.`) between the environment and the hash.
The **project(s)** part is one of: The **project(s)** part is one of:
- The id of a specific project, for example: `default`. This indicates that the token is **only valid for this project**.
- A pair of opening and closing square brackets: `[]`. This indicates that the token is **valid for a discrete list of projects**. The list of projects is not shown in the token. - The id of a specific project, for example: `default`. This indicates that the token is **only valid for this project**.
- An asterisk: `*`. This indicates that the token is **valid for all projects (current and future)**. - A pair of opening and closing square brackets: `[]`. This indicates that the token is **valid for a discrete list of projects**. The list of projects is not shown in the token.
- An asterisk: `*`. This indicates that the token is **valid for all projects (current and future)**.
The **environment** is the name of an environment on your Unleash server, such as `development`. The **environment** is the name of an environment on your Unleash server, such as `development`.
The **hash** is 64 character long hexadecimal string. The **hash** is 64 character long hexadecimal string.
Some example client tokens are: Some example client tokens are:
- A token with access to toggles in the "development" environment of a single project, "project-a":
``` - A token with access to toggles in the "development" environment of a single project, "project-a":
project-a:development.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178 ```
``` project-a:development.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178
- A token with access to toggles in the "production" environment multiple projects: ```
``` - A token with access to toggles in the "production" environment multiple projects:
[]:production.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178 ```
``` []:production.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178
- A token with access to toggles in the "development" environment of all projects: ```
``` - A token with access to toggles in the "development" environment of all projects:
*:development.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178 ```
``` *:development.be44368985f7fb3237c584ef86f3d6bdada42ddbd63a019d26955178
```
## Proxy client keys {#proxy-client-keys} ## Proxy client keys {#proxy-client-keys}
Use proxy client keys to connect [Proxy client SDKs (front-end SDKs)](../sdks/index.md#front-end-sdks) to the [Unleash Proxy](../sdks/unleash-proxy.md). As opposed to the [API tokens](#api-tokens), Proxy client keys are *not* considered secret and are safe to use on any clients (refer to the [the proxy documentation for more about privacy](../sdks/unleash-proxy.md#we-care-about-privacy)). They do _not_ let you connect to the Unleash server API. Use proxy client keys to connect [Proxy client SDKs (front-end SDKs)](../sdks/index.md#front-end-sdks) to the [Unleash Proxy](../sdks/unleash-proxy.md). As opposed to the [API tokens](#api-tokens), Proxy client keys are _not_ considered secret and are safe to use on any clients (refer to the [the proxy documentation for more about privacy](../sdks/unleash-proxy.md#we-care-about-privacy)). They do _not_ let you connect to the Unleash server API.
Proxy client keys are arbitrary strings that you *must* provide the Unleash proxy with on startup. Unleash does not generate proxy client keys for you. Because of this, they have no specific format. Proxy client keys are arbitrary strings that you _must_ provide the Unleash proxy with on startup. They can be whatever you want and you **create them yourself**.
:::info Creating proxy client keys
To designate a string as a proxy client key, add it to the `clientKeys` list when starting the proxy, as mentioned in the [_configuration_ section of the Unleash proxy documentation](../sdks/unleash-proxy.md#configuration). Connecting clients should then specify the same string as their client key.
:::
Unleash does not generate proxy client keys for you. Because of this, they have no specific format.
Use Proxy client keys to: Use Proxy client keys to:
- Connect [Proxy client SDKs](../sdks/index.md#front-end-sdks) to the [Unleash Proxy](../sdks/unleash-proxy.md)
- Connect your own custom Proxy clients (or pure HTTP requests) to the Unleash Proxy - Connect [Proxy client SDKs](../sdks/index.md#front-end-sdks) to the [Unleash Proxy](../sdks/unleash-proxy.md)
- Connect your own custom Proxy clients (or pure HTTP requests) to the Unleash Proxy
Do **not** use Proxy client keys to: Do **not** use Proxy client keys to:
- Connect to the Unleash API. It will not work. Use an appropriate [API token](#api-tokens) instead.
- Connect to the Unleash API. It will not work. Use an appropriate [API token](#api-tokens) instead.

View File

@ -0,0 +1,49 @@
---
title: Front-end API access
---
:::info Availability
The Unleash front-end API is an experimental feature and is currently in development.
<!-- TODO: link blog post with release notes -->
:::
The **Unleash front-end API** offers a simplified workflow for connecting a client-side (front-end) applications to Unleash. It provides the exact same API as the [Unleash proxy](../sdks/unleash-proxy.md). The front-end API is a quick and easy way to add Unleash to single-page applications and mobile apps.
<!-- TODO: image illustrating connection -->
Compared to using the Unleash proxy, using the Unleash front-end API has both benefits and drawbacks. The benefits are:
- **Managing client-side API tokens is easier.** With the Unleash proxy, you need to create and manage client keys manually; with the front-end API, you manage client-side API tokens in the exact same manner as other API tokens.
- **You don't need to configure and run an Unleash proxy.** The front-end API is part of Unleash itself and not an external process. All proxy clients will work exactly the same as they would with the Proxy.
On the other hand, using the front-end API has the following drawbacks compared to using the proxy:
- **It can't handle a large number of requests per second.** Because the front-end API is part of Unleash, you can't scale it horizontally the way you can scale the proxy.
- **It sends client details to your Unleash instance.** Unleash only stores these details in its short-term runtime cache, but this can be a privacy issue for some use cases.
These points make the Unleash front-end API best suited for development purposes and applications that dont receive a lot of traffic, such as internal dashboards. However, because the API is identical to the Unleash proxy API, you can go from one to the other at any time. As such, you can start out by using the front-end API and switch to using the proxy when you need it.
## Using the Unleash front-end API
When using the front-end API in an SDK, there's three things you need to configure.
### Front-end API tokens
As a client-side API, you should use a [front-end API token](../reference/api-tokens-and-client-keys.mdx#front-end-api-tokens) to interact with it. Refer to the [how to create API tokens](../user_guide/token.mdx) guide for steps on how to create API tokens.
### Cross-origin resource sharing (CORS) configuration {#cors}
You need to allow traffic from your application domains to use the Unleash front-end API with web and hybrid mobile applications. You can update the front-end API CORS settings from the Unleash UI under _admin \> CORS_ or by using the API.
### API URL
The client needs to point to the correct API endpoint. The front-end API is available at `<your-unleash-instance>/api/frontend`.
<!-- Point to the API docs when they're published -->
### API token
You can create appropriate token, with type `FRONTEND` on `<YOUR_UNLEASH_URL>/admin/api/create-token` page or with a request to `/api/admin/api-tokens`. See our guide on [how to create API tokens](../user_guide/token.mdx) for more details.

View File

@ -5,10 +5,7 @@ title: Android Proxy SDK
In this guide we'll explain how to use feature toggles in an Android application using Unleash's [Android Proxy SDK](https://github.com/Unleash/unleash-android-proxy-sdk) and the [Unleash Proxy](https://github.com/Unleash/unleash-proxy). In this guide we'll explain how to use feature toggles in an Android application using Unleash's [Android Proxy SDK](https://github.com/Unleash/unleash-android-proxy-sdk) and the [Unleash Proxy](https://github.com/Unleash/unleash-proxy).
:::note The Android proxy SDK requires the Unleash Proxy or _Unleash v4.16 or later_. Refer to the [Unleash front-end API documentation](/reference/front-end-api.md) guide for simple setup. For large-scale, deployments refer to the [proxy documentation](/sdks/unleash-proxy) for how to set it up and [how to configure the proxy secrets](/sdks/unleash-proxy#configuration-variables). :::
:::note
The Android proxy SDK requires the Unleash Proxy to function. You'll need the proxy's URL and a configured proxy secret. Refer to the [proxy documentation](/sdks/unleash-proxy) for how to set it up and [how to configure the proxy secrets](/sdks/unleash-proxy#configuration-variables).
:::
## How to use the Android Proxy SDK ## How to use the Android Proxy SDK
@ -57,6 +54,7 @@ val myAppContext = UnleashContext.newBuilder()
### Step 4: Configure the Client ### Step 4: Configure the Client
To create a client, use the `UnleashConfig.newBuilder` method. When building a configuration, you'll need to provide it with: To create a client, use the `UnleashConfig.newBuilder` method. When building a configuration, you'll need to provide it with:
- `proxyUrl`: the URL your proxy is available at - `proxyUrl`: the URL your proxy is available at
- `clientKey`: the [proxy client key](/sdks/unleash-proxy#configuration-variables) you wish to use (this method was known as `clientSecret` prior to version 0.4.0) - `clientKey`: the [proxy client key](/sdks/unleash-proxy#configuration-variables) you wish to use (this method was known as `clientSecret` prior to version 0.4.0)
- `pollMode`: how you want to load the toggle status - `pollMode`: how you want to load the toggle status

View File

@ -52,7 +52,7 @@ To shut down the client (turn off the polling) you can simply call the destroy-m
unleash.Close() unleash.Close()
### Built in activation strategies {#built-in-activation-strategies} ### Built-in activation strategies {#built-in-activation-strategies}
The Go client comes with implementations for the built-in activation strategies provided by unleash. The Go client comes with implementations for the built-in activation strategies provided by unleash.

View File

@ -1,6 +1,6 @@
--- ---
id: index id: index
title: Client SDK overview title: SDK overview
slug: /sdks slug: /sdks
--- ---
@ -23,9 +23,9 @@ Server-side clients run on your server and communicate directly with your Unleas
- [Rust SDK](https://github.com/unleash/unleash-client-rust) - [Rust SDK](https://github.com/unleash/unleash-client-rust)
- [.NET SDK](/sdks/dot_net_sdk) - [.NET SDK](/sdks/dot_net_sdk)
### Front-end SDKs ### Client-side SDKs
For security and performance reasons, the front-end SDKs do not communicate directly with your Unleash instance. Instead, they go via the [Unleash Proxy](unleash-proxy.md). Client-side SDKs can connect to the [Unleash Proxy](unleash-proxy.md) or to the [Unleash front-end API](../reference/front-end-api.md), but _not_ to the regular Unleash client API.
- [Android SDK](/sdks/android_proxy_sdk) - [Android SDK](/sdks/android_proxy_sdk)
- [iOS Proxy SDK](/sdks/proxy-ios) - [iOS Proxy SDK](/sdks/proxy-ios)

View File

@ -3,7 +3,7 @@ id: proxy-ios
title: iOS Proxy SDK title: iOS Proxy SDK
--- ---
In this guide we explain how to use feature toggles in Swift applications via [The Unleash Proxy](./unleash-proxy). You can also checkout the source code for the [iOS Proxy SDK](https://github.com/Unleash/unleash-proxy-client-swift). In this guide we explain how to use feature toggles in Swift applications via the [Unleash Proxy](./unleash-proxy.md). You can also check out the [source code for the iOS Proxy SDK](https://github.com/Unleash/unleash-proxy-client-swift).
## Introduction {#introduction} ## Introduction {#introduction}

View File

@ -3,43 +3,57 @@ id: proxy-javascript
title: JavaScript Proxy SDK title: JavaScript Proxy SDK
--- ---
In this guide we explain how to use feature toggles in a Single Page App via [The Unleash Proxy](/sdks/unleash-proxy). You can also checkout the source code for the [JavaScript Proxy SDK](https://github.com/unleash/unleash-proxy-client-js). This guide shows you how to use feature toggles in a single-page app with the [Unleash Proxy](/sdks/unleash-proxy) and the [Unleash front-end API](../reference/front-end-api). You can also check out the source code for the [JavaScript Proxy SDK](https://github.com/unleash/unleash-proxy-client-js) on GitHub for more details around the SDK.
## Introduction {#introduction} ## Introduction {#introduction}
For single-page apps we have a tiny proxy-client in JavaScript, without any external dependencies, except from browser APIs. This client will store toggles relevant for the current user in local-storage and synchronize with the Unleash Proxy in the background. This means we can bootstrap the toggles for a specific use the next time the user visits the web-page. The JavaScript proxy client is a tiny Unleash client written in JavaScript without any external dependencies (except from browser APIs). This client stores toggles relevant for the current user in `localStorage` and synchronizes with Unleash (the proxy _or_ the Unleash front-end API) in the background. Because toggles are stored in the user's browser, the client can use them to bootstrap itself the next time the user visits the same web page.
> We are looking in to also [supporting react-native](https://github.com/Unleash/unleash/issues/785) with this SDK. Reach out if you want to help us validate the implementation. > We are looking in to also [supporting react-native](https://github.com/Unleash/unleash/issues/785) with this SDK. Reach out if you want to help us validate the implementation.
## How to use the JavaScript Proxy SDK ## How to use the JavaScript Proxy SDK
**Step 1: Install** ## Step 1: Install
```shell npm2yarn ```shell npm2yarn
npm install unleash-proxy-client npm install unleash-proxy-client
``` ```
**Step 2: Initialize the SDK** ## Step 2: Initialize the SDK
You need to have an Unleash Proxy server running. In addition you will need a proxy-specific `clientKey` in order to connect to the Unleash Proxy. For more on how to set up client keys, [consult the Unleash Proxy docs](unleash-proxy.md#configuration-variables).
```js ```js
import { UnleashClient } from 'unleash-proxy-client'; import { UnleashClient } from 'unleash-proxy-client';
const unleash = new UnleashClient({ const unleash = new UnleashClient({
url: 'https://eu.unleash-hosted.com/hosted/proxy', url: 'https://eu.unleash-hosted.com/hosted/proxy',
clientKey: 'your-proxy-key', clientKey: 'your-client-key',
appName: 'my-webapp', appName: 'my-webapp',
}); });
// Used to set the context fields, shared with the Unleash Proxy // Use `updateContext` to set Unleash context fields.
unleash.updateContext({ userId: '1233' }); unleash.updateContext({ userId: '1233' });
// Start the background polling // Start the background polling
unleash.start(); unleash.start();
``` ```
**Step 3: Check if feature toggle is enabled** ### Option A: Connecting to the Unleash proxy
:::tip Prerequisites
To connect to an Unleash proxy, you need to have an instance of the proxy running.
:::
Add the proxy's URL and a [proxy client key](../reference/api-tokens-and-client-keys.mdx#proxy-client-keys). The [_configuration_ section of the Unleash proxy docs](unleash-proxy.md#configuration-variables) contain more info on how to configure client keys for your proxy.
### Option B: Connecting directly to Unleash
Use the url to your Unleash instance's front-end API (`<unleash-url>/api/frontend`) as the `url` parameter. For the `clientKey` parameter, use a `FRONTEND` token generated from your Unleash instance. Refer to the [_how to create API tokens_](/user_guide/api-token) guide for the necessary steps.
You might also need to set up cross-origin resource sharing (CORS) for your instance. Visit the [CORS section of the front-end API guide](../reference/front-end-api.md#cors) for more information on setting up CORS.
### Step 3: Check if feature toggle is enabled
```js ```js
unleash.isEnabled('proxy.demo'); unleash.isEnabled('proxy.demo');
@ -54,7 +68,7 @@ if (variant.name === 'blue') {
} }
``` ```
**Listen for updates via the EventEmitter** ## Listen for updates via the EventEmitter
The client is also an event emitter. This means that your code can subscribe to updates from the client. This is a neat way to update a single page app when toggle state updates. The client is also an event emitter. This means that your code can subscribe to updates from the client. This is a neat way to update a single page app when toggle state updates.

View File

@ -3,7 +3,7 @@ id: proxy-react
title: React Proxy SDK title: React Proxy SDK
--- ---
This library is meant to be used with the [unleash-proxy](https://github.com/Unleash/unleash-proxy). The proxy application layer will sit between your unleash instance and your client applications, and provides performance and security benefits. DO NOT TRY to connect this library directly to the unleash instance, as the datasets follow different formats because the proxy only returns evaluated toggle information. This library can be used with the [Unleash Proxy](https://github.com/Unleash/unleash-proxy) or with the [Unleash front-end API](../reference/front-end-api). It is _not_ compatible with the regular Unleash client API.
For more detailed information, check out the [React Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-react). For more detailed information, check out the [React Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-react).
@ -23,7 +23,7 @@ The configuration variables are:
- **`url`** - **`url`**
Your proxy's URL. Your proxy's URL or the Unleash front-end API endpoint (`<unleash-url>/api/frontend`).
- **`clientKey`** - **`clientKey`**
@ -45,7 +45,7 @@ The configuration variables are:
import { FlagProvider } from '@unleash/proxy-client-react'; import { FlagProvider } from '@unleash/proxy-client-react';
const config = { const config = {
url: 'https://HOSTNAME/api/proxy', url: 'https://PROXY_HOSTNAME/api/proxy', // or https://UNLEASH_HOSTNAME/api/frontend
clientKey: 'PROXYKEY', clientKey: 'PROXYKEY',
refreshInterval: 15, refreshInterval: 15,
appName: 'your-app-name', appName: 'your-app-name',

View File

@ -8,7 +8,7 @@ title: Svelte Proxy SDK
</div> </div>
<br/> <br/>
This library is meant to be used with the [unleash-proxy](https://github.com/Unleash/unleash-proxy). The proxy application layer will sit between your unleash instance and your client applications, and provides performance and security benefits. DO NOT TRY to connect this library directly to the unleash instance, as the datasets follow different formats because the proxy only returns evaluated toggle information. This library can be used with the [Unleash Proxy](https://github.com/Unleash/unleash-proxy) or with the [Unleash front-end API](../reference/front-end-api). It is _not_ compatible with the regular Unleash client API.
For more detailed information, check out the [Svelte Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-svelte). For more detailed information, check out the [Svelte Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-svelte).

View File

@ -8,7 +8,7 @@ title: Vue Proxy SDK
</div> </div>
<br/> <br/>
This library is meant to be used with the [unleash-proxy](https://github.com/Unleash/unleash-proxy). The proxy application layer will sit between your unleash instance and your client applications, and provides performance and security benefits. DO NOT TRY to connect this library directly to the unleash instance, as the datasets follow different formats because the proxy only returns evaluated toggle information. This library can be used with the [Unleash Proxy](https://github.com/Unleash/unleash-proxy) or with the [Unleash front-end API](../reference/front-end-api). It is _not_ compatible with the regular Unleash client API.
For more detailed information, check out the [Vue Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-vue). For more detailed information, check out the [Vue Proxy SDK on GitHub](https://github.com/Unleash/proxy-client-vue).

View File

@ -11,7 +11,7 @@ Looking for how to run the Unleash proxy? Check out the [_How to run the Unleash
::: :::
A lot of our users wanted to use feature toggles in their single-page and native applications. To solve this in a performant and privacy concerned way we built The Unleash Proxy A lot of our users wanted to use feature toggles in their single-page and native applications. To solve this in a performant and privacy-focused way we built the Unleash proxy.
The Unleash Proxy sits between the Unleash API and the application. It provides a simple and super-fast API, as it has all the data it needs available in memory. The Unleash Proxy sits between the Unleash API and the application. It provides a simple and super-fast API, as it has all the data it needs available in memory.

View File

@ -64,7 +64,7 @@ You'll need to configure the proxy and the proxy client SDKs.
For the proxy, configure: For the proxy, configure:
- The Unleash API url. This is your Unleash instance URL followed by "/api". - The Unleash API url. This is your Unleash instance URL followed by "/api".
- A [client API token](../reference/api-tokens-and-client-keys.mdx#client-tokens). (Refer to [how to create API tokens](../user_guide/token.md) for the steps to create one.) - A [client API token](../reference/api-tokens-and-client-keys.mdx#client-tokens). (Refer to [how to create API tokens](../user_guide/token.mdx) for the steps to create one.)
- One or more [proxy client keys](../reference/api-tokens-and-client-keys.mdx#proxy-client-keys). Refer to the [configuration section of the proxy document](../sdks/unleash-proxy#configuration) for more details. - One or more [proxy client keys](../reference/api-tokens-and-client-keys.mdx#proxy-client-keys). Refer to the [configuration section of the proxy document](../sdks/unleash-proxy#configuration) for more details.
For the proxy client SDK, configure: For the proxy client SDK, configure:
@ -91,7 +91,7 @@ You'll need to configure the proxy and the proxy client SDKs.
For the proxy, configure: For the proxy, configure:
- The Unleash API url. This is your Unleash instance URL followed by "/api". - The Unleash API url. This is your Unleash instance URL followed by "/api".
- A [client API token](../reference/api-tokens-and-client-keys.mdx#client-tokens). (Refer to [how to create API tokens](../user_guide/token.md) for the steps to create one.) - A [client API token](../reference/api-tokens-and-client-keys.mdx#client-tokens). (Refer to [how to create API tokens](../user_guide/token.mdx) for the steps to create one.)
- One or more [proxy client keys](../reference/api-tokens-and-client-keys.mdx#proxy-client-keys). Refer to the [configuration section of the proxy document](../sdks/unleash-proxy#configuration) for more details. - One or more [proxy client keys](../reference/api-tokens-and-client-keys.mdx#proxy-client-keys). Refer to the [configuration section of the proxy document](../sdks/unleash-proxy#configuration) for more details.
For the proxy client SDK, configure: For the proxy client SDK, configure:

View File

@ -59,7 +59,10 @@ This strategy has the following modelling name in the code:
### Custom stickiness (beta) {#custom-stickiness} ### Custom stickiness (beta) {#custom-stickiness}
:::note This feature is currently in beta and is not yet supported by all our SDKs. Check out the [SDK compatibility table](../sdks/index.md#server-side-sdk-compatibility-table) to see what SDKs support it at the moment. ::: :::note
This feature is currently in beta and is not yet supported by all our SDKs. Check out the [SDK compatibility table](../sdks/index.md#server-side-sdk-compatibility-table) to see what SDKs support it at the moment.
:::
By enabling the stickiness option on a custom context field you can use the custom context field to group users with the gradual rollout strategy. This will guarantee a consistent behavior for specific values of this context field. By enabling the stickiness option on a custom context field you can use the custom context field to group users with the gradual rollout strategy. This will guarantee a consistent behavior for specific values of this context field.

View File

@ -13,7 +13,7 @@ Activation strategies compound, and every single strategy will be evaluated. If
> Unless you add activation strategies on toggle creation, the toggle will be created with the default strategy. The default strategy says that the toggle is either 100% off or 100% on for all users. This means that any other strategies you add will have no effect. If you want to use strategies to control rollout you need to remove the default strategy. > Unless you add activation strategies on toggle creation, the toggle will be created with the default strategy. The default strategy says that the toggle is either 100% off or 100% on for all users. This means that any other strategies you add will have no effect. If you want to use strategies to control rollout you need to remove the default strategy.
Unleash comes with a set of built in strategies. [But you can also build your own custom strategies.](../advanced/custom_activation_strategy) Unleash comes with a set of built-in strategies, but you can also build your own [custom strategies](../advanced/custom-activation-strategy.md).
[You can read more about activation strategies here.](./activation_strategy) [You can read more about activation strategies here.](./activation_strategy)

View File

@ -18,6 +18,7 @@ Have questions that you can't find the answer to in these docs? You can always t
## Documentation structure ## Documentation structure
Our documentation is split into four parts, using the [Diátaxis documentation framework](https://diataxis.fr/): Our documentation is split into four parts, using the [Diátaxis documentation framework](https://diataxis.fr/):
- [tutorials and introductory material](#tutorials) - [tutorials and introductory material](#tutorials)
- [how-to guides](#how-to-guides) - [how-to guides](#how-to-guides)
- [reference documentation](#reference-documentation) - [reference documentation](#reference-documentation)
@ -26,6 +27,7 @@ Our documentation is split into four parts, using the [Diátaxis documentation f
### Tutorials and introductory material {#tutorials} ### Tutorials and introductory material {#tutorials}
New to Unleash? Not sure where to get started? The tutorials guide you through your first steps with Unleash: New to Unleash? Not sure where to get started? The tutorials guide you through your first steps with Unleash:
- [Unleash introductory overview](unleash_overview.md) - [Unleash introductory overview](unleash_overview.md)
- [Important Unleash concepts](important-concepts.md) - [Important Unleash concepts](important-concepts.md)
- [Quickstart guides](quickstart.md) - [Quickstart guides](quickstart.md)
@ -35,6 +37,7 @@ New to Unleash? Not sure where to get started? The tutorials guide you through y
Our how-to guides show you how to perform a number of common tasks that you'll want to do. Think of them as recipes. They are more advanced than the tutorials and assume you have some working knowledge of Unleash. Our how-to guides show you how to perform a number of common tasks that you'll want to do. Think of them as recipes. They are more advanced than the tutorials and assume you have some working knowledge of Unleash.
The guides are organized into the following categories: The guides are organized into the following categories:
- [API how-tos](/how-to/api) - [API how-tos](/how-to/api)
- [Feature toggles, strategies, context, and general how-tos](/how-to/misc) - [Feature toggles, strategies, context, and general how-tos](/how-to/misc)
- [Users and permissions how-tos](/how-to/users-and-permissions) - [Users and permissions how-tos](/how-to/users-and-permissions)
@ -45,9 +48,10 @@ The guides are organized into the following categories:
The reference docs contain technical reference for Unleash and the API. Go here to find out how Unleash works and what configuration options are available. They're like an Unleash encyclopedia and assume you have a grip on key Unleash concepts. The reference docs contain technical reference for Unleash and the API. Go here to find out how Unleash works and what configuration options are available. They're like an Unleash encyclopedia and assume you have a grip on key Unleash concepts.
The reference docs are organized into the following topics: The reference docs are organized into the following topics:
- [Addons](/addons) - [Addons](/addons)
- [API documentation](/api) - [API documentation](/api)
- [Unleash Client SDKs](/sdks) - [Unleash SDKs](/sdks)
- [Deployment and management of Unleash](/deploy) - [Deployment and management of Unleash](/deploy)
- [Integrations with other systems](/integrations) - [Integrations with other systems](/integrations)
- [Unleash concepts](/reference/concepts) - [Unleash concepts](/reference/concepts)
@ -58,8 +62,8 @@ The reference docs are organized into the following topics:
## Other resources and communities ## Other resources and communities
💻 The core of Unleash is all open source and [hosted on GitHub](https://www.heroku.com/deploy/?template=https://github.com/Unleash/unleash "Unleash on GitHub"). 💻 The core of Unleash is all open source and [hosted on GitHub](https://www.heroku.com/deploy/?template=https://github.com/Unleash/unleash 'Unleash on GitHub').
💬 If you've got questions or just wanna chat to the team and other Unleash users, come [join our Slack community](https://slack.unleash.run/) 💬 If you've got questions or just wanna chat to the team and other Unleash users, come [join our Slack community](https://slack.unleash.run/)
🐦 You can also follow us [on Twitter](https://twitter.com/getunleash "Unleash on Twitter"), [LinkedIn](https://www.linkedin.com/company/getunleash/ "Unleash on LinkedIn"), or [Instagram](https://www.instagram.com/getunleash/ "Unleash on Instagram") for more updates and extra content. 🐦 You can also follow us [on Twitter](https://twitter.com/getunleash 'Unleash on Twitter'), [LinkedIn](https://www.linkedin.com/company/getunleash/ 'Unleash on LinkedIn'), or [Instagram](https://www.instagram.com/getunleash/ 'Unleash on Instagram') for more updates and extra content.

View File

@ -172,7 +172,7 @@ http://CHANGEME/api/admin/features
Next, find the navigation, open up the Admin panel and find the API Access tab. Click the "Add new api key" button and create a client key. This key can be used to connect to the instance with our [SDKs](sdks/index.md). Next, find the navigation, open up the Admin panel and find the API Access tab. Click the "Add new api key" button and create a client key. This key can be used to connect to the instance with our [SDKs](sdks/index.md).
You can find more [information about API keys here](token.md). You can find more [information about API keys here](token.mdx).
Now that you have your API key created, you have what you need to connect to the SDK (NodeJS example): Now that you have your API key created, you have what you need to connect to the SDK (NodeJS example):
@ -333,7 +333,7 @@ http://CHANGEME/api/admin/features
Find the navigation, open up the Admin panel and find the API Access tab. Click the "Add new api key" button and create a client key. This key can be used to connect to the instance with our [SDKs](sdks/index.md). Find the navigation, open up the Admin panel and find the API Access tab. Click the "Add new api key" button and create a client key. This key can be used to connect to the instance with our [SDKs](sdks/index.md).
You can find more [information about API keys here](token.md). You can find more [information about API keys here](token.mdx).
Now that you have your API key created, you have what you need to connect to the SDK (NodeJS example): Now that you have your API key created, you have what you need to connect to the SDK (NodeJS example):

View File

@ -1,50 +0,0 @@
---
id: api-token
title: How to create API Tokens
---
In order to connect to Unleash clients will need an API token to grant access. A client SDK will need to token with "client privileges", which allows them to fetch feature toggle configuration and post usage metrics back.
## Create API Token {#create-api-token}
### Permissions {#permissions}
To create an API token you'll need the CREATE_API_TOKEN permission level, at the time of writing (v4.0.0), this level is only set for instance admins.
Eventually one should be able to customize which users has access to create tokens.
All users are able to see tokens with CLIENT level access, but only instance admins can see tokens with ADMIN level access.
### Step-by-step {#step-by-step}
**1. Select `Advanced` from the top-line menu**
![Admin menu](/img/admin_top-line_menu.png)
**2. Select `API Access` from the dropdown**
![Tab Menu](/img/admin_advanced_dropdown.png)
**3. Select `API ACCESS` from the tab men**
![Tab Menu](/img/admin_tab_menu.png)
**4. Click `Add new API key` at the top right of the page**
![Tab Menu](/img/admin_new_api_key_button.png)
**Client keys**
4a. If you're configuring an SDK select `Client` in the pop-up. And give the key an identifying name allowing you to recognize it later
![Api key client](/img/add_new_api_key.png)
5a. Copy the `Secret` column and add this to your client
![Api key list](/img/api_key_list.png)
**Admin operations**
4a. If you're going to be using the admin interface via CURL you'll need a key with `Admin` rights. Select `Admin` in the `Add new API key` popup.
Remember to give the key a username allowing you to recognize the key in audit logs later
5a. Copy the key in the `Secret` column and use it in your authorization header. For curl, that would be `-H "Authorization: <yoursecrethere>"`

View File

@ -0,0 +1,38 @@
---
id: api-token
title: How to create API Tokens
---
import newTokenImage from '/img/admin_create_token_form.png';
::: info Permissions
Creating API tokens requires you to have the `CREATE_API_TOKEN` permission. This means that, as of now, **only instance admins can create API tokens.**
All users can see tokens with `CLIENT` level access, but only instance admins can see tokens with `ADMIN` level access.
:::
Unleash SDKs use API tokens to authenticate to the Unleash API. Unleash supports different types of API tokens, each with different levels of access and privileges. Refer to the [API tokens and client keys](../reference/api-tokens-and-client-keys.mdx) article for complete overview of the different token types.
## Step 1: Navigate to the API token creation form {#step-1}
Navigate to the _API access_ page in the admin UI (available at the URL `/admin/api`). Use the navigation menu item "Configure" and select "API access".
![The admin UI navigation "Configure" submenu with the API access item highlighted.](/img/admin_configure_api.png)
On the API access page, use the "New API token" button to navigate to the token creation form.
![The API access page with the "New API token" button highlighted.](/img/admin_new_api_key_button.png)
## Step 2: Fill in the API token form {#step-2}
![API token creation form. ](/img/admin_create_token_form.png)
Fill in the form with the desired values for the token you want to create. Refer to the [API tokens and client keys](../reference/api-tokens-and-client-keys.mdx#token-data) article for a detailed explanation of what all the fields mean.
## Using API tokens
When you have created the API token, it will be listed on the API access page. If you have the required permissions to see the token, you can copy it for easy use in your applications.
![API access token table with a "copy token" button highlighted.](/img/admin_copy_token.png)

View File

@ -192,7 +192,7 @@ module.exports = {
}, },
{ {
type: 'category', type: 'category',
label: 'Client SDKs', label: 'Application SDKs',
link: { type: 'doc', id: 'sdks/index' }, link: { type: 'doc', id: 'sdks/index' },
items: [ items: [
{ {
@ -289,6 +289,7 @@ module.exports = {
'reference/feature-toggles', 'reference/feature-toggles',
'advanced/feature_toggle_types', 'advanced/feature_toggle_types',
'advanced/toggle_variants', 'advanced/toggle_variants',
'reference/front-end-api',
'reference/playground', 'reference/playground',
'user_guide/projects', 'user_guide/projects',
'user_guide/rbac', 'user_guide/rbac',

Binary file not shown.

Before

Width:  |  Height:  |  Size: 330 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 454 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 72 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 60 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 67 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 63 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 563 KiB

After

Width:  |  Height:  |  Size: 36 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 576 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 45 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 232 KiB