Run Streamlit apps with optional remote HTTPS access.
Project description
streamlit-remote
streamlit-remote runs a Streamlit app locally, can serve it over local HTTPS, and can expose it through a temporary remote HTTPS URL.
It supports Cloudflare Quick Tunnel, ngrok, and managed self-signed certificates for local HTTPS. It is meant for development, demos, and temporary sharing, similar in spirit to Slidev's remote access workflow.
Installation
pip install streamlit-remote
This package requires Python 3.10 or newer.
Basic Usage
st-remote app.py
This starts Streamlit on http://localhost:8501, starts a Cloudflare Quick Tunnel to that local URL, prefixes logs from both child processes, prints the public trycloudflare.com URL once Cloudflare reports it, and opens that remote URL in your browser.
You can also use the alias:
streamlit-remote app.py
Options
st-remote APP [--port 8501] [--host localhost] [--https off] [--provider cloudflare]
Useful options:
st-remote app.py --port 9000
st-remote app.py --host 0.0.0.0
st-remote app.py --no-remote
st-remote app.py --no-browser
st-remote app.py --dry-run
st-remote app.py --https self-signed --no-remote
st-remote app.py --https mkcert --no-remote
st-remote app.py --provider ngrok
st-remote app.py --provider ngrok --tunnel-log-level warn
st-remote app.py --provider ngrok --remote-auth oauth --oauth-provider google
st-remote app.py --provider ngrok --ngrok-traffic-policy-file policy.yml
st-remote app.py -- --server.headless true
Extra arguments after -- are passed to python -m streamlit run.
st-remote starts Streamlit in headless mode so Streamlit does not open the local URL automatically. When remote access is enabled, st-remote opens the detected remote HTTPS URL instead. Use --no-browser to suppress browser opening.
Local HTTPS
By default, Streamlit runs locally over HTTP:
st-remote app.py --https off
For local HTTPS, use managed self-signed mode:
st-remote app.py --https self-signed --no-remote
streamlit-remote creates and reuses a local development certificate in its own cache directory, then passes Streamlit's server.sslCertFile and server.sslKeyFile options automatically. You do not need to choose filenames or manage generated certificate files.
Browsers generally do not trust self-signed certificates by default. You may see a certificate warning unless you manually trust the generated certificate. This mode is intended for local development and testing, not production.
For trusted local HTTPS, use mkcert:
st-remote app.py --https mkcert --no-remote
This requires the mkcert command to be installed and available on PATH.
Install instructions are available from mkcert:
https://github.com/FiloSottile/mkcert
streamlit-remote creates and reuses mkcert certificate files in its own cache directory, runs mkcert -install when it needs to generate them, and passes Streamlit's SSL options automatically.
Advanced users can pass existing certificate files:
st-remote app.py --https cert-files \
--ssl-cert-file cert.pem \
--ssl-key-file key.pem
Remote Providers
Cloudflare Tunnel
Cloudflare Quick Tunnel requires the cloudflared command to be installed and available on PATH.
Install instructions are available from Cloudflare:
https://developers.cloudflare.com/cloudflare-one/connections/connect-networks/downloads/
streamlit-remote checks for cloudflared before starting the tunnel and prints an actionable error if it is missing. It does not install cloudflared automatically.
ngrok
ngrok requires the ngrok command to be installed and available on PATH.
Install instructions are available from ngrok:
Configure your ngrok account token before use:
ngrok config add-authtoken TOKEN
Then run:
st-remote app.py --provider ngrok
ngrok provides HTTPS for the public URL while forwarding to your local Streamlit app. If you combine ngrok with local self-signed HTTPS:
st-remote app.py --provider ngrok --https self-signed
ngrok still provides HTTPS for the public URL. The self-signed certificate is used only between the local ngrok agent and Streamlit.
ngrok Remote Auth
For quick access control with ngrok, use managed OAuth:
st-remote app.py --provider ngrok --remote-auth oauth --oauth-provider google
Supported managed OAuth providers are github, gitlab, google, linkedin, microsoft, and twitch. streamlit-remote writes a temporary ngrok Traffic Policy file, starts ngrok with --traffic-policy-file, and removes the temporary file on shutdown.
Advanced users can provide their own ngrok Traffic Policy file:
st-remote app.py --provider ngrok --ngrok-traffic-policy-file policy.yml
This is useful for provider-specific policies such as OIDC, Basic Auth, IP restrictions, or custom OAuth configuration.
Tunnel Logs
Tunnel provider logs are shown by default:
st-remote app.py --tunnel-log-level info
Use a quieter level to reduce provider noise while keeping Streamlit logs visible:
st-remote app.py --provider ngrok --tunnel-log-level warn
st-remote app.py --provider ngrok --tunnel-log-level error
st-remote app.py --provider ngrok --tunnel-log-level off
off suppresses printed tunnel logs but still captures provider output internally when needed to detect the remote URL. ngrok also uses its local agent API as a fallback for URL detection.
HTTPS Serving vs Remote Access
The design treats HTTPS serving and remote access as separate concepts.
HTTPS serving means the user-facing URL uses HTTPS. Remote access means the app is reachable from outside your local machine.
Cloudflare Quick Tunnel and ngrok usually provide both at once: Streamlit can run locally over plain HTTP, while the provider gives you a public HTTPS URL that forwards to the local app.
Local self-signed and mkcert HTTPS are different: Streamlit itself runs with HTTPS locally. You can use local HTTPS without remote access, or combine it with a remote provider when you specifically want HTTPS between the tunnel agent and Streamlit.
Common combinations:
--https off + --provider cloudflare
Public HTTPS via Cloudflare, local HTTP Streamlit.
--https off + --provider ngrok
Public HTTPS via ngrok, local HTTP Streamlit.
--https self-signed + --no-remote
Local HTTPS Streamlit only.
--https mkcert + --no-remote
Local HTTPS Streamlit with a locally trusted mkcert certificate.
--https self-signed + --provider ngrok
Public HTTPS via ngrok, local HTTPS between ngrok and Streamlit.
For managed self-signed HTTPS with Cloudflare Tunnel, streamlit-remote also passes Cloudflare's origin TLS verification flag automatically so cloudflared can connect to the local self-signed Streamlit server.
Security
This exposes a local Streamlit app to the internet.
Do not use it for sensitive data unless you have proper authentication and access control in place. Cloudflare Quick Tunnel and ngrok are best suited for development, demos, and temporary sharing.
ngrok remote auth can add provider-level access control before requests reach Streamlit. Cloudflare Quick Tunnel auth is not supported by this package; Cloudflare Access requires a configured Zero Trust application and is outside the current Quick Tunnel workflow.
Streamlit's built-in SSL configuration is useful for local testing, but it is not a replacement for a production HTTPS reverse proxy.
Limitations
The current package does not include production Cloudflare named tunnels, Cloudflare Access integration, built-in password protection, or reverse proxy management.
Roadmap
- Cloudflare named tunnel support
- Cloudflare Access integration
- more ngrok Traffic Policy helpers
Development
uv run ruff format
uv run ruff check --fix
uv run basedpyright
uv run pytest
Install the local pre-commit hooks with:
uv run pre-commit install
Run all hooks manually with:
uv run pre-commit run --all-files
Release Management
This project uses scriv-release for changelog-fragment based releases.
For user-visible changes, add a fragment:
uv run scriv create --edit
When fragments are merged to main, the release workflow opens or updates a changelog preview PR. Merging that preview PR tags the release. Tag pushes matching v* run the PyPI publish workflow through Trusted Publishing.
The release workflow expects a GitHub App configured through RELEASE_APP_CLIENT_ID and RELEASE_APP_KEY so release tags can trigger the downstream publish workflow.
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
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 streamlit_remote-0.3.0.tar.gz.
File metadata
- Download URL: streamlit_remote-0.3.0.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e88504ceb4ec7c579a091f7db575414cc803a643377a0ea3a0dfafdbefecb099
|
|
| MD5 |
58890e96d20ea8e704ccbf603995f600
|
|
| BLAKE2b-256 |
fd3e9f433711e996716af29f260861eb35ead3152a6b97384006f1a787b7823b
|
File details
Details for the file streamlit_remote-0.3.0-py3-none-any.whl.
File metadata
- Download URL: streamlit_remote-0.3.0-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c4ccb8818d543591358c4b5565051a139227c0a1688882779cf6a1136f95f43f
|
|
| MD5 |
3c0afd0636901f6f55052cf9e34967a3
|
|
| BLAKE2b-256 |
5f49fec7f0b0d1642f61c631a5d5047e819852c2c256454a801a66e5a720e843
|