Skip to main content

.NET / C# Cloud SDK Usage

Nuget GitHub

DevCycleUser Object

The user object is required for all methods. The only required field in the user object is userId

See the DevCycleUser class in .NET DevCycleUser model doc for all accepted fields.

DevCycleUser user = new DevCycleUser("a_user_id");

Get and use Variable by key

This method will fetch a specific variable value by key for a given user. It will return the variable value from the server unless an error occurs or the server has no response. In that case it will return a variable value with the value set to whatever was passed in as the defaultValue parameter.

bool result = await client.VariableValueAsync(user, "YOUR_KEY", true);

The default value can be of type String, Boolean, Number, or Object.

If you would like to get the full Variable object you can use VariableAsync() instead. This contains fields such as: key, value, type, defaultValue, isDefaulted.

Getting All Variables

To get values from your Variables, the value field inside the variable object can be accessed.

This method will fetch all variables for a given user and return as DictionaryString, Feature;

Dictionary<string, IVariable> result = await client.AllVariablesAsync(user);

Getting All Features

This method will fetch all features for a given user and return them as Dictionary<String, Feature>

Dictionary<string, Feature> result = await client.AllFeaturesAsync(user);

Track Event

To POST custom event for a user, pass in the user and event object.

var event = new DevCycleEvent("test event", "test target");

DevCycleResponse result = await client.TrackAsync(user, event);

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:

DevCycleCloudOptions options = new DevCycleCloudOptions(true);
DevCycleCloudClient devcycleClient = new DevCycleCloudClientBuilder()
.SetSDKKey("<DEVCYCLE_SERVER_SDK_KEY>")
.SetOptions(options)
.Build();
var user = new DevCycleUser("test_user", "example@example.com");

This will send a request to our EdgeDB API to save the custom data under the user test_user.

In the example, email is associated to the user test_user. In your next identify call for the same userId, you may omit any of the data you've sent already as it will be pulled from the EdgeDB storage when segmenting to experiments and features.

SDK Proxy

To further enable various deployment configurations - we provide a background process that can be used to proxy requests to the DevCycle API. This is useful when you have a more unique deployment style, or the SDK is not able to make requests to the DevCycle API directly. The installation and setup process for the proxy can be found here: https://github.com/DevCycleHQ/sdk-proxy#readme.

See the SDK Proxy section for more information.