geoder101.Microsoft.Extensions.DependencyInjection
1.0.9
dotnet add package geoder101.Microsoft.Extensions.DependencyInjection --version 1.0.9
NuGet\Install-Package geoder101.Microsoft.Extensions.DependencyInjection -Version 1.0.9
<PackageReference Include="geoder101.Microsoft.Extensions.DependencyInjection" Version="1.0.9" />
<PackageVersion Include="geoder101.Microsoft.Extensions.DependencyInjection" Version="1.0.9" />
<PackageReference Include="geoder101.Microsoft.Extensions.DependencyInjection" />
paket add geoder101.Microsoft.Extensions.DependencyInjection --version 1.0.9
#r "nuget: geoder101.Microsoft.Extensions.DependencyInjection, 1.0.9"
#:package geoder101.Microsoft.Extensions.DependencyInjection@1.0.9
#addin nuget:?package=geoder101.Microsoft.Extensions.DependencyInjection&version=1.0.9
#tool nuget:?package=geoder101.Microsoft.Extensions.DependencyInjection&version=1.0.9
DependencyInjection.Microsoft
Complementary extensions for
Microsoft.Extensions.DependencyInjectionthat enable advanced service composition and extensibility.
Overview
This library complements Microsoft.Extensions.DependencyInjection with capabilities not provided out of the box. It focuses on service composition and extensibility so you can layer cross-cutting concerns (logging, caching, validation, retries, metrics) onto existing registrations without changing their implementations.
Installation
dotnet add package geoder101.Microsoft.Extensions.DependencyInjection
Quick Start
Basic Decorator
using Microsoft.Extensions.DependencyInjection;
var services = new ServiceCollection();
// Register your service
services.AddTransient<INotificationService, EmailNotificationService>();
// Decorate it with logging
services.Decorate<INotificationService, LoggingNotificationDecorator>();
var provider = services.BuildServiceProvider();
var notificationService = provider.GetRequiredService<INotificationService>();
// Returns LoggingNotificationDecorator wrapping EmailNotificationService
Decorator with Factory
services.AddScoped<IOrderProcessor, OrderProcessor>();
// Use factory to access IServiceProvider
services.Decorate<IOrderProcessor>((provider, inner) =>
{
var logger = provider.GetRequiredService<ILogger<OrderProcessorDecorator>>();
return new OrderProcessorDecorator(inner, logger);
});
Chaining Multiple Decorators
services.AddTransient<ICalculator, Calculator>();
// Add multiple decorators - they wrap in order
services.Decorate<ICalculator, CachingCalculatorDecorator>();
services.Decorate<ICalculator, LoggingCalculatorDecorator>();
services.Decorate<ICalculator, ValidationCalculatorDecorator>();
// Result: ValidationCalculatorDecorator -> LoggingCalculatorDecorator -> CachingCalculatorDecorator -> Calculator
Use Cases
The decorator pattern is ideal for adding cross-cutting concerns to your services:
- Logging - Track method calls, parameters, and results
- Caching - Add response caching to expensive operations
- Validation - Validate inputs before calling the actual service
- Retry Logic - Add resilience with automatic retries
- Performance Monitoring - Track execution time and metrics
- Authorization - Add security checks before method execution
Documentation
📚 Decorator Pattern Guide - Comprehensive documentation including:
- Complete API reference
- Real-world examples (logging, caching, retry, validation, metrics)
- Service lifetime behavior
- Best practices and common patterns
- Troubleshooting guide
Project Structure
DependencyInjection.Microsoft/
├── src/
│ ├── DependencyInjection.Microsoft/ # Main library
│ └── DependencyInjection.Microsoft.UnitTests/ # Unit tests
├── docs/
│ └── Decorator.md # Detailed documentation
└── README.md # This file
Contributing
Contributions are welcome! Please feel free to submit issues or pull requests.
License
This project is licensed under the MIT License - see the LICENSE.txt file for details.
Co-authored with Artificial Intelligence
This repository is part of an ongoing exploration into human-AI co-creation.
The code, comments, and structure emerged through dialogue between human intent and LLM reasoning — reviewed, refined, and grounded in human understanding.
| 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. net10.0 was computed. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net8.0
- Microsoft.Extensions.DependencyInjection (>= 9.0.10)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on geoder101.Microsoft.Extensions.DependencyInjection:
| Package | Downloads |
|---|---|
|
geoder101.MoqProxy.DependencyInjection.Microsoft
Microsoft.Extensions.DependencyInjection integration for MoqProxy. Enables wrapping DI-registered services with Moq proxies for testing - verify calls to real implementations, spy on service interactions, and test integration scenarios without modifying production code. |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.9 | 250 | 11/6/2025 |
| 1.0.8 | 209 | 11/6/2025 |
| 1.0.6-alpha | 185 | 10/20/2025 |
| 1.0.2-alpha | 268 | 10/19/2025 |
| 1.0.1-alpha | 194 | 10/19/2025 |