Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/atticuszz/fastapi_supabase_template
👏fastapi deeply integrates with supabase,auth,curd postgresql,file upload ,etc , all in one😎,inspired by full stack fastapi postgresql
https://github.com/atticuszz/fastapi_supabase_template
fastapi fastapi-admin fastapi-crud fastapi-template python supabase supabase-auth supabase-client supabase-db supabase-storage
Last synced: about 2 months ago
JSON representation
👏fastapi deeply integrates with supabase,auth,curd postgresql,file upload ,etc , all in one😎,inspired by full stack fastapi postgresql
- Host: GitHub
- URL: https://github.com/atticuszz/fastapi_supabase_template
- Owner: Atticuszz
- License: mit
- Created: 2023-10-29T10:12:30.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-11-04T23:46:26.000Z (about 2 months ago)
- Last Synced: 2024-11-05T00:28:17.693Z (about 2 months ago)
- Topics: fastapi, fastapi-admin, fastapi-crud, fastapi-template, python, supabase, supabase-auth, supabase-client, supabase-db, supabase-storage
- Language: Python
- Homepage:
- Size: 1.42 MB
- Stars: 107
- Watchers: 3
- Forks: 6
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# ⚡SupaFast⚡
___
> supabase & fastapi crud template![supafast.drawio.png](assets%2Fsupafast.drawio.png)
## Features 🚀
___
### FastAPI&supabase
1. works of authorization all handled by supabase-py and fastapi **dependency** without any extra code
2. supabase-py crud integration with **pydantic** model validation### Pytest
1. pytest integration with **pytest-cov**
2. pytest **fixtures** for fastapi client and supabase client
3. pytest **fixtures** for access_token and refresh_token
4. test for **CRUD** operations
5. test for **api** operations### CI/CD
1. **codecov** for coverage report
2. **poetry** for dependency management and pytest integration
3. **pre-commit** for code quality
4. **latest_changes.yml** for auto update README.md
5. **Semantic Release** for auto release and changelog
6. **docker** for deployment## How to use it
___
![](assets/usage.gif)1. create your github repo and config it
1. allow ci to access your repo
![img.png](assets/img.png)
2. config ci_tokens
1. `CODECOV_TOKEN` for codecov in `.github/workflows/ci.yml` ,`semantic-release` is optional for auto release
2. `ATTICUS_PAT`should replace with your GitHub token for latest_changes.yml in `.github/workflows/latest_changes.yml`
3. `DOCKER_USERNAME` and `DOCKER_PASSWORD` for docker-image.yml in `.github/workflows/docker-image.yml`
4. replace `tags: atticuszhou/supafast:latest` with your docker repo in `.github/workflows/docker-image.yml`
3. config fastapi setting in `your_project\src\app\core\config.py`
4. config `pyproject.toml` with your project name and description,etc2. cd your repo and install dependencies with [uv](https://github.com/astral-sh/uv), which is an extremely fast Python package and project manager, written in Rust.
```shell
uv sync --all-extras --dev
```
3. set your supabase env```shell
export SUPABASE_URL=your_supabase_url
export SUPABASE_KEY=your_supabase_key
export SUPERUSER_EMAIL=your_superuser_email
export SUPERUSER_PASSWORD=your_superuser_password
```
4. config fastapi settings
```python
# src/app/core/config.py
class Settings(BaseSettings):
API_V1_STR: str = "/api/v1"
SUPABASE_URL: str = Field(default_factory=lambda: os.getenv("SUPABASE_URL"))
SUPABASE_KEY: str = Field(default_factory=lambda: os.getenv("SUPABASE_KEY"))
SUPERUSER_EMAIL: str = Field(default_factory=lambda: os.getenv("SUPERUSER_EMAIL"))
SUPERUSER_PASSWORD: str = Field(default=lambda: os.getenv("SUPERUSER_PASSWORD"))
# SERVER_NAME: str
SERVER_HOST: AnyHttpUrl = "https://localhost"
SERVER_PORT: int = 8000
BACKEND_CORS_ORIGINS: list[AnyHttpUrl] = []
PROJECT_NAME: str = "fastapi supabase template"
Config: ClassVar[ConfigDict] = ConfigDict(arbitrary_types_allowed=True)
```5. run server
```shell
uv run uvicorn src.app.main:app --reload
```## Roadmap 🫶
___- [x] FastAPI backend
- [x] **standard** structure
for **FastAPI** project
```text
── src
│ └── app
│ ├── api
│ │ ├── api_v1
│ │ │ ├── endpoints
│ │ │ │ ├── __init__.py
│ │ │ │ └── items.py
│ │ │ ├── __init__.py
│ │ │ └── api.py
│ │ ├── __init__.py
│ │ └── deps.py
│ ├── core
│ │ ├── __init__.py
│ │ ├── config.py
│ │ └── events.py
│ ├── crud
│ │ ├── __init__.py
│ │ ├── base.py
│ │ └── crud_item.py
│ ├── schemas
│ │ ├── __init__.py
│ │ ├── auth.py
│ │ ├── base.py
│ │ ├── item.py
│ │ └── msg.py
│ ├── services
│ │ └── __init__.py
│ ├── utils
│ │ └── __init__.py
│ ├── __init__.py
│ └── main.py
...
```
- [x] **auto-auth** by fastapi dependency with supabase-auth
- [x] **CRUD** operations pytest
- [x] **api** requests pytest
- [ ] Supabase integration
- [x] crud supabase-postgresql
- [ ] websocket with supabase-realtime
- [ ] curd supabase-storage
- [ ] supafunc integration
- [x] deployment
- [x] Full **Docker** integration (Docker based).
- [ ] clone
- [ ] cookiecutter
## Release Notes 🥸___
### Latest Changes
## License
This project is licensed under the terms of the MIT license.