> ## Documentation Index
> Fetch the complete documentation index at: https://docs.getbifrost.ai/llms.txt
> Use this file to discover all available pages before exploring further.

# Guardrails

> Enterprise-grade content safety and security validation with support for native regex and secrets detection, AWS Bedrock Guardrails, Azure Content Safety, GraySwan Cygnal, and Patronus AI.

## Overview

**Guardrails** in Bifrost provide enterprise-grade content safety, security validation, and policy enforcement for LLM requests and responses. The system validates inputs and outputs in real-time against your specified policies, ensuring responsible AI deployment with protection against harmful content, prompt injection, PII leakage, credential leakage, and policy violations.

<Frame>
  <img src="https://mintcdn.com/bifrost/ybRKIoKPYjpUizJp/media/guardrails/guardrails-overview.png?fit=max&auto=format&n=ybRKIoKPYjpUizJp&q=85&s=2ce9317a9410d77426bb8d56f09ee80d" alt="Guardrails overview showing rules and profiles management" width="3482" height="2106" data-path="media/guardrails/guardrails-overview.png" />
</Frame>

### Supported Providers

<CardGroup cols={2}>
  <Card title="Secrets Detection" icon="key" href="/enterprise/guardrails/secrets-detection">
    Built-in Gitleaks-backed detection for leaked API keys, tokens, private keys, and credentials.
  </Card>

  <Card title="Custom Regex" icon="code" href="/enterprise/guardrails/custom-regex">
    In-process regex guardrails, including the built-in PII Detection template.
  </Card>

  <Card title="AWS Bedrock Guardrails" icon="aws" href="/integrations/guardrails/aws-bedrock">
    Enterprise content filtering, PII detection, and prompt attack prevention.
  </Card>

  <Card title="Azure Content Safety" icon="microsoft" href="/integrations/guardrails/azure-content-safety">
    Multi-modal content moderation with severity-based filtering.
  </Card>

  <Card title="GraySwan Cygnal" icon="shield-check" href="/integrations/guardrails/grayswan">
    AI safety monitoring with natural language rule definitions.
  </Card>

  <Card title="Patronus AI" icon="brain" href="/integrations/guardrails/patronus-ai">
    LLM security, hallucination detection, and safety evaluation.
  </Card>
</CardGroup>

### Core Concepts

Bifrost Guardrails are built around two core concepts that work together to provide flexible and powerful content protection:

| Concept      | Description                                                                                                                                                                                                                                                    |
| ------------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| **Rules**    | Custom policies defined using CEL (Common Expression Language) that determine what content to validate and when. Rules can apply to inputs, outputs, or both, and can be linked to one or more profiles for evaluation.                                        |
| **Profiles** | Configurations for guardrail providers, including Bifrost-native providers (Custom Regex, Secrets Detection) and external providers (AWS Bedrock, Azure Content Safety, GraySwan, Patronus AI). Profiles are reusable and can be shared across multiple rules. |

**How They Work Together:**

* **Profiles** define *how* content is evaluated using native Bifrost checks or external provider capabilities
* **Rules** define *when* and *what* content gets evaluated using CEL expressions
* A single rule can use multiple profiles for layered protection
* Profiles can be reused across different rules for consistency

### Key Features

| Feature                    | Description                                                                                                                       |
| -------------------------- | --------------------------------------------------------------------------------------------------------------------------------- |
| **Multi-Provider Support** | Bifrost-native Custom Regex and Secrets Detection, plus AWS Bedrock, Azure Content Safety, GraySwan, and Patronus AI integrations |
| **Dual-Stage Validation**  | Guard both inputs (prompts) and outputs (responses)                                                                               |
| **Real-Time Processing**   | Synchronous and asynchronous validation modes                                                                                     |
| **CEL-Based Rules**        | Define custom policies using Common Expression Language                                                                           |
| **Reusable Profiles**      | Configure providers once, use across multiple rules                                                                               |
| **Sampling Control**       | Apply rules to a percentage of requests for performance tuning                                                                    |
| **Automatic Remediation**  | Block, redact, or modify content based on policy                                                                                  |
| **Comprehensive Logging**  | Detailed audit trails for compliance                                                                                              |

### Navigating Guardrails in the UI

Access Guardrails from the Bifrost dashboard:

| Page              | Path                       | Description                               |
| ----------------- | -------------------------- | ----------------------------------------- |
| **Configuration** | Guardrails > Configuration | Manage guardrail rules and their settings |
| **Providers**     | Guardrails > Providers     | Configure and manage guardrail profiles   |

### Architecture

The following diagram illustrates how Rules and Profiles work together to validate LLM requests:

```mermaid theme={null}
flowchart TB
    subgraph request_flow [Request Flow]
        Request[LLM Request] --> InputValidation[Input Validation]
        InputValidation --> LLMProvider[LLM Provider]
        LLMProvider --> OutputValidation[Output Validation]
        OutputValidation --> Response[Response]
    end

    subgraph rules [Guardrail Rules]
        Rule1[Rule: Block PII]
        Rule2[Rule: Content Filter]
        Rule3[Rule: Prompt Injection]
        Rule4[Rule: Credential Leakage]
    end

    subgraph profiles [Guardrail Profiles]
        Profile1[AWS Bedrock Profile]
        Profile2[Azure Content Safety Profile]
        Profile3[Patronus AI Profile]
        Profile4[GraySwan Profile]
        Profile5[Secrets Detection Profile]
        Profile6[Custom Regex Profile]
    end

    InputValidation --> Rule1
    InputValidation --> Rule3
    InputValidation --> Rule4
    OutputValidation --> Rule2

    Rule1 --> Profile6
    Rule2 --> Profile2
    Rule2 --> Profile3
    Rule3 --> Profile1
    Rule4 --> Profile5
```

**Flow Description:**

1. **Incoming Request** - LLM request arrives at Bifrost
2. **Input Validation** - Applicable rules evaluate the input using linked profiles
3. **LLM Processing** - If input passes, request is forwarded to the LLM provider
4. **Output Validation** - Response is evaluated by output rules using linked profiles
5. **Response** - Validated response is returned (or blocked/modified based on violations)

***

## Guardrail Rules

Guardrail Rules are custom policies that define when and how content validation occurs. Rules use CEL (Common Expression Language) expressions to evaluate requests and can be linked to one or more profiles for execution.

<Frame>
  <img src="https://mintcdn.com/bifrost/cukTMCqLBY9L8bCo/media/guardrails/query-creation.png?fit=max&auto=format&n=cukTMCqLBY9L8bCo&q=85&s=85f0b1e9ab067bb3e1269340f6010311" alt="Guardrail rules list showing configured rules with status and actions" width="3920" height="3142" data-path="media/guardrails/query-creation.png" />
</Frame>

### Rule Properties

| Property              | Type    | Required | Description                                 |
| --------------------- | ------- | -------- | ------------------------------------------- |
| `id`                  | integer | Yes      | Unique identifier for the rule              |
| `name`                | string  | Yes      | Descriptive name for the rule               |
| `description`         | string  | No       | Explanation of what the rule does           |
| `enabled`             | boolean | Yes      | Whether the rule is active                  |
| `cel_expression`      | string  | Yes      | CEL expression for rule evaluation          |
| `apply_to`            | enum    | Yes      | When to apply: `input`, `output`, or `both` |
| `sampling_rate`       | integer | No       | Percentage of requests to evaluate (0-100)  |
| `timeout`             | integer | No       | Execution timeout in milliseconds           |
| `provider_config_ids` | array   | No       | IDs of profiles to use for evaluation       |

### Creating Rules

<Tabs group="rules-config">
  <Tab title="Web UI">
    1. **Navigate to Rules**
       * Go to **Guardrails** > **Configuration**
       * Click **Add Rule**

    <Frame>
      <img src="https://mintcdn.com/bifrost/ybRKIoKPYjpUizJp/media/guardrails/cel-rule-builder.png?fit=max&auto=format&n=ybRKIoKPYjpUizJp&q=85&s=3165107aefebd8a18f9377e21172e2e3" alt="Guardrail rules list showing configured rules with status and actions" width="1888" height="1336" data-path="media/guardrails/cel-rule-builder.png" />
    </Frame>

    2. **Configure Rule Settings**

    **Basic Information:**

    * **Name**: Enter a descriptive name (e.g., "Block PII in Prompts")
    * **Description**: Explain the rule's purpose
    * **Enabled**: Toggle to activate the rule

    **Evaluation Settings:**

    * **Apply To**: Select when to apply the rule
      * `input` - Validate incoming prompts only
      * `output` - Validate LLM responses only
      * `both` - Validate both inputs and outputs
    * **CEL Expression**: Define the validation logic
    * **Sampling Rate**: Set percentage of requests to evaluate (default: 100%)
    * **Timeout**: Set maximum execution time in milliseconds

    3. **Link Profiles**
       * Select one or more profiles to use for evaluation
       * Rules will execute all linked profiles in sequence

    4. **Save and Test**
       * Click **Save Rule**
       * Use the **Test** button to validate with sample content
  </Tab>

  <Tab title="API">
    **Create a Guardrail Rule:**

    ```bash theme={null}
    curl -X POST http://localhost:8080/api/enterprise/guardrails/rules \
      -H "Content-Type: application/json" \
      -d '{
        "id": 1,
        "name": "Block PII in Prompts",
        "description": "Prevent PII from being sent to LLM providers",
        "enabled": true,
        "cel_expression": "request.messages.exists(m, m.role == \"user\")",
        "apply_to": "input",
        "sampling_rate": 100,
        "timeout": 5000,
        "provider_config_ids": [1, 2]
      }'
    ```

    **List All Rules:**

    ```bash theme={null}
    curl -X GET http://localhost:8080/api/enterprise/guardrails/rules \
      -H "Content-Type: application/json"

    # Response
    {
      "rules": [
        {
          "id": 1,
          "name": "Block PII in Prompts",
          "description": "Prevent PII from being sent to LLM providers",
          "enabled": true,
          "cel_expression": "request.messages.exists(m, m.role == \"user\")",
          "apply_to": "input",
          "sampling_rate": 100,
          "timeout": 5000,
          "provider_config_ids": [1, 2]
        }
      ]
    }
    ```

    **Update a Rule:**

    ```bash theme={null}
    curl -X PUT http://localhost:8080/api/enterprise/guardrails/rules/1 \
      -H "Content-Type: application/json" \
      -d '{
        "enabled": false,
        "sampling_rate": 50
      }'
    ```

    **Delete a Rule:**

    ```bash theme={null}
    curl -X DELETE http://localhost:8080/api/enterprise/guardrails/rules/1
    ```
  </Tab>

  <Tab title="config.json">
    ```json theme={null}
    {
      "guardrails_config": {
        "guardrail_rules": [
          {
            "id": 1,
            "name": "Block PII in Prompts",
            "description": "Prevent PII from being sent to LLM providers",
            "enabled": true,
            "cel_expression": "request.messages.exists(m, m.role == \"user\")",
            "apply_to": "input",
            "sampling_rate": 100,
            "timeout": 5000,
            "provider_config_ids": [1, 2]
          },
          {
            "id": 2,
            "name": "Content Filter for Responses",
            "description": "Filter harmful content from LLM responses",
            "enabled": true,
            "cel_expression": "true",
            "apply_to": "output",
            "sampling_rate": 100,
            "timeout": 3000,
            "provider_config_ids": [2]
          },
          {
            "id": 3,
            "name": "Prompt Injection Detection",
            "description": "Detect and block prompt injection attempts",
            "enabled": true,
            "cel_expression": "request.messages.size() > 0",
            "apply_to": "input",
            "sampling_rate": 100,
            "timeout": 2000,
            "provider_config_ids": [1]
          }
        ]
      }
    }
    ```
  </Tab>

  <Tab title="Helm">
    ```yaml theme={null}
    guardrails_config:
      guardrail_rules:
        - id: 1
          name: "Block PII in Prompts"
          description: "Prevent PII from being sent to LLM providers"
          enabled: true
          cel_expression: "request.messages.exists(m, m.role == 'user')"
          apply_to: "input"
          sampling_rate: 100
          timeout: 5000
          provider_config_ids: [1, 2]
        - id: 2
          name: "Content Filter for Responses"
          description: "Filter harmful content from LLM responses"
          enabled: true
          cel_expression: "true"
          apply_to: "output"
          sampling_rate: 100
          timeout: 3000
          provider_config_ids: [2]
    ```
  </Tab>
</Tabs>

### CEL Expression Examples

CEL (Common Expression Language) provides a powerful way to define rule conditions. Here are common patterns:

**Always Apply Rule:**

```cel theme={null}
true
```

**Apply to User Messages Only:**

```cel theme={null}
request.messages.exists(m, m.role == "user")
```

**Apply to Messages Containing Keywords:**

```cel theme={null}
request.messages.exists(m, m.content.contains("confidential"))
```

**Apply Based on Model:**

```cel theme={null}
request.model.startsWith("gpt-4")
```

**Apply to Long Prompts:**

```cel theme={null}
request.messages.filter(m, m.role == "user").map(m, m.content.size()).sum() > 1000
```

**Combine Multiple Conditions:**

```cel theme={null}
request.model.startsWith("gpt-4") && request.messages.exists(m, m.role == "user" && m.content.size() > 500)
```

### Linking Rules to Profiles

Rules can be linked to multiple profiles for comprehensive validation:

<Frame>
  <img src="https://mintcdn.com/bifrost/cukTMCqLBY9L8bCo/media/guardrails/query-creation.png?fit=max&auto=format&n=cukTMCqLBY9L8bCo&q=85&s=85f0b1e9ab067bb3e1269340f6010311" alt="Rule configuration showing linked profiles" width="3920" height="3142" data-path="media/guardrails/query-creation.png" />
</Frame>

**Best Practices:**

* Link credential-leakage rules to [Secrets Detection](/enterprise/guardrails/secrets-detection)
* Link PII detection rules to profiles with PII capabilities (Custom Regex PII template, Bedrock, Patronus)
* Link content filtering rules to profiles with content safety features (Azure, Bedrock, GraySwan)
* Use GraySwan for custom natural language rules when you need flexible, readable policies
* Use multiple profiles for defense-in-depth (e.g., Bedrock + Patronus for PII, Azure + GraySwan for content)
* Set appropriate timeouts when using multiple profiles

***

## Managing Profiles

Profiles are reusable configurations for guardrail providers. External providers include credentials, endpoints, and detection thresholds. Bifrost-native providers such as Custom Regex and Secrets Detection run locally and do not require external service credentials.

<Frame>
  <img src="https://mintcdn.com/bifrost/ybRKIoKPYjpUizJp/media/guardrails/provider-aws-create.png?fit=max&auto=format&n=ybRKIoKPYjpUizJp&q=85&s=d0f044360dead9bd23408f1a18b1bda0" alt="Guardrail profiles list showing configured providers" width="3500" height="2122" data-path="media/guardrails/provider-aws-create.png" />
</Frame>

### Profile Properties

| Property        | Type    | Required | Description                                                                      |
| --------------- | ------- | -------- | -------------------------------------------------------------------------------- |
| `id`            | integer | Yes      | Unique identifier for the profile                                                |
| `provider_name` | string  | Yes      | Provider type: `regex`, `secrets`, `bedrock`, `azure`, `grayswan`, `patronus-ai` |
| `policy_name`   | string  | Yes      | Descriptive name for the policy                                                  |
| `enabled`       | boolean | Yes      | Whether the profile is active                                                    |
| `config`        | object  | No       | Provider-specific configuration                                                  |

### Creating Profiles

<Tabs group="profiles-config">
  <Tab title="Web UI">
    1. **Navigate to Providers**
       * Go to **Guardrails** > **Providers**
       * Click **Add Profile**

    <Frame>
      <img src="https://mintcdn.com/bifrost/ybRKIoKPYjpUizJp/media/guardrails/guardrails-rule-list-2.png?fit=max&auto=format&n=ybRKIoKPYjpUizJp&q=85&s=33e21785e47b9a8c1a1222843cee59f5" alt="Create guardrail profile form" width="3492" height="2100" data-path="media/guardrails/guardrails-rule-list-2.png" />
    </Frame>

    2. **Select Provider Type**
       * Choose from: Secrets Detection, Custom Regex, AWS Bedrock, Azure Content Safety, GraySwan, or Patronus AI

    3. **Configure Provider Settings**
       * Enter credentials and endpoint information for external providers, or local settings for native providers
       * Configure detection thresholds and actions
       * See provider-specific setup sections above for detailed configuration

    4. **Save Profile**
       * Click **Save Profile**
       * The profile is now available for linking to rules
  </Tab>

  <Tab title="API">
    **Create a Profile:**

    ```bash theme={null}
    curl -X POST http://localhost:8080/api/enterprise/guardrails/providers \
      -H "Content-Type: application/json" \
      -d '{
        "id": 1,
        "provider_name": "bedrock",
        "policy_name": "PII Detection Profile",
        "enabled": true,
        "config": {
          "access_key": "env.AWS_ACCESS_KEY_ID",
          "secret_key": "env.AWS_SECRET_ACCESS_KEY",
          "guardrail_arn": "arn:aws:bedrock:us-east-1:123456789:guardrail/abc123",
          "guardrail_version": "1",
          "region": "us-east-1"
        }
      }'
    ```

    **List All Profiles:**

    ```bash theme={null}
    curl -X GET http://localhost:8080/api/enterprise/guardrails/providers \
      -H "Content-Type: application/json"

    # Response
    {
      "providers": [
        {
          "id": 1,
          "provider_name": "bedrock",
          "policy_name": "PII Detection Profile",
          "enabled": true
        },
        {
          "id": 2,
          "provider_name": "azure",
          "policy_name": "Content Safety Profile",
          "enabled": true
        }
      ]
    }
    ```

    **Update a Profile:**

    ```bash theme={null}
    curl -X PUT http://localhost:8080/api/enterprise/guardrails/providers/1 \
      -H "Content-Type: application/json" \
      -d '{
        "enabled": false
      }'
    ```

    **Delete a Profile:**

    ```bash theme={null}
    curl -X DELETE http://localhost:8080/api/enterprise/guardrails/providers/1
    ```
  </Tab>

  <Tab title="config.json">
    ```json theme={null}
    {
      "guardrails_config": {
        "guardrail_providers": [
            {
              "id": 1,
              "provider_name": "secrets",
              "policy_name": "Block Leaked Credentials",
              "enabled": true,
              "config": {
                "ignored_secret_keywords": ["example", "dummy"]
              }
            },
            {
              "id": 2,
              "provider_name": "regex",
              "policy_name": "PII Detection",
              "enabled": true,
              "config": {
                "patterns": [
                  { "pattern": "\\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,}\\b", "description": "Email address", "flags": "i" },
                  { "pattern": "\\b\\d{3}-\\d{2}-\\d{4}\\b", "description": "US Social Security Number" }
                ]
              }
            },
            {
              "id": 3,
              "provider_name": "bedrock",
              "policy_name": "PII Detection Profile",
              "enabled": true,
              "config": {
                "access_key": "env.AWS_ACCESS_KEY_ID",
                "secret_key": "env.AWS_SECRET_ACCESS_KEY",
                "guardrail_arn": "arn:aws:bedrock:us-east-1:123456789:guardrail/abc123",
                "guardrail_version": "1",
                "region": "us-east-1"
              }
            },
            {
              "id": 4,
              "provider_name": "azure",
              "policy_name": "Content Safety Profile",
              "enabled": true,
              "config": {
                "endpoint": "https://your-resource.cognitiveservices.azure.com/",
                "api_key": "env.AZURE_CONTENT_SAFETY_API_KEY",
                "analyze_enabled": true,
                "analyze_severity_threshold": "medium",
                "jailbreak_shield_enabled": true,
                "indirect_attack_shield_enabled": true
              }
            },
            {
              "id": 5,
              "provider_name": "grayswan",
              "policy_name": "Custom Safety Rules",
              "enabled": true,
              "config": {
                "api_key": "env.GRAYSWAN_API_KEY",
                "violation_threshold": 0.5,
                "reasoning_mode": "hybrid",
                "rules": {
                  "no_pii": "Do not allow personally identifiable information",
                  "professional_tone": "Ensure responses maintain a professional tone"
                }
              }
            },
            {
              "id": 6,
              "provider_name": "patronus-ai",
              "policy_name": "Hallucination Detection",
              "enabled": true,
              "config": {
                "api_key": "env.PATRONUS_API_KEY",
                "api_endpoint": "https://api.patronus.ai/v1"
              }
            }
          ]
        }
      }
    ```
  </Tab>

  <Tab title="Helm">
    ```yaml theme={null}
    guardrails_config:
      guardrail_providers:
        - id: 1
          provider_name: "secrets"
          policy_name: "Block Leaked Credentials"
          enabled: true
          config:
            ignored_secret_keywords:
              - "example"
              - "dummy"
        - id: 2
          provider_name: "regex"
          policy_name: "PII Detection"
          enabled: true
          config:
            patterns:
              - pattern: "\\b[A-Z0-9._%+-]+@[A-Z0-9.-]+\\.[A-Z]{2,}\\b"
                description: "Email address"
                flags: "i"
              - pattern: "\\b\\d{3}-\\d{2}-\\d{4}\\b"
                description: "US Social Security Number"
        - id: 3
          provider_name: "bedrock"
          policy_name: "PII Detection Profile"
          enabled: true
          config:
            guardrail_arn: "arn:aws:bedrock:us-east-1:123456789:guardrail/abc123"
            guardrail_version: "1"
            region: "us-east-1"
            # AWS Authentication (choose one method):
            # Option 1: Explicit credentials
            access_key: "env.AWS_ACCESS_KEY_ID"
            secret_key: "env.AWS_SECRET_ACCESS_KEY"
            # Option 2: IAM Role - omit access_key and secret_key
            # (Bifrost will use IAM credentials from the environment)
        - id: 4
          provider_name: "azure"
          policy_name: "Content Safety Profile"
          enabled: true
          config:
            endpoint: "https://your-resource.cognitiveservices.azure.com/"
            api_key: "env.AZURE_CONTENT_SAFETY_API_KEY"
            analyze_enabled: true
            analyze_severity_threshold: "medium"
            jailbreak_shield_enabled: true
        - id: 5
          provider_name: "grayswan"
          policy_name: "Custom Safety Rules"
          enabled: true
          config:
            api_key: "env.GRAYSWAN_API_KEY"
            violation_threshold: 0.5
            reasoning_mode: "hybrid"
            rules:
              no_pii: "Do not allow personally identifiable information"
              professional_tone: "Ensure responses maintain a professional tone"
        - id: 6
          provider_name: "patronus-ai"
          policy_name: "Hallucination Detection"
          enabled: true
          config:
            api_endpoint: "https://api.patronus.ai/v1"
    ```
  </Tab>
</Tabs>

### Provider Capabilities

Third-party guardrail providers offer different capabilities. Bifrost-native providers are documented separately: [Secrets Detection](/enterprise/guardrails/secrets-detection) covers credential leakage, and [Custom Regex](/enterprise/guardrails/custom-regex) covers deterministic pattern checks, including the PII Detection template.

| Capability                    | AWS Bedrock | Azure Content Safety | GraySwan | Patronus AI |
| ----------------------------- | ----------- | -------------------- | -------- | ----------- |
| PII Detection                 | Yes         | No                   | No       | Yes         |
| Content Filtering             | Yes         | Yes                  | Yes      | Yes         |
| Prompt Injection              | Yes         | Yes                  | Yes      | Yes         |
| Hallucination Detection       | No          | No                   | No       | Yes         |
| Toxicity Screening            | Yes         | Yes                  | Yes      | Yes         |
| Custom Policies               | Yes         | Yes                  | Yes      | Yes         |
| Custom Natural Language Rules | No          | No                   | Yes      | No          |
| Image Support                 | Yes         | No                   | No       | No          |
| IPI Detection                 | No          | Yes                  | Yes      | No          |
| Mutation Detection            | No          | No                   | Yes      | No          |

### Best Practices

**Profile Organization:**

* Create separate profiles for different use cases (PII, content filtering, etc.)
* Use descriptive policy names that indicate the profile's purpose
* Keep credentials secure using environment variables

**Performance Considerations:**

* Enable only the profiles you need to minimize latency
* Use sampling rates on rules for high-traffic endpoints
* Set appropriate timeouts to prevent slow requests

**Security:**

* Store API keys and credentials in environment variables or secrets managers
* Regularly rotate credentials
* Use least-privilege IAM roles for AWS Bedrock

***

## Using Guardrails in Requests

### Attaching Guardrails to API Calls

Once configured, attach guardrails to your LLM requests using custom headers:

**Single Guardrail:**

```bash theme={null}
curl -X POST http://localhost:8080/v1/chat/completions \
  -H "Content-Type: application/json" \
  -H "x-bf-guardrail-id: bedrock-prod-guardrail" \
  -d '{
    "model": "gpt-4o-mini",
    "messages": [
      {
        "role": "user",
        "content": "Help me with this task"
      }
    ]
  }'
```

**Multiple Guardrails (Sequential):**

```bash theme={null}
curl -X POST http://localhost:8080/v1/chat/completions \
  -H "Content-Type: application/json" \
  -H "x-bf-guardrail-ids: bedrock-prod-guardrail,azure-content-safety-001" \
  -d '{
    "model": "gpt-4o-mini",
    "messages": [
      {
        "role": "user",
        "content": "Help me with this task"
      }
    ]
  }'
```

**Guardrail Configuration in Request:**

```bash theme={null}
curl -X POST http://localhost:8080/v1/chat/completions \
  -H "Content-Type: application/json" \
  -d '{
    "model": "gpt-4o-mini",
    "messages": [
      {
        "role": "user",
        "content": "Help me with this task"
      }
    ],
    "bifrost_config": {
      "guardrails": {
        "input": ["bedrock-prod-guardrail"],
        "output": ["patronus-ai-001"],
        "async": false
      }
    }
  }'
```

### Guardrail Response Handling

**Successful Validation (200):**

```json theme={null}
{
  "id": "chatcmpl-abc123",
  "object": "chat.completion",
  "created": 1699564800,
  "model": "gpt-4o-mini",
  "choices": [
    {
      "index": 0,
      "message": {
        "role": "assistant",
        "content": "I'd be happy to help you with your task..."
      },
      "finish_reason": "stop"
    }
  ],
  "extra_fields": {
    "guardrails": {
      "input_validation": {
        "guardrail_id": "bedrock-prod-guardrail",
        "status": "passed",
        "violations": [],
        "processing_time_ms": 245
      },
      "output_validation": {
        "guardrail_id": "patronus-ai-001",
        "status": "passed",
        "violations": [],
        "processing_time_ms": 312
      }
    }
  }
}
```

**Validation Failure - Blocked (446):**

```json theme={null}
{
  "error": {
    "message": "Request blocked by guardrails",
    "type": "guardrail_violation",
    "code": 446,
    "details": {
      "guardrail_id": "bedrock-prod-guardrail",
      "validation_stage": "input",
      "violations": [
        {
          "type": "PII",
          "category": "SSN",
          "severity": "HIGH",
          "action": "block",
          "text_excerpt": "My SSN is ***-**-****"
        },
        {
          "type": "prompt_injection",
          "severity": "CRITICAL",
          "action": "block",
          "confidence": 0.95
        }
      ],
      "processing_time_ms": 198
    }
  }
}
```

**Validation Warning - Logged (246):**

```json theme={null}
{
  "id": "chatcmpl-def456",
  "object": "chat.completion",
  "created": 1699564800,
  "model": "gpt-4o-mini",
  "choices": [
    {
      "index": 0,
      "message": {
        "role": "assistant",
        "content": "Response with redacted content..."
      },
      "finish_reason": "stop"
    }
  ],
  "bifrost_metadata": {
    "guardrails": {
      "output_validation": {
        "guardrail_id": "azure-content-safety-001",
        "status": "warning",
        "violations": [
          {
            "type": "profanity",
            "severity": "LOW",
            "action": "redact",
            "modifications": 2
          }
        ],
        "processing_time_ms": 187
      }
    }
  }
}
```
