FeatureSelect.AspNetCore
1.0.6
dotnet add package FeatureSelect.AspNetCore --version 1.0.6
NuGet\Install-Package FeatureSelect.AspNetCore -Version 1.0.6
<PackageReference Include="FeatureSelect.AspNetCore" Version="1.0.6" />
paket add FeatureSelect.AspNetCore --version 1.0.6
#r "nuget: FeatureSelect.AspNetCore, 1.0.6"
// Install FeatureSelect.AspNetCore as a Cake Addin #addin nuget:?package=FeatureSelect.AspNetCore&version=1.0.6 // Install FeatureSelect.AspNetCore as a Cake Tool #tool nuget:?package=FeatureSelect.AspNetCore&version=1.0.6
FeatureSelect
FeatureSelect is a flexible feature toggle library with ASP.NET Core integration.
Installing
Install via NuGet
Install-Package FeatureSelect
Usage
Create a feature source and use it get a feature. A "feature" takes two functions, one to execute if the feature is enabled, and one to execute if the feature is disabled.
var source = new ConfigurationFeatureSource(Configuration);
var feature = source.GetFeature("MyFeature");
var result = feature.Execute(() => "My feature is enabled", () => "My feature is disabled");
In order to integrate with ASP.NET Core, register FeatureSelect in Program.cs using the AddFeatureSelect
extension method.
var builder = WebApplication.CreateBuilder(args);
var config = builder.Configuration;
builder.Services.AddControllers();
builder.Services.AddFeatureSelect(config.GetSection("Features"));
var app = builder.Build();
app.UseRouting();
app.MapControllers();
app.Run();
Now in your controllers you can use the [IfEnabled]
and [IfDisabled]
attributes to toggle on/off any controller or route.
[IfEnabled("Customers")]
public class CustomerController
{
[HttpGet("/customers")]
[IfEnabled("GetCustomers")]
public IActionResult Get()
{
...
}
}
You can also inject an instance of FeatureSource
.
public class MyController
{
[HttpGet("/my-feature")]
public string Get([FromServices] FeatureSource features)
{
return features
.GetFeature("MyFeature")
.Execute(() => "My feature is enabled", () => "My feature is disabled");
}
}
In order to configure which features are enabled simple define them in appsettings.json
, or you User Secrets or environment variables.
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"AllowedHosts": "*",
"Features": {
"feature1": "enabled",
"feature2": "diabled",
"feature3": "enabled"
}
}
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 was computed. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. |
.NET Core | netcoreapp3.1 is compatible. |
-
.NETCoreApp 3.1
- FeatureSelect (>= 1.0.6)
- Microsoft.AspNetCore.Mvc.Core (>= 2.2.5)
- Microsoft.Extensions.Configuration.Abstractions (>= 3.1.28)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 3.1.28)
-
net6.0
- FeatureSelect (>= 1.0.6)
- Microsoft.AspNetCore.Mvc.Core (>= 2.2.5)
- Microsoft.Extensions.Configuration.Abstractions (>= 6.0.0)
- Microsoft.Extensions.DependencyInjection.Abstractions (>= 6.0.0)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.