Skip to content
Menu

vercel curl

Last updated May 28, 2026

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. Use the -- separator to pass flags through to the underlying curl:

terminal
vercel curl /api/users -- --request POST --header "Content-Type: application/json" --data '{"name":"John"}'

Making a POST request with JSON data to create a new user. The -- separator passes everything after it to curl.

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 by passing curl's -v flag after --:

terminal
vercel curl /api/data -- -v

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

Capture a session trace for the request and print the trace request ID:

terminal
vercel curl --trace /api/hello

Using the --trace option to capture a request trace.

After the request completes, the command prints a vercel traces get command you can run to inspect the trace. See vercel traces for 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. To pass flags through to the underlying curl command, place them after the -- separator.

The --deployment option lets you specify a deployment ID or 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 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.

The --yes option, shorthand -y, skips the confirmation prompt when linking is required. Use it in non-interactive environments like CI, or run vercel link ahead of time to link your project and avoid the prompt entirely.

terminal
vercel curl /api/hello --yes

Skipping the link confirmation prompt with --yes.

The --trace option captures a request trace for the request and prints the trace request ID once the response completes. When targeting a production deployment, the command prompts for confirmation unless --yes is set.

terminal
vercel curl --trace /api/hello

Using the --trace option to capture a request trace.

The --json option only applies with --trace. Instead of streaming the response body to stdout, the command captures it and emits a JSON envelope with the response body and request ID:

terminal
vercel curl --trace --json /api/hello
stdout
{
  "response": "...",
  "requestId": "abc-123"
}

Using the --json option with --trace to emit a JSON envelope.

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.