Python port of vercel/serve — static file serving and directory listing
Project description
ssserve
(spelled hisss serve)
Python port of vercel/serve — static file serving and directory listing. (vibecoded)
Run
run directly without installing:
uvx ssserve
Install
uv tool install ssserve
Usage
ssserve [path] [options]
Defaults to current directory and port 3000.
Options
| Flag | Description |
|---|---|
-l, --listen URI |
Listen endpoint (default: tcp://0.0.0.0:3000, multi-allowed) |
-s, --single |
SPA mode — rewrite 404s to index.html |
-C, --cors |
Enable CORS headers |
-u, --no-compression |
Disable gzip compression |
-S, --symlinks |
Resolve symlinks |
-L, --no-request-logging |
Disable request logging |
-c, --config PATH |
Path to serve.json |
--no-etag |
Disable ETag (use Last-Modified) |
--ssl-cert FILE |
SSL certificate (PEM) |
--ssl-key FILE |
SSL private key (PEM) |
--ssl-pass FILE |
SSL passphrase file |
--no-port-switching |
Don't auto-switch if port is taken |
-d, --debug |
Debug output |
--version |
Show version |
--help |
Show help |
Examples
# Serve current directory on port 3000
ssserve
# Serve specific directory on port 5000 with CORS
ssserve -l 5000 -C ./my-site
# Serve with HTTPS
ssserve --ssl-cert cert.pem --ssl-key key.pem
# SPA mode for React/Vue apps
ssserve -s dist
# Multiple listeners
ssserve -l tcp://0.0.0.0:3000 -l unix:/tmp/serve.sock
Configuration
Create a serve.json file in the served directory:
{
"public": "_site",
"cleanUrls": true,
"rewrites": [
{ "source": "/api/**", "destination": "/index.html" }
],
"redirects": [
{ "source": "/old", "destination": "/new", "type": 302 }
],
"headers": [
{
"source": "**/*.@(jpg|png)",
"headers": [
{ "key": "Cache-Control", "value": "max-age=7200" }
]
}
],
"directoryListing": false,
"trailingSlash": true,
"etag": true,
"symlinks": false,
"renderSingle": false
}
Testing
E2E tests verify behaviour, performance, and resource consumption against a live server process.
# Run all tests
uv run pytest tests/ -v
# Run only e2e tests
uv run pytest tests/e2e/ -v
Test layout
| File | Tests | What it covers |
|---|---|---|
tests/e2e/test_behavior.py |
47 | File serving, directory listing, clean URLs, redirects, rewrites, CORS, gzip, ETag/304, Range requests, SPA mode, custom headers, symlinks, path traversal |
tests/e2e/test_performance.py |
8 | Latency (p50/p95/p99), TTFB, gzip vs raw, concurrent throughput — measure-only |
tests/e2e/test_resources.py |
7 | RSS memory, CPU usage, file descriptor count — measure-only |
Dependencies: pytest, psutil (see [dependency-groups] in pyproject.toml).
Tests run automatically on CI via .github/workflows/tests.yml.
Benchmarks
Micro-benchmarks using airspeed velocity track performance of core operations across commits:
| Benchmark | What it measures |
|---|---|
TimeRouteToRegex |
Pattern compilation for route matching |
TimeMatchGlob |
Glob matching and exclusion lists |
TimeParseByteRange |
HTTP Range header parsing |
TimeFormatSize |
File size formatting |
TimeFormatDate |
Date formatting |
TimeParseListen |
Listen URI parsing |
TimeMergeConfig |
Config merging from serve.json |
TimeRenderListing |
HTML directory listing rendering (100 files) |
# Validate benchmarks
uv run asv check --python=same
# Quick run
uv run asv run --python=same --quick
# Full run across configured pythons
uv run asv run
Benchmarks run automatically on CI via .github/workflows/benchmarks.yml.
License
MIT
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ssserve-0.2.0.tar.gz.
File metadata
- Download URL: ssserve-0.2.0.tar.gz
- Upload date:
- Size: 13.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
124359f7e5d4321ab7ad078318f68bdbc35103990e151ef861f3d2ba5ac5f6d6
|
|
| MD5 |
29a0c2612f7e91ac687b5e600c92b90e
|
|
| BLAKE2b-256 |
9fc4e1faa66c6a7984220a8ec18316e83793784b27f8a679eec0bd628d9715a1
|
Provenance
The following attestation bundles were made for ssserve-0.2.0.tar.gz:
Publisher:
publish.yml on prakashsellathurai/ssserve
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ssserve-0.2.0.tar.gz -
Subject digest:
124359f7e5d4321ab7ad078318f68bdbc35103990e151ef861f3d2ba5ac5f6d6 - Sigstore transparency entry: 1633103492
- Sigstore integration time:
-
Permalink:
prakashsellathurai/ssserve@da3427ff90edaf256d20bfe3a03e15227ca2bf4e -
Branch / Tag:
refs/heads/main - Owner: https://github.com/prakashsellathurai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@da3427ff90edaf256d20bfe3a03e15227ca2bf4e -
Trigger Event:
push
-
Statement type:
File details
Details for the file ssserve-0.2.0-py3-none-any.whl.
File metadata
- Download URL: ssserve-0.2.0-py3-none-any.whl
- Upload date:
- Size: 13.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b91eb1316f5ced8234ed81916c6338279402aa64720ab0b675753b794981795a
|
|
| MD5 |
a253ce39e126bf9af727de3ce0f0996e
|
|
| BLAKE2b-256 |
97adabb174f55e46fa3d92399451b4701c4d7ba504f960f216c40565fa711e89
|
Provenance
The following attestation bundles were made for ssserve-0.2.0-py3-none-any.whl:
Publisher:
publish.yml on prakashsellathurai/ssserve
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ssserve-0.2.0-py3-none-any.whl -
Subject digest:
b91eb1316f5ced8234ed81916c6338279402aa64720ab0b675753b794981795a - Sigstore transparency entry: 1633103538
- Sigstore integration time:
-
Permalink:
prakashsellathurai/ssserve@da3427ff90edaf256d20bfe3a03e15227ca2bf4e -
Branch / Tag:
refs/heads/main - Owner: https://github.com/prakashsellathurai
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@da3427ff90edaf256d20bfe3a03e15227ca2bf4e -
Trigger Event:
push
-
Statement type: