Skip to main content

PHP Server SDK Usage

Packagist GitHub

User Object

The full user data must be passed into every method. The only required field is user_id. The rest are optional and are used by the system for user segmentation into Variables and Features.

See the User model in the PHP user model doc for all accepted fields including custom fields.

use DevCycle\Model\DevCycleUser;

$user_data = new DevCycleUser(array("user_id"=>"my-user"));

In addition to the properties you set on the DevCycleUser yourself, these properties are automatically set by the SDK and are ready for segmentation:

PropertyTypeDescription
platformStringPlatform/OS
platformVersionStringPlatform/OS Version

Get and use Variable by key

To get values from your Variables, variableValue() is used to fetch Variable values using the user data, Variable key, coupled with a default value for the Variable. The default Variable will be used in cases where the user is not segmented into a Feature using that Variable, or the Project configuration is unavailable to be fetched from DevCycle's CDN.

try {
$result = $devcycleClient->variableValue($user_data, "my-key", "default");
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling DevCycleClient->variableValue: ', $e->getMessage(), PHP_EOL;
}

The default value can be of type string, boolean, number, or object.

If you would like to get the full Variable object defined by getVariableByKey you can use variable() instead of variableValue(). This contains fields such as: key, value, type, defaultValue, isDefaulted, eval: evaluation object containing reason, details, and targetId for why the Variable was bucketed into its value (see Evaluation Reasons).

Get all Variables

try {
$result = $devcycleClient->allVariables($user_data);
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling DevCycleClient->allVariables: ', $e->getMessage(), PHP_EOL;
}

See getVariables on the Bucketing API for the Variable response format.

caution

This method is intended to be used for debugging and analytics purposes, not as a method for retrieving the value of Variables to change code behaviour. For that purpose, we strongly recommend using the individual Variable access method described in Get and use Variable by key Using this method instead will result in no evaluation events being tracked for individual Variables, and will not allow the use of other DevCycle features such as Code Usage detection

Getting all Features

try {
$result = $devcycleClient->allFeatures($user_data);
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling DevCycleClient->allFeatures: ', $e->getMessage(), PHP_EOL;
}

See getFeatures on the Bucketing API for the Feature response format.

Track Event

use DevCycle\Model\DevCycleEvent;

$event_data = new DevCycleEvent(array("type"=>"my-event"));

try {
$result = $devcycleClient->track($user_data, $event_data);
print_r($result);
} catch (Exception $e) {
echo 'Exception when calling DevCycleClient->track: ', $e->getMessage(), PHP_EOL;
}

EdgeDB

EdgeDB allows you to save user data to our EdgeDB storage so that you don't have to pass in all the user data every time you identify a user. Read more about EdgeDB.

To get started, contact us at support@devcycle.com to enable EdgeDB for your Project.

Once you have EdgeDB enabled in your Project, pass in the enableEdgeDB option to turn on EdgeDB mode for the SDK:


use DevCycle\Api\DevCycleClient;
use DevCycle\Model\DevCycleOptions;
use DevCycle\Model\DevCycleUser;

$options = new DevCycleOptions(true);
$devCycleClient = new DevCycleClient(
sdkKey: getenv("DEVCYCLE_SERVER_SDK_KEY"),
dvcOptions: $options);

Async Methods

Each method in this Usage document has a corresponding asynchronous method:

$result = $devcycleClient->allVariables($user_data);
$devcycleClient->allVariablesAsync($user_data)->then(function($result) {
print_r($result);
});

Evaluation Hooks

Using evaluation hooks, you can hook into the lifecycle of a Variable evaluation to execute code before and after execution of the evaluation.

Note: Each evaluation will wait for all hooks before returning the Variable evaluation, which depending on the complexity of the hooks will cause slower function call times. This also may lead to blocking Variable evaluations in the future until all hooks return depending on the volume of calls to .variable.

warning

Do not call any Variable evaluation functions (.variable/.variableValue) in any of the hooks, as it may cause infinite recursion.

To add a hook:

$hook = new EvalHook(
before: function (HookContext $context) use (&$beforeCalled) {
// before hook
},
after: function (HookContext $context) use (&$afterCalled) {
// after hook
},
onFinally: function (HookContext $context) use (&$onFinallyCalled) {
// onFinally hook
},
error: function (HookContext $context, \Exception $error) use (&$errorCalled) {
// error hook
}
);
$this->client->addHook($hook);

You can also clear the hooks:

$this->client->clearHooks();

Models

User

User data is provided to most SDK requests to identify the user / context of the Feature evaluation

NameTypeDescriptionNotes
user_idStringUnique id to identify the user
emailStringUser's email used to identify the user on the dashboard / target audiences[optional]
nameStringUser's name used to identify the user on the dashboard / target audiences[optional]
languageStringUser's language in ISO 639-1 format[optional]
countryStringUser's country in ISO 3166 alpha-2 format[optional]
app_versionStringApp Version of the running application[optional]
app_buildStringApp Build number of the running application[optional]
custom_dataObjectUser's custom data to target the user with, data will be logged to DevCycle for use in dashboard.[optional]
private_custom_dataObjectUser's custom data to target the user with, data will not be logged to DevCycle only used for Feature bucketing.[optional]
created_dateFloatDate the user was created, Unix epoch timestamp format[optional]
last_seen_dateFloatDate the user was created, Unix epoch timestamp format[optional]
platformStringPlatform the Client SDK is running on[optional]
platform_versionStringVersion of the platform the Client SDK is running on[optional]
device_modelStringUser's device model[optional]
sdk_typeStringDevCycle SDK type[optional]
sdk_versionStringDevCycle SDK Version[optional]

Event

Event data is provided to track calls to log events to DevCycle

NameTypeDescriptionNotes
typeStringCustom event type
targetStringCustom event target / subject of event. Contextual to event type[optional]
dateFloatUnix epoch time the event occurred according to client[optional]
valueFloatValue for numerical events. Contextual to event type[optional]
meta_dataObjectExtra JSON metadata for event. Contextual to event type[optional]

Variable

Variable objects are returned by the SDK when calling variable or allVariables.

NameTypeDescriptionNotes
_idStringunique database id
keyStringUnique key by Project, can be used in the SDK / API to reference by 'key' rather than _id.
typeStringVariable type
valueObjectVariable value can be a string, number, boolean, or JSON

Feature

Feature objects are returned by the SDK when calling allFeatures

NameTypeDescriptionNotes
_idStringunique database id
keyStringUnique key by Project, can be used in the SDK / API to reference by 'key' rather than _id.
typeStringFeature type
_variationStringBucketed Feature Variation
eval_reasonStringEvaluation reasoning[optional]

Tests

To run the tests, use:

composer install
vendor/bin/phpunit