Headers
Header requirements and options for the Portkey API
Portkey API accepts 4 kinds of headers for your requests:
Portkey Authentication Header | Required | For Portkey auth |
Provider Authentication Headers OR Cloud-Specific Headers | Required | For provider auth |
Additional Portkey Headers | Optional | To pass config , metadata , trace id , cache refresh etc. |
Custom Headers | Optional | To forward any other headers directly |
Portkey Authentication
Portkey API Key
Authenticate your requests with your Portkey API key. Obtain API key from the Portkey dashboard.
Environment variable: PORTKEY_API_KEY
Provider Authentication
In addition to the Portkey API key, you must provide information about the AI provider you’re using. There are 4 ways to do this:
1. Provider Slug + Auth
Useful if you do not want to save your API keys to Portkey vault and make direct requests.
Specifies the provider you’re using (e.g., openai
, anthropic
, vertex-ai
).
List of Portkey supported providers here.
Pass the auth details for the specified provider as a "Bearer $TOKEN"
.
If your provider expects their auth with headers such as x-api-key
or api-key
, you can pass the token with the Authorization
header directly and Portkey will convert it into the provider-specific format.
2. Virtual Key
Save your provider auth on Portkey and use a virtual key to directly make a call. Docs)
3. Config
Pass your Portkey config with this header. Accepts a JSON object
or a config ID
that can also contain gateway configuration settings, and provider details.
- Configs can be saved in the Portkey UI and referenced by their ID (Docs)
- Configs also enable other optional features like Caching, Load Balancing, Fallback, Retries, and Timeouts.
4. Custom Host
Specifies the base URL where you want to send your request
Target provider that’s availabe on your base URL. If you are unsure of which target provider to set, you can set openai
.
Pass the auth details for the specified provider as a "Bearer $TOKEN"
.
If your provider expects their auth with headers such as x-api-key
or api-key
, you can pass the token with the Authorization
header directly and Portkey will convert it into the provider-specific format.
Additional Portkey Headers
There are additional optional Portkey headers that enable various features and enhancements:
Trace ID
An ID you can pass to refer to one or more requests later on. If not provided, Portkey generates a trace ID automatically for each request. (Docs)
Metadata
Allows you to attach custom metadata to your requests, which can be filtered later in the analytics and log dashboards.
You can include the special metadata type _user
to associate requests with specific users. (Docs)
Cache Force Refresh
Forces a cache refresh for your request by making a new API call and storing the updated value.
Expects true
or false
See the caching documentation for more information. (Docs)
Cache Namespace
Partition your cache store based on custom strings, ignoring metadata and other headers.
Request Timeout
Set timeout after which a request automatically terminates. The time is set in milliseconds.
Custom Headers
You can pass any other headers your API expects by directly forwarding them without any processing by Portkey.
This is especially useful if you want to pass send sensitive headers.
Forward Headers
Pass all the headers you want to forward directly in this array. (Docs)
Cloud-Specific Headers (Azure
, Google
, AWS
)
Pass more configuration headers for Azure OpenAI
, Google Vertex AI
, or AWS Bedrock
Azure
x-portkey-azure-resource-name
,x-portkey-azure-deployment-id
,x-portkey-azure-api-version
,Authorization
,x-portkey-azure-model-name
Google Vertex AI
x-portkey-vertex-project-id
,x-portkey-vertex-region
,X-Vertex-AI-LLM-Request-Type
AWS Bedrock
x-portkey-aws-session-token
,x-portkey-aws-secret-access-key
,x-portkey-aws-region
,x-portkey-aws-session-token
List of All Headers
For a comprehensive list of all available parameters and their detailed descriptions, please refer to the Portkey SDK Client documentation.
SDK
Using Headers in SDKs
You can send these headers through REST API calls as well as by using the OpenAI or Portkey SDKs. With the Portkey SDK, Other than cacheForceRefresh
, traceID
, and metadata
, rest of the headers are passed while instantiating the Portkey client.
Was this page helpful?