Common library for Eppo JavaScript SDKs (web, react native, and node)
npm install @eppo/js-client-sdk-commonRefer to our SDK documentation for how to install and use the SDK.
To set up the package for local development, run make prepare after cloning the repository
* Jest encountered an unexpected token
``
Details:
/.../node_modules/@eppo/js-client-sdk-common/node_modules/uuid/dist/esm-browser/index.js:1
({"Object.
^^^^^^
SyntaxError: Unexpected token 'export'
`jest.config.js
Add the following line to your file:transformIgnorePatterns: ['
It may be useful to install the local version of this package as you develop the client SDK or Node SDK.
This can be done in two steps:
1. Open the directory with the client SDK you want to add this library to, and run make prepareyarn add --force file:../js-client-sdk-common
2. Add the local version of this library to the SDK you are developing by running (this assumes both repositories were cloned into the same directory)
When publishing releases, the following rules apply:
- Standard Release:
- Create a release with tag format vX.Y.Z (e.g., v4.3.5)latest
- Keep "Set as latest release" checked
- Package will be published to NPM with the tag
- Pre-release:
- Create a release with tag format vX.Y.Z-label.N (e.g., v4.3.5-alpha.1)alpha.1
- Check the "Set as pre-release" option
- Package will be published to NPM with the pre-release label as its tag (e.g., )
Note: The release will not be published if:
- A pre-release is marked as "latest"
- A pre-release label is used without checking "Set as pre-release"
You can generate a bootstrap configuration string from either the command line or programmatically via the
ConfigurationWireHelper class.
The tool allows you to specify the target SDK this configuration will be used on. It is important to correctly specify
the intended SDK, as this determines whether the configuration is obfuscated (for client SDKs) or not (for server SDKs).
#### Command Line Usage
Install as a project dependency:
`bashInstall as a dependency
npm install --save-dev @eppo/js-client-sdk-common
Common usage examples:
`bash
Basic usage
yarn bootstrap-config --key --output bootstrap-config.jsonWith custom SDK name (default is 'js-client-sdk')
yarn bootstrap-config --key --sdk androidWith custom base URL
yarn bootstrap-config --key --base-url https://api.custom-domain.comOutput configuration to stdout
yarn bootstrap-config --key Show help
yarn bootstrap-config --help
`The tool accepts the following arguments:
-
--key, -k: SDK key (required, can also be set via EPPO_SDK_KEY environment variable)
- --sdk: Target SDK name (default: 'js-client-sdk')
- --base-url: Custom base URL for the API
- --output, -o: Output file path (if not specified, outputs to console)
- --help, -h: Show help#### Programmatic Usage
`typescript
import { ConfigurationHelper } from '@eppo/js-client-sdk-common';async function getBootstrapConfig() {
// Initialize the helper
const helper = ConfigurationHelper.build(
'your-sdk-key',
{
sdkName: 'android', // optional: target SDK name (default: 'js-client-sdk')
baseUrl: 'https://api.custom-domain.com', // optional: custom base URL
});
// Fetch the configuration
const config = await helper.fetchConfiguration();
const configString = config.toString();
// You are responsible to transport this string to the client
const clientInitialData = {eppoConfig: eppoConfigString};
// Client-side
const client = getInstance();
const initialConfig = configurationFromString(clientInitialData.eppoConfig);
client.setInitialConfig(configurationFromString(configString));
}
``The tool will output a JSON string containing the configuration wire format that can be used to bootstrap Eppo SDKs.