Skip to content

Latest commit

 

History

History
166 lines (106 loc) · 8.23 KB

README.markdown

File metadata and controls

166 lines (106 loc) · 8.23 KB

Config.Net Build status NuGet

A comprehensive easy to use and powerful .NET configuration library, fully covered with unit tests and tested in the wild on thousands of servers and applications.

This library eliminates the problem of having configuration in different places, having to convert types between different providers, hardcoding configuration keys accross the solution, depending on specific configuration source implementation. It's doing that by exposing an abstract configuration interface and providing most common implementation for configuration sources like app.config, environment variables etc.

See release notes for release history, issues etc.

Note: Current version (v2) is not compatible with v1. If you need to come back to v1 documentation please follow this link.

Quick Start

Usually developers will hardcode reading cofiguration values from different sources like app.config, local json file etc. For instance, consider this code example:

var clientId = ConfigurationManager.AppSettings["AuthClientId"];
var clientSecret = ConfigurationManager.AppSettings["AuthClientSecret"];

You would guess that this code is trying to read a configuration setting from the local app.config file by name and that might be true, however there are numerous problems with this approach:

  • settings are referenced by a hardcoded string name which is prone to typos and therefore crashes in runtime.
  • there is no easy way to find out where a particular setting is used in code, except for performing a fulltext search (provided that the string was not mistyped)
  • if you decide to store configuration in a different place the code must be rewritten.

Welcome to Config.Net which solves most of those problems. Let's rewrite this abomination using Config.Net approach. First, we need to define a configuration container which describes which settings are used in your application or a library:

Declare Settings Container

using Config.Net;

public class AllSettings : SettingsContainer
{
    public readonly Option<string> AuthClientId;

    public readonly Option<string> AuthClientSecret;

    protected override void OnConfigure(IConfigConfiguration configuration)
    {
         configuration.UseAppConfig();
    }
}

Let's go through this code snippet:

  • We have declared AllSettings class which will store configuration for oru application. All configuration classes must derive from SettingsContainer.
  • Two strong-typed configuration options were declared. Note they are both readonly which is another plus towards code quality.
  • Option<T> is a configuration option definition in Config.Net where generic parameter specifies the type. There is a limited set of supported types and you can create your own
  • OnConfigure mehtod implementation specifies that app.config should be used as a configuration store.

Use Settings

Once container has been defined start using the settings, for instance:

var c = new AllSettings();

string clientId = c.AuthClientId;
string clientSecret = c.AuthClientSecret;

Two things worth to note in this snippet:

  • An instance of AllSettings container was created. Normally you would create an instance of a settings container per application instance for performance reasons.
  • The settings were read from the settings container. Note the syntax and that for example AuthClientId is defined as an Option<string> but casted to string. This is because Option<T> class has implicit casting operator to T defined.

Using Multiple Sources

OnConfigure method is used to prepare settings container for use. You can use it to add multiple configuration sources. To get the list of sources use IntelliSense (type dot-Use after configuration). For instance this method implementation:

protected override void OnConfigure(IConfigConfiguration configuration)
{
    configuration.UseAppConfig();
    configuration.UseEnvironmentVariables();
}

causes the container to use both app.config and environment variables as configuration source.

The order in which sources are added is important - Config.Net will try to read the source in the configured order and return the value from the first store where it exists.

Writing Settings

Some configuration stores support writing values. You can write the value back by calling the .Write() method on an option definition:

c.AuthClientId.Write("new value");

Config.Net will write the value to the first store which supports writing. If none of the stores support writing the call will be ignored.

Caching

By defalut config.net caches configuration values for 1 hour. After that it will read it again from the list of configured stores. If you want to change it to something else set the variable in the OnConfigure method:

protected override void OnConfigure(IConfigConfiguration configuration)
{
    configuration.CacheTimeout = TimeSpan.FromMinutes(1);	//sets caching to 1 minute

    configuration.UseAppConfig();
    configuration.UseEnvironmentVariables();
}

setting it to TimeSpan.Zero disables caching completely.

Ways to declare settings

There are a few requirements to declaring a setting a s member of derived SettingsContainer class:

  • The field must be read-only
  • It cannot be static

A setting has a few basic properties:

  • Name which by default is the same as a variable name. Config.Net uses reflection to get the variable name. Variable name is important as it's used to read the option from a specific store.
  • Default Value which is defaulted to the default value of the type i.e. 0 for int, null for classes etc.

The simplest form of declaring an option is:

public readonly Option<string> AuthClientId = new Option<string>();

This sets option name to AuthClientId and default value to null. However if you need to specify the name explicitly change it to the following:

public readonly Option<string> AuthClientId = new Option<string>("AuthenticationClientId", null);

This sets option name to AuthenticationClientId whereas local variable name is still AuthClientId. It is recommended that you set option name explicitly anyway, even if it matches the variable name. It saves from potential refactoring problems as when you rename the variable but config files still hold the old name.

Default Value

Default value is returned in case an option cannot be found in any of the stores. This is useful in situations when you want to introduce a configurable option, but don't want to store it in an external configuration store yet. In fact you can use options to declare constants in your code that way.

To change the default value pass it as a constructor argument in option initialisation:

public readonly Option<string> AuthClientId = new Option<string>("AuthenticationClientId", "default id");

This always returns "defualt id" when AuthenticationClientId is not found in any of the configured stores.

Available Stores

The list of available built-in and external stores is maintained on this page:

Name Readable Writeable Package Purpose
AppConfig v x internal .NET app.config files
EnvironmentVariables v v internal OS environment variables
CommandLine v x internal Parsing command line as configuration source
IniFile v v internal INI files
JSON v v internal JSON file storage
InMemory v v internal In-memory storage
Storage.Net Integration v v external anything that storage.net supports