Skip to main content

This is a fastapi scaff.

Project description

fastapi-scaff

What is this?

  • by: axiner
  • fastapi-scaff
  • This is a fastapi scaff.
    • new project
    • add api
    • about project:
      • auto init project (conf, db, log...)
      • auto register router
      • auto register middleware
      • ...
      • integrated jwt\api-key
      • integrated sqlalchemy
      • integrated migration
      • integrated celery
      • integrated docker deployment
      • ...
    • about structure:
      • standard
      • light
      • tiny
      • single
    • more documents: 请点击链接

Project structure

  • ASM: ASM mode

    • A api
    • S services(&schemas)
    • M models(&repositories)
  • Calling process: main.py(initializer) -> (middleware) - api - services(&schemas) - (models&repositories)

  • Structure: (The naming has been finalized after multiple revisions, making it concise and easy to understand)

    └── fastapi-scaff
        ├── app                         (应用)
        │   ├── api                     ├── (api)
        │   │   └── v1                  │   └── (v1)
        │   ├── initializer             ├── (初始化)
        │   │   ├── conf                │   ├── (配置)
        │   │   ├── db                  │   ├── (数据库)
        │   │   ├── log                 │   ├── (日志)
        │   │   └── ...                 │   └── (...)
        │   ├── middleware              ├── (中间件)
        │   ├── migrations              ├── (数据库迁移)
        │   ├── models                  ├── (数据模型)
        │   ├── repositories            ├── (数据仓库)
        │   ├── schemas                 ├── (数据结构)
        │   ├── services                ├── (业务逻辑)
        │   ├── utils                   ├── (utils)
        │   └── main.py                 └── (main.py)
        ├── app_celery                  (应用-celery)
        ├── config                      (配置目录)
        ├── docs                        (文档目录)
        ├── logs                        (日志目录)
        ├── tests                       (测试目录)
        ├── .dockerignore
        ├── .gitignore
        ├── .python-version
        ├── build.sh
        ├── docker-compose.yaml
        ├── Dockerfile
        ├── LICENSE
        ├── README.md
        ├── requirements.txt
        └── runserver.py
    
  • 【Other structure】

    • light:Please create and view (with -e light)
    • tiny:Please create and view (with -e tiny)
    • single:Please create and view (with -e single)

Installation

This package can be installed using pip (Python>=3.11):

pip install fastapi-scaff

Scaff usage

  • 1)help document
    • fastapi-scaff -h
  • 2)new project
    • fastapi-scaff new <myproj>
    • light structure: fastapi-scaff new <myproj> -e light
    • tiny structure: fastapi-scaff new <myproj> -e tiny
    • single structure: fastapi-scaff new <myproj> -e single
  • 3)add api
    • cd to project root dir
    • fastapi-scaff add <myapi>
  • 4)integrated celery
    • M1。new with --celery: fastapi-scaff new <myproj> --celery
    • M2。add with --celery: fastapi-scaff add <mycelery> --celery

Project run

  • 1)cd to project root dir
  • 2)modify the configuration, such as for the database
  • 3)pip install -r requirements.txt
  • 4)python runserver.py
  • x)migration
    • eg (Can be executed before runserver):
      • generate: python runmigration.py generate init
      • upgrade: python runmigration.py upgrade
    • about alembic: click here
  • x)docker, please see:
    • project files:
      • build.sh
      • docker-compose.yaml | docker-compose.swarm.yaml[config/nginx.conf]
      • Dockerfile | Dockerfile.slim
    • about docker: click here

License

This project is released under the MIT License (MIT). See LICENSE


☕ 请我喝咖啡

享受开源,也感谢支持。

如果本项目对您有用,可以考虑 Buy Me a Coffee :)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fastapi_scaff-0.7.2-py3-none-any.whl (74.8 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_scaff-0.7.2-py3-none-any.whl.

File metadata

  • Download URL: fastapi_scaff-0.7.2-py3-none-any.whl
  • Upload date:
  • Size: 74.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.11

File hashes

Hashes for fastapi_scaff-0.7.2-py3-none-any.whl
Algorithm Hash digest
SHA256 89cb3d3a01e4783a9b46d64fad37ff84237e46cf66d8cebc23dcdc5adaa2ed07
MD5 9f111017659b777a9677bbe82de432ef
BLAKE2b-256 486e93e623e51d929e2804a0d813e36b03856fc793b36d630f01c2a331c82ada

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page