Skip to main content

Lazy dependency injection.

Project description

PythonSupport PyPI version

Introduction

Main focus is an easy way to create lazy universally injectable dependencies; in less magical way. It also leans more on the side of making it easier to get the dependency you need anywhere in the codebase.

py-xinject allows you to easily inject lazily created universal dependencies into whatever code that needs them, in an easy to understand and self-documenting way.

Documentation

📄 Detailed Documentation | 🐍 PyPi

Install

# via pip
pip install xinject

# via poetry
poetry add xinject

Quick Start

# This is the "my_resources.py" file/module.

import boto3
from xinject import DependencyPerThread


class S3(DependencyPerThread):
    def __init__(self, **kwargs):
        # Keeping this simple; a more complex version
        # may store the `kwargs` and lazily create the s3 resource
        # only when it's asked for (via a `@property or some such).

        self.resource = boto3.resource('s3', **kwargs)

To use this resource in codebase, you can do this:

# This is the "my_functions.py" file/module

from .my_resources import S3

def download_file(file_name, dest_path):
    # Get dependency
    s3_resource = S3.grab().resource
    s3_resource.Bucket('my-bucket').download_file(file_name, dest_path)

Inject a different version of the resource:

from .my_resources import S3
from .my_functions import download_file

us_west_s3_resource = S3(region_name='us-west-2')

def get_s3_file_from_us_west(file, dest_path):
    # Can use Dependencies as a context-manager,
    # inject `use_west_s3_resource` inside `with`:
    with us_west_s3_resource:
        download_file(file, dest_path)

# Can also use Dependencies as a function decorator,
# inject `use_west_s3_resource` whenever this method is called.
@us_west_s3_resource
def get_s3_file_from_us_west(file, dest_path):
    download_file(file, dest_path)

Licensing

This library is licensed under the MIT-0 License. See the LICENSE file.

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

xinject-1.4.1.tar.gz (33.3 kB view details)

Uploaded Source

Built Distribution

xinject-1.4.1-py3-none-any.whl (35.3 kB view details)

Uploaded Python 3

File details

Details for the file xinject-1.4.1.tar.gz.

File metadata

  • Download URL: xinject-1.4.1.tar.gz
  • Upload date:
  • Size: 33.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.6 Linux/5.15.0-1035-azure

File hashes

Hashes for xinject-1.4.1.tar.gz
Algorithm Hash digest
SHA256 48588c3b5bb62731fde5e759cccdf4ab8ea1c53d2e442c6aa1109415485491cd
MD5 b0f9f5ad7d32a9b93b9a4f454421df10
BLAKE2b-256 1abcb9f3ef6be0a170cedcb8f2e23b424cd97180433e8246767a41ed164f78ba

See more details on using hashes here.

File details

Details for the file xinject-1.4.1-py3-none-any.whl.

File metadata

  • Download URL: xinject-1.4.1-py3-none-any.whl
  • Upload date:
  • Size: 35.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.4.2 CPython/3.10.6 Linux/5.15.0-1035-azure

File hashes

Hashes for xinject-1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 849d8d6c7b6d337283624d28a43e7e741c886ea7118910c50d052bd213d21d93
MD5 216b3eaeefdf58f4e4f7a8f49eefb8fa
BLAKE2b-256 b4f1eddd6fe2be207e725174f0fdf8afd7fa9694ecaa707e83a3585f92eba467

See more details on using hashes here.

Supported by

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