aemarcoToolboxAppOptions 8.0.7
See the version list below for details.
dotnet add package aemarcoToolboxAppOptions --version 8.0.7
NuGet\Install-Package aemarcoToolboxAppOptions -Version 8.0.7
<PackageReference Include="aemarcoToolboxAppOptions" Version="8.0.7" />
paket add aemarcoToolboxAppOptions --version 8.0.7
#r "nuget: aemarcoToolboxAppOptions, 8.0.7"
// Install aemarcoToolboxAppOptions as a Cake Addin #addin nuget:?package=aemarcoToolboxAppOptions&version=8.0.7 // Install aemarcoToolboxAppOptions as a Cake Tool #tool nuget:?package=aemarcoToolboxAppOptions&version=8.0.7
aemarcoToolboxAppOptions
<a href=https://www.nuget.org/packages/aemarcoToolboxAppOptions><img src="https://buildstats.info/nuget/aemarcoToolboxAppOptions"></a><br/>
Overview
This package provides a opinionated approach to the Options pattern described in the Microsoft docs. With minimal setup, all the Option classes will be registered in the IOC container and mapped to the IConfiguration source.
- Automatic mapping of sections to classes (convention driven, but can be adjusted)
- Beside registering the interfaces from Microsoft, registers the class itself as well (singleton)
- Registers also interfaces which you put on the settings class
- Allows text transformations between IConfiguration and the settings class
- Option to use fluent validation on settings
- Option to validate settings during startup (on by default, opt-out in options)
Get Started
During startup of the app
{
services.AddConfigOptionsUtils(config);
}
Create your class representing your options
{
public class MySettings : ISettingsBase
{
public string? Text { get; set; }
public bool Enable { get; set; }
}
}
In appsetting.json (or other IConfiguration source)
{
"MySettings": {
"Text": "SomeText",
"Enable": true
}
}
StringTransformation
String transformations will be executed in the order defined in the setup process. You could define your own, but PlaceholderTransformation is built in already.
{
services.AddConfigOptionsUtils(
config,
x => x
.AddStringTransformation(new PlaceholderTransformation());
}
PlaceholderTransformation does resolve placeholders {{{...}}} through the entire IConfguration by Key. That maybe usefull when piecing together file or url path.
{
"Message": "Hello world!",
"MySettings": {
"Text": "The message is {{{Message}}}",
"Enable": true
}
}
Fluent Validation
Just define your Validators in the assemblies where setting classes are defined. The tool will register them, and use them if present. By default, Validation takes place at startup.
{
services.AddConfigOptionsUtils(
config,
x => x
.EnableValidationOnStartup(false); //on by default
}
Setting classes in multiple assemblies
The tool relies on assembly scanning during the setup. If your option classes are in other assemblies, you may pass one of the types as assembly marker, and/or use the assemblies itself.
{
services.AddConfigOptionsUtils(
config,
x => x
.AddAssemblyMarker(typeof(MySettings))
// and/or
.AddAssemblies(someAssemblies));
}
Mapping Path
By default, the class name is exactly matched to the root level of the configuration. You may define your own path in the settings class
{
[SettingsPath("Settings")]
public class MySettings : ISettingsBase
{
public string? Text { get; set; }
public bool Enable { get; set; }
}
}
would map to
{
"Settings": {
"Text": "SomeText",
"Enable": true
}
}
You could even do it nested, just use the colon seperated path as you would with GetSection().
{
[SettingsPath("Settings:Nested")]
public class MySettings : ISettingsBase
{
public string? Text { get; set; }
public bool Enable { get; set; }
}
}
would map to
{
"Settings": {
"Nested":{
"Text": "SomeText",
"Enable": true
}
}
}
Product | Versions 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 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. |
-
net8.0
- aemarcoExtensions (>= 8.0.7)
- FluentValidation.DependencyInjectionExtensions (>= 11.11.0)
- Microsoft.Extensions.Configuration.Binder (>= 9.0.0)
- Microsoft.Extensions.Configuration.Json (>= 9.0.0)
- Microsoft.Extensions.Hosting.Abstractions (>= 9.0.0)
- Microsoft.Extensions.Options (>= 9.0.0)
NuGet packages (3)
Showing the top 3 NuGet packages that depend on aemarcoToolboxAppOptions:
Package | Downloads |
---|---|
aemarcoWpfTools
c# wpf tools collection |
|
aemarcoWebTools
c# web tools collection |
|
aemarcoConsoleTools
c# console tools collection |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
8.2.3 | 57 | 1/9/2025 |
8.2.2 | 60 | 1/9/2025 |
8.1.4 | 102 | 1/1/2025 |
8.1.3 | 90 | 12/31/2024 |
8.1.2 | 87 | 12/26/2024 |
8.0.8 | 83 | 12/23/2024 |
8.0.7 | 86 | 12/23/2024 |
8.0.6 | 85 | 12/22/2024 |
8.0.5 | 76 | 12/21/2024 |
8.0.4 | 91 | 11/17/2024 |
8.0.3 | 127 | 11/17/2024 |
5.0.21 | 91 | 11/16/2024 |
5.0.20 | 111 | 10/20/2024 |
5.0.19 | 99 | 10/19/2024 |
5.0.18 | 126 | 10/19/2024 |
5.0.17 | 114 | 10/13/2024 |
5.0.16 | 102 | 10/12/2024 |
5.0.6 | 94 | 10/6/2024 |
5.0.5 | 99 | 10/2/2024 |
5.0.4 | 91 | 10/1/2024 |
5.0.3 | 93 | 9/22/2024 |
5.0.2 | 192 | 9/16/2024 |
4.0.9 | 114 | 9/15/2024 |
4.0.8 | 104 | 9/8/2024 |
4.0.7 | 84 | 9/8/2024 |
4.0.6 | 91 | 9/8/2024 |
4.0.5 | 84 | 9/8/2024 |
4.0.2 | 111 | 9/8/2024 |
3.1.27 | 106 | 9/8/2024 |
3.1.26 | 109 | 9/7/2024 |
3.1.25 | 107 | 9/7/2024 |
3.1.24 | 104 | 9/7/2024 |
3.1.23 | 95 | 9/1/2024 |
3.1.22 | 102 | 9/1/2024 |
3.1.21 | 121 | 6/16/2024 |
3.1.20 | 101 | 5/31/2024 |
3.1.19 | 93 | 5/20/2024 |
3.1.18 | 106 | 5/10/2024 |
3.1.17 | 129 | 4/12/2024 |
3.1.16 | 124 | 4/4/2024 |
3.1.15 | 139 | 3/22/2024 |
3.1.11 | 124 | 3/19/2024 |
3.1.10 | 134 | 2/16/2024 |
3.1.7 | 154 | 2/11/2024 |
3.1.6 | 137 | 2/11/2024 |
3.1.5 | 130 | 2/11/2024 |
3.1.4 | 125 | 2/11/2024 |
3.0.18 | 180 | 1/29/2024 |
3.0.17 | 110 | 1/29/2024 |
3.0.16 | 109 | 1/27/2024 |
3.0.15 | 109 | 1/27/2024 |
3.0.8 | 112 | 1/27/2024 |
3.0.7 | 171 | 1/13/2024 |
2.0.18 | 189 | 1/4/2024 |
2.0.17 | 197 | 1/1/2024 |
2.0.16 | 193 | 12/27/2023 |
2.0.15 | 181 | 12/26/2023 |
2.0.14 | 188 | 12/26/2023 |
2.0.13 | 163 | 12/25/2023 |
2.0.11 | 154 | 12/23/2023 |
2.0.10 | 187 | 12/16/2023 |
2.0.9 | 170 | 12/15/2023 |
2.0.8 | 188 | 12/14/2023 |
2.0.7 | 180 | 12/13/2023 |
2.0.5 | 199 | 12/11/2023 |
2.0.4 | 187 | 12/11/2023 |
2.0.2 | 207 | 12/10/2023 |
1.9.2 | 190 | 12/10/2023 |
1.8.4 | 203 | 12/10/2023 |
1.8.3 | 223 | 12/9/2023 |
1.8.2 | 192 | 12/9/2023 |
1.1.28 | 231 | 11/27/2023 |
1.1.27 | 197 | 11/26/2023 |
1.1.26 | 217 | 11/18/2023 |
1.1.25 | 197 | 11/17/2023 |
1.1.24 | 251 | 10/30/2023 |
1.1.23 | 212 | 10/29/2023 |
1.1.22 | 220 | 10/22/2023 |
1.1.21 | 232 | 10/17/2023 |
1.1.20 | 252 | 9/16/2023 |
1.1.19 | 319 | 8/27/2023 |
1.1.18 | 242 | 7/31/2023 |
1.1.17 | 274 | 7/16/2023 |
1.1.16 | 266 | 7/9/2023 |
1.1.15 | 286 | 7/8/2023 |
1.1.14 | 284 | 7/5/2023 |
1.1.13 | 258 | 6/29/2023 |
1.1.12 | 273 | 5/1/2023 |
1.1.11 | 438 | 3/5/2023 |
1.1.10 | 396 | 3/3/2023 |
1.1.9 | 424 | 2/28/2023 |
1.1.7 | 450 | 2/26/2023 |
1.1.6 | 413 | 2/26/2023 |
1.1.5 | 290 | 2/26/2023 |
1.1.3 | 274 | 2/25/2023 |