EinsTools.Utilities.ConfigParser 0.0.3-rc.1

This is a prerelease version of EinsTools.Utilities.ConfigParser.
There is a newer version of this package available.
See the version list below for details.
dotnet add package EinsTools.Utilities.ConfigParser --version 0.0.3-rc.1                
NuGet\Install-Package EinsTools.Utilities.ConfigParser -Version 0.0.3-rc.1                
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="EinsTools.Utilities.ConfigParser" Version="0.0.3-rc.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add EinsTools.Utilities.ConfigParser --version 0.0.3-rc.1                
#r "nuget: EinsTools.Utilities.ConfigParser, 0.0.3-rc.1"                
#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 EinsTools.Utilities.ConfigParser as a Cake Addin
#addin nuget:?package=EinsTools.Utilities.ConfigParser&version=0.0.3-rc.1&prerelease

// Install EinsTools.Utilities.ConfigParser as a Cake Tool
#tool nuget:?package=EinsTools.Utilities.ConfigParser&version=0.0.3-rc.1&prerelease                

EinsTools.Utilities.ConfigParser

Description

The ConfigParser is an extension for the Microsoft.Extensions.Configuration library. It allows you to use referenced in your configuration files.

For example:

{
  "A": "Hello",
  "B": "World",
  "C": "$(A) $(B)!"
}

The ConfigParser will replace the $(A) and $(B) with the values from the configuration file. Requesting the value of C will return "Hello World!".

You can reference values from different levels. In the following example the value of C will be "Hello World!", while "D:C" will be "Goodbye World!".

{
  "A": "Hello",
  "B": "World",
  "C": "$(A) $(B)!",
  "D": {
    "A": "Goodbye",
    "C": "$(A) $(B)!"
  }
}

References will only be resolved from the same or upper levels. In the following example the value of B will be "Hello !".

{
  "A": "Hello",
  "B": "$(A) $(D)!",
  "C": {
    "D": "World"
  }
}

You can however use the Microsoft.Configuration path syntax. Thus the following example will result in the value of B being "Hello World!".

{
  "A": "Hello",
  "B": "$(A) $(C:D)!",
  "C": {
    "D": "World"
  }
}

Default values

If a reference is not found, it will be replaced with an empty string. You can however specify a default value that will be used instead. The default value is separated from the reference by a pipe character. For example:

{
  "A": "Hello",
  "B": "World",
  "C": "$(A) $(D|Goodbye)!"
}

The value of C will be "Hello Goodbye!".

Prefixes

You can prefix a reference with the strings "ref:", "env:" or "file:".

"ref:" will reference a value from the configuration file. This is the default behaviour, if no prefix is used. "env:" will reference a value from the environment variables. "file:" will reference a value from a file. The value behind the prefix will be interpreted as a reference to another value in the configuration file, which should hold the file name.

For example:

{
  "A": "./test.txt",
  "B": "$(env:PATH)",
  "C": "$(file:C)"
}

The value of A will be interpreted as a file name. The value of B will be the value of the environment variable PATH. The value of C will be the content of the file test.txt.

Path Joining

If the name of a reference ends with a slash, we will make sure that the value ends in a Path Separator. If the path already ends in a path separator, we will not add another one. If the path does not end in a path separator, we will add one. This is useful to combine paths. For example:

{
  "A": "C:\\Program Files",
  "B": "C:\\Program Files\\",
  "C": "MyApp",
  "D": "$(A/)$(C)",
  "E": "$(B/)$(C)"
}

The values of D and E will be "C:\Program Files\MyApp". Which seperator is used, depends on the operating system. It will be a slash on Linux and MacOs and a backslash on Windows.

Usage

You have to first create you configuration as usual. As soon as you have an IConfigurationRoot, you can use the ConfigParser to parse the values.

var baseCfg = new ConfigurationBuilder()
    .AddJsonFile("config.json")
    .Build();
var cfg = new ConfigurationBuilder()
    .AddEinsToolsConfiguration(baseCfg)
    .Build();

The cfg variable will now contain the parsed configuration. You can use it as usual.

Product Compatible and additional computed target framework versions.
.NET 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.  net9.0 was computed.  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. 
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.0.0.1 115 1/26/2024
0.0.3.1 132 12/29/2023
0.0.3-rc.5 96 9/5/2023
0.0.3-rc.4 83 9/4/2023
0.0.3-rc.3 84 9/4/2023
0.0.3-rc.2 92 8/31/2023
0.0.3-rc.1 82 8/31/2023
0.0.3-rc.0 78 8/31/2023

Version 0.0.3
- Initial version