OLT.Extensions.Configuration 10.0.0

Prefix Reserved
dotnet add package OLT.Extensions.Configuration --version 10.0.0
                    
NuGet\Install-Package OLT.Extensions.Configuration -Version 10.0.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="OLT.Extensions.Configuration" Version="10.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="OLT.Extensions.Configuration" Version="10.0.0" />
                    
Directory.Packages.props
<PackageReference Include="OLT.Extensions.Configuration" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add OLT.Extensions.Configuration --version 10.0.0
                    
#r "nuget: OLT.Extensions.Configuration, 10.0.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.
#:package OLT.Extensions.Configuration@10.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=OLT.Extensions.Configuration&version=10.0.0
                    
Install as a Cake Addin
#tool nuget:?package=OLT.Extensions.Configuration&version=10.0.0
                    
Install as a Cake Tool

CI Quality Gate Status

IConfiguration extensions

Configuration


// Examples of Connection String Parsers
services.Configure<OltConnectionConfigApiKey>("GrowthBook", options => options.Parse(configuration.GetOltConnectionString("GrowthBook")));
services.Configure<OltConnectionConfigRabbitMq>(opts => opts.Parse(Configuration.GetOltConnectionString("RabbitMq")));
services.Configure<OltConnectionConfigAmazon>(opts => opts.Parse(Configuration.GetOltConnectionString("AWS")));
services.Configure<OltConnectionConfigWcf>("AddressLookup", options => options.Parse(configuration.GetOltConnectionString("AddressLookup")));


// Example of GetOltConnectionString
// This looks for "connection-string" first, then falls back to the config.GetConnectionString()
// WHY?  When you have Azure App Config or AWS Parameter store as the last configuration provider loaded, you need a way to use a local connection string.
services
    .AddDbContext<DatabaseContext>(optionsBuilder =>
    {
        optionsBuilder
              .UseSqlServer(configuration.GetOltConnectionString(AppConstants.ConnectionStrings.DbConnectionName), opt => opt.CommandTimeout(120));

        if (System.Diagnostics.Debugger.IsAttached)
        {
            optionsBuilder
                .EnableSensitiveDataLogging()
                .EnableDetailedErrors();
        }
    });

Example 1


public class GrowthBookClient : IGrowthBookClient
{
    readonly HttpClient _client;
    readonly ILogger<GrowthBookClient> _logger;
    readonly OltConnectionConfigApiKey _config;

    public GrowthBookClient(HttpClient client, IOptionsSnapshot<OltConnectionConfigApiKey> options, ILogger<GrowthBookClient> logger)
    {
        _client = client;
        _logger = logger;
        _config = options.Get("GrowthBook");
    }

    public async Task<IEnumerable<FeatureFlagDto>> GetFeatureFlagsAsync(CancellationToken stoppingToken = default(CancellationToken))
    {
        if (string.IsNullOrEmpty(_config.Endpoint)) throw new Exception("Invalid GrowthBook Endpoint");

        var response = await _client.GetAsync(_config.Endpoint, stoppingToken);

        if (response.IsSuccessStatusCode)
        {
           // Do Stuff Here
        }
        else
        {
            throw new OltException($"GrowthBook Http Error: {response.StatusCode}");
        }
    }
}

Example 2 (using MassTransit RabbitMq)


services.AddMassTransit(transitConfigure =>
{
    transitConfigure.AddConsumer<QueueItemConsumer>();
    transitConfigure.AddDelayedMessageScheduler();
    transitConfigure.SetKebabCaseEndpointNameFormatter();

    transitConfigure.UsingRabbitMq((context, cfg) =>
    {
        var connectionConfig = context.GetRequiredService<IOptions<OltConnectionConfigRabbitMq>>().Value;
        if (string.IsNullOrEmpty(connectionConfig.Host)) throw new Exception("Invalid RabbitMq Connection String");

        cfg.Host(new Uri(connectionConfig.Host), h =>
        {
            h.Username(connectionConfig.Username);
            h.Password(connectionConfig.Password);
        });

        cfg.ReceiveEndpoint("queue-name-here", ep =>
        {
            ep.PrefetchCount = 32;
            ep.UseMessageRetry(r => r.Interval(2, 100));
            ep.ConfigureConsumer<QueueItemConsumer>(context);
        });

    });

});
Product Compatible and additional computed target framework versions.
.NET net8.0 is compatible.  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.  net9.0 is compatible.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed.  net10.0 is compatible.  net10.0-android was computed.  net10.0-browser was computed.  net10.0-ios was computed.  net10.0-maccatalyst was computed.  net10.0-macos was computed.  net10.0-tvos was computed.  net10.0-windows was computed. 
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
10.0.0 94 2/25/2026
10.0.0-beta-0001 114 12/26/2025
9.0.0 287 8/25/2025
9.0.0-beta-0013 270 1/30/2025 9.0.0-beta-0013 is deprecated because it is no longer maintained.
9.0.0-beta-0011 157 1/30/2025 9.0.0-beta-0011 is deprecated because it is no longer maintained.
9.0.0-beta-0009 188 12/30/2024 9.0.0-beta-0009 is deprecated because it is no longer maintained.
9.0.0-beta-0007 191 12/9/2024 9.0.0-beta-0007 is deprecated because it is no longer maintained.
9.0.0-beta-0005 160 12/2/2024 9.0.0-beta-0005 is deprecated because it is no longer maintained.
8.4.0-beta-0010 178 11/7/2024 8.4.0-beta-0010 is deprecated because it is no longer maintained.
8.4.0-beta-0005 172 10/9/2024 8.4.0-beta-0005 is deprecated because it is no longer maintained.
8.3.1 2,182 8/26/2024 8.3.1 is deprecated because it is no longer maintained.
8.3.1-beta-0005 209 8/21/2024 8.3.1-beta-0005 is deprecated because it is no longer maintained.
8.3.0 285 8/9/2024 8.3.0 is deprecated because it is no longer maintained.
8.3.0-beta-0015 168 6/3/2024 8.3.0-beta-0015 is deprecated because it is no longer maintained.
8.3.0-beta-0010 203 5/13/2024 8.3.0-beta-0010 is deprecated because it is no longer maintained.
8.3.0-beta-0005 190 5/10/2024 8.3.0-beta-0005 is deprecated because it is no longer maintained.
8.2.1 640 4/22/2024 8.2.1 is deprecated because it is no longer maintained.
8.2.0 443 4/8/2024 8.2.0 is deprecated because it is no longer maintained.
8.1.0 280 3/10/2024 8.1.0 is deprecated because it is no longer maintained.
8.0.0 289 2/21/2024 8.0.0 is deprecated because it is no longer maintained.
Loading failed