aiomisc-dependency


Nameaiomisc-dependency JSON
Version 0.1.20 PyPI version JSON
download
home_pagehttps://github.com/aiokitchen/aiomisc-dependency
Summaryaiomisc-dependency - dependency injection in aiomisc
upload_time2023-05-10 18:13:31
maintainer
docs_urlNone
authorYuri Shikanov
requires_python
licenseMIT
keywords
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            aiomisc-dependency
==================

Dependency injection plugin for aiomisc_ built with aiodine_ library and
support pytest fixture style dependency injection.

.. _aiodine: https://github.com/bocadilloproject/aiodine
.. _aiomisc: https://github.com/aiokitchen/aiomisc

.. contents:: Table of contents


Installation
------------

Installing from pypi:

.. code-block:: bash

    pip3 install aiomisc aiomisc-dependency


How to use
----------

Register dependency
*******************

To register dependency you can use ``aiomisc_dependency.dependency`` decorator.

.. code-block:: python

    from aiomisc_dependency import dependency

    @dependency
    async def pg_engine():
        pg_engine = await create_engine(dsn=pg_url)
        yield pg_engine
        pg_engine.close()
        await pg_engine.wait_closed()


As you can see dependency can be async generator function. Code after yield
will be executed on teardown to correctly close the dependency.

Coroutine functions, non async functions and generators are also supported.


Use dependency
**************

To use dependency you need to add it's name to ``__dependencies__`` property
for every service which depends on it. Specified dependencies will be injected
as service's attributes on entrypoint startup. If needed to map the dependency
with a different name, then, use ``__dependencies_map__``

.. code-block:: python

    from contextlib import suppress
    from types import MappingProxyType

    import aiohttp
    from aiomisc.service.aiohttp import AIOHTTPService

    class HealthcheckService(AIOHTTPService):

        __dependencies__ = ('pg_engine',)

        async def create_application(self):
            app = aiohttp.web.Application()
            app.add_routes([aiohttp.web.get('/ping', self.healthcheck_handler)])
            return app

        async def healthcheck_handler(self, request):
            pg_status = False
            with suppress(Exception):
               async with self.pg_engine.acquire() as conn:
                   await conn.execute('SELECT 1')
                   pg_status = True

            return aiohttp.web.json_response(
                {'db': pg_status},
                status=(200 if pg_status else 500),
            )


    class RESTService(AIOHTTPService):

        __dependencies__ = ('pg_engine',)

        ...

    class AnotherRESTService(AIOHTTPService):

        __dependencies_map__ = MappingProxyType({'pg_engine': 'engine'})

        ...

If any required dependency won't be found on entrypoint startup,
``RuntimeError`` will be raised.

You can set a dependency manually by adding it to kw arguments on service
creation. This could be convenient in tests.

.. code-block:: python

    from unittest import Mock

    def test_rest_service():
        pg_engine_mock = Mock()
        service = RESTService(pg_engine=pg_engine_mock)
        ...

Dependencies for dependencies
*****************************

You can use dependencies as arguments for other dependencies. Arguments will
injected automatically.

.. code-block:: python

    @dependency
    async def pg_connection(pg_engine):
        async with pg_engine.acquire() as conn:
            yield conn


``loop`` built-in dependency
****************************

Built-in ``loop`` dependency can be used if your dependency requires
event loop instance.

.. code-block:: python

    import aioredis

    @dependency
    async def redis_pool(loop):
        pool = aioredis.create_pool(redis_url, loop=loop)
        yield pool
        pool.close()
        await pool.wait_closed()

LICENSE
-------

MIT

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/aiokitchen/aiomisc-dependency",
    "name": "aiomisc-dependency",
    "maintainer": "",
    "docs_url": null,
    "requires_python": "",
    "maintainer_email": "",
    "keywords": "",
    "author": "Yuri Shikanov",
    "author_email": "dizballanze@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/a3/aa/267661dcde9a98a5eec668f7343fb0e60c4aaf6bb53df91206bb6badcc71/aiomisc_dependency-0.1.20.tar.gz",
    "platform": "all",
    "description": "aiomisc-dependency\n==================\n\nDependency injection plugin for aiomisc_ built with aiodine_ library and\nsupport pytest fixture style dependency injection.\n\n.. _aiodine: https://github.com/bocadilloproject/aiodine\n.. _aiomisc: https://github.com/aiokitchen/aiomisc\n\n.. contents:: Table of contents\n\n\nInstallation\n------------\n\nInstalling from pypi:\n\n.. code-block:: bash\n\n    pip3 install aiomisc aiomisc-dependency\n\n\nHow to use\n----------\n\nRegister dependency\n*******************\n\nTo register dependency you can use ``aiomisc_dependency.dependency`` decorator.\n\n.. code-block:: python\n\n    from aiomisc_dependency import dependency\n\n    @dependency\n    async def pg_engine():\n        pg_engine = await create_engine(dsn=pg_url)\n        yield pg_engine\n        pg_engine.close()\n        await pg_engine.wait_closed()\n\n\nAs you can see dependency can be async generator function. Code after yield\nwill be executed on teardown to correctly close the dependency.\n\nCoroutine functions, non async functions and generators are also supported.\n\n\nUse dependency\n**************\n\nTo use dependency you need to add it's name to ``__dependencies__`` property\nfor every service which depends on it. Specified dependencies will be injected\nas service's attributes on entrypoint startup. If needed to map the dependency\nwith a different name, then, use ``__dependencies_map__``\n\n.. code-block:: python\n\n    from contextlib import suppress\n    from types import MappingProxyType\n\n    import aiohttp\n    from aiomisc.service.aiohttp import AIOHTTPService\n\n    class HealthcheckService(AIOHTTPService):\n\n        __dependencies__ = ('pg_engine',)\n\n        async def create_application(self):\n            app = aiohttp.web.Application()\n            app.add_routes([aiohttp.web.get('/ping', self.healthcheck_handler)])\n            return app\n\n        async def healthcheck_handler(self, request):\n            pg_status = False\n            with suppress(Exception):\n               async with self.pg_engine.acquire() as conn:\n                   await conn.execute('SELECT 1')\n                   pg_status = True\n\n            return aiohttp.web.json_response(\n                {'db': pg_status},\n                status=(200 if pg_status else 500),\n            )\n\n\n    class RESTService(AIOHTTPService):\n\n        __dependencies__ = ('pg_engine',)\n\n        ...\n\n    class AnotherRESTService(AIOHTTPService):\n\n        __dependencies_map__ = MappingProxyType({'pg_engine': 'engine'})\n\n        ...\n\nIf any required dependency won't be found on entrypoint startup,\n``RuntimeError`` will be raised.\n\nYou can set a dependency manually by adding it to kw arguments on service\ncreation. This could be convenient in tests.\n\n.. code-block:: python\n\n    from unittest import Mock\n\n    def test_rest_service():\n        pg_engine_mock = Mock()\n        service = RESTService(pg_engine=pg_engine_mock)\n        ...\n\nDependencies for dependencies\n*****************************\n\nYou can use dependencies as arguments for other dependencies. Arguments will\ninjected automatically.\n\n.. code-block:: python\n\n    @dependency\n    async def pg_connection(pg_engine):\n        async with pg_engine.acquire() as conn:\n            yield conn\n\n\n``loop`` built-in dependency\n****************************\n\nBuilt-in ``loop`` dependency can be used if your dependency requires\nevent loop instance.\n\n.. code-block:: python\n\n    import aioredis\n\n    @dependency\n    async def redis_pool(loop):\n        pool = aioredis.create_pool(redis_url, loop=loop)\n        yield pool\n        pool.close()\n        await pool.wait_closed()\n\nLICENSE\n-------\n\nMIT\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "aiomisc-dependency - dependency injection in aiomisc",
    "version": "0.1.20",
    "project_urls": {
        "Homepage": "https://github.com/aiokitchen/aiomisc-dependency"
    },
    "split_keywords": [],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "85d5fd684456780a84be343106fd45f329ca56114e09d9df1a8e080c50e18bd0",
                "md5": "826bceb00f0fb3cf675ef184f70e210c",
                "sha256": "353609b871c7b69641300d9069b2033a76b1bd8806e6049696729b64b9e5b87a"
            },
            "downloads": -1,
            "filename": "aiomisc_dependency-0.1.20-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "826bceb00f0fb3cf675ef184f70e210c",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 5814,
            "upload_time": "2023-05-10T18:13:30",
            "upload_time_iso_8601": "2023-05-10T18:13:30.594272Z",
            "url": "https://files.pythonhosted.org/packages/85/d5/fd684456780a84be343106fd45f329ca56114e09d9df1a8e080c50e18bd0/aiomisc_dependency-0.1.20-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "a3aa267661dcde9a98a5eec668f7343fb0e60c4aaf6bb53df91206bb6badcc71",
                "md5": "d2ed9cb6ab9a9864c09f14e1b28df44f",
                "sha256": "ce40db771f8a02855307797af0058bbf4d978c6a66cddde8a033735509bb9262"
            },
            "downloads": -1,
            "filename": "aiomisc_dependency-0.1.20.tar.gz",
            "has_sig": false,
            "md5_digest": "d2ed9cb6ab9a9864c09f14e1b28df44f",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 7470,
            "upload_time": "2023-05-10T18:13:31",
            "upload_time_iso_8601": "2023-05-10T18:13:31.900414Z",
            "url": "https://files.pythonhosted.org/packages/a3/aa/267661dcde9a98a5eec668f7343fb0e60c4aaf6bb53df91206bb6badcc71/aiomisc_dependency-0.1.20.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-05-10 18:13:31",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "aiokitchen",
    "github_project": "aiomisc-dependency",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "tox": true,
    "lcname": "aiomisc-dependency"
}
        
Elapsed time: 0.12283s