Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
unleash-proxy-client
Advanced tools
A browser client that can be used together with Unleash Edge or the Unleash Frontend API.
The unleash-proxy-client npm package is a client library for the Unleash Proxy, which is a feature management system. It allows you to control feature toggles in your application, enabling or disabling features without deploying new code. This is particularly useful for A/B testing, gradual rollouts, and canary releases.
Initialize Client
This code initializes the Unleash client with the necessary configuration such as the URL of the Unleash Proxy, the client key, and the application name. The `start` method is called to begin fetching feature toggles.
const { UnleashClient } = require('unleash-proxy-client');
const unleash = new UnleashClient({
url: 'https://app.unleash-hosted.com/demo/api/frontend',
clientKey: 'your-client-key',
appName: 'my-app'
});
unleash.start();
Check Feature Toggle
This code checks if a specific feature toggle is enabled. The `isEnabled` method returns a boolean indicating the status of the feature toggle.
const isEnabled = unleash.isEnabled('feature-toggle-name');
console.log(`Feature is enabled: ${isEnabled}`);
Register Event Listeners
This code registers event listeners for the Unleash client. The `update` event is triggered when feature toggles are updated, and the `error` event is triggered if there is an error fetching feature toggles.
unleash.on('update', () => {
console.log('Feature toggles updated');
});
unleash.on('error', (error) => {
console.error('Error fetching feature toggles:', error);
});
LaunchDarkly is a feature management platform that allows you to control the release of features to users. It offers similar functionality to Unleash, such as feature toggles, A/B testing, and gradual rollouts. The main difference is that LaunchDarkly is a commercial product with more advanced analytics and targeting capabilities.
ConfigCat is a feature flag and configuration management service. It provides similar functionalities to Unleash, including feature toggles and remote configuration. ConfigCat is known for its simplicity and ease of use, making it a good alternative for smaller projects or teams.
Flagr is an open-source feature flagging and A/B testing service. It allows you to create and manage feature flags and run experiments. Flagr is similar to Unleash in that it is open-source and can be self-hosted, but it also includes built-in support for A/B testing and experimentation.
The JavaScript 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 Unleash front-end API or Unleash edge) 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.
This client expect fetch
to be available.
This package is not tied to any framework, but can be used together most popular frameworks, examples:
npm install unleash-proxy-client
💡 TIP: As a client-side SDK, this SDK requires you to connect to either Unleash Edge or to the Unleash front-end API. Refer to the connection options section for more information.
Configure the client according to your needs. The following example provides only the required options. Refer to the section on available options for the full list.
import { UnleashClient } from 'unleash-proxy-client';
const unleash = new UnleashClient({
url: 'https://<your-unleash-instance>/api/frontend',
clientKey: '<your-client-side-token>',
appName: 'my-webapp',
});
// Start the background polling
unleash.start();
To connect this SDK to your Unleash instance's front-end API, 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 guide for the necessary steps.
This SDK can also be used with Unleash Edge.
You should wait for the client's ready
or initialized
events before you start working with it. Before it's ready, the client might not report the correct state for your features.
unleash.on('ready', () => {
if (unleash.isEnabled('js.demo')) {
console.log('js.demo is enabled');
} else {
console.log('js.demo is disabled');
}
});
The difference between the events is described in the section on available events.
Once the client is ready, you can start checking features in your application. Use the isEnabled
method to check the state of any feature you want:
unleash.isEnabled('js.demo');
You can use the getVariant
method to get the variant of an enabled feature that has variants. If the feature is disabled or if it has no variants, then you will get back the disabled variant
const variant = unleash.getVariant('proxy.demo');
if (variant.name === 'blue') {
// something with variant blue...
}
The Unleash context is used to evaluate features against attributes of a the current user. To update and configure the Unleash context in this SDK, use the updateContext
, setContextField
and removeContextField
methods.
The context you set in your app will be passed along to the Unleash proxy or the front-end API as query parameters for feature evaluation.
The updateContext
method will replace the entire
(mutable part) of the Unleash context with the data that you pass in.
The setContextField
method only acts on the property that you choose. It does not affect any other properties of the Unleash context.
unleash.updateContext({ userId: '1233' });
unleash.setContextField('userId', '4141');
The removeContextField
method only acts on the property that you choose. It does not affect any other properties of the Unleash context.
unleash.updateContext({ userId: '1233', sessionId: 'sessionNotAffected' });
unleash.removeContextField('userId');
The Unleash SDK takes the following options:
option | required | default | description |
---|---|---|---|
url | yes | n/a | The Unleash URL to connect to. E.g.: https://examples.com/api/front-end |
clientKey | yes | n/a | The Unleash API Secret to be used |
appName | yes | n/a | The name of the application using this SDK. Will be used as part of the metrics sent to Unleash. Will also be part of the Unleash Context. |
context | no | {} | The initial Unleash context. This will be used as the initial context for all feature toggle evaluations. The appName and environment options will automatically be populated with the values you pass for those options. |
refreshInterval | no | 30 | How often, in seconds, the SDK should check for updated toggle configuration. If set to 0 will disable checking for updates |
disableRefresh | no | false | If set to true, the client will not check for updated toggle configuration |
metricsInterval | no | 60 | How often, in seconds, the SDK should send usage metrics back to Unleash. It will be started after the initial metrics report, which is sent after the configured metricsIntervalInitial |
metricsIntervalInitial | no | 2 | How long the SDK should wait for the first metrics report back to the Unleash API. If you want to disable the initial metrics call you can set it to 0. |
disableMetrics | no | false | Set this option to true if you want to disable usage metrics |
storageProvider | no | LocalStorageProvider in browser, InMemoryStorageProvider otherwise | Allows you to inject a custom storeProvider |
fetch | no | window.fetch or global fetch | Allows you to override the fetch implementation to use. Useful in Node.js environments where you can inject node-fetch |
createAbortController | no | () => new AbortController() | Allows you to override the default AbortController creation. Used to cancel requests with outdated context. Set it to () => null if you don't want to handle it. |
bootstrap | no | [] | Allows you to bootstrap the cached feature toggle configuration. |
bootstrapOverride | no | true | Should the bootstrap automatically override cached data in the local-storage. Will only be used if bootstrap is not an empty array. |
headerName | no | Authorization | Which header the SDK should use to authorize with Unleash / Unleash Edge. The header will be given the clientKey as its value. |
customHeaders | no | {} | Additional headers to use when making HTTP requests to Unleash. In case of name collisions with the default headers, the customHeaders value will be used if it is not null or undefined . customHeaders values that are null or undefined will be ignored. |
impressionDataAll | no | false | Allows you to trigger "impression" events for all getToggle and getVariant invocations. This is particularly useful for "disabled" feature toggles that are not visible to frontend SDKs. |
environment | no | default | Sets the environment option of the Unleash context. This does not affect the SDK's Unleash environment. |
usePOSTrequests | no | false | Configures the client to use POST requests instead of GET when requesting enabled features. This is helpful when sensitive information (like user email, when used as a user ID) is passed in the context to avoid leaking it in the URL. NOTE: Post requests are not supported by the frontend api built into Unleash. |
experimental | no | {} | Enabling optional experimentation. togglesStorageTTL : How long (Time To Live), in seconds, the toggles in storage are considered valid and should not be fetched on start. If set to 0 will disable expiration checking and will be considered always expired. |
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.
unleash.on('update', () => {
const myToggle = unleash.isEnabled('js.demo');
//do something useful
});
PS! Please remember that you should always register your event listeners before your call
unleash.start()
. If you register them after you have started the SDK you risk loosing important events.
You may provide a custom session id via the "context". If you do not provide a sessionId this SDK will create a random session id, which will also be stored in the provided storage (local storage). By always having a consistent sessionId available ensures that even "anonymous" users will get a consistent experience when feature toggles is evaluated, in combination with a gradual (percentage based) rollout.
You can stop the Unleash client by calling the stop
method. Once the client has been stopped, it will no longer check for updates or send metrics to the server.
A stopped client can be restarted.
unleash.stop()
This SDK can work with React Native storage @react-native-async-storage/async-storage or react-native-shared-preferences and many more to backup feature toggles locally. This is useful for bootstrapping the SDK the next time the user comes back to your application.
You can provide your own storage implementation.
Examples:
import SharedPreferences from 'react-native-shared-preferences';
import { UnleashClient } from 'unleash-proxy-client';
const unleash = new UnleashClient({
url: 'https://eu.unleash-hosted.com/hosted/proxy',
clientKey: 'your-proxy-key',
appName: 'my-webapp',
storageProvider: {
save: (name: string, data: any) => SharedPreferences.setItem(name, data),
get: (name: string) => SharedPreferences.getItem(name, (val) => val)
},
});
import AsyncStorage from '@react-native-async-storage/async-storage';
import { UnleashClient } from 'unleash-proxy-client';
const PREFIX = 'unleash:repository';
const unleash = new UnleashClient({
url: 'https://eu.unleash-hosted.com/hosted/proxy',
clientKey: 'your-proxy-key',
appName: 'my-webapp',
storageProvider: {
save: (name: string, data: any) => {
const repo = JSON.stringify(data);
const key = `${PREFIX}:${name}`;
return AsyncStorage.setItem(key, repo);
},
get: (name: string) => {
const key = `${PREFIX}:${name}`;
const data = await AsyncStorage.getItem(key);
return data ? JSON.parse(data) : undefined;
}
},
});
This SDK can also be used in node.js applications (from v1.4.0). Please note that you will need to provide a valid "fetch" implementation. Only ECMAScript modules is exported from this package.
import fetch from 'node-fetch';
import { UnleashClient, InMemoryStorageProvider } from 'unleash-proxy-client';
const unleash = new UnleashClient({
url: 'https://app.unleash-hosted.com/demo/proxy',
clientKey: 'proxy-123',
appName: 'nodejs-proxy',
storageProvider: new InMemoryStorageProvider(),
fetch,
});
await unleash.start();
const isEnabled = unleash.isEnabled('proxy.demo');
console.log(isEnabled);
index.mjs
<html>
<head>
<script src="https://unpkg.com/unleash-proxy-client@latest/build/main.min.js" type="text/javascript"></script>
<script type="text/javascript">
var config = {url: 'https://app.unleash-hosted.com/demo/proxy', clientKey: 'proxy-123', appName: 'web'};
var client = new unleash.UnleashClient(config);
client.updateContext({userId: '1233'})
client.on('update', () => {
console.log(client.isEnabled('proxy.demo'));
});
client.start();
</script>
</head>
</html>
Now it is possible to bootstrap the SDK with your own feature toggle configuration when you don't want to make an API call.
This is also useful if you require the toggles to be in a certain state immediately after initializing the SDK.
Add a bootstrap
attribute when create a new UnleashClient
.
There's also a bootstrapOverride
attribute which is by default is true
.
import { UnleashClient } from 'unleash-proxy-client';
const unleash = new UnleashClient({
url: 'https://app.unleash-hosted.com/demo/proxy',
clientKey: 'proxy-123',
appName: 'nodejs-proxy',
bootstrap: [{
"enabled": true,
"name": "demoApp.step4",
"variant": {
"enabled": true,
"name": "blue",
"feature_enabled": true,
}
}],
bootstrapOverride: false
});
NOTES: ⚠️
If bootstrapOverride
is true
(by default), any local cached data will be overridden with the bootstrap specified.
If bootstrapOverride
is false
any local cached data will not be overridden unless the local cache is empty.
You can opt out of the Unleash feature flag auto-refresh mechanism and metrics update by settings the refreshInterval
and/or metricsInterval
options to 0
.
In this case, it becomes your responsibility to call updateToggles
and/or sendMetrics
methods.
This approach is useful in environments that do not support the setInterval
API, such as service workers.
FAQs
A browser client that can be used together with Unleash Edge or the Unleash Frontend API.
We found that unleash-proxy-client demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 3 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.