AutoInjectRegister 1.5.1

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

// Install AutoInjectRegister as a Cake Tool
#tool nuget:?package=AutoInjectRegister&version=1.5.1                

AutoInjectRegister

Auto register classes and interfaces for dependency injection. Add the auto inject attribute to the top of any class file to be marked for auto injection. This will help you know the scope of each class just by looking at the class file.

For .Net and C#.

Adding Auto Inject to DI

Add to your program or startup file

 builder.Services.AutoInjectRegisterServices();

Alternatively, if you would like to be more specific with which assembly you would like added, add a type from an assembly you want added. This will only register files in that assembly, so be aware that it won't take everything plus that assembly. It will only take the assembly specified.

  builder.Services.AutoInjectRegisterServices(typeof(IDbReader), typeof(ICache), typeof(IProxy));

If you would like to use exclude specific types you will need to pass in an options class into the register services method.

public class AutoInjectorOptions
{
    public IEnumerable<Type> TypesToScan { get; set; } = [];
    public IEnumerable<Type> TypesToExclude { get; set; } = [];
}

You can then pass the options class in like this.

builder.Services.AutoInjectRegisterServices(
    new AutoInjectorOptions 
    {
        TypesToScan = [typeof(MyClass), typeof(YourClass)],
        TypesToExclude = [typeof(ExclusionClass), typeof(ExclusionClass)] 
    }
);

Register your classes

Add the auto inject attribute to your classes in two different ways.

No paramter attribute

You will have access to three attributes.

    [AutoInjectTransient]

    [AutoInjectScoped]

    [AutoInjectsSingleton]

You can implement them like so.

    [AutoInjectTransient]
    internal class ExampleTransientClass : IExampleTransientInterface
    {
        ...
    }

    [AutoInjectScoped]
    internal class ExampleScopedClass : IExampleScopedInterface
    {
        ...
    }

    
    
    [AutoInjectsSingleton]
    internal class SingletonClassOnly
    {
        ...
    }

Whilst you can implement multiple attributes of different lifetimes, avoid doing so as it could cause confusion of the lifetime of the service. If a class does have multiple attributes it will be registered in the order of the enum, ServiceLifetime.

  [AutoInjectScoped]
  [AutoInjectsSingleton] // This should be what it is registered as
  [AutoInjectTransient]
  internal class ExampleMultipleServiceClass : IExampleMultipleServiceInterface
  {
      ...
  }

Base attribute with a parameter

You can also use the base class if you prefer that. The benefit of this is you will get compiler issues if you use the attribute multiple times.

  // class with interface implementation
  [AutoInject(ServiceLifetime.Scoped)]
  internal class ScopedTestClass : ScopedTestInterface
  {
      ...
  }

  // class only
  [AutoInject(Lifetime.Scoped)]
  internal class ScopedTestClassOnly
  {
      ...
  }

Using TryAddService instead of AddService

In the case you want to try add the service instead of add, you can use the addtype enum as a parameter for all attributes types.

  // class with interface implementation
  [AutoInject(ServiceLifetime.Scoped, AddType.TryAdd)]
  internal class ScopedTestClass : ScopedTestInterface
  {
      ...
  }

  // class only
  [AutoInjectSingleton(AddType.TryAdd)]
  internal class SingletonClass
  {
      ...
  }

Avaliable Service lifetimes

This is just from the microsoft enum, ServiceLifetime.

  Transient,
  Scoped,
  Singleton

Avaliable AddTypes

  Add,
  TryAdd
Product Compatible and additional computed target framework versions.
.NET net9.0 is compatible. 
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.5.2 73 11/18/2024
1.5.1 71 11/18/2024
1.5.0 75 11/16/2024
1.4.0 68 11/15/2024
1.3.0 86 9/22/2024
1.2.0 97 9/14/2024
1.1.0 94 9/3/2024
1.0.1 101 9/2/2024
1.0.0 88 9/2/2024

Optimisations to speed up the registration process... not that it was slow, but it could be faster :).