Portkey’s webhook guardrails allow you to integrate your existing guardrail infrastructure with our AI Gateway. This is perfect for teams that have already built custom guardrail pipelines (like PII redaction, sensitive content filtering, or data validation) and want to: 
Enforce guardrails directly within the AI request flow 
Make existing guardrail systems production-ready 
Modify AI requests and responses in real-time 
 
How It Works  
You add a Webhook as a Guardrail Check in Portkey 
When a request passes through Portkey’s Gateway:
Portkey sends relevant data to your webhook endpoint 
Your webhook evaluates the request/response and returns a verdict 
Based on your webhook’s response, Portkey either allows the request to proceed, modifies it if required, or applies your configured guardrail actions 
 
 
 
Setting Up a Webhook Guardrail  
In the Guardrail configuration UI, you’ll need to provide: 
Field Description Type Webhook URL Your webhook’s endpoint URL stringHeaders Headers to include with webhook requests JSONTimeout Maximum wait time for webhook response number (ms)
 
Webhook URL  
This should be a publicly accessible URL where your webhook is hosted. 
Enterprise Feature : Portkey Enterprise customers can configure secure access to webhooks within private networks.
 
Specify headers as a JSON object: 
{  
  "Authorization" :  "Bearer YOUR_API_KEY" ,  
  "Content-Type" :  "application/json"  
}  
 
Timeout  
The maximum time Portkey will wait for your webhook to respond before proceeding with a default verdict: true. 
Default: 3000ms (3 seconds) 
If your webhook processing is time-intensive, consider increasing this value 
 
Webhook Request Structure  
Your webhook should accept POST requests with the following structure: 
Header Description Content-TypeAlways set to application/json Custom Headers Any headers you configured in the Portkey UI 
 
Request Body  
Portkey sends comprehensive information about the AI request to your webhook: 
Show Webhook Request Structure
Information about the user’s request to the LLM OpenAI compliant request body json.
Last message/prompt content from the overall request body.
Whether the request uses streaming
Information about the LLM’s response (empty for beforeRequestHook) OpenAI compliant response body json.
Last message/prompt content from the overall response body.
HTTP status code from LLM provider
Portkey provider slug. Example: openai, azure-openai, etc.
Type of request: chatComplete, complete, or embed
Custom metadata passed with the request. Can come from: 1) the x-portkey-metadata header, 2) default API key settings, or 3) workspace defaults.
When the hook is triggered: beforeRequestHook or afterRequestHook
 
Event Types  
Your webhook can be triggered at two points: 
beforeRequestHook : Before the request is sent to the LLM provider 
afterRequestHook : After receiving a response from the LLM provider 
 
beforeRequestHook Example
afterRequestHook Example
 {  
    "request" : {  
        "json" : {  
            "stream" :  false ,  
            "messages" : [  
                {  
                    "role" :  "system" ,  
                    "content" :  "You are a helpful assistant"  
                },  
                {  
                    "role" :  "user" ,  
                    "content" :  "Say Hi"  
                }  
            ],  
            "max_tokens" :  20 ,  
            "n" :  1 ,  
            "model" :  "gpt-4o-mini"  
        },  
        "text" :  "Say Hi" ,  
        "isStreamingRequest" :  false ,  
        "isTransformed" :  false  
    },  
    "response" : {  
        "json" : {},  
        "text" :  "" ,  
        "statusCode" :  null ,  
        "isTransformed" :  false  
    },  
    "provider" :  "openai" ,  
    "requestType" :  "chatComplete" ,  
    "metadata" : {  
        "_user" :  "visarg123"  
    },  
    "eventType" :  "beforeRequestHook"  
}  
 See all 35 lines
 
Webhook Response Structure  
Your webhook must return a response that follows this structure: 
Response Body  
Show Webhook Response Schema
Whether the request/response passes your guardrail check: 
true: No violations detected 
false: Violations detected 
 Optional field to modify the request or response Modified request data (only for beforeRequestHook)
If this field is found in the Webhook response, Portkey will fully override the existing request body with the returned data. 
Modified response data (only for afterRequestHook)
If this field is found in the Webhook response, Portkey will fully override the existing response body with the returned data. 
 
Webhook Capabilities  
Your webhook can perform three main actions: 
Simple Validation  
Return a verdict without modifying the request/response: 
{  
  "verdict" :  true   // or false if the request violates your guardrails  
}  
 
Modify the user’s request before it reaches the LLM provider: 
{  
  "verdict" :  true ,  
  "transformedData" : {  
    "request" : {  
      "json" : {  
        "messages" : [  
          {  
            "role" :  "system" ,  
            "content" :  "You are a helpful assistant. Do not provide harmful content."  
          },  
          {  
            "role" :  "user" ,  
            "content" :  "Original user message"  
          }  
        ],  
        "max_tokens" :  100 ,  
        "model" :  "gpt-4o"  
      }  
    }  
  }  
}  
 
Modify the LLM’s response before it reaches the user: 
{  
  "verdict" :  true ,  
  "transformedData" : {  
    "response" : {  
      "json" : {  
        "id" :  "chatcmpl-123" ,  
        "object" :  "chat.completion" ,  
        "created" :  1741592832 ,  
        "model" :  "gpt-4o-mini" ,  
        "choices" : [  
          {  
            "index" :  0 ,  
            "message" : {  
              "role" :  "assistant" ,  
              "content" :  "I've filtered this response to comply with our content policies."  
            },  
            "finish_reason" :  "stop"  
          }  
        ],  
        "usage" : {  
          "prompt_tokens" :  23 ,  
          "completion_tokens" :  12 ,  
          "total_tokens" :  35  
        }  
      },  
      "text" :  "I've filtered this response to comply with our content policies."  
    }  
  }  
}  
 
You can include additional context with each request using Portkey’s metadata feature: 
// In your API request to Portkey  
"x-portkey-metadata" : { "user" :  "john" ,  "context" :  "customer_support" }  
 
This metadata will be forwarded to your webhook in the metadata field. Learn more about metadata . 
Important Implementation Notes  
Complete Transformations : When using transformedData, include all fields in your transformed object, not just the changed portions. 
 
Independent Verdict and Transformation : The verdict and any transformations are independent. You can return verdict: false while still returning transformations. 
 
Default Behavior : If your webhook fails to respond within the timeout period, Portkey will default to verdict: true. 
 
Event Type Awareness : When implementing transformations, ensure your webhook checks the eventType field to determine whether it’s being called before or after the LLM request. 
 
 
Example Implementation  
Check out our Guardrail Webhook implementation on GitHub: 
Guardrail Webhook Implementation 
 
Get Help  
Building custom webhooks? Join the Portkey Discord community  for support and to share your implementation experiences!