Rigutins.DotNetDIPlus 1.0.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Rigutins.DotNetDIPlus --version 1.0.0
                    
NuGet\Install-Package Rigutins.DotNetDIPlus -Version 1.0.0
                    
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Rigutins.DotNetDIPlus" Version="1.0.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Rigutins.DotNetDIPlus" Version="1.0.0" />
                    
Directory.Packages.props
<PackageReference Include="Rigutins.DotNetDIPlus" />
                    
Project file
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add Rigutins.DotNetDIPlus --version 1.0.0
                    
#r "nuget: Rigutins.DotNetDIPlus, 1.0.0"
                    
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#:package Rigutins.DotNetDIPlus@1.0.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Rigutins.DotNetDIPlus&version=1.0.0
                    
Install as a Cake Addin
#tool nuget:?package=Rigutins.DotNetDIPlus&version=1.0.0
                    
Install as a Cake Tool

DotNetDIPlus

DotNetDIPlus is a library that provides advanced patterns for the .NET dependency injection, extending the built-in .NET dependency injection container with additional features and patterns that can make it easier to work with dependency injection in complex use cases.

Note: This library is not a dependency injection container. It is a library that extends the built-in .NET dependency injection container with additional features and patterns.

Features

  • Service forwarding: Register a service implementation as multiple service types.
  • Decorator pattern: Register decorators for services (for services that use the decorator pattern).
  • Composite pattern: Register a composite service that combines multiple services (for services that use the composite pattern).
  • Other methods: Register services by specifying a service lifetime.

Installation

To use this library, add the Rigutins.DotNetDIPlus NuGet package to your project.

The library is currently available for:

  • .NET Standard 2.0
  • .NET Standard 2.1
  • .NET 6.0
  • .NET 7.0

Usage

Service forwarding

Service forwarding in dependency injection allows you to register a single service implementation as multiple service types. This can be useful when you have a service that implements multiple interfaces or when you want to register a service as both an interface and a base class.

For example, consider the following service implementation:

public class MyService : IService1, IService2
{
    // ...
}

To register this service implementation as both IService1 and IService2, this library provides the following extension method:

services.AddSingleton<IService1, IService2, MyService>();

This registers MyService as a singleton service for both IService1 and IService2. With this registration, you can now inject IService1 or IService2 into your classes and get the same instance of MyService.

Similar methods are available for scoped and transient services.

Decorator pattern

The decorator pattern is a design pattern that allows behavior to be added to an individual object, either statically or dynamically, without affecting the behavior of other objects from the same class.

For example, consider the following service implementation and decorator:

// The original service implementation.
public class MyService : IService
{
    // ...
}

// The decorator service.
public class DecoratorService : IService
{
    // The original service implementation that is being decorated.
    private readonly IService _service;

    public DecoratorService(IService service)
    {
        _service = service;
    }

    // ...
}

To use the decorator pattern with dependency injection, you can register a decorator service that wraps the original service implementation. The decorator service can then add behavior before or after calling the original service implementation.

To use the decorator pattern with the .NET dependency injection container, first, you need to register the original service implementation, and then you use the Decorate method provided by this library to register the decorator service.

// Register the original service implementation.
services.AddSingleton<IService, MyService>();

// Register the decorator service, to decorate the original service implementation.
services.Decorate<IService, DecoratorService>();

This registers DecoratorService as a singleton service that decorates MyService. The decorator service will use the same lifetime as the service it decorates.

Each time IService is injected, an instance of DecoratorService will be provided, which will, in turn, contain an instance of MyService.

The same can be done for scoped and transient services.

Composite pattern

The composite pattern is a design pattern that allows you to treat a group of objects in the same way as a single object. This can be useful when you have a collection of objects that you want to treat as a single object, or when you want to apply an operation to a group of objects in a uniform way.

In the context of dependency injection, the composite pattern can be used to combine multiple service implementations into a single composite service. This can be useful when you want to provide a single service that aggregates the functionality of multiple services.

For example, consider the following service implementations:

public class ServiceImpementation1 : IService
{
    public void DoSomething()
    {
        // ...
    }
}

public class ServiceImpementation2 : IService
{
    public void DoSomething()
    {
        // ...
    }
}

// Composite service implementation that delegates calls to the appropriate implementation
public class CompositeService : IService
{
    // The services that are being combined.
    private readonly IEnumerable<IService> _services;

    // Here both ServiceImpementation1 and ServiceImpementation2 should be injected.
    public CompositeService(IEnumerable<IService> services)
    {
        _services = services;
    }

    public void DoSomething()
    {
        foreach (var service in _services)
        {
            service.DoSomething();
        }
    }
}

To register all the services for dependency injection and compose them into a single composite service, first, you need to register the individual service implementations, and then you use the Compose method provided by this library to register the composite service.

// Register the individual services.
services.AddSingleton<IService, ServiceImpementation1>();
services.AddScoped<IService, ServiceImpementation2>();

// Compose all the currently registered IService implementations into a single composite service.
services.Compose<IService, CompositeService>();

This registers CompositeService as a single composite service that receives all the registered IService implementations. Each time IService is injected, an instance of CompositeService will be injected, which will, in turn, contain an IEnumerable of all the registered IService implementations.

The composite service will use the most specific lifetime of the services it combines (in this example, the composite service will be scoped).

Other methods

This library also contains some generic methods that allow you to register services by specifying a service lifetime.

For example, to register a singleton service, you can use the Add method and specify the desired lifetime:

services.Add<IService, MyService>(ServiceLifetime.Singleton);

The same can be done for scoped and transient lifetimes.

Contributing

Contributions are welcome!

This library is being developed in my free time, to share some implementations that I've found useful when working with some more complex use cases in dependency injection in .NET. As such, it has not been tested under all possible scenarios, so if you find any issues or have any suggestions, feel free to open an issue or submit a pull request.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  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 is compatible.  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 was computed.  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. 
.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 is compatible. 
.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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
1.2.0 319 12/8/2023
1.1.0 335 8/7/2023
1.0.0 249 6/5/2023