![]() |
VOOZH | about |
dotnet add package Splitio.OpenFeature.Provider --version 2.1.1
NuGet\Install-Package Splitio.OpenFeature.Provider -Version 2.1.1
<PackageReference Include="Splitio.OpenFeature.Provider" Version="2.1.1" />
<PackageVersion Include="Splitio.OpenFeature.Provider" Version="2.1.1" />Directory.Packages.props
<PackageReference Include="Splitio.OpenFeature.Provider" />Project file
paket add Splitio.OpenFeature.Provider --version 2.1.1
#r "nuget: Splitio.OpenFeature.Provider, 2.1.1"
#:package Splitio.OpenFeature.Provider@2.1.1
#addin nuget:?package=Splitio.OpenFeature.Provider&version=2.1.1Install as a Cake Addin
#tool nuget:?package=Splitio.OpenFeature.Provider&version=2.1.1Install as a Cake Tool
This Provider is designed to allow the use of OpenFeature with Harness Feature Management & Experimentation, the platform for controlled rollouts, serving features to your users via the Split feature flag to manage your complete customer experience.
This SDK is compatible with .NET 6.0 and higher.
Below is a simple example that describes the instantiation of the Split Provider. Please see the OpenFeature Documentation for details on how to use the OpenFeature SDK.
using OpenFeature;
using Splitio.OpenFeature;
Dictionary<string, object> initialContext = new Dictionary<string, object>();
var config = new ConfigurationOptions
{
Logger = new CustomLogger()
};
initialContext.Add("ConfigOptions", config);
initialContext.Add("SdkKey", "SPLIT SDK API KEY");
initialContext.Add("ReadyBlockTime", 5000);
Api api = OpenFeature.Api.Instance;
api.setProviderAsync(new Provider(initialContext));
If you are more familiar with Split or want access to other initialization options, you can provide a Split Client to the constructor. See the Split .NET Documentation for more information.
using OpenFeature;
using Splitio.OpenFeature;
using Splitio.Services.Client.Classes
Api api = OpenFeature.Api.Instance;
var config = new ConfigurationOptions
{
Ready = 10000
};
var splitClient = new SplitFactory("YOUR_API_KEY", config).Client();
Dictionary<string, object> initialContext = new Dictionary<string, object>();
initialContext.Add("SplitClient", splitClient);
api.SetProviderAsync(new Provider(initialContext));
After the initial setup you can use OpenFeature according to their documentation.
One important note is that the Split Provider requires a targeting key to be set. Often times this should be set when evaluating the value of a flag by setting an EvaluationContext which contains the targeting key. An example flag evaluation is
var context = EvaluationContext.Builder().Set("targetingKey", "randomKey").Build();
var result = await client.GetBooleanValueAsync("boolFlag", false, context);
If the same targeting key is used repeatedly, the evaluation context may be set at the client level
var context = EvaluationContext.Builder().Set("targetingKey", "randomKey").Build();
client.SetContext(context)
or at the OpenFeatureAPI level
var context = EvaluationContext.Builder().Set("targetingKey", "randomKey").Build();
api.setEvaluationContext(context)
If the context was set at the client or api level, it is not required to provide it during flag evaluation.
The Split team monitors all issues submitted to this issue tracker. We encourage you to use this issue tracker to submit any bug reports, feedback, and feature enhancements. We'll do our best to respond in a timely manner.
Please see to find all you need to submit a Pull Request (PR).
Licensed under the Apache License, Version 2.0. See: Apache License.
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 was computed. net5.0-windows net5.0-windows was computed. net6.0 net6.0 was computed. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 is compatible. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 is compatible. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 netcoreapp2.0 was computed. netcoreapp2.1 netcoreapp2.1 was computed. netcoreapp2.2 netcoreapp2.2 was computed. netcoreapp3.0 netcoreapp3.0 was computed. netcoreapp3.1 netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 netstandard2.0 is compatible. netstandard2.1 netstandard2.1 was computed. |
| .NET Framework | net461 net461 was computed. net462 net462 is compatible. net463 net463 was computed. net47 net47 was computed. net471 net471 was computed. net472 net472 was computed. net48 net48 was computed. net481 net481 was computed. |
| MonoAndroid | monoandroid monoandroid was computed. |
| MonoMac | monomac monomac was computed. |
| MonoTouch | monotouch monotouch was computed. |
| Tizen | tizen40 tizen40 was computed. tizen60 tizen60 was computed. |
| Xamarin.iOS | xamarinios xamarinios was computed. |
| Xamarin.Mac | xamarinmac xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos xamarinwatchos was computed. |
This package is not used by any NuGet packages.
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 2.1.1 | 841 | 3/27/2026 |
| 2.1.1-rc.1 | 70 | 3/27/2026 |
| 2.1.0 | 1,101 | 2/12/2026 |
| 2.1.0-rc.1 | 71 | 2/12/2026 |
| 2.0.0 | 2,367 | 11/11/2025 |