Resolve Concelier/Excititor merge conflicts
This commit is contained in:
64
src/StellaOps.DependencyInjection/ServiceBindingAttribute.cs
Normal file
64
src/StellaOps.DependencyInjection/ServiceBindingAttribute.cs
Normal file
@@ -0,0 +1,64 @@
|
||||
using System;
|
||||
using Microsoft.Extensions.DependencyInjection;
|
||||
|
||||
namespace StellaOps.DependencyInjection;
|
||||
|
||||
/// <summary>
|
||||
/// Declares how a plug-in type should be registered with the host dependency injection container.
|
||||
/// </summary>
|
||||
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = false)]
|
||||
public sealed class ServiceBindingAttribute : Attribute
|
||||
{
|
||||
/// <summary>
|
||||
/// Creates a binding that registers the decorated type as itself with a singleton lifetime.
|
||||
/// </summary>
|
||||
public ServiceBindingAttribute()
|
||||
: this(null, ServiceLifetime.Singleton)
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates a binding that registers the decorated type as itself with the specified lifetime.
|
||||
/// </summary>
|
||||
public ServiceBindingAttribute(ServiceLifetime lifetime)
|
||||
: this(null, lifetime)
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates a binding that registers the decorated type as the specified service type with a singleton lifetime.
|
||||
/// </summary>
|
||||
public ServiceBindingAttribute(Type serviceType)
|
||||
: this(serviceType, ServiceLifetime.Singleton)
|
||||
{
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Creates a binding that registers the decorated type as the specified service type.
|
||||
/// </summary>
|
||||
public ServiceBindingAttribute(Type? serviceType, ServiceLifetime lifetime)
|
||||
{
|
||||
ServiceType = serviceType;
|
||||
Lifetime = lifetime;
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// The service contract that should resolve to the decorated implementation. When <c>null</c>, the implementation registers itself.
|
||||
/// </summary>
|
||||
public Type? ServiceType { get; }
|
||||
|
||||
/// <summary>
|
||||
/// The lifetime that should be used when registering the decorated implementation.
|
||||
/// </summary>
|
||||
public ServiceLifetime Lifetime { get; }
|
||||
|
||||
/// <summary>
|
||||
/// Indicates whether existing descriptors for the same service type should be removed before this binding is applied.
|
||||
/// </summary>
|
||||
public bool ReplaceExisting { get; init; }
|
||||
|
||||
/// <summary>
|
||||
/// When true, the implementation is also registered as itself even if a service type is specified.
|
||||
/// </summary>
|
||||
public bool RegisterAsSelf { get; init; }
|
||||
}
|
||||
Reference in New Issue
Block a user