Skip to main content

Serves Vue assets on a FastAPI app. Use fastapi-vue-setup tool to add Vue build to your package.

Project description

fastapi-vue

Runtime helpers for FastAPI + Vite/Vue projects.

Overview

This package provides:

  • fastapi_vue.Frontend: serves built SPA assets (with SPA support, caching, and optional zstd)
  • fastapi_vue.server.run: a small Uvicorn runner with convenient listen endpoint parsing

Quickstart

Serve built frontend assets from frontend-build/:

from pathlib import Path
from contextlib import asynccontextmanager
from fastapi import FastAPI
from fastapi_vue import Frontend

frontend = Frontend(Path(__file__).with_name("frontend-build"), spa=True)

@asynccontextmanager
async def lifespan(app: FastAPI):
    await frontend.load()
    yield

app = FastAPI(lifespan=lifespan)

# Add API routes here...

# Final catch-all route for frontend files (keep at end of file)
frontend.route(app, "/")

Frontend

Frontend serves a directory with:

  • RAM caching, with zstd compression when smaller than original
  • Browser caching: ETag + Last-Modified, Immutable assets
  • Favicon mapping (serve PNG or other images there instead)
  • SPA routing (serve browsers index.html at all paths not otherwise handled)

Dev-mode behavior with FastAPI(debug=True): requests error HTTP 409 with a message telling you to use the Vite dev server instead. Avoids accidentally using outdated frontend-build during development.

  • directory: Path on local filesystem
  • index: Index file name (default: index.html)
  • spa: Serve index at any path (default: False)
  • catch_all: Register a single catch-all handler instead of a route to each file; default for SPA
  • cached: Path prefixes treated as immutable (default: /assets/)
  • favicon: Optional path or glob (e.g. /assets/logo*.png)
  • zstdlevel: Compression level (default: 18)

ℹ️ Even when your page has a meta tag giving favicon location, browsers still try loading /favicon.ico whenever looking at something else. We find it more convenient to simply serve the image where the browser expects it, with correct MIME type. This also allows having a default favicon for your application that can be easily overriden at the reverse proxy (Caddy, Nginx) to serve the company branding if needed in deployment.

Server runner

When you need more flexibility than fastapi CLI can provide (e.g. CLI arguments to your own program), you may use this convenience to run FastAPI app with Uvicorn startup on given listen endpoints. Runs in the same process if possible but delegates to uvicorn.run() for auto-reloads and multiple workers. This would typically be called from your CLI main, which can set its own env variables to pass information to the FastAPI instances that run (Python imports only work in same-process mode).

from fastapi_vue import server

server.run("my_app.app:app", listen=["localhost:8000"])
  • As a deployment option, environment FORWARDED_ALLOW_IPS controls X-Forwarded trusted IPs (default: 127.0.0.1,::1).

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_vue-1.0.2.tar.gz (7.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_vue-1.0.2-py3-none-any.whl (8.9 kB view details)

Uploaded Python 3

File details

Details for the file fastapi_vue-1.0.2.tar.gz.

File metadata

  • Download URL: fastapi_vue-1.0.2.tar.gz
  • Upload date:
  • Size: 7.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","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":null}

File hashes

Hashes for fastapi_vue-1.0.2.tar.gz
Algorithm Hash digest
SHA256 a39454bc1e9ab2b28b2b365f27ec2ac590c5a0d821b6c9e371fd62602a2d00cc
MD5 f1d14730872b563488fea5fd79bcdb41
BLAKE2b-256 8c537b5b80f8d5a852193a9d7d21d84f10a78d9837d19856dd02ae3c1a34641e

See more details on using hashes here.

File details

Details for the file fastapi_vue-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: fastapi_vue-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 8.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.21 {"installer":{"name":"uv","version":"0.9.21","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":null}

File hashes

Hashes for fastapi_vue-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 82e2f23b5f722f3508e6f98b1e6589f69a3513b7869178ce77533cdf2d413e69
MD5 62f9fadb6a0031df913867fa1a894e94
BLAKE2b-256 fae8bb5eab3fb2cb8f0c0f98ad12763e7c4184928b9b15f266c16478bc5c1563

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