vercel curl

vercel curl

Last updated November 4, 2025

The vercel curl command is currently in beta. Features and behavior may change.

The vercel curl command works like curl, but automatically handles deployment protection bypass tokens for you. When your project has Deployment Protection enabled, this command lets you test protected deployments without manually managing bypass secrets.

The command runs the system curl command with the same arguments you provide, but adds an x-vercel-protection-bypass header with a valid token. This makes it simple to test API endpoints, check responses, or debug issues on protected deployments.

This command is available in Vercel CLI v48.8.0 and later. If you're using an older version, see Updating Vercel CLI.

terminal
vercel curl [path]

Using the vercel curl command to make an HTTP request to a deployment.

Make a GET request to your production deployment:

terminal
vercel curl /api/hello

Making a GET request to the /api/hello endpoint on your production deployment.

Send a POST request with JSON data:

terminal
vercel curl /api/users -X POST -H "Content-Type: application/json" -d '{"name":"John"}'

Making a POST request with JSON data to create a new user.

Test a specific deployment by its URL:

terminal
vercel curl /api/status --deployment https://my-app-abc123.vercel.app

Making a request to a specific deployment instead of the production deployment.

See detailed request information:

terminal
vercel curl /api/data -v

Using curl's -v flag for verbose output, which shows headers and connection details.

When you run vercel curl:

  1. The CLI finds your linked project (or you can specify one with --scope)
  2. It gets the latest production deployment URL (or uses the deployment you specified)
  3. It retrieves or generates a deployment protection bypass token
  4. It runs the system curl command with the bypass token in the x-vercel-protection-bypass header

The command requires curl to be installed on your system.

These are options that only apply to the vercel curl command.

The --deployment option, shorthand -d, lets you specify a deployment URL to request instead of using the production deployment.

terminal
vercel curl /api/hello --deployment https://my-app-abc123.vercel.app

Using the --deployment option to target a specific deployment.

The --protection-bypass option, shorthand -b, lets you provide your own deployment protection bypass secret instead of automatically generating one. This is useful when you already have a bypass secret configured.

terminal
vercel curl /api/hello --protection-bypass your-secret-here

Using the --protection-bypass option with a manual secret.

You can also use the VERCEL_AUTOMATION_BYPASS_SECRET environment variable:

terminal
export VERCEL_AUTOMATION_BYPASS_SECRET=your-secret-here
vercel curl /api/hello

Setting the bypass secret as an environment variable.

Make sure curl is installed on your system:

terminal
# macOS (using Homebrew)
brew install curl
 
# Ubuntu/Debian
sudo apt-get install curl
 
# Windows (using Chocolatey)
choco install curl

Installing curl on different operating systems.

Make sure you're in a directory with a linked Vercel project and that the project has at least one deployment:

terminal
# Link your project
vercel link
 
# Deploy your project
vercel deploy

Linking your project and creating a deployment.

If automatic token creation fails, you can create a bypass secret manually in the Vercel Dashboard:

  1. Go to your project's SettingsDeployment Protection
  2. Find "Protection Bypass for Automation"
  3. Click "Create" or "Generate" to create a new secret
  4. Copy the generated secret
  5. Use it with the --protection-bypass flag or VERCEL_AUTOMATION_BYPASS_SECRET environment variable

When using --deployment, verify that:

  • The deployment ID or URL is correct
  • The deployment belongs to your linked project
  • The deployment hasn't been deleted

The following global options can be passed when using the vercel curl command:

For more information on global options and their usage, refer to the options section.


Was this helpful?

supported.