os.getenv() just like any other environment variable. Secrets can be scoped to specific environments (e.g., different API keys for staging vs production) and are separate from the platform environment variables that fal injects automatically.
Setting Secrets
You can set secrets from the Dashboard, the CLI, or the Python SDK.Dashboard
Navigate to Dashboard > Secrets to create, edit, and delete secrets. Select the environment (e.g., main, staging) from the dropdown, then add your key-value pairs. Values are encrypted and never displayed after creation.CLI
--env flag:
Python SDK
Accessing Secrets at Runtime
Secrets are available as standard environment variables inside your app. Useos.getenv() to read them in setup(), endpoint handlers, or anywhere else in your runner code.
Secrets are injected when a runner starts. If you update a secret, running runners keep the old value. Only new runners (from a new deploy or scale-up) pick up the updated value. To force all runners to use the new value, redeploy your app with
fal deploy.Secrets During Build
For security, secrets are not available as environment variables during the image build stage. The built image is cached and may be shared across environments, so injecting secrets into the build would risk leaking them. Instead, use the${} substitution syntax in your requirements list. fal replaces ${SECRET_NAME} with the secret value at build time without exposing it in the cached image.
Docker Build Secrets
If you use a custom container image, you can pass build-time secrets via thesecrets parameter on ContainerImage. These are mounted as Docker build secrets (via --mount=type=secret) and are available inside your Dockerfile during the build but not persisted in the final image.
Secrets Per Environment
Secrets can be scoped to specific environments, letting you use different credentials for development, staging, and production. When you deploy to an environment, the runner receives the secrets set for that environment.Managing Secrets
Listing
List your secrets to see their names, environments, and creation dates. Values are never displayed.| Name | Env | Created At |
|---|---|---|
| HF_TOKEN | main | 2026-01-15 10:30:00 |
| DATABASE_URL | main | 2026-01-15 10:31:00 |