pip instal simple-injector
from simple_injector import SimpleInjector, inject
from random import random
class Repository():
def __init__(self):
self.number = random()
def get_a_number(self):
return self.number
class Service():
def __init__(self, repo: Repository):
self.repo = repo
def get_number(self):
return {"n":self.repo.get_a_number()}
def bootstrap():
SimpleInjector().register(Repository)
SimpleInjector().singleton(Service)
bootstrap()
repo = inject(Repository)
serv = inject(Service)
This will always return the same instance of the SimpleInjector.
Used to register a class on the dependencies list.
Can also receive an instance of the object that you want to assign to it.
Can also receive a callable with one parameter, that will be the instance of the Reference.
Can also receive a callable with 0 parameters.
Any lambda received as a parameter should always return the instance that will be injected.
Used to register a class as a singleton on the dependencies list.
This class' dependencies will be resolved at the moment of this method call, so all its dependencies must be already registered with SimpleInjector.
Used to register a class with its instantiate object on the dependencies list.
Any call to SimpleInjector().resolve(class)
to this class will be resolved with the object previously provided.
Used to resolve a dependency of a class that has been registered prior to the execution of this resolve method.
This method will return an object it has on the dependency list for this class, if it is a singleton, or a registered object, otherwise it will return a new instance for the class provided, injecting all needed dependencies, if they were registered prior to the execution of this method.
Can be used if you need to get a new instance of some class, or if you want a new instance and want to override some param on the constructor of the class.
Can be used if you need to be sure that the SimpleInjector has no dependencies registered on its list