OpenID Connect (OIDC) Federation
Secure the access to your backend using OIDC Federation to enable auto-generated, short-lived, and non-persistent credentials.When you create long-lived, persistent credentials in your backend to allow access from your web applications, you increase the security risk of these credentials being leaked and hacked. You can mitigate this risk with OpenID Connect (OIDC) federation which issues short-lived, non-persistent tokens that are signed by Vercel's OIDC Identity Provider (IdP).
Cloud providers such as Amazon Web Services, Google Cloud Platform, and Microsoft Azure can trust these tokens and exchange them for short-lived credentials. This way, you can avoid storing long-lived credentials as Vercel environment variables.
- No persisted credentials: There is no need to copy and paste long-lived access tokens from your cloud provider into your Vercel environment variables. Instead, you can exchange the OIDC token for short-lived access tokens with your trusted cloud provider
- Granular access control: You can configure your cloud providers to grant different permissions depending on project or environment. For instance, you can separate your development, preview and production environments on your cloud provider and only grant Vercel issued OIDC tokens access to the necessary environment(s)
- Local development access: You can configure your cloud provider to trust local development environments so that long-lived credentials do not need to be stored locally
In order to allow your deployment to connect with your backend securely, start by enabling OIDC federation for your Vercel project:
- Open your project from the Vercel dashboard
- Select the Settings tab
- From the Security section, enable the Secure backend access with OIDC federation toggle
Then, configure your backend to trust Vercel's OIDC Identity Provider and connect to it from your Vercel deployment:
- Connect to Amazon Web Services (AWS)
- Connect to Google Cloud Platform (GCP)
- Connect to Microsoft Azure
- Connect to your own API
When you run a build, Vercel automatically generates a new token and assigns it to the VERCEL_OIDC_TOKEN
environment variable. You can then exchange the token for short-lived access tokens with your cloud provider.
When your application invokes a function, the OIDC token is set to the x-vercel-oidc-token
header
on the function's Request
object.
Vercel does not generate a fresh OIDC token for each execution but caches the token for a maximum of 45 minutes. While the token has a Time to Live (TTL) of 60 minutes, Vercel provides the difference to ensure the token doesn't expire within the lifecycle of a function's maximum execution duration.
You can download the VERCEL_OIDC_TOKEN
straight to your local development environment using the CLI command
vercel env pull
.
vercel env pull
This writes the VERCEL_OIDC_TOKEN
environment variable and other environment variables targeted
to development
to the .env.local
file of your project folder. See the CLI docs for more information.
Was this helpful?