Skip to main content

Generate a FastAPI app from an OpenAPI file.

Project description

fastapi-code-generator

Generate a FastAPI application from an OpenAPI document.

PyPI version Downloads PyPI - Python Version codecov license Code style: black

📣 💼 Maintainer update: Open to opportunities. 🔗 koxudaxi.dev

Documentation

The docs site is the source of truth for user-facing documentation:

Use this README as a quick start. The full examples, templating details, and development workflow live in docs/.

Installation

uv tool install fastapi-code-generator
pip install fastapi-code-generator

Quick Start

fastapi-codegen --input openapi.yaml --output app --output-model-type pydantic_v2.BaseModel

fastapi-code-generator uses datamodel-code-generator to build the model layer. See the overview guide for a complete end-to-end example, custom templates, custom visitors, and router generation.

Command Help Snapshot

This block is generated from the current CLI so the README and docs overview stay aligned. For tested option scenarios and examples, use the CLI reference page.

Usage: fastapi-codegen [OPTIONS]

Options:
  -e, --encoding TEXT             [default: utf-8]
  -i, --input TEXT                [required]
  -o, --output PATH               [required]
  -m, --model-file TEXT
  -t, --template-dir PATH
  --model-template-dir PATH
  --enum-field-as-literal [all|one|none]
  -r, --generate-routers
  --specify-tags TEXT
  -c, --custom-visitor PATH
  --disable-timestamp
  --strict-nullable               Respect explicit OpenAPI nullable flags when
                                  generating models.
  --include-request-argument      Auto-inject a FastAPI Request parameter into
                                  operations when not present.
  --allow-remote-refs / --no-allow-remote-refs
                                  Allow or block fetching remote $ref targets
                                  over HTTP/HTTPS. The default follows
                                  datamodel-code-generator compatibility
                                  behavior.
  --allow-private-network         Allow trusted remote $ref targets on local
                                  or private network addresses.
  -d, --output-model-type [pydantic_v2.BaseModel|pydantic_v2.dataclass|dataclasses.dataclass|typing.TypedDict|msgspec.Struct]
                                  [default: pydantic_v2.BaseModel]
  -p, --python-version [3.10|3.11|3.12|3.13|3.14]
                                  [default: 3.10]
  -V, --version
  --use-annotated                 Use typing.Annotated for generated model
                                  field constraints.
  --reuse-model                   Reuse identical generated models as the same
                                  type.
  --enable-faux-immutability      Generate frozen Pydantic models so instances
                                  are hashable when their fields are hashable.
  --install-completion            Install completion for the current shell.
  --show-completion               Show completion for the current shell, to
                                  copy it or customize the installation.
  --help                          Show this message and exit.

Common Tasks

  • Generate a single-file app from an OpenAPI spec: fastapi-codegen --input openapi.yaml --output app
  • Generate router modules for larger applications: fastapi-codegen --input openapi.yaml --output app --template-dir modular_template --generate-routers
  • Limit router regeneration to specific tags: fastapi-codegen --input openapi.yaml --output app --template-dir modular_template --generate-routers --specify-tags "Wild Boars, Fat Cats"
  • Target Pydantic v2 output: fastapi-codegen --input openapi.yaml --output app --output-model-type pydantic_v2.BaseModel

Further Reading

Project details


Download files

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

Source Distribution

fastapi_code_generator-0.8.1.tar.gz (61.4 kB view details)

Uploaded Source

Built Distribution

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

fastapi_code_generator-0.8.1-py3-none-any.whl (30.6 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_code_generator-0.8.1.tar.gz.

File metadata

  • Download URL: fastapi_code_generator-0.8.1.tar.gz
  • Upload date:
  • Size: 61.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fastapi_code_generator-0.8.1.tar.gz
Algorithm Hash digest
SHA256 1090acac5b5c9ec7f523aa811af0b8e94ddd8392791ec6f6b64c76b976f849c6
MD5 fff7de6f5cfd34ff708b6436e3f49ac6
BLAKE2b-256 c21053b806d94ac0f392bd58cd79dacb2bec25b106601daf58cf6200f6005859

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_code_generator-0.8.1.tar.gz:

Publisher: publish.yml on koxudaxi/fastapi-code-generator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fastapi_code_generator-0.8.1-py3-none-any.whl.

File metadata

File hashes

Hashes for fastapi_code_generator-0.8.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8182f85afc0d5d0b47fa2b7d7866e97c431a7e5323ac23434bb9669bc8b15e81
MD5 ad4f552dc7f4ae0eb64df1a943da402a
BLAKE2b-256 037fea112ec43f75289e9a2e5cf254718ba19cd127c34cf4ca5f423598778d1f

See more details on using hashes here.

Provenance

The following attestation bundles were made for fastapi_code_generator-0.8.1-py3-none-any.whl:

Publisher: publish.yml on koxudaxi/fastapi-code-generator

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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