Skip to content

Latest commit

 

History

History
137 lines (109 loc) · 3.5 KB

Readme.md

File metadata and controls

137 lines (109 loc) · 3.5 KB

ReDI: Reusable Dependency Injection

alt text MIT license NuGet stable version

Purpose

The ReDI framework aims to simplify dependency management within your projects. By encapsulating dependencies in modules, it allows you to create reusable libraries and easily set up test environments.

Compatability

It targets the .net 2.1 standard and can be used in both .NET and Unity.

Install

Add the ReDI package to your project using NuGet:

Install-Package ReDI

Basic Usage

Let's define Foo class, that use IGreeter to print greeting, and concrete greeter.

public class Foo 
{
    private readonly IGreeter _greeter;

    public Foo(IGreeter greeter) { _greeter = greeter; }
    
    public void PrintGreeting()
    {
        Console.WriteLine(_greeter.GetGreeting());
    }
}

public interface IGreeter
{
    public string GetGreeting();
}

public class HelloWorldGreeter : IGreeter
{
    public string GetGreeting() => "Hello World";
}

Now our goal is to make them work together, so let's define module where we will pack them

public class FooModule : IModule
{
    public void BindDependencies(TypeManager typeBinder)
    {
        typeBinder.AddSingleton<Foo>();
        typeBinder.AddSingleton<IGreeter, HelloWorldGreeter>();
    }

    public void BindModuleDependencies(ModuleManager moduleBinder)
    {
    }
}

Great, now we know basics, we can create some module that we will reuse.

Let's define weather module, that provides weather service and use it later

public class WeatherModule : IModule
{
    public void BindDependencies(TypeManager typeBinder)
    {
        typeBinder.AddTransient<WeatherService>();
    }

    public void BindModuleDependencies(ModuleManager moduleBinder)
    {
    }
}

public class WeatherService
{
    public int GetWeatherTemperature() => 100; //it's hot
}

Now let's define class that use that service, and want to inject it.

Injecting attribute can be applied to properties, fields and methods. Calling order: Fields -> Properties -> Methods

public class Bar
{
    [Inject] private WeatherService _weatherService;

    public void PrintWeather()
    {
        Console.WriteLine($"Temperature is {_weatherService.GetWeatherTemperature()}");
    }
}

public class BarModule : IModule
{
    public void BindDependencies(TypeManager typeBinder)
    {
        var bar = new Bar();
        typeBinder.AddTransient<Bar>().ImplementingInterfaces().FromInstance(bar);
    }

    public void BindModuleDependencies(ModuleManager moduleBinder)
    {
        moduleBinder.RegisterModule<WeatherModule>();
    }
}

Now let's use everything in our program

var containerBuilder = new ContainerBuilder();
containerBuilder.AddModule<FooModule>();
containerBuilder.AddModule<BarModule>();
var container = containerBuilder.Build();

var foo = container.Resolve<Foo>();
var bar = container.Resolve<Bar>();

foo.PrintGreeting();
bar.PrintWeather();

Encapsulating dependencies making testing is much easier, and it allows you to write reusable libraries.

Contributing

Feel free to contribute to the ReDI framework by submitting pull requests or reporting issues on the GitHub repository.

License

This project is licensed under the MIT License.

For more detailed information, visit the documentation (in-progress).

Happy coding! 🚀