Skip to content

Readymade FastAPI boilerplate for production level project. If the repo is helpful, please give a star and fork it.

Notifications You must be signed in to change notification settings

MahmudJewel/fastapi-production-boilerplate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

48 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FastAPI Production Kit

A production based FastAPI template

If the repo is helpful for you, please give a star and fork it.

Click here to download/fork the repository

Features:

  • FastAPI project structure tree
  • user module
    • id, first name, last name, email as username, password, role, is_active created_at, updated_at
  • admin dashboard => sqladmin
  • authentication => JWT
  • db migration => alembic
  • middleware
  • three types of server
    • production, development, test
  • UUID as primary key
  • Applied RBAC(Role Based Access Control)
  • Applied google auth(OAuth2)

Structured Tree

├── alembic     # Manages database migrations
├── alembic.ini
├── app
│   ├── api
│   │   ├── endpoints   # Contains modules for each feature (user, product, payments).
│   │   │   ├── __init__.py
│   │   │   └── user
│   │   │       ├── auth.py
│   │   │       ├── functions.py
│   │   │       ├── __init__.py
│   │   │       └── user.py
│   │   ├── __init__.py
│   │   └── routers     # Contains FastAPI routers, where each router corresponds to a feature.
│   │       ├── main_router.py
│   │       ├── __init__.py
│   │       └── user.py
│   ├── core    # Contains core functionality like database management, dependencies, etc. 
│   │   ├── database.py
│   │   ├── dependencies.py
│   │   ├── __init__.py
│   │   └── settings.py
│   ├── __init__.py
│   ├── main.py     # Initializes the FastAPI app and brings together various components.
│   ├── models      # Contains modules defining database models for users, products, payments, etc.
│   │   ├── admin.py
│   │   ├── common.py
│   │   ├── __init__.py
│   │   └── user.py
│   ├── schemas    # Pydantic model for data validation
│   │   ├── __init__.py
│   │   └── user.py
│   └── utils       # Can include utility functions that are used across different features.
├── requirements.txt # Lists project dependencies.

app/api/endpoints/: Contains modules for each feature (user, product, payments).

app/api/routers/: Contains FastAPI routers, where each router corresponds to a feature.

app/models/: Contains modules defining database models for users, products, payments, etc.

app/core/: Contains core functionality like database management, dependencies, etc.

app/utils/: Can include utility functions that are used across different features.

app/main.py: Initializes the FastAPI app and brings together various components.

tests/: Houses your test cases.

alembic/: Manages database migrations.

docs/: Holds documentation files.

scripts/: Contains utility scripts.

requirements.txt: Lists project dependencies.

Setup

  1. The first thing to do is to clone the repository:
$ https://github.com/MahmudJewel/fastapi-production-boilerplate
  1. Create a virtual environment to install dependencies in and activate it:
$ cd fastapi-production-boilerplate
$ python -m venv venv
$ source venv/bin/activate
  1. Then install the dependencies:
# for fixed version
(venv)$ pip install -r requirements.txt

# or for updated version
(venv)$ pip install -r dev.txt

Note the (venv) in front of the prompt. This indicates that this terminal session operates in a virtual environment set up by virtualenv2. 4. Now rename .env.example to .env and give the information on the .env file.

  1. Migrate the database:
(venv)$ alembic upgrade head
(venv)$ uvicorn app.main:app --reload
  1. Then Run the project
# start the server
(venv)$ uvicorn app.main:app --reload # using directly uvicorn ==> old one => before version 0.100.0
or
(venv)$ fastapi dev app/main.py # using fastapi CLI ==> after version 0.100.0

User module's API

SRL METHOD ROUTE FUNCTIONALITY Fields Access
1 POST /login Login user email, password All User
2 POST /refresh/?refresh_token= Refresh access token None All User
3 POST /users/ Create new user email, password, first name, last name Anyone
4 GET /users/ Get all users list email, password, first name, last name, role, is_active, created_at, updated_at, id Admin
5 GET /users/me/ Get current user details email, password, first name, last name, role, is_active, created_at, updated_at, id Any User
6 GET /users/{user_id} Get indivisual users details email, password, first name, last name, role, is_active, created_at, updated_at, id Any User
7 PATCH /users/{user_id} Update the user partially email, password, is_active, role Admin
8 DELETE /users/{user_id} Delete the user None Admin
9 GET / Home page None Anyone
10 GET /admin Admin Dashboard None Anyone

OAuth2 - Social Auth

SRL METHOD ROUTE FUNCTIONALITY Fields Access
1 GET /social/google/login Login by google None Anyone
2 GET /social/auth/google/callback Callback for google None Anyone

Tools

Back-end

Language:

Python

Frameworks:

FastAPI
pydantic

Other libraries / tools:

SQLAlchemy
starlette
uvicorn
python-jose
alembic

warning!!!

  • Do not use the same secret key that I provided.
  • Always use new secret key for each project
  • The command will generate new secret key.
openssl rand -hex 32

For practicing level project, Please follow this repo https://github.com/MahmudJewel/fastapi-starter-boilerplate

Happy Coding