Documentation
A flexible and feature-rich logging library for .NET applications. This library provides multiple logger implementations (Console and File), automatic caller information capture, custom log levels, and seamless integration with Microsoft.Extensions.Logging.
Features
- Multiple Logger Implementations: Console and File loggers with customizable configurations
- Automatic Caller Information: Capture file path and method name automatically using compiler attributes
- Custom Log Levels: 7 severity levels - Trace, Debug, Information, Warning, Error, Exception, and Critical
- Color-Coded Console Output: ANSI color support for better console readability on Windows and Unix-like systems
- Flexible File Logging: Configurable log file output with options for splitting logs
- Trace ID Support: Built-in correlation ID tracking for distributed tracing
- Microsoft.Extensions.Logging Integration: Seamless integration with ASP.NET Core and other frameworks using the standard logging abstractions
- Standalone and State Loggers: Use independently or as part of a larger logging state management system
Installation
NuGet Package
Install the package from NuGet:
dotnet add package ArturRios.Logging
Or via the Package Manager:
Install-Package ArturRios.Logging
GitHub Submodule
You can also include this repository as a submodule in your project:
git submodule add https://github.com/artur-rios/dotnet-logging.git dotnet-logging
Quick Start
Standalone Logger
The simplest way to get started is using the StandaloneLogger:
using ArturRios.Logging;
using ArturRios.Logging.Configuration;
// Create console logger configuration
var consoleConfig = new ConsoleLoggerConfiguration
{
// Controls ANSI color usage in console output
UseColors = true
};
// Initialize standalone logger
var logger = new StandaloneLogger(new List<LoggerConfiguration> { consoleConfig });
// Log messages
logger.Info("Application started");
logger.Debug("Debug information");
logger.Error("An error occurred");
File Logger
Log to files with configurable output:
var fileConfig = new FileLoggerConfiguration
{
ApplicationName = "MyApp", // Required: used in log file names
FolderScheme = LogFolderScheme.ByMonth, // Organize logs by month
FileSplitLevel = LogSplitLevel.Day, // Split logs by day
FilePath = "./logs" // Base path for log files (optional)
};
var logger = new StandaloneLogger(new List<LoggerConfiguration> { fileConfig });
logger.Info("This will be written to a file");
Multiple Loggers
Use multiple loggers simultaneously:
var configurations = new List<LoggerConfiguration>
{
new ConsoleLoggerConfiguration
{
// Controls ANSI color usage in console output
UseColors = true
},
new FileLoggerConfiguration
{
ApplicationName = "MyApp", // Required
FolderScheme = LogFolderScheme.ByMonth,
FileSplitLevel = LogSplitLevel.Day,
FilePath = "./logs"
}
};
var logger = new StandaloneLogger(configurations);
// Messages will be logged to both console and file based on their log level
logger.Warn("This warning appears in both console and file");
Microsoft.Extensions.Logging Integration
Integrate with ASP.NET Core or other frameworks using the standard logging abstractions:
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.Logging;
using ArturRios.Logging.Adapter;
var services = new ServiceCollection();
services.AddLogging(builder =>
{
builder.AddCustomLogger();
});
var serviceProvider = services.BuildServiceProvider();
var logger = serviceProvider.GetRequiredService<ILogger<MyClass>>();
logger.LogInformation("Integrated with ASP.NET Core");
Configuration
ConsoleLoggerConfiguration
var config = new ConsoleLoggerConfiguration
{
// Enable or disable ANSI color output in the console
UseColors = true
};
FileLoggerConfiguration
var config = new FileLoggerConfiguration
{
ApplicationName = "MyApp", // Required: used in log file names
FolderScheme = LogFolderScheme.ByMonth, // Organize logs by month
FileSplitLevel = LogSplitLevel.Day, // Split logs by day
FilePath = "./logs" // Base path for log files (optional)
};
Log Levels
The library supports the following log levels in order of severity:
- Trace - Most detailed, diagnostic-level logging
- Debug - Debug and development information
- Information - General informational messages
- Warning - Potential issues or unexpected behavior
- Error - Errors that occurred during execution
- Exception - Exceptions that were thrown
- Critical - Critical errors requiring immediate attention
State Logger
The StateLogger class allows you to manage logging state across your application:
using ArturRios.Logging;
var stateLogger = new StateLogger();
stateLogger.SetTraceId("trace-123");
stateLogger.Log("Operation started");
stateLogger.ClearTraceId();
Automatic Caller Information
The library automatically captures the calling file and method name without any additional configuration:
logger.Info("User logged in");
// Automatically captures: filename and method name where this call was made
Trace ID Support
Track related log entries across operations with trace IDs:
var logger = new StandaloneLogger(configurations);
logger.TraceId = "request-uuid-12345";
logger.Info("Processing request"); // Will include trace ID in output
logger.Debug("Step 1 complete"); // Will include trace ID in output
Contributing
Contributions are welcome! Please feel free to submit issues and pull requests to improve this project.
Versioning
Semantic Versioning (SemVer). Breaking changes result in a new major version. New methods or non-breaking behavior changes increment the minor version; fixes or tweaks increment the patch.
Build, test and publish
Use the official .NET CLI to build, test and publish the project and Git for source control. If you want, optional helper toolsets I built to facilitate these tasks are available:
Legal Details
This project is licensed under the MIT License. A copy of the license is available at LICENSE in the repository.