Diay is a dependency injection/inversion of control library for Python 3.5 and higher. It leverages the type hints introduced in 3.5 to allow you to easily call functions or construct classes that require specific types of objects to function.
As an extremely basic and somewhat contrived example - the value of the library doesn't really come into play until you have fairly deeply nested dependencies - let's say you want to render a jinja2 template using some data from an API.
injector = diay.Injector()
injector.set_instance(SomeConfigClass, my_config_object)
@injector.provider
def make_jinja_environment() -> jinja2.Environment:
return jinja2.Environment()
@injector.provider
def make_api_client(config: SomeConfigClass) -> some.APIclient:
return some.APIclient(config.api_token)
def render(j2env: jinja2.Environment, apiclient: some.APIclient):
data = apiclient.get('/some/data')
template = j2env.get_template('some-template.html.j2', data=data)
return template.render()
html = injector.call(render)
The contents of this repository is released under the MIT license. See the LICENSE file included for more information.