Skip to main content

Dependency injection framework designed with Python in mind.

Project description

https://img.shields.io/pypi/v/picobox.svg https://travis-ci.org/ikalnytskyi/picobox.svg https://codecov.io/gh/ikalnytskyi/picobox/branch/master/graph/badge.svg https://img.shields.io/badge/Say%20Thanks-!-1EAEDB.svg

Picobox is opinionated dependency injection framework designed to be clean, pragmatic and with Python in mind. No complex graphs, no implicit injections, no type bindings – just picoboxes, and explicit demands!

Why?

Because we usually want to decouple our code and Python lack of clean and pragmatic solutions (even third parties).

Features

  • Support both values and factories.
  • Support scopes (e.g. singleton, threadlocal).
  • Push boxes on stack, and use the top one to access values.
  • Thread-safe.
  • Lightweight ( ~141 LOC ).
  • Zero dependencies.
  • Pure Python.

Quickstart

First

$ [sudo] python -m pip install picobox

and then

import picobox
import requests

@picobox.pass_('conf')
@picobox.pass_('requests', as_='session')
def get_resource(uri, session, conf):
    return session.get(conf['base_uri'] + uri)

box = picobox.Box()
box.put('conf', {'base_uri': 'http://example.com'})
box.put('requests', factory=requests.Session, scope=picobox.threadlocal)

with picobox.push(box):
    get_resource('/resource', requests.Session(), {})
    get_resource('/resource', requests.Session())
    get_resource('/resource')

Project details


Download files

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

Filename, size & hash SHA256 hash help File type Python version Upload date
picobox-2.0.0.tar.gz (25.1 kB) Copy SHA256 hash SHA256 Source None Mar 18, 2018

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page