This library helps you not get involved in the complexities of FastAPI and its libraries and focus all your attention on the application.
-
Proper structure and ready
-
Ruff - An extremely fast Python linter and code formatter, written in Rust.
-
pre-commit - A framework for managing and maintaining multi-language pre-commit hooks.
-
SQLAlchemy - SQLAlchemy is the Python SQL toolkit and Object Relational Mapper that gives application developers the full power and flexibility of SQL
-
Tortoise ORM - Tortoise ORM is an easy-to-use asyncio ORM (Object Relational Mapper) inspired by Django.
-
SQLModel ORM - SQLModel, SQL databases in Python, designed for simplicity, compatibility, and robustness.
-
Beanie ODM - Beanie - is an asynchronous Python object-document mapper (ODM) for MongoDB.
-
fastapi-and-logging - FastAPI-and-Logging simplifies log handling, allowing for effective organization, tracking, and analysis of logs in FastAPI applications, aiding in debugging and issue resolution.
-
fastapi-and-caching - FastAPI and Caching is an extension for FastAPI that provides support for various caching mechanisms, allowing you to easily leverage caching within your FastAPI applications.
-
fastapi-and-babel - FastAPIAndBabel allows you to easily use babel in your FastAPI projects and offers some features to improve and ease things.
-
APScheduler Advanced Python Scheduler (APScheduler) is a Python library that lets you schedule your Python code to be executed later, either just once or periodically.
-
FastStream - the simplest way to work with a messaging queues
-
Authx - Ready-to-use and customizable Authentications and Oauth2 management for FastAPI ⚡
pip install fastapi-fast-template
By executing the following command, you initiate the project configuration.
fast init
-- Enter the name of the application (default: Fast Template): FastTemplate
-- Enter the config module type (default: multiple): simple or multiple
-- Enter the ORM/ODM (default: sqlalchemy): sqlalchemy, tortoise, sqlmodel or beanie
Initializing has been done successfully.
🥳🥳, your project has been created!
.
├── logs/
├── src/
│ ├── models/
│ ├── repositories/
│ │ ├── base.py
│ ├── routers/
│ │ ├── __init__.py
│ ├── schemas/
│ ├── services/
│ ├── utils/
│ │ ├── lifespan.py
│ ├── app.py
│ ├── config.py
│ ├── database.py
│ ├── main.py
├── tests/
├── LICENSE
├── .env
├── .env.sample
├── .fast_template.ini
├── .gitignore
├── .pre-commit-config.yaml
└── ruff.toml
Now, you can run it as follows.
python src/main.py
INFO: Will watch for changes in these directories: ['.']
INFO: Loading environment from '.env'
INFO: Uvicorn running on http://127.0.0.1:8000 (Press CTRL+C to quit)
INFO: Started reloader process [44167] using StatReload
INFO: Started server process [44175]
INFO: Waiting for application startup.
INFO: Application startup complete.
You can add Babel to your project as follows.
fast extension --name babel
Please select the default language (default: en): fa
...
...
...
compiling catalog translations/fa/LC_MESSAGES/messages.po to translations/fa/LC_MESSAGES/messages.mo
For more information, click here.
You can add APScheduler to your project as follows.
fast extension --name scheduler
To use it, you can check the "tasks" directory and the "__init__.py" module.
from tasks import scheduler
async def fast_template_scheduler():
print("FastAPI Fast Template")
scheduler.add_job(
func = fast_template_scheduler,
trigger = CronTrigger(minute = "*/30", timezone = "Asia/Tehran")
)
By running the project, the scheduler is executed.
For more information, click here.
You can add caching to your project as follows.
fast extension --name caching
To use it, you can check the "utils" directory and the "caching.py" module.
from utils.caching import cache
@app.get("/")
@cache.cached(key="root", expire=30, prefix="router")
def root():
return "FastAPI Fast Template"
For more information, click here.
You can add logging to your project as follows.
fast extension --name logging
Please select the log type (default: incoming): (choose from incoming, apicall, exception)
You can now check out the app.py module and apply your changes to it.
For more information, click here.
You can add broker to your project as follows.
fast extension --name stream
Please select the broker (default: redis): (choose from redis, aiokafka, confluent, rabbit, nats)
You can run it with the following command
faststream run src.stream:app
For more information, click here.
You can have direct access to the documentation of each library used by using the following command.
fast doc
Quick access to the documents of the tools used in this template.
___________________________________
👉 FastAPI https://fastapi.tiangolo.com
👉 SQLAlchemy https://www.sqlalchemy.org
👉 Tortoise ORM https://tortoise.github.io
👉 SQLModel ORM https://sqlmodel.tiangolo.com
👉 Beanie ODM https://beanie-odm.dev
👉 FastAPI-And-Babel https://github.com/heysaeid/fastapi-and-babel
👉 FastAPI-And-Logging https://github.com/heysaeid/fastapi-and-logging
👉 FastAPI-And-Caching https://github.com/heysaeid/fastapi-and-caching
👉 APScheduler https://fastapi.tiangolo.com
👉 FastStream https://faststream.airt.ai
👉 AuthX https://github.com/yezz123/authx
And ...
___________________________________