![]() |
VOOZH | about |
dotnet add package Serilog.Enrichers.CallerInfo --version 1.0.6
NuGet\Install-Package Serilog.Enrichers.CallerInfo -Version 1.0.6
<PackageReference Include="Serilog.Enrichers.CallerInfo" Version="1.0.6" />
<PackageVersion Include="Serilog.Enrichers.CallerInfo" Version="1.0.6" />Directory.Packages.props
<PackageReference Include="Serilog.Enrichers.CallerInfo" />Project file
paket add Serilog.Enrichers.CallerInfo --version 1.0.6
#r "nuget: Serilog.Enrichers.CallerInfo, 1.0.6"
#:package Serilog.Enrichers.CallerInfo@1.0.6
#addin nuget:?package=Serilog.Enrichers.CallerInfo&version=1.0.6Install as a Cake Addin
#tool nuget:?package=Serilog.Enrichers.CallerInfo&version=1.0.6Install as a Cake Tool
👁 GitHub
👁 GitHub Workflow Status
👁 Nuget (with prereleases)
👁 Nuget
A simple Serilog enricher to add information about the calling method. Loosely based on Serilog.Enrichers.WithCaller, but with the properties split up for a consistent format that can be parsed automatically.
Performance may be low due the usage of reflection to obtain assembly and method information, as well as the retrieval of the current stacktrace whenever a new log event is added.
To get the actual method that emitted the log event, the stack trace is traversed and the first method that is in a matching assembly is considered the correct one.
To configure which assemblies are the correct one, one can either use the configuration method with assemblyPrefix or the one that directly accepts a collection of fully qualified assembly names.
When passing in only a prefix, the assembly that calls the configuration method is recursively analyzed for referenced assemblies and whether they match the prefix.
If you e.g. have a solution with projects being called MySolution.Web, MySolution.Domain, etc., you can limit the included assemblies by passing in the prefix MySolution.
Be aware that the assembly from which you configure the logger must also have the correct prefix, otherwise no assemblies will be considered and the enricher won't work.
To define a custom assembly from which to start scanning referenced assemblies (instead of the calling assembly), you can define the optional startingAssembly parameter, which must be a fully qualified assembly name.
// With assembly prefix
Log.Logger = new LoggerConfiguration()
.Enrich.WithCallerInfo(
includeFileInfo: true,
assemblyPrefix: "MySolution.",
prefix: "myprefix_",
filePathDepth: 3,
excludedPrefixes: new List<string> { "SomeOtherProject." })
.WriteTo.InMemory()
.CreateLogger();
// With fully qualified assembly names
Log.Logger = new LoggerConfiguration()
.Enrich.WithCallerInfo(
includeFileInfo: true,
allowedAssemblies: new List<string> { "Serilog.Enrichers.CallerInfo.Tests" },
prefix: "myprefix_")
.WriteTo.InMemory()
.CreateLogger();
Or via appsettings.json (using Serilog.Settings.Configuration):
With assembly prefix (when configuring via appsettings.json, you have to define the starting assembly, as the calling assembly is otherwise Serilog.Settings.Configuration (see #1)):
"Serilog": {
"Enrich": [
{
"Name": "WithCallerInfo",
"Args": {
"includeFileInfo": "true",
"assemblyPrefix": "MySolution.",
"startingAssembly": "MySolution.Web"
}
}
]
}
With fully qualified assembly names:
"Serilog": {
"Enrich": [
{
"Name": "WithCallerInfo",
"Args": {
"includeFileInfo": "true",
"allowedAssemblies": [ "Assembly1", "Assembly2" ],
"prefix": "myprefix_"
}
}
]
}
The following properties are added:
| Property | Description | Depends on |
|---|---|---|
Method |
The calling method | |
Namespace |
The namespace of the calling method (including class name) | |
SourceFile |
The path of the source file of the calling method | includeFileInfo and filePathDepth |
LineNumber |
The line number of the calling method | includeFileInfo |
ColumnNumber |
The column number of the calling method | includeFileInfo |
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net5.0 net5.0 was computed. net5.0-windows net5.0-windows was computed. net6.0 net6.0 is compatible. net6.0-android net6.0-android was computed. net6.0-ios net6.0-ios was computed. net6.0-maccatalyst net6.0-maccatalyst was computed. net6.0-macos net6.0-macos was computed. net6.0-tvos net6.0-tvos was computed. net6.0-windows net6.0-windows was computed. net7.0 net7.0 was computed. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 was computed. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
| .NET Core | netcoreapp2.0 netcoreapp2.0 was computed. netcoreapp2.1 netcoreapp2.1 was computed. netcoreapp2.2 netcoreapp2.2 was computed. netcoreapp3.0 netcoreapp3.0 was computed. netcoreapp3.1 netcoreapp3.1 was computed. |
| .NET Standard | netstandard2.0 netstandard2.0 is compatible. netstandard2.1 netstandard2.1 was computed. |
| .NET Framework | net461 net461 was computed. net462 net462 was computed. net463 net463 was computed. net47 net47 was computed. net471 net471 was computed. net472 net472 was computed. net48 net48 was computed. net481 net481 was computed. |
| MonoAndroid | monoandroid monoandroid was computed. |
| MonoMac | monomac monomac was computed. |
| MonoTouch | monotouch monotouch was computed. |
| Tizen | tizen40 tizen40 was computed. tizen60 tizen60 was computed. |
| Xamarin.iOS | xamarinios xamarinios was computed. |
| Xamarin.Mac | xamarinmac xamarinmac was computed. |
| Xamarin.TVOS | xamarintvos xamarintvos was computed. |
| Xamarin.WatchOS | xamarinwatchos xamarinwatchos was computed. |
Showing the top 4 NuGet packages that depend on Serilog.Enrichers.CallerInfo:
| Package | Downloads |
|---|---|
|
Dinaup
Cliente oficial para conectar con la API de Dinaup, permitiendo gestionar compras, ventas, inventario y logística en tiempo real para empresas con múltiples sucursales. Esta es versión beta. |
|
|
Talverse.NotificationService
A complete solution for sending notifications |
|
|
IFNK.ApiHelper
net core api 帮助类 Release Notes: 1.0.3 修改自动验证 Release Notes: 1.0.7 修改自动验证 1.0.9 log 级别 1.0.10 堆栈 更详细 1.0.11 添加日志功能 1.0.12 修改日志功能 |
|
|
SAI.LogModule
Package Description |
Showing the top 2 popular GitHub repositories that depend on Serilog.Enrichers.CallerInfo:
| Repository | Stars |
|---|---|
|
King-zzk/Steam-Workshops-Tools-SWTools
Steam创意工坊下载文件工具
|
|
|
kzeedev/MTWireGuard
A web-based GUI for managing Wireguard on Mikrotik devices.
|