Skip to main content

A lean dependency injection container

Project description

Sashimono

Coverage Status made-with-python GitHub license

A lean dependency injection container

This package provides a lean and explicit DI container for code modularization and flexibility in application development.

Motivation

The main goal of 'sashimono' in it's version 0.1.z was split application development into multiple packages in a coherent way, allowing each piece to be developed and maintained in isolated environments without compromising the whole application and its integration. This meant that the package lived with two responsibilities, that of being a dependency container and that of being a plugin system. And while the initial idea of sashimono was fine, it made the package awkward to use for those who only wanted to use one of those features. So we decided to split the package into two that would fulfill those responsibilities separately. Since version 1.y.zSashimono only responds to the dependency container feature.

For this version we took a bit of inspiration from Bottle, to make the package so small, atomic and dependency-free that you can simply download it to your project folder instead of installing it. Although we will keep both options.

Example

The idea of using a DI container revolves around the Container object and it's the main and only object that Sashimono explicitly provides.

from sashimono import Container

The Container works as a dictionary that binds types and strings with the function that holds how the objects must be build using container itself.

from sashimono import Container

c = Container()
c["number"] = Container.singleton(lambda c: 5)
print(c["number"])

The output must be 5

But how do they work? Sashimono uses the singleton and factory methods to define the construction expressions. Those expressions are executed when you try to access a specific object by building it. In the example above, the expression lambda c:5 is executed when called in print(c['number']) resulting in 5. The c parameter represents the container itself, so you can perform dependency injection within those build expressions. Because singleton was used, if we try to access c["number"] once again, it will give us the exact same instance that was already generated.

from sashimono import Container

class Foo:
    def __init__(number):
        self.number  = number


c = Container()
c["number"] = Container.singleton(lambda c: 5)
c[Foo] = Container.factory(lambda c: Foo(c["number"]))
print(c[Foo].number)

The output must be 5

In this other example some manual DI was made and the factory method was used so every time you access to Foo through the container it will give you a new instance of Foo. The same can be made relaying on automatic injection as you can see in the next example.

from sashimono import Container

class Foo:
    def __init__(number):
        self.number  = number

c = Container()
c["number"] = Container.singleton(5)
c[Foo] = Container.factory(Foo)
print(c[Foo].number)

The output must be 5

We made a tweak around class inheritance too. When you store a class and ask for it using its parent in the container, if that parent doesn't exist in the container, it'll return the child class that's already stored. Check it out in the next example.

from sashimono import Container

class Foo:
    def __init__(number):
        self.number  = number

class Baa(Foo):
    ...

c = Container()
c["number"] = Container.singleton(5)
c[Baa] = Container.factory(Baa)
print(c[Foo].number)

The output must be 5

So even if Foo wasn't defined inside the container if you ask for it the container will search a child of Foo, in this case Baa, to return.

That's all.Happy coding! 👋

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sashimono-1.1.3.tar.gz (5.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sashimono-1.1.3-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

Details for the file sashimono-1.1.3.tar.gz.

File metadata

  • Download URL: sashimono-1.1.3.tar.gz
  • Upload date:
  • Size: 5.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sashimono-1.1.3.tar.gz
Algorithm Hash digest
SHA256 d99fbc46fefc1589c798aba9e20c80ee610fff77afab89768a74667374d83d4b
MD5 5ea9f272cc7e04d3fdd47ee507fc40bf
BLAKE2b-256 18ca3163d26b98a250b5302e89bfe32e08bfc92c9ae5191b7e22ef5ac19d2170

See more details on using hashes here.

File details

Details for the file sashimono-1.1.3-py3-none-any.whl.

File metadata

  • Download URL: sashimono-1.1.3-py3-none-any.whl
  • Upload date:
  • Size: 5.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for sashimono-1.1.3-py3-none-any.whl
Algorithm Hash digest
SHA256 cc55aab98fa9280b799b0548929d9b878bd63816ce0b9929e258480451abb0ad
MD5 2a75fec227ad1ec9644099a41c941210
BLAKE2b-256 5865fd97acf13384a4f1f17d8e3220a6287d313033d6d53b87445deea8e0b891

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page