1
0
mirror of https://github.com/Unleash/unleash.git synced 2024-10-18 20:09:08 +02:00
unleash.unleash/website/docs/advanced/custom-activation-strategy.md
2021-12-23 11:42:34 +01:00

5.0 KiB

id title
custom_activation_strategy Custom Activation Strategies

:::tip This document is a reference for custom activation strategies. If you're looking for a guide on how to use them, see the how to use custom strategies guide. :::

Custom activation strategies let you define your own activation strategies to use with Unleash. When the built-in activation strategies aren't enough, custom activation strategies are there to provide you with the flexibility you need.

Custom activation strategies work exactly like the built-in activation strategies when working in the admin UI.

Definition

A strategy creation form. It has fields labeled "strategy name" — "TimeStamp" — and "description" — "activate toggle after a given timestamp". It also has fields for a parameter named "enableAfter". The parameter is of type "string" and the parameter description is "Expected format: YYYY-MM-DD HH:MM". The parameter is required.

You define custom activation strategies on your Unleash instance, either via the admin UI or via the API. A strategy contains:

  • A strategy name: You'll use this to refer to the strategy in the UI and in code.
  • An optional description: Use this to describe what the strategy should do.
  • An optional list of parameters: Use this to provide the strategy with arguments it should use in its evaluation.

The strategy name is the only required parameter, but adding a good description will make it easier to remember what a strategy should do. The list of parameters lets you pass data from the Unleash instance to the strategy implementation.

Parameters

The strategy configuration screen for the custom "TimeStamp" strategy. The "enableAfter" field says "2021-12-25 00:00".

Parameters let you provide arguments to your strategy that it can access for evaluation. When creating a strategy, each parameter can be either required or optional. This marking is to help the user understand what they need to fill out; they can still save the strategy without filling out a required field.

Each parameter consists of three parts:

  • a name: must be unique among the strategy's parameters.
  • an optional description: describe the purpose or format of the parameter.
  • a parameter type: dictates the kind of input field the user will see in the admin UI and the type of the value in the implementation code.

Parameter types

Each parameter has one of five different parameter types. A parameter's type impacts the kind of controls shown in the admin UI and how it's represented in code.

Here's an overview over how the types are represented in the JSON payload returned from the Unleash server. The exact types will vary based on your programming language's type system.

:::note Unset values Values of all types have an empty string ("") as the default value. As such, if you don't interact with a control or otherwise set a value, the value will be an empty string, regardless of the value's type. :::

type name code representation example value UI control
string string "a string" A standard input field
percentage an int between 0 and 100 (inclusive) 99 A value slider
list string (values are comma-separated) "one,two" A multi-input text field
number string "123" A numeric text field
boolean "true" or "false" "true" An on/off toggle

A strategy with five parameters, one of each type.

Implementation

:::note If you have not implemented the strategy in your client SDK, the check will always return false because the client doesn't recognize the strategy. :::

While custom strategies are defined on the Unleash server, they must be implemented on the client. All official Unleash client SDKs provide a way for you to implement custom strategies. You should refer to the individual SDK's documentation for specifics, but for an example, you can have a look at the Node.js client implementation section in the how to use custom strategies guide.

The exact method for implementing custom strategies will vary between SDKs, but the server SDKs follow the same patterns. For front-end client SDKs (Android, JavaScript, React, iOS), the custom activation strategy must be implemented in the Unleash Proxy.

When implementing a strategy in your client, you will get access to the strategy's parameters and the Unleash Context. Again, refer to your specific SDK's documentation for more details.