DBaker.DepRegAttributes
3.0.0
.NET Core 3.1
dotnet add package DBaker.DepRegAttributes --version 3.0.0
NuGet\Install-Package DBaker.DepRegAttributes -Version 3.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="DBaker.DepRegAttributes" Version="3.0.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add DBaker.DepRegAttributes --version 3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: DBaker.DepRegAttributes, 3.0.0"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. Copy this into the interactive tool or source code of the script to reference the package.
// Install DBaker.DepRegAttributes as a Cake Addin
#addin nuget:?package=DBaker.DepRegAttributes&version=3.0.0
// Install DBaker.DepRegAttributes as a Cake Tool
#tool nuget:?package=DBaker.DepRegAttributes&version=3.0.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
DBaker.DepRegAttributes
Register dependencies with attributes!
Example Usage:
[RegisterTransient]
public class TransientRegisteredAsSelf
{
//This will be registered as TransientRegisteredAsSelf
...
}
[RegisterTransient]
public class TransientRegisteredAsInterface : ITransientRegisteredAsInterface
{
//This will be registered as ITransientRegisteredAsInterface
//This only automatically happens if the interface and class name match
//Note: providing any parameters will override this behavior
...
}
[RegisterTransient(typeof(IInterface))]
public class TransientRegisteredWithInterface: IInterface
{
//This will be registered as IInterface
...
}
[RegisterTransient(typeof(IInterface))]
public class TransientRegisteredWithInterface: ITransientRegisteredAsInterface, IInterface
{
//This will be registered only as IInterface
//Providing parameters overrides the automatic registration by interfaces with the same name
...
}
[RegisterTransient(typeof(IInterface1), typeof(IInterface2))]
public class TransientRegisteredWithMultipleInterface: IInterface1, IInterface2
{
//This will be registered as IInterface1 and IInterface2
...
}
[RegisterSingleton(typeof(IInterface1), typeof(IInterface2))]
public class SingletonRegisteredWithMultipleInterface: IInterface1, IInterface2
{
//This will be registered as IInterface1 and IInterface2
//Requesting either interface from the service provider will give you the exact same object
...
}
You can register Transient, Scoped, and Singletons:
[RegisterTransient]
...
[RegisterScoped]
...
[RegisterSingleton]
...
In order for the attributes to work you will need to create an extension in the project you are using the attributes:
public static class ServiceCollectionExtentions
{
public static IServiceCollection AddExampleLibraryRegistration(this IServiceCollection services)
{
return services.RegisterDependenciesByAttribute();
}
}
You can use tagging to filter the servicees you register. If you add no tag, your service will be registered all the time.
[RegisterTransient(new string[] { "tag1", "tag2" })]
public class TagExample1
{
...
}
[RegisterTransient(new string[] { "tag2", "tag3" }, typeof(IInterface1), typeof(IInterface2))]
public class TagExample2 : IInterface1, IInterface2
{
...
}
//register dependencies based on tag
public static class ServiceCollectionExtentions
{
public static IServiceCollection AddByTag(this IServiceCollection services)
{
//This will get TagExample1
return services.RegisterDependenciesByAttribute("tag1");
}
public static IServiceCollection AddByTag2(this IServiceCollection services)
{
//This will get TagExample1 and TagExample2
return services.RegisterDependenciesByAttribute("tag2");
}
public static IServiceCollection AddByTag3(this IServiceCollection services)
{
//This will get TagExample2
return services.RegisterDependenciesByAttribute("tag3");
}
public static IServiceCollection AddAll(this IServiceCollection services)
{
//This will get TagExample1 and TagExample2
return services.RegisterDependenciesByAttribute();
}
}
You can look at examples of usage in the DepRegAttributes.Example and DepRegAttributes.ExampleLibrary projects.
Product | Versions |
---|---|
.NET | net5.0 net5.0-windows net6.0 net6.0-android net6.0-ios net6.0-maccatalyst net6.0-macos net6.0-tvos net6.0-windows net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows |
.NET Core | netcoreapp3.1 |
Compatible target framework(s)
Additional computed target framework(s)
Learn more about Target Frameworks and .NET Standard.
-
.NETCoreApp 3.1
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.