DotNet.MultiSourceConfiguration
0.4.1
See the version list below for details.
dotnet add package DotNet.MultiSourceConfiguration --version 0.4.1
NuGet\Install-Package DotNet.MultiSourceConfiguration -Version 0.4.1
<PackageReference Include="DotNet.MultiSourceConfiguration" Version="0.4.1" />
paket add DotNet.MultiSourceConfiguration --version 0.4.1
#r "nuget: DotNet.MultiSourceConfiguration, 0.4.1"
// Install DotNet.MultiSourceConfiguration as a Cake Addin #addin nuget:?package=DotNet.MultiSourceConfiguration&version=0.4.1 // Install DotNet.MultiSourceConfiguration as a Cake Tool #tool nuget:?package=DotNet.MultiSourceConfiguration&version=0.4.1
DotNet.MultiSourceConfiguration
Configuration library with multiple sources for .NET.
Why DotNet.MultiSourceConfiguration
A very typical scenario in microservices (which typically run in containers) is to configure a service via a configuration file, and overwrite that configuration with whatever you can find in environment variables and command line. Used to Spring Boot's approach to configuration based in properties and property sources, I have struggled to find a simple library in .NET allowing to read configuration from different sources and overwrite it in a specified source order.
The Microsoft.Extensions.Configuration project follow a very similar approach but have some drawbacks:
- It has a huge amount of dependencies.
- At the moment of writing DotNet.MultiSourceConfiguration, the existing documentation was outdated and did not work with the last version of the library.
How to use it
The approach followed by DotNet.MultiSourceConfiguration is the population of configuration classes, that can subsequently be registered on an IOC container or made avaialable as a static property. The properties of the configuration class must be decorated with the Property
attribute, indicating the name of the property that must be mapped to the property:
public class TestConfigurationDto
{
// By default properties are not required
[Property("test.int.property")]
public int? IntProperty { get; set; }
// The required condition of a property can be explicitly included
[Property("test.string.property", Required = true)]
public string StringProperty { get; set; }
// Properties can be marked as not required. The default value of the
// given type converter will be applied (typically, null).
[Property("test.long.property", Required = false)]
public long? LongProperty { get; set; }
// The "Default" property can be used to provide a default value in
// case it is not provided via configuration.
[Property("test.bool.property", Default = "true")]
public bool? BoolProperty { get; set; }
}
Configuration classes are populated via a configuration builder, which can be specified a series of sources:
class Program
{
static void Main(string[] args)
{
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder();
configurationBuilder.AddSources(
new AppSettingsSource(), new EnvironmentVariableSource(), new CommandLineSource(args));
TestConfigurationDto configurationInterface = configurationBuilder.Build<TestConfigurationDto>();
...
}
}
The configuration builder implements the IConfigurationBuilder interface. This way, the configuration builder is easier to mock in unit tests of classes that depend on it. A common pattern is to register the configuration builder in an IoC container and inject it in classes that need it.
The configuration builder has caching capabilities, allowing to re-use built configuration classes until a configurable cache expiration times out. When the cache expires and a configuration class is re-built, then the configuration is re-read from the sources. The cache expiration is configurable via the CacheExpiration
property (by default the cache expiration is 0, i.e. no caching is done):
IConfigurationBuilder configurationBuilder = new ConfigurationBuilder();
configurationBuilder.AddSources(
new AppSettingsSource(), new EnvironmentVariableSource(), new CommandLineSource(args));
configurationBuilder.CacheExpiration = TimeSpan.FromMinutes(2);
Property Sources
The available property sources are:
- AppSettingsSource: looks for the properties in the .NET application settings file.
- EnvironmentVariableSource: looks for the properties in the system environment variables.
- CommandLineSource: tries to match the properties with arguments in the command line, with the format
--<property>=<value>
. - MemorySource: allows to define a series of properties in memory as use them as source of configuration.
In addition to these property sources you can implement your own by providing implementations of the IStringConfigSource
interface:
public interface IStringConfigSource
{
bool TryGetString(string property, out string value);
}
The configuration properties are overwritten by the given property sources in the order they are specified in the AddSources
call. In the example above, the properties will be first read in the application settings file. Subsequently they will be overwritten with the properties found in environment variables (in case they are found). Finally, the properties will be overwritten with the values found in command-line arguments.
This provides a very convenient deployment behavior (specially for applications running in containers), in which applications take some default configuration from application settings, that is overwritten by the environment variables set in the machine (or container) and are finally overwritten with whatever has been provided in command line arguments.
Property Types
The following types for configuration properties are available:
- bool?, bool?[]
- string, string[]
- int?, int[]
- long?, long[]
- decimal?, decimal[]
- float?, float[]
- double?, double[]
In addition to these types, you can add your own type converters by providing implementations of the ITypeConverter
interface to the AddTypeConverter<T>()
method of ConfigurationBuilder
. For convenience, the LambdaConverter
is provided, that makes it easier to implement your own type converter:
configurationBuilder.AddTypeConverter(new LambdaConverter<MyType>(null /* Default value */, s => MyType.Parse(s) /* Converter lambda */));
Get DotNet.MultiSourceConfiguration
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net45 is compatible. net451 was computed. net452 was computed. net46 was computed. net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
This package has no dependencies.
NuGet packages (1)
Showing the top 1 NuGet packages that depend on DotNet.MultiSourceConfiguration:
Package | Downloads |
---|---|
DotNet.MultiSourceConfiguration.Zookeeper
Zookeeper configuration source for the DotNet.MultiSourceConfiguration library. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
0.8.0 | 4,689 | 10/8/2019 |
0.7.3 | 583 | 7/2/2019 |
0.7.2 | 586 | 5/28/2019 |
0.7.1 | 703 | 2/1/2019 |
0.7.0 | 1,509 | 11/17/2017 |
0.6.0 | 896 | 11/16/2017 |
0.5.0 | 1,216 | 11/14/2017 |
0.4.1 | 1,937 | 11/2/2017 |
0.4.0 | 1,726 | 7/26/2017 |
0.3.3 | 1,106 | 6/13/2017 |
0.3.2 | 959 | 6/12/2017 |
0.3.1 | 928 | 5/12/2017 |
0.3.0 | 964 | 3/28/2017 |
0.2.1 | 935 | 3/23/2017 |
0.2.0 | 906 | 3/23/2017 |
0.1.1 | 979 | 3/22/2017 |
0.1.0 | 1,715 | 3/22/2017 |
Fixed the parsing of configuration values in different cultures: the invariant culture is always used. For instance, the decimal separator is always '.'.