> ## 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.

# Edit an image

> Edits an image using a text prompt and optional mask. Request must be sent as multipart/form-data
with at least `model`, `prompt` (unless `type` is `background_removal`), and `image` (or `image[]`).




## OpenAPI

````yaml /openapi/openapi.json post /v1/images/edits
openapi: 3.1.0
info:
  title: Bifrost API
  description: >
    Bifrost HTTP Transport API for AI model inference and gateway management.


    This API provides a unified interface for interacting with multiple AI
    providers

    including OpenAI, Anthropic, Bedrock, Gemini, and more through a single API,

    along with comprehensive management APIs for configuring and monitoring the
    gateway.


    ## API Structure


    ### Unified Inference API (`/v1/*`)

    The primary API using Bifrost's unified format. Model parameters use the
    format

    `provider/model` (e.g., `openai/gpt-4`, `anthropic/claude-3-opus`).


    ### Async Inference API (`/v1/async/*`)

    Submit inference requests for asynchronous execution. Returns a job ID
    immediately

    and allows polling for results. Supports all inference types except batches,
    files,

    and containers.


    ### Provider Integration APIs

    Native provider-format APIs for drop-in compatibility:

    - `/openai/*` - OpenAI-compatible API

    - `/anthropic/*` - Anthropic-compatible API

    - `/genai/*` - Google GenAI (Gemini) compatible API

    - `/bedrock/*` - AWS Bedrock compatible API

    - `/cohere/*` - Cohere compatible API


    ### Framework Integration APIs

    Multi-provider proxy endpoints for AI frameworks:

    - `/litellm/*` - LiteLLM proxy with all provider formats

    - `/langchain/*` - LangChain compatible endpoints

    - `/pydanticai/*` - PydanticAI compatible endpoints


    ### Management APIs (`/api/*`)

    APIs for managing and monitoring the Bifrost gateway:

    - `/api/config` - Configuration management

    - `/api/providers` - Provider and API key management

    - `/api/plugins` - Plugin management

    - `/api/governance/*` - Virtual keys, teams, customers, budgets, rate
    limits, routing rules, and pricing overrides

    - `/api/logs` - Log search and analytics

    - `/api/mcp/*` - MCP (Model Context Protocol) client management

    - `/api/session/*` - Authentication and session management

    - `/api/cache/*` - Cache management

    - `/health` - Health check endpoint


    ## Fallbacks

    Requests can include fallback models that will be tried if the primary model
    fails.
  version: 1.0.0
  contact:
    name: Contact Us
    url: https://getmaxim.ai/bifrost
  license:
    name: Apache 2.0
    url: https://opensource.org/licenses/Apache-2.0
servers:
  - url: '{baseUrl}'
    description: Your Bifrost instance
    variables:
      baseUrl:
        default: http://localhost:8080
        description: Base URL of your Bifrost instance (e.g. https://bifrost.mycompany.com)
security:
  - BearerAuth: []
  - BasicAuth: []
  - ApiKeyAuth: []
tags:
  - name: Models
    description: Model listing and information
  - name: Chat Completions
    description: Chat-based text generation
  - name: Text Completions
    description: Text completion generation
  - name: Responses
    description: OpenAI Responses API compatible endpoints
  - name: OCR
    description: Optical character recognition for documents and images
  - name: Rerank
    description: Document reranking by relevance to a query
  - name: Embeddings
    description: Text embedding generation
  - name: Images
    description: Image generations, editing, and variations
  - name: Videos
    description: Video generation and management
  - name: Audio
    description: Speech synthesis and transcription
  - name: Count Tokens
    description: Token counting utilities
  - name: Batch
    description: Batch processing operations
  - name: Files
    description: File management operations
  - name: Containers
    description: Container management operations
  - name: Async Jobs
    description: Asynchronous job submission and retrieval endpoints
  - name: Realtime
    description: Realtime WebSocket and WebRTC endpoints
  - name: OpenAI Integration
    description: OpenAI-compatible API endpoints (/openai/*)
  - name: Azure Integration
    description: Azure OpenAI integration endpoints
  - name: Anthropic Integration
    description: Anthropic-compatible API endpoints (/anthropic/*)
  - name: GenAI Integration
    description: Google GenAI (Gemini) compatible API endpoints (/genai/*)
  - name: Bedrock Integration
    description: AWS Bedrock compatible API endpoints (/bedrock/*)
  - name: Cohere Integration
    description: Cohere compatible API endpoints (/cohere/*)
  - name: LiteLLM Integration
    description: LiteLLM proxy endpoints with multi-provider support (/litellm/*)
  - name: LangChain Integration
    description: LangChain compatible endpoints with multi-provider support (/langchain/*)
  - name: PydanticAI Integration
    description: >-
      PydanticAI compatible endpoints with multi-provider support
      (/pydanticai/*)
  - name: Health
    description: Health check endpoints
  - name: Configuration
    description: Configuration management endpoints
  - name: Session
    description: Session and authentication endpoints
  - name: Providers
    description: Provider management endpoints
  - name: Plugins
    description: Plugin management endpoints
  - name: MCP
    description: Model Context Protocol endpoints
  - name: Governance
    description: Virtual keys, teams, and customers management
  - name: Logging
    description: Log search and management endpoints
  - name: Cache
    description: Cache management endpoints
paths:
  /v1/images/edits:
    post:
      tags:
        - Images
      summary: Edit an image
      description: >
        Edits an image using a text prompt and optional mask. Request must be
        sent as multipart/form-data

        with at least `model`, `prompt` (unless `type` is `background_removal`),
        and `image` (or `image[]`).
      operationId: imageEdit
      requestBody:
        required: true
        content:
          multipart/form-data:
            schema:
              type: object
              required:
                - model
                - image
              properties:
                model:
                  type: string
                  description: Model identifier in format `provider/model`
                prompt:
                  type: string
                  description: >
                    Text prompt describing the edit. Required unless `type` is
                    `background_removal`.
                image:
                  type: string
                  format: binary
                  description: >
                    Image file to edit. Use field name `image` for a single file
                    or `image[]` for multiple files.
                mask:
                  type: string
                  format: binary
                  description: >-
                    Optional mask image for inpainting (transparent areas
                    indicate regions to edit)
                type:
                  type: string
                  enum:
                    - inpainting
                    - outpainting
                    - background_removal
                  description: Type of edit operation
                'n':
                  type: integer
                  minimum: 1
                  maximum: 10
                  description: Number of images to generate
                size:
                  type: string
                  enum:
                    - 256x256
                    - 512x512
                    - 1024x1024
                    - 1536x1024
                    - 1024x1536
                    - auto
                  description: Size of the output image
                response_format:
                  type: string
                  enum:
                    - url
                    - b64_json
                  default: url
                  description: Format of the response
                stream:
                  type: boolean
                  default: false
                  description: When true, stream the response via Server-Sent Events
                background:
                  type: string
                  enum:
                    - transparent
                    - opaque
                    - auto
                  description: Background type for the image
                input_fidelity:
                  type: string
                  enum:
                    - low
                    - high
                  description: How closely to follow the original image
                partial_images:
                  type: integer
                  minimum: 0
                  maximum: 3
                  description: Number of partial images to generate when streaming
                quality:
                  type: string
                  enum:
                    - auto
                    - high
                    - medium
                    - low
                    - standard
                  description: Quality of the output image
                output_format:
                  type: string
                  enum:
                    - png
                    - webp
                    - jpeg
                  description: Output image format
                num_inference_steps:
                  type: integer
                  description: Number of inference steps
                seed:
                  type: integer
                  description: Seed for reproducible editing
                output_compression:
                  type: integer
                  minimum: 0
                  maximum: 100
                  description: Compression level (0-100%)
                negative_prompt:
                  type: string
                  description: What to avoid in the edit
                user:
                  type: string
                  description: User identifier for tracking
                fallbacks:
                  type: array
                  items:
                    $ref: '#/components/schemas/Fallback'
                  description: Fallback models to try if primary model fails
      responses:
        '200':
          description: >
            Successful response. Returns JSON for non-streaming requests, or
            Server-Sent Events (SSE) stream when `stream=true`.

            When streaming, events are sent with the following event types:

            - `image_edit.partial_image`: Intermediate image chunks with
            base64-encoded image data

            - `image_edit.completed`: Final event for each image with usage
            information

            - `error`: Error events with error details
          content:
            application/json:
              schema:
                type: object
                properties:
                  id:
                    type: string
                    description: Unique identifier for the generation request
                  created:
                    type: integer
                    format: int64
                    description: Unix timestamp when the image was created
                  model:
                    type: string
                    description: Model used for generation
                  data:
                    type: array
                    items:
                      type: object
                      properties:
                        url:
                          type: string
                          format: uri
                          description: URL of the generated image
                        b64_json:
                          type: string
                          description: Base64-encoded image data
                        revised_prompt:
                          type: string
                          description: Revised prompt used for generation
                        index:
                          type: integer
                          description: Index of this image
                    description: Array of generated images
                  background:
                    type: string
                    description: Background type for the image
                  output_format:
                    type: string
                    enum:
                      - png
                      - webp
                      - jpeg
                    description: Output image format
                  quality:
                    type: string
                    description: Quality of the generated image
                  size:
                    type: string
                    enum:
                      - 256x256
                      - 512x512
                      - 1024x1024
                      - 1792x1024
                      - 1024x1792
                      - 1536x1024
                      - 1024x1536
                      - auto
                    description: Size of the generated image
                  usage:
                    type: object
                    properties:
                      input_tokens:
                        type: integer
                        description: Number of input tokens
                      input_tokens_details:
                        type: object
                        properties:
                          image_tokens:
                            type: integer
                            description: Tokens used for images
                          text_tokens:
                            type: integer
                            description: Tokens used for text
                      total_tokens:
                        type: integer
                        description: Total tokens used
                      output_tokens:
                        type: integer
                        description: Number of output tokens
                      output_tokens_details:
                        type: object
                        properties:
                          image_tokens:
                            type: integer
                            description: Tokens used for images
                          text_tokens:
                            type: integer
                            description: Tokens used for text
                  extra_fields:
                    $ref: '#/components/schemas/BifrostResponseExtraFields'
            text/event-stream:
              schema:
                type: object
                description: |
                  Streaming response chunk for image edit.
                  Sent via Server-Sent Events (SSE) when `stream=true`.
                properties:
                  id:
                    type: string
                    description: Request identifier
                  type:
                    type: string
                    enum:
                      - image_edit.partial_image
                      - image_edit.completed
                      - error
                    description: Type of stream event
                  partial_image_index:
                    type: integer
                    description: Index of the partial image chunk
                  sequence_number:
                    type: integer
                    description: Sequence number for event ordering within the stream
                  b64_json:
                    type: string
                    description: Base64-encoded chunk of image data; optional
                  url:
                    type: string
                    format: uri
                    description: Optional public URL to the image chunk
                  created_at:
                    type: integer
                    format: int64
                    description: Timestamp when chunk was created
                  size:
                    type: string
                    description: Size of the image
                  quality:
                    type: string
                    description: Quality setting used
                  background:
                    type: string
                    description: Background type used
                  output_format:
                    type: string
                    enum:
                      - png
                      - webp
                      - jpeg
                    description: Output format used
                  revised_prompt:
                    type: string
                    description: Revised prompt
                  usage:
                    type: object
                    properties:
                      input_tokens:
                        type: integer
                        description: Number of input tokens
                      input_tokens_details:
                        type: object
                        properties:
                          image_tokens:
                            type: integer
                            description: Tokens used for images
                          text_tokens:
                            type: integer
                            description: Tokens used for text
                      total_tokens:
                        type: integer
                        description: Total tokens used
                      output_tokens:
                        type: integer
                        description: Number of output tokens
                      output_tokens_details:
                        type: object
                        properties:
                          image_tokens:
                            type: integer
                            description: Tokens used for images
                          text_tokens:
                            type: integer
                            description: Tokens used for text
                    description: Token usage
                  error:
                    $ref: '#/components/schemas/BifrostError'
                    description: Error information if edit failed
                  extra_fields:
                    $ref: '#/components/schemas/BifrostResponseExtraFields'
        '400':
          description: Bad request
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/BifrostError'
        '500':
          description: Internal server error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/BifrostError'
      security:
        - BearerAuth: []
        - BasicAuth: []
        - VirtualKeyAuth: []
        - ApiKeyAuth: []
components:
  schemas:
    Fallback:
      type: object
      description: Fallback model configuration
      required:
        - provider
        - model
      properties:
        provider:
          $ref: '#/components/schemas/ModelProvider'
        model:
          type: string
          description: Model name
    BifrostResponseExtraFields:
      type: object
      description: Additional fields included in responses
      properties:
        request_type:
          type: string
          description: Type of request that was made
        provider:
          $ref: '#/components/schemas/ModelProvider'
        model_requested:
          type: string
          description: The model that was requested
        model_deployment:
          type: string
          description: The actual model deployment used
        latency:
          type: integer
          format: int64
          description: Request latency in milliseconds
        chunk_index:
          type: integer
          description: Index of the chunk for streaming responses
        raw_request:
          type: object
          description: Raw request if enabled
        raw_response:
          type: object
          description: Raw response if enabled
        cache_debug:
          $ref: '#/components/schemas/BifrostCacheDebug'
    BifrostError:
      type: object
      description: Error response from Bifrost
      properties:
        event_id:
          type: string
        type:
          type: string
        is_bifrost_error:
          type: boolean
        status_code:
          type: integer
        error:
          $ref: '#/components/schemas/ErrorField'
        extra_fields:
          $ref: '#/components/schemas/BifrostErrorExtraFields'
    ModelProvider:
      type: string
      description: AI model provider identifier
      enum:
        - openai
        - azure
        - anthropic
        - bedrock
        - cohere
        - vertex
        - vllm
        - mistral
        - ollama
        - groq
        - sgl
        - parasail
        - perplexity
        - replicate
        - cerebras
        - gemini
        - openrouter
        - elevenlabs
        - huggingface
        - nebius
        - xai
        - runway
        - fireworks
    BifrostCacheDebug:
      type: object
      properties:
        cache_hit:
          type: boolean
        cache_id:
          type: string
        hit_type:
          type: string
        requested_provider:
          type: string
        requested_model:
          type: string
        provider_used:
          type: string
        model_used:
          type: string
        input_tokens:
          type: integer
        threshold:
          type: number
        similarity:
          type: number
    ErrorField:
      type: object
      properties:
        type:
          type: string
        code:
          type: string
        message:
          type: string
        param:
          type: string
        event_id:
          type: string
    BifrostErrorExtraFields:
      type: object
      properties:
        provider:
          $ref: '#/components/schemas/ModelProvider'
        model_requested:
          type: string
        request_type:
          type: string
  securitySchemes:
    BearerAuth:
      type: http
      scheme: bearer
      description: >
        Bearer token authentication. Use your provider API key or Bifrost
        authentication token.

        Virtual keys (prefixed with `sk-bf-`) can also be passed here.
    BasicAuth:
      type: http
      scheme: basic
      description: |
        Basic authentication using username and password.
    ApiKeyAuth:
      type: apiKey
      in: header
      name: x-api-key
      description: |
        API key authentication via the `x-api-key` header.
        Virtual keys (prefixed with `sk-bf-`) can also be passed here.
    VirtualKeyAuth:
      type: apiKey
      in: header
      name: x-bf-vk
      description: >
        Bifrost Virtual Key for governance, routing, and access control.
        Supported on all inference endpoints (`/v1/*`, `/openai/*`,
        `/anthropic/*`, `/bedrock/*`, `/cohere/*`, `/genai/*`, `/langchain/*`,
        `/litellm/*`, `/pydanticai/*`, `/mcp`), not on management APIs
        (`/api/*`).

        Example: `sk-bf-*` prefixed keys.

````