Lussatite.FeatureManagement.SessionManagers.Core 0.2.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Lussatite.FeatureManagement.SessionManagers.Core --version 0.2.0                
NuGet\Install-Package Lussatite.FeatureManagement.SessionManagers.Core -Version 0.2.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Lussatite.FeatureManagement.SessionManagers.Core" Version="0.2.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Lussatite.FeatureManagement.SessionManagers.Core --version 0.2.0                
#r "nuget: Lussatite.FeatureManagement.SessionManagers.Core, 0.2.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Lussatite.FeatureManagement.SessionManagers.Core as a Cake Addin
#addin nuget:?package=Lussatite.FeatureManagement.SessionManagers.Core&version=0.2.0

// Install Lussatite.FeatureManagement.SessionManagers.Core as a Cake Tool
#tool nuget:?package=Lussatite.FeatureManagement.SessionManagers.Core&version=0.2.0                

Lussatite.FeatureManagement

A light implementation of Microsoft.FeatureManagement interfaces.

Quickstart

  1. Take a dependency on Lussatite.FeatureManagement and Lussatite.FeatureManagement.LazyCache.

  2. Define a set of string constants for the names of your features. Look at the various static TestFeatures.cs files for ideas.

  3. Create a value provider by implementing ISessionManager or use one or more of the Lussatite.FeatureManagement.SessionManagers.* packages. Note that Lussaite.FeatureManagement does not write back to the session manager (unlike the Microsoft.FeatureManagement implementation).

  4. Wire-up the following in your IoC/DI container:

    • Session manager classes will need to be injected into the feature manager manually, since order does matter.
    • LussatiteLazyCacheFeatureManager as IFeatureManagerSnapshot (usually per-request / scoped lifetime).
  5. Inject IFeatureManagerSnapshot into your controller or service classes.

  6. await _feature.IsEnabledAsync(string feature) to obtain the status of the feature flag.

Packages

Lussatite.FeatureManagement:

Target: .NET Standard 2.0

  • LussatiteFeatureManager: A basic implementation of IFeatureManager.
  • This does not implement the Task<bool> IsEnabledAsync<TContext>(string feature, TContext context) method.
  • This does not make any calls back to the ISessionManager Task SetAsync(string featureName, bool enabled) method.

Lussatite.FeatureManagement.LazyCache:

Target: .NET Standard 2.0

  • LussatiteLazyCacheFeatureManager: A caching IFeatureManagerSnapshot implementation that uses LazyCache.
  • This does not implement the Task<bool> IsEnabledAsync<TContext>(string feature, TContext context) method.
  • This does not make any calls back to the ISessionManager Task SetAsync(string featureName, bool enabled) method.

Lussatite.FeatureManagement.SessionManagers.Core:

Target: .NET Core 3.1 (also compatible with .NET 5+)

  • ConfigurationValueSessionManager: A read-only ISessionManager implementation that uses IConfiguration to obtain its values.
  • SqlSessionManager: A read-only ISessionManager implementation that uses the user-provided DbCommand to obtain its values.

Lussatite.FeatureManagement.SessionManagers.Framework:

Target: .NET Framework 4.8

  • ConfigurationValueSessionManager: A read-only ISessionManager implementation that uses the static class ConfigurationManager to obtain its values.
  • SqlSessionManager: A read-only ISessionManager implementation that uses the user-provided DbCommand to obtain its values.

Build Status

Build-Test

References

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.6.3 1,629 6/29/2022
1.6.2 428 6/28/2022
1.6.1 447 6/28/2022
1.6.0 869 6/15/2022
1.5.0 431 6/9/2022
1.4.1 1,481 5/24/2022
1.4.0 436 5/24/2022
1.3.1 421 5/23/2022
1.3.0 432 5/22/2022
1.2.0 408 5/20/2022
1.1.0 426 5/19/2022
1.0.0 439 5/16/2022
0.2.1 456 5/15/2022
0.2.0 423 5/14/2022