Lidi is a lightweight dependency injector designed to simplify dependency management in your Python projects.
Project description
Lidi (LIghtweight Dependency Injector)
Lidi is a lightweight dependency injector designed to simplify dependency management in your Python projects. It provides a simple and intuitive API for binding classes and resolving dependencies.
Installation
You can install Lidi using pip:
pip install lidipy
Usage
Basic Binding
To bind a class to an instance or a callable, you can use the bind()
method of the Lidi
instance:
from lidipy import Lidi
class Parent:
pass
class Child:
pass
lidi = Lidi()
# bind instance
lidi.bind(Parent, Child())
# or bind a callable
lidi.bind(Parent, Child)
Singleton Binding
If you want to bind a class as a singleton, you can pass the singleton
parameter as True
when calling the bind()
method:
lidi.bind(Parent, Child(), singleton=True)
With singleton binding, the same instance of the class will be returned every time it is resolved.
Resolving Dependencies
To resolve a class and its dependencies, you can use the resolve()
method of the Lidi class:
instance = lidi.resolve(Parent) # instance is Child()
If the class was bound as a singleton, the same instance will be returned each time it is resolved.
Deferred Resolution
Lidi also supports deferred resolution using the resolve_defer()
method. This method returns a callable that, when invoked, resolves the class:
deferred_resolve = lidi.resolve_defer(Parent)
instance = deferred_resolve()
Class Attribute Resolution
Class attributes are often services or repositories. Lidi supports resolution of bindings using the resolve_attr
method.
lidi.bind(Parent, Child)
class Repository:
service: Parent = lidi.resolve_attr(Parent) # instance is Child()
Handling Missing Bindings
If a binding is missing for a requested type, a BindingMissing
exception will be raised.
You can handle this exception and provide appropriate error handling in your application.
from lidipy import BindingMissing
try:
instance = lidi.resolve(Mother)
except BindingMissing as e:
print(e) # Outputs: "Binding missing for type: Mother"
Usage with Dataclasses
Lidi can be used seamlessly with Python's dataclasses. Here's an example of how to use dataclasses with Lidi:
from dataclasses import dataclass
from lidipy import Lidi
lidi = Lidi()
@dataclass(frozen=True)
class Config:
db_url: str
# Bind Config
lidi.bind(Config, Config(db_url="example.com:5432"))
@dataclass
class Database:
config: Config = lidi.resolve(Config) # or lidi.resolve_defer(Config)
def connect(self):
print(f"Connecting to database at {self.config.db_url}")
# Bind Database
lidi.bind(Database, Database)
# Resolve the dataclass with dependencies
database = lidi.resolve(Database)
database.connect() # Output: Connecting to database at example.com:5432
Dynamic binds on runtime
Lidi supports bindings change on runtime, here's an example:
from dataclasses import dataclass, field
from lidipy import Lidi
lidi = Lidi()
@dataclass
class Config:
db_url: str
@dataclass
class Database:
config: Config = field(default_factory=lidi.resolve_defer(Config))
def connect(self):
print(f"Connecting to database at {self.config.db_url}")
# Bind the initial dependencies
lidi.bind(Config, Config(db_url="example.com:5432"))
lidi.bind(Database, Database)
# Initial resolve
database = lidi.resolve(Database)
database.connect() # Output: Connecting to database at example.com:5432
# Dynamically change binding
lidi.bind(Config, Config(db_url="other-example.com:5432"))
# Second resolve
database = lidi.resolve(Database)
database.connect() # Output: Connecting to database at other-example.com:5432
Contributing
Contributions are welcome! If you find a bug or want to suggest an improvement, please open an issue or submit a pull request on the GitHub repository.
License
Lidi is licensed under the MIT License. Feel free to use, modify, and distribute this project as per the terms of the license.
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
Built Distribution
File details
Details for the file lidipy-0.3.1.tar.gz
.
File metadata
- Download URL: lidipy-0.3.1.tar.gz
- Upload date:
- Size: 4.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | aa7f95d9c96be6dff1fb3acbf8a03ceecc21151f4c8f33e0a06224ef92372149 |
|
MD5 | 9e51c7b916b0dc1fad534b405109680c |
|
BLAKE2b-256 | d9c9242f9360779a4b85adfd445fe1d98aefe4ba2ef1e449cc0c4d1d9a6968c5 |
File details
Details for the file lidipy-0.3.1-py3-none-any.whl
.
File metadata
- Download URL: lidipy-0.3.1-py3-none-any.whl
- Upload date:
- Size: 6.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.10.12 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 808dc9a603fb6ef71fd46986a45d3bf58831940aa449fb031ebade7932a4fd73 |
|
MD5 | 9a2f52ee2800abebf98e5c35203738fd |
|
BLAKE2b-256 | de68a176ee71ed34326e6807baabc18ba106a5e4dce0041f0969b19ef23e9cb6 |