- Notifications
You must be signed in to change notification settings - Fork12
🍪 Cookiecutter template to build and deploy fastapi backends..batteries included
License
NotificationsYou must be signed in to change notification settings
nickatnight/cookiecutter-fastapi-backend
Folders and files
| Name | Name | Last commit message | Last commit date | |
|---|---|---|---|---|
Repository files navigation
Cookiecutter template to build and deploy fastapi backends to your favorite PaaS..batteries included.
Supported PaaS's:
- Render
- DigitalOcean
- Platform.sh (Coming soon)
- Fly.io (Coming soon)
Install the latest Cookiecutter if you haven't installed it yet:
# pipx is strongly recommended.$ pipx install cookiecutter# If pipx is not an option,# you can install cookiecutter in your Python user directory.$ python -m pip install --user cookiecutter
Generate project from GitHub template:
$ pipx run cookiecutter gh:nickatnight/cookiecutter-fastapi-backend
Or from Python code:
fromcookiecutter.mainimportcookiecuttercookiecutter("gh:nickatnight/cookiecutter-fastapi-backend")
- 🐳Docker & Docker Compose integration and optimization forlocal development. Fast bundles using build stages anduv
- 💻Production ready Python web server usingFastAPI
- ✏️SQLModelLibrary for interacting with SQL databases from Python code, with Python objects. It is designed to be intuitive, easy to use, highly compatible, and robust
- 🚈Alembic Lightweight database migration tool for usage with theSQLAlchemy Database Toolkit for Python
- 💾postgresql Powerful open sourceobject-relational database
- 🏪Redis In-memory data structurestore, used as a distributed, in-memory key–value database, cache and message broker
- ⚙️Common Base models and repository classes for common CRUD operations and database schemas.
- 🌱CeleryAsynchronous task or job queue
- 📥Continuous Integration/Deployment ModularGitHub Actions to lint, test, and deploy to your favorite platform-as-a-service. Automatically includesCodecov reporting.
- ↩️pre-commitGit hooks to maintain code quality using modern tooling (ruff, black, isort)
- 🚀Sentry Application monitoring and error tracking. You can sign up for free atsentry.io
The generator (cookiecutter) will ask you for some data, you might want to have at hand before generating the project.
The input variables, with their default values (some auto generated) are:
project_name: The name of the projectauthor_email: The authors email...for maintainer info inpyproject.tomlpy_version: The version of Python to install. Options are3.9,3.10, and3.11db_container_name: The name of the database container. Defaultdbbackend_container_name: The name of the backend container. Defaultbackenduse_celery: Whether to use Celery and Redis for asynchronous tasks. Defaultnoperiodic_tasks: Whether to use Celery Beat for periodic tasks. Defaultnouse_sentry: Whether to use Sentry for application monitoring and error tracking. Defaultnogithub_username: The username of the GitHub user. Used for badge display in generated projectREADME.mddeployments: Deploy to your favorite platform, Render.com, DigitalOcean, (and more to come). Defaultnone
See full documentationhere.
About
🍪 Cookiecutter template to build and deploy fastapi backends..batteries included
Topics
Resources
License
Uh oh!
There was an error while loading.Please reload this page.
Stars
Watchers
Forks
Uh oh!
There was an error while loading.Please reload this page.