1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-11 00:08:30 +01:00
unleash.unleash/docs/user_guide/native-apps.md
egilconr 1d9065aff1
chore: Improve our user documentation (#733)
Co-authored-by: Christopher Kolstad <chriswk@fastmail.com>
Co-authored-by: Fredrik Strand Oseberg <fredrik.no@gmail.com>
Co-authored-by: Ivar Conradi Østhus <ivarconr@gmail.com>
Co-authored-by: Eco C <egilconr@gmail.com>
2021-02-25 16:01:36 +01:00

1.9 KiB

id title
native_apps Working with native apps

Enterprise feature

Working with native apps, require the unleash proxy. The Unleash Proxy is only available with the Unleash-hosted offering and is not part of Unleash Open-Source.

For a highlevel introduction to the Unleash-proxy, please read this short article The Unleash-Proxy

The Unleash-proxy consist of the proxy that exposes a simple API for the client.

Unleash Proxy

The Proxy-client

There is a js implentation of the proxy-client available. Find it here: https://github.com/unleash-hosted/unleash-proxy-client-js

The Proxy-API

When accessing the Proxy, Unleash context fields from the session context can be added as parameters to the request. The proxy will return only enabled feature toggles and their evaluated value for the given context. You may also use custom context fields in combination with strategy constraints.

https://hostname.com/api/proxy?appName=webapp&userId=123&country=NO

The Proxy will return a list of all the active feature toggles, including variants, available. See an example below

{
    "toggles": [
    {
        "enabled": true,
        "name": "SimpleToggle",
        "variant": {
            "enabled": false,
            "name": "disabled"
        }
    },
    {
        "enabled": true,
        "name": "ToggleWithVariant",
        "variant": {
            "enabled": true,
            "name": "brown"
        }
    },
    {
        "enabled": true,
        "name": "ToggleWithVariantAndPayload",
        "variant": {
            "enabled": true,
            "name": "default",
            "payload": {
                "type": "string",
                "value": "Some custom value here!"
            }
        }
    }
    ]
}