Nefarius.Utilities.AspNetCore
2.5.1
Prefix Reserved
dotnet add package Nefarius.Utilities.AspNetCore --version 2.5.1
NuGet\Install-Package Nefarius.Utilities.AspNetCore -Version 2.5.1
<PackageReference Include="Nefarius.Utilities.AspNetCore" Version="2.5.1" />
paket add Nefarius.Utilities.AspNetCore --version 2.5.1
#r "nuget: Nefarius.Utilities.AspNetCore, 2.5.1"
// Install Nefarius.Utilities.AspNetCore as a Cake Addin #addin nuget:?package=Nefarius.Utilities.AspNetCore&version=2.5.1 // Install Nefarius.Utilities.AspNetCore as a Cake Tool #tool nuget:?package=Nefarius.Utilities.AspNetCore&version=2.5.1
Nefarius.Utilities.AspNetCore
My opinionated collection of utilities for ASP.NET Core applications.
Features
- Sets up application (and optionally web requests) logging with Serilog
- Sets up application log file rotation and compression
- Sets up W3C logging to a separate access log file
- Compresses rolled W3C log files and allows for their own retention settings
- Sets up forwarded headers and auto-configures local networks so the correct client IP ends up in logs and middleware
- ⚠️ This assumes that your app sits behind a reverse proxy, do not enable this setting if your app faces the Internet directly or header spoofing becomes possible!
- ... and more as I start incorporating this lib in my projects!
How to use
Replace 👇
WebApplicationBuilder builder = WebApplication.CreateBuilder(args);
with 👇
WebApplicationBuilder builder = WebApplication.CreateBuilder(args).Setup();
and 👇
WebApplication app = builder.Build();
with 👇
WebApplication app = builder.Build().Setup();
and you're all set! 👏 The Setup
extension methods take optional configuration arguments you can provide to alter the default behaviour.
Loading additional configuration
Let's assume you have a custom /app/secrets/appsettings.json
file adding one or more additional sinks (MongoDB in this example):
{
"Serilog": {
"Using": [
"Serilog.Sinks.MongoDB"
],
"WriteTo": [
{
"Name": "MongoDBBson",
"Args": {
"databaseUrl": "mongodb+srv://db-cluster/database?authSource=admin",
"collectionName": "logs",
"cappedMaxSizeMb": "1024",
"cappedMaxDocuments": "50000",
"rollingInterval": "Month"
}
}
]
}
}
To have this configuration file read/merged you can access and modify the Configuration
of the WebApplicationBuilderOptions
like so:
WebApplicationBuilder builder = WebApplication.CreateBuilder(args).Setup(opts =>
{
// loads settings from K8s secret
opts.Configuration.AddJsonFile("secrets/appsettings.json", optional: true);
});
This ensures that the Serilog sinks configuration is read early enough when the logger is created.
Example configurations
From code
Enable and customize W3C log compression
The following settings use the library defaults, they're simply explained here and don't need to be exclusively set if you're satisfied with the defaults 😉
var builder = WebApplication.CreateBuilder().Setup(options =>
{
// this will only keep three most recent uncompressed log files
options.W3C.RetainedFileCountLimit = 3;
// on rotation, make a compressed archive copy before deleting the original
options.W3C.CompressDeletedLogFiles = true;
// keeps the last 90 compressed log files on top of the original files
// after this, even the compressed logs are finally deleted from disk
options.W3C.RetainedCompressedFileCountLimit = 90;
});
From appsettings.json
You can also alter the defaults from your configuration; simply stick to the options classes and property naming conventions like so:
{
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft.AspNetCore": "Warning"
}
},
"WebApplicationBuilderOptions": {
"AutoDetectPrivateNetworks": false
},
"WebApplicationOptions": {
"UseForwardedHeaders": false
}
}
Bear in mind that changing the same option in code will take priority over application configuration.
From docker-compose.yml
Using this format you can change the settings directly in the compose file:
...
environment:
- TZ=Europe/Vienna
- WebApplicationBuilderOptions__W3C__RetainedCompressedFileCountLimit=600
- WebApplicationBuilderOptions__W3C__RetainedFileCountLimit=12
...
3rd party credits
Product | Versions 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 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. |
-
net6.0
- MonoMod.RuntimeDetour (>= 25.2.1)
- Serilog.AspNetCore (>= 9.0.0)
- Serilog.Sinks.File.Archive (>= 1.0.6)
- SharpZipLib (>= 1.4.2)
-
net8.0
- MonoMod.RuntimeDetour (>= 25.2.1)
- Serilog.AspNetCore (>= 9.0.0)
- Serilog.Sinks.File.Archive (>= 1.0.6)
- SharpZipLib (>= 1.4.2)
-
net9.0
- MonoMod.RuntimeDetour (>= 25.2.1)
- Serilog.AspNetCore (>= 9.0.0)
- Serilog.Sinks.File.Archive (>= 1.0.6)
- SharpZipLib (>= 1.4.2)
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 | |
---|---|---|---|
2.5.1 | 581 | 12/14/2024 | |
2.5.0 | 448 | 11/13/2024 | |
2.4.0 | 203 | 11/8/2024 | |
2.4.0-pre001 | 83 | 11/8/2024 | |
2.3.1 | 137 | 10/29/2024 | |
2.3.0 | 2,042 | 3/8/2024 | |
2.2.3 | 127 | 3/6/2024 | |
2.2.2 | 243 | 2/25/2024 | |
2.2.1 | 249 | 2/19/2024 | |
2.2.0 | 434 | 1/13/2024 | |
2.1.0 | 99 | 1/13/2024 | |
2.0.0 | 105 | 1/11/2024 | |
1.16.0 | 366 | 12/7/2023 | |
1.15.0 | 270 | 11/19/2023 | |
1.14.0 | 142 | 11/17/2023 | |
1.13.0 | 158 | 11/17/2023 | |
1.12.0 | 123 | 11/17/2023 | |
1.11.0 | 436 | 9/16/2023 | |
1.10.1 | 152 | 9/13/2023 | |
1.10.0 | 155 | 9/13/2023 | |
1.9.1 | 159 | 9/12/2023 | |
1.8.4 | 336 | 8/7/2023 | |
1.8.3 | 644 | 4/30/2023 | |
1.8.0 | 190 | 4/30/2023 | |
1.7.3-pre | 146 | 4/30/2023 | |
1.7.2-pre | 140 | 4/30/2023 | |
1.7.1 | 178 | 4/29/2023 | |
1.7.0 | 198 | 4/29/2023 | |
1.6.1 | 202 | 4/28/2023 | |
1.6.0 | 193 | 4/27/2023 | |
1.5.1 | 187 | 4/27/2023 | |
1.5.0 | 197 | 4/27/2023 | |
1.4.2 | 175 | 4/27/2023 | |
1.4.1 | 596 | 1/24/2023 | |
1.4.0 | 356 | 1/5/2023 | |
1.3.0 | 321 | 1/4/2023 | |
1.0.1 | 303 | 1/4/2023 | |
1.0.0-pre | 168 | 1/4/2023 |