Metadata-Version: 2.1
Name: aiogram3-di
Version: 1.0.1
Summary: Dependency Injection implementation for aiogram 3.
Home-page: https://github.com/Vladyslav49/aiogram3_di
Author: Vladyslav49
License: MIT
Requires-Python: >=3.9
Description-Content-Type: text/markdown
License-File: LICENSE

### Example of usage

```python
import logging
from os import getenv
from typing import Annotated

from aiogram import Router, Bot, Dispatcher
from aiogram.types import Message, User

from aiogram3_di import DIMiddleware, Depends

router = Router()


def get_user_full_name(event_from_user: User) -> str:
    return event_from_user.full_name


@router.message()
async def _(message: Message, full_name: Annotated[str, Depends(get_user_full_name)]) -> None:
    await message.answer(f'Hi {full_name}')


def main() -> None:
    logging.basicConfig(level=logging.INFO)

    bot = Bot(token=getenv('BOT_TOKEN'))

    dp = Dispatcher()
    dp.include_router(router)
    dp.message.middleware(DIMiddleware())  # register Dependency Injection middleware
    dp.run_polling(bot)


if __name__ == '__main__':
    main()
```

### Details

It is inspired by [FastAPI]('https://github.com/tiangolo/fastapi').

If you define a normal def, your function will be called in a different thread.

### License

MIT
