kameleoon / openfeature-php
Kameleoon OpenFeature PHP
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 1
Forks: 0
Open Issues: 0
pkg:composer/kameleoon/openfeature-php
Requires
- kameleoon/kameleoon-client-php: >=4.4.0
- open-feature/sdk: >=2.0.8
README
The Kameleoon OpenFeature provider for PHP allows you to connect your OpenFeature PHP implementation to Kameleoon without installing the PHP Kameleoon SDK.
Warning
This is a beta version. Breaking changes may be introduced before general release.
Supported PHP versions
This version of the SDK is built for the following targets:
- PHP 8.0 and above.
Get started
This section explains how to install, configure, and customize the Kameleoon OpenFeature provider.
Install dependencies
First, install the required dependencies in your application.
add in composer.json
{
  "require": {
    "kameleoon/openfeature-php": ">=0.0.1"
  }
}
composer install
Usage
The following example shows how to use the Kameleoon provider with the OpenFeature SDK.
use OpenFeature\implementation\flags\Attributes; use OpenFeature\implementation\flags\EvaluationContext; use OpenFeature\OpenFeatureAPI; use Kameleoon\KameleoonProvider; use Kameleoon\KameleoonClientConfig; $clientConfig = new KameleoonClientConfig( "clientId", "clientSecret", ); $provider = new KameleoonProvider('siteCode', $clientConfig); $api = OpenFeatureAPI::getInstance(); $api->setProvider($provider); $client = $api->getClient(); $dataDictionary = [ 'variableKey' => 'stringKey' ]; $evalContext = new EvaluationContext("visitorCode", new Attributes($dataDictionary)); $evaluationDetails = $client->getStringDetails("featureKey", 5, $evalContext); $numberOfRecommendedProducts = $evaluationDetails->getValue(); print_r("Number of recommended products: " . $numberOfRecommendedProducts);
Customize the Kameleoon provider
You can customize the Kameleoon provider by changing the KameleoonClientConfig object that you passed to the constructor above. For example:
$clientConfig = new KameleoonClientConfig( clientId: "clientId", clientSecret: "clientSecret", kameleoonWorkDir: "/tmp/kameleoon/php-client/", // kameleoonWorkDir: optional / ("/tmp/kameleoon/php-client/" by default) refreshIntervalMinute: 60, // refreshIntervalMinute: in minutes, optional (60 minutes by default) defaultTimeoutMillisecond: 10_000, // defaultTimeoutMillisecond: in milliseconds, optional (10_000 ms by default) debugMode: false, // debugMode: optional (false by default) cookieOptions: $cookieOptions, // cookieOptions: optional environment: "development" // environment: optional ("production" by default) ); $provider = new KameleoonProvider('siteCode', $clientConfig);
Note
For additional configuration options, see the Kameleoon documentation.
EvaluationContext and Kameleoon Data
Kameleoon uses the concept of associating Data to users, while the OpenFeature SDK uses the concept of an EvaluationContext, which is a dictionary of string keys and values. The Kameleoon provider maps the EvaluationContext to the Kameleoon Data.
Note
To get the evaluation for a specific visitor, set the targeting_key value for the EvaluationContext to the visitor code (user ID). If the value is not provided, then the defaultValue parameter will be returned.
$values = [ 'variableKey' => 'stringKey' ]; $evalContext = new EvaluationContext("userId", new Attributes($values));
The Kameleoon provider provides a few predefined parameters that you can use to target a visitor from a specific audience and track each conversion. These are:
| Parameter | Description | 
|---|---|
| DataType::CUSTOM_DATA | The parameter is used to set CustomDatafor a visitor. | 
| DataType::CONVERSION | The parameter is used to track a Conversionfor a visitor. | 
DataType::CUSTOM_DATA
Use DataType::CUSTOM_DATA to set CustomData for a visitor. The DataType::CUSTOM_DATA field has the following parameters:
| Parameter | Type | Description | 
|---|---|---|
| CustomDataType::INDEX | int | Index or ID of the custom data to store. This field is mandatory. | 
| CustomDataType::VALUES | string or array | Value of the custom data to store. This field is mandatory. | 
Example
$customeDataDictionary = [ DataType::CUSTOM_DATA => [ CustomDataType::INDEX => 1, CustomDataType::VALUES => '10' ] ]; $evalContext = new EvaluationContext("userId", new Attributes($customeDataDictionary));
DataType::CONVERSION
Use DataType::CONVERSION to track a Conversion for a visitor. The DataType::CONVERSION field has the following parameters:
| Parameter | Type | Description | 
|---|---|---|
| ConversionType::GOAL_ID | int | Identifier of the goal. This field is mandatory. | 
| ConversionType::REVENUE | float | Revenue associated with the conversion. This field is optional. | 
Example
$conversionDictionary = [ DataType::CONVERSION => [ ConversionType::GOAL_ID => 1, ConversionType::REVENUE => 200 ] ]; $evalContext = new EvaluationContext("userId", new Attributes($conversionDictionary));
Use multiple Kameleoon Data types
You can provide many different kinds of Kameleoon data within a single EvaluationContext instance.
For example, the following code provides one DataType::CONVERSION instance and two DataType::CUSTOM_DATA instances.
$dataDictionary = [ DataType::CONVERSION => [ ConversionType::GOAL_ID => 1, ConversionType::REVENUE => 200 ], DataType::CUSTOM_DATA => [ [ CustomDataType::INDEX => 1, CustomDataType::VALUES => ['10', '30'] ], [ CustomDataType::INDEX => 2, CustomDataType::VALUES => '20' ] ] ]; $evalContext = new EvaluationContext("userId", $dataDictionary);