ReHackt.Extensions.Options.Validation
9.0.1
dotnet add package ReHackt.Extensions.Options.Validation --version 9.0.1
NuGet\Install-Package ReHackt.Extensions.Options.Validation -Version 9.0.1
<PackageReference Include="ReHackt.Extensions.Options.Validation" Version="9.0.1" />
paket add ReHackt.Extensions.Options.Validation --version 9.0.1
#r "nuget: ReHackt.Extensions.Options.Validation, 9.0.1"
// Install ReHackt.Extensions.Options.Validation as a Cake Addin #addin nuget:?package=ReHackt.Extensions.Options.Validation&version=9.0.1 // Install ReHackt.Extensions.Options.Validation as a Cake Tool #tool nuget:?package=ReHackt.Extensions.Options.Validation&version=9.0.1
ReHackt.Extensions.Options.Validation
Extends OptionsBuilder<T>
and IServiceCollection
with nested data annotations validation and eager validation on start.
Get started
Get it on <a href="https://www.nuget.org/packages/ReHackt.Extensions.Options.Validation"><img src="https://www.nuget.org/Content/gallery/img/default-package-icon.svg" height=18 style="height:18px;" /> NuGet</a>
TL;DR
- Create your options class(es)
- Decorate your options with data annotations
- Call
ConfigureAndValidate<T>(Action<T> configureOptions)
on yourIServiceCollection
ConfigureAndValidate
will configure your options (calling the base Configure
method), but will also check that the built configuration respects the data annotations, otherwise an OptionsValidationException (with details) is thrown as soon as the application is started. No misconfiguration surprise at runtime!
Example
// Startup configuration
public void ConfigureServices(IServiceCollection services)
{
services.ConfigureAndValidate<ApplicationOptions>(options => _configuration.Bind(options));
...
}
// Options classes
public class ApplicationOptions
{
[Required]
public EmailOptions Email { get; set; }
public SecurityOptions Security { get; set; }
...
}
public class EmailOptions
{
[Required]
public string Host { get; set; }
[Required]
public int Port { get; set; }
public bool UseSsl { get; set; }
...
}
public class SecurityOptions
{
[Range(8, int.MaxValue, ErrorMessage = "The {0} must be greater than {1}.")]
public int PasswordMinLength { get; set; } = 8;
...
}
Use
ServiceCollection extension
ConfigureAndValidate
services.ConfigureAndValidate<TOptions>(configureOptions)
Is syntactic sugar for
services
.AddOptions<TOptions>()
.Configure(configureOptions)
.ValidateDataAnnotationsRecursively()
.ValidateOnStart() // or ValidateEagerly()
.Services
OptionsBuilder extensions
ValidateDataAnnotationsRecursively
This method register this options instance for validation of its DataAnnotations at the first dependency injection. Nested objects are supported.
ValidateOnStart
(or ValidateEagerly
in previous versions)
This method validates this options instance at application startup rather than at the first dependency injection.
ConfigureAndValidate
optionsBuilder.ConfigureAndValidate<TOptions>(configureOptions)
Is syntactic sugar for
optionsBuilder
.Configure(configureOptions)
.ValidateDataAnnotationsRecursively()
.ValidateOnStart() // or ValidateEagerly()
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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 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 is compatible. 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. |
.NET Core | netcoreapp2.0 was computed. netcoreapp2.1 was computed. netcoreapp2.2 was computed. netcoreapp3.0 was computed. netcoreapp3.1 was computed. |
.NET Standard | netstandard2.0 is compatible. netstandard2.1 was computed. |
.NET Framework | net461 was computed. net462 was computed. net463 was computed. net47 was computed. net471 was computed. net472 was computed. net48 was computed. net481 was computed. |
MonoAndroid | monoandroid was computed. |
MonoMac | monomac was computed. |
MonoTouch | monotouch was computed. |
Tizen | tizen40 was computed. tizen60 was computed. |
Xamarin.iOS | xamarinios was computed. |
Xamarin.Mac | xamarinmac was computed. |
Xamarin.TVOS | xamarintvos was computed. |
Xamarin.WatchOS | xamarinwatchos was computed. |
-
.NETStandard 2.0
- Microsoft.Extensions.Hosting (>= 9.0.1)
- Microsoft.Extensions.Options (>= 9.0.1)
- System.ComponentModel.Annotations (>= 5.0.0)
-
net8.0
- Microsoft.Extensions.Hosting (>= 9.0.1)
- Microsoft.Extensions.Options (>= 9.0.1)
-
net9.0
- Microsoft.Extensions.Hosting (>= 9.0.1)
- Microsoft.Extensions.Options (>= 9.0.1)
NuGet packages (6)
Showing the top 5 NuGet packages that depend on ReHackt.Extensions.Options.Validation:
Package | Downloads |
---|---|
ReHackt.AspNetCore.Authentication
Package Description |
|
ReHackt.Email
Provides an email layout to create email templates with Razor and tag helpers, and a service abstraction to send emails. |
|
ReHackt.RazorEmails
Provides an email layout to create email templates with Razor and tag helpers, and a service to send emails using SMTP. |
|
ReHackt.AspNetCore.Builder
Package Description |
|
Quantoz.Nexus.Sdk.Shared
Shared files used by sdk's for interacting with the Quantoz Nexus environment. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
9.0.1 | 207 | 1/14/2025 |
9.0.0 | 9,651 | 11/12/2024 |
8.0.3 | 18,151 | 10/9/2024 |
8.0.2 | 130,722 | 2/15/2024 |
8.0.1 | 11,248 | 1/18/2024 |
8.0.0 | 1,384 | 1/18/2024 |
7.0.1 | 167,803 | 4/17/2023 |
7.0.0 | 57,408 | 12/2/2022 |
6.0.3 | 423,519 | 8/24/2022 |
6.0.2 | 2,258 | 8/10/2022 |
6.0.1 | 74,891 | 12/30/2021 |
6.0.0 | 76,511 | 11/27/2021 |
5.0.0 | 33,562 | 11/11/2020 |
3.1.9 | 12,689 | 10/15/2020 |
3.1.8 | 562 | 9/14/2020 |
3.1.7 | 496 | 9/14/2020 |
3.1.6 | 495 | 9/14/2020 |
3.1.5 | 513 | 9/14/2020 |
3.1.4 | 502 | 9/14/2020 |
3.1.3 | 505 | 9/14/2020 |
3.1.2 | 513 | 9/14/2020 |
3.1.1 | 502 | 9/14/2020 |
3.1.0 | 839 | 9/14/2020 |