Woof.Config 6.2.0-alpha.3

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

// Install Woof.Config as a Cake Tool
#tool nuget:?package=Woof.Config&version=6.2.0-alpha.3&prerelease                

Woof.Config

.NET extension created by CodeDog

Distributed under MIT License. (c)2021 by CodeDog, All rights reserved.


About

A proper solution to replace the legacy .NET project XML settings. Universal application settings in JSON for both Linux and Windows programs.

A modern solution using the cutting edge .NET 6.0 JsonNode tech.

History

JsonNode

If you haven't heard about JsonNode in 2021, that's expected. When .NET 6.0 was officialy released that class is completely not advertised or mentioned among .NET 6.0 features. Tech blogs describe it as being experimental, though the mentions I've found was from the time from before official release.

From the other hand you probably couldn't code in C# not knowing the great Netwtonsoft.Json: the most popular NuGet package!

Even Microsoft was using it in early versions of .NET as dependency for Core projects, it was used for JSON IConfigurationProvider.

Then it was replaced with their own solution: System.Text.Json, more specifically: System.Text.Json.JsonDocument and System.Text.Json.JsonElement classes.

However until .NET 6.0 - it was read only. You could read JSON files and parse them as document trees, but creating and modifying such trees was not possible then.

And here we have JsonNode, the proper .NET replacement for Newtonsof.Json. It has everything, it's blazing fast, it's built in and it's super easy to use in modern C# code.

Woof.Config module is based on JsonNode. It's aimed to provide DI free, super easy to implement application configuration for all kind of cross-platform .NET projects.

It connects the powerful Microsoft's IConfiguration interface with JsonNode. Directly. Each IConfigurationSection is bound directly to its corresponding JsonNode object.

That gives the configuration mutability by default. You change a configuration value, the associated JSON document is changed and the changes can be saved.

Mutable JSON configurations

For now - to make it possible - the original value must not be nullable. It stems from how the configuration binder works.

Each value in IConfiguration can be either IConfigurationSection and in fact, internally, is a IConfiguration section, just one that actually has a string value.

Even in JSON - values have types. The JSON structure defines the types of values as being either text, number, bolean value, object or array.

The type is obvious from the syntax except one case - the null value.

It doesn't provide any type information and that's exact reason why nullable configuration values cannot be used in fully mutable configurations.

Usage

The goal is to provide a dynamic configuration for the C# program that is easily accessible and editable either by the user or the app itself.

The location of the file must be obvious. So does it's name.

The name of the file without extension matches the main program executable name.

The file can reside either in user's directory, or in the same directory the application is installed.

It's a similar idea to the legacy .NET project XML configuration files.

The Woof.Config module determines the location of the file internally. It searches for it first in the main executable directory, then in user's directory.

Linux path:

(In search order)

  • ./[executable_name].json
  • ~/.[executable_name]/[executable_name].json

Windows path:

  • .\[executable_name].json
  • %LOCALAPPDATA%\[company]\[product]\[executable_name].json
  • %LOCALAPPDATA%\[product]\[executable_name].json
  • %LOCALAPPDATA%\[executable_name]\[executable_name].json

In development, the configuration should just be copied to the output directory, then it can be moved to user's directory either by the application or the application installer.

Once Woof.JsonConfig object is loaded, it provides both pahts for that purpose.

In order to use the configuration the JSON file must be created first.

It provides the structure for the configuration properties.

Then, to access the configuration data in program - either IConfiguration methods and properties can be used, or the object can be bound to a strong typed configuration record with IConfiguration.Get<T>() extension.

Yes, the recommended type for the configuration section is a record type. All objects (mapped to sections) should be read-only pre-initialized getters.

Each complex type must be defined as section record.

For example, if we defined the configuration both in JSON file and already created a strong typed record for it named Configuration, here's an example usage:

var jsonConfig = new JsonConfig();
var config = jsonConfig.Get<Configuration>();

In order to modify a configuration value use IConfiguration.SetValue<T>() extension method.

A modified configuration can be saved like this:

await jsonConfig.SaveAsync();

or

jsonConfig.Save();

For more details see the provided examples and use built-in XML documentation.

Version 6.2 API change

This package is incompatible with older versions. Previous Woof.Config packed too many features in one module. It provided both data protection, Azure Key Vault access and data encryption.

Those features was moved to separate packages:

  • Woof.Config.AKV
  • Woof.Config.Protected
  • Woof.Config.AKV.Protected

In order to use multi platform compatible data protection the .Protected packages depend on Woof.LinuxAdmin - that can configure the data protection for Linux system automatically.

Read the packages documentation in order to migrate.

Compatibility

The package is compatible with .NET 6.0 or newer. The applications using the module can run both on Windows and Linux.

This package was thoroughly tested on Windows 11 and Ubuntu 20.


Disclaimer

Please report any issues on GitHub.

Woof Toolkit is a work in progress in constant development, however it's carefully maintained with production code quality.

Pre-release packages are not fully tested. Use them with caution. Not all features will work as described, or at all. They sole purpose is to test the package before the official release.

You can use pre-release packages safely when you test all used features properly by yourself. Please don't forget to report issues on GitHub! It helps with the package development and improves the quality.

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
6.2.0-alpha.4 162 11/30/2021
6.2.0-alpha.3 143 11/30/2021
6.2.0-alpha.2 151 11/30/2021
6.2.0-alpha.1 152 11/30/2021
6.1.3 1,422 11/28/2021
6.1.2 283 11/27/2021
6.1.1 2,352 11/25/2021
6.1.0 3,359 11/25/2021
6.0.2 4,856 11/24/2021
6.0.1 290 11/17/2021
6.0.0 302 11/9/2021
5.5.3 337 11/8/2021
5.5.2 313 11/7/2021
5.5.1 313 11/7/2021
5.5.0 403 11/7/2021
5.4.0 321 11/5/2021
5.2.1 429 10/25/2021
5.2.0 470 10/13/2021 5.2.0 is deprecated because it has critical bugs.
5.1.0 475 10/12/2021 5.1.0 is deprecated because it has critical bugs.
5.0.2 484 9/29/2021 5.0.2 is deprecated because it has critical bugs.
5.0.1 432 8/19/2021 5.0.1 is deprecated because it has critical bugs.
5.0.0 448 8/19/2021 5.0.0 is deprecated because it has critical bugs.
1.0.0 490 7/29/2021 1.0.0 is deprecated because it has critical bugs.

Properly extendable API. Fixed path resolver bug.