Skip to main content

Generate typed url_path_for functions for FastAPI applications.

Project description

Type-Safe Route URL Generator for FastAPI

Stop guessing route names. This tool analyzes your FastAPI application and generates a typed wrapper for url_path_for, giving you instant autocompletion and catching typos before they hit production.

Installation

uvx generate-fastapi-typed-routes@latest

Usage

Point the tool at your FastAPI app and tell it where to save the generated code:

uvx generate-fastapi-typed-routes@latest --app-module myapp.main:app --output myapp/routes.py

Now, instead of using the raw app.url_path_for, import your generated function:

from myapp.routes import app_url_path_for

# Complete with IDE autocompletion and type checking!
url = app_url_path_for("get_user_profile", user_id=123)

CLI Arguments

  • --app-module: The import path to your FastAPI app instance (e.g., src.main:app). You can pass this multiple times to generate helpers for multiple apps in one file.
  • --output: The file path where the generated Python code will be saved.
  • --prefix: (Optional) Custom prefix for the generated function. Defaults to the app variable name (e.g., app becomes app_url_path_for). Use this if you have multiple apps to keep things distinct.

Features

  • Zero Runtime Overhead: The generated code is just type hints and a simple wrapper.
  • IDE Autocompletion: Never type a route name manually again. Your editor will list every available route name defined in your app.
  • Refactoring Safe: Change a route name in your app, and your type checker (mypy, pyright) will flag every place usage that needs updating.
  • Multi-App Support: Easily manage routes for projects with multiple FastAPI instances.

MIT License

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

generate_fastapi_typed_routes-0.2.0.tar.gz (3.6 kB view details)

Uploaded Source

Built Distribution

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

generate_fastapi_typed_routes-0.2.0-py3-none-any.whl (4.6 kB view details)

Uploaded Python 3

File details

Details for the file generate_fastapi_typed_routes-0.2.0.tar.gz.

File metadata

  • Download URL: generate_fastapi_typed_routes-0.2.0.tar.gz
  • Upload date:
  • Size: 3.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for generate_fastapi_typed_routes-0.2.0.tar.gz
Algorithm Hash digest
SHA256 87dc43733f5c6b66d04dd3276ba2c517d3efc00df6356e2266521dc0294a6100
MD5 a696e1ed9751da243478e078fc34ce98
BLAKE2b-256 2bab4019a4ad7575b8340378c15de4c3bbcbcafde04c8334519b26f91593b9cf

See more details on using hashes here.

File details

Details for the file generate_fastapi_typed_routes-0.2.0-py3-none-any.whl.

File metadata

  • Download URL: generate_fastapi_typed_routes-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 4.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.9.27 {"installer":{"name":"uv","version":"0.9.27","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for generate_fastapi_typed_routes-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2098adb7038e84257b56263fdf095551867e7859119e94e79880e22b20d6c2ac
MD5 075702c5b589433b349d9c9183c670d9
BLAKE2b-256 45a68f7b2c2e4f0222efe5b82bf4f824d854dadc21c34f7b659246c9ada87b31

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