Skip to main content

A powerful async-only dependency injection framework for Python.

Project description

PyPI codecov

Overview

Linkd is a powerful dependency-injection framework for asyncio-based Python applications.

This library aims to provide an easy way for framework developers to provide dependency-injection functionality, while also being suitable for use with standalone applications with a little bit more work.

For an example of linkd in action, have a look at hikari-lightbulb which uses it to provide all dependency injection functionality.

Installation

Use the package manager pip to install linkd.

pip install linkd

Usage

Standalone

The most basic usage of linkd involves three main steps:

  • Creating a DependencyInjectionManager and registering dependencies
  • Setting up an injection context
  • Enabling injection on a function

An example of all the above can be seen below:

import asyncio

import linkd

# create a manager instance
manager = linkd.DependencyInjectionManager()
# register a dependency to on of the manager's registries
manager.registry_for(linkd.Contexts.ROOT).register_value(str, "thomm.o")

# enable injection on a function with the inject decorator
@linkd.inject
async def greet(who: str) -> str:
    # the 'who' parameter will be injected by linkd
    return f"hello {who}"


# use the contextual decorator to automatically set up an injection context
@manager.contextual(linkd.Contexts.ROOT)
async def main() -> None:
    # call the injected method
    print(await greet())


if __name__ == "__main__":
    asyncio.run(main())

Supported Framework

Linkd currently supports the following frameworks (click to jump to example usage):

If your framework isn't mentioned here, feel free to open an issue requesting support!

Issues

If you find any bugs, issues, or unexpected behaviour while using the library, you should open an issue with details of the problem and how to reproduce if possible. Please also open an issue for any new features you would like to see added.

Contributing

Pull requests are welcome. For major changes, please open an issue/discussion first to discuss what you would like to change.

Please try to ensure that documentation is updated if you add any features accessible through the public API.

If you use this library and like it, feel free to sign up to GitHub and star the project, it is greatly appreciated and lets me know that I'm going in the right direction!

Links

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

linkd-0.1.0.tar.gz (44.2 kB view details)

Uploaded Source

Built Distribution

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

linkd-0.1.0-py3-none-any.whl (39.7 kB view details)

Uploaded Python 3

File details

Details for the file linkd-0.1.0.tar.gz.

File metadata

  • Download URL: linkd-0.1.0.tar.gz
  • Upload date:
  • Size: 44.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for linkd-0.1.0.tar.gz
Algorithm Hash digest
SHA256 d346edd0b008bbbc027cc5ae7823b865034bf66607b2fc428244d12f9c83f8b2
MD5 b16dc7cca3943378489a79e83551e29e
BLAKE2b-256 b5e6bb03a751cd924f3cae2fae5bc935c5a46a653b4c7ce3b2263b39d298f9fc

See more details on using hashes here.

File details

Details for the file linkd-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: linkd-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 39.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: python-requests/2.32.5

File hashes

Hashes for linkd-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 8dc69cfd27717721b29f0fe5d42f834a89a3c5215b7bc8e691c74b6faf4d725c
MD5 7ab023734231ec282e50d52257ed34a6
BLAKE2b-256 0a6d2203183c5a6626e1b811ac07cb87fa46b8b25ed363b78e6cd3b62f7d0b0d

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