AttributeBasedRegistration 2.2.1

There is a newer version of this package available.
See the version list below for details.
dotnet add package AttributeBasedRegistration --version 2.2.1                
NuGet\Install-Package AttributeBasedRegistration -Version 2.2.1                
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="AttributeBasedRegistration" Version="2.2.1" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add AttributeBasedRegistration --version 2.2.1                
#r "nuget: AttributeBasedRegistration, 2.2.1"                
#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.
// Install AttributeBasedRegistration as a Cake Addin
#addin nuget:?package=AttributeBasedRegistration&version=2.2.1

// Install AttributeBasedRegistration as a Cake Tool
#tool nuget:?package=AttributeBasedRegistration&version=2.2.1                

AttributeBasedRegistration

Build Status

Library allowing registering services with Autofac and Microsoft's DI container via attributes. Additionally contains various extensions to Autofac and Microsoft's DI container.

Features

Set of attributes allowing automatic registration:

  • [ServiceImplementation] - marks the class as an implementation of a service, allows for a quick definition providing a few possible ctors
  • [RegisterAs] - explicitly defines service types or a registration strategy
  • [Lifetime] - explicitly defines the lifetime with which the service should be registered (Autofac's based - Microsoft's DI equivalent will be used) - some supported only with Autofac
  • [EnableInterception] - enables interception on the service, in theory supports intercepting classes and interfaces (or both) (Intercept enum) though intercepting classes sometimes suffers from weird Castle.Core bugs thus when using interception it is encouraged to use interface service types - supported only with Autofac
  • [InterceptedBy] - defines interceptor types that should intercept calls to the service - supported only with Autofac
  • [FindConstructorsWith] - defines a constructor finder to use during creation of the service instance, supports only parameterless ctors and can't be used in conjunction with interceptors - supported only with Autofac
  • [DecoratedBy] - defines types that decorate this service - supported only with Autofac

The usage of the Lifetime attribute versus supplying the lifetime to the ServiceImplementation is per users taste, the data from the more specific attribute will take precedence.

Similar to the above, using multiple RegisterAs or InterceptedBy attributes versus one and supplying multiple types is per users taste - types will be aggregated from all attributes.

Installation

To pick up and register services via attributes use the extensions method on ContainerBuilder or IServiceCollection provided by the library:

builder.AddAttributeDefinedServices(assembliesToScan);

Documentation

Documentation available at https://mikym.github.io/AttributeBasedRegistration/.

Example usage


public interface ICustomService1
{
}

[ServiceImplementation]
[RegisterAs(typeof(ICustomService))]
[Lifetime(ServiceLifetime.InstancePerLifetimeScope)]
[DecoratedBy(1, typeof(ISomeDecorator))]
[EnableInterception(InterceptionStrategy.Interface)]
[InterceptedBy(1, typeof(ISomeInterceptor))]
public class CustomService1 : ICustomService1
{
}

public interface ICustomService2
{
}

[ServiceImplementation(ServiceLifetime.SingleInstance, RegistrationStrategy.AsConventionNamedInterface)]
public class CustomService2 : ICustomService2
{
}

Product 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 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages (5)

Showing the top 5 NuGet packages that depend on AttributeBasedRegistration:

Package Downloads
DataExplorer

Library featuring an opinionated, reusable data access layer offering abstractions and implementations for SQL storages (EF Core).

ResultCommander

Library featuring a command handler pattern.

AttributeBasedRegistration.Autofac

Extensions to Autofac DI mainly allowing registration of services via attributes amongst other minor things.

ResultCQRS

Library featuring CQRS pattern.

DataExplorer.Unstable

Library featuring common patterns in regard to working with data storages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.2.7 1,771 6 months ago
2.2.6 2,263 1/24/2024
2.2.5 240 1/22/2024
2.2.4 123 1/22/2024
2.2.3 589 11/22/2023
2.2.2 554 11/20/2023
2.2.1 149 11/20/2023
2.2.0 216 11/20/2023
2.1.3 1,517 8/18/2023
2.1.2 940 7/10/2023
2.1.1 1,640 4/3/2023
2.1.0 1,353 3/14/2023
2.0.10 4,210 1/9/2023
2.0.9 1,186 12/22/2022
2.0.8 436 12/22/2022
2.0.7 316 12/22/2022
2.0.6 1,164 11/21/2022
2.0.5 1,416 11/19/2022
2.0.4 911 11/19/2022
2.0.3 606 11/19/2022
2.0.2 307 11/19/2022
2.0.1 433 11/19/2022
2.0.0 323 11/19/2022
1.2.15 1,566 9/27/2022
1.2.14 421 9/27/2022
1.2.13 406 9/27/2022
1.2.12 1,268 9/26/2022
1.2.11 447 9/26/2022
1.2.10 1,151 9/24/2022
1.2.9 782 9/24/2022
1.2.8 673 9/24/2022
1.2.7 402 9/24/2022
1.2.6 658 9/24/2022
1.2.5 434 9/24/2022
1.2.4 428 9/24/2022
1.2.3 456 9/24/2022
1.2.2 511 9/24/2022
1.2.1 430 9/24/2022
1.2.0 433 9/24/2022
1.1.16 444 9/24/2022
1.1.15 425 9/24/2022
1.1.14 428 9/24/2022
1.1.13 428 9/24/2022
1.1.12 431 9/24/2022
1.1.11 417 9/24/2022
1.1.10 1,663 9/19/2022
1.1.9 1,229 9/19/2022
1.1.8 1,151 9/19/2022
1.1.7 457 9/19/2022
1.1.6 1,115 9/19/2022
1.1.5 435 9/19/2022
1.1.4 438 9/19/2022
1.1.3 426 9/19/2022
1.1.2 443 9/19/2022
1.1.1 409 9/17/2022
1.1.0 425 9/17/2022
1.0.0 7,083 8/24/2022