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

# Upload a file to a conversation



## OpenAPI

````yaml /public/api/openapi.json post /v1/public/agents/conversations/{conversation_id}/files
openapi: 3.1.0
info:
  title: Quintus Public Chat API
  description: >-
    Quintus Public Chat API - for embedding agent conversations in
    customer-facing

    front-ends (websites, apps).


    **Authentication.** Two schemes:


    1. **API Key** (`X-API-Key` header) - used to **start** a conversation and
    to
       **refresh** its session token. Scoped per agent via `api_key.resources["agents"]`.
    2. **Session Token** (`Authorization: Bearer ...`) - short-lived JWT
    returned by
       `POST /conversations`. Used for everything inside an existing conversation
       (send messages, upload files, fetch state, terminate).

    **Rate limiting.** Requests are rate-limited per API key and per session
    token.

    Exceeding the limit returns `429 Too Many Requests` with a `Retry-After`
    header.

    Limits and headers are subject to change - clients should always honor
    `Retry-After`.


    **Errors.** All non-2xx responses use the standard `ErrorEnvelope` shape
    with a

    stable `error.code` for programmatic handling.
  contact:
    name: Quintus Support
    email: support@quintus.tec.br
  license:
    name: Proprietary - Quintus
    url: https://quintus.tec.br/
  version: 1.0.0
servers:
  - url: https://api.quintus.tec.br
security: []
tags:
  - name: Conversations
    description: Conversation lifecycle and tokens.
  - name: Messages
    description: Send and read messages within a conversation.
  - name: Files
    description: Upload and list files attached to a conversation.
  - name: Feedback
    description: Conversation-level feedback (NPS-style).
paths:
  /v1/public/agents/conversations/{conversation_id}/files:
    post:
      tags:
        - Files
      summary: Upload a file to a conversation
      operationId: uploadConversationFile
      parameters:
        - name: conversation_id
          in: path
          required: true
          schema:
            type: string
            title: Conversation Id
      requestBody:
        required: true
        content:
          multipart/form-data:
            schema:
              $ref: '#/components/schemas/Body_uploadConversationFile'
      responses:
        '201':
          description: Successful Response
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/File'
        '400':
          description: Bad request (invalid input, unsupported file type, etc.)
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
        '401':
          description: Authentication missing or invalid
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
        '403':
          description: Authenticated but not allowed for this resource
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
        '404':
          description: Resource not found
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
        '409':
          description: Conflict (resource exists, closed, etc.)
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
        '422':
          description: Validation Error
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/HTTPValidationError'
        '429':
          description: Rate limit exceeded - see Retry-After header
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/ErrorEnvelope'
      security:
        - SessionToken: []
components:
  schemas:
    Body_uploadConversationFile:
      properties:
        file:
          type: string
          format: binary
          title: File
      type: object
      required:
        - file
      title: Body_uploadConversationFile
    File:
      properties:
        id:
          type: string
          title: Id
        name:
          type: string
          title: Name
        size:
          type: integer
          title: Size
        mime_type:
          type: string
          title: Mime Type
        created_at:
          type: string
          format: date-time
          title: Created At
      type: object
      required:
        - id
        - name
        - size
        - mime_type
        - created_at
      title: File
    ErrorEnvelope:
      example:
        error:
          code: session_token_expired
          context: {}
          message: Session token has expired. Refresh to continue.
          name: SessionTokenExpiredError
        request_id: 5f0c-...
        timestamp: '2026-04-27T12:00:00Z'
      properties:
        error:
          $ref: '#/components/schemas/ErrorBody'
        request_id:
          anyOf:
            - type: string
            - type: 'null'
          default: null
          description: Request ID for support correlation.
          title: Request Id
        timestamp:
          anyOf:
            - type: string
            - type: 'null'
          default: null
          description: ISO-8601 server timestamp when the error occurred.
          title: Timestamp
      required:
        - error
      title: ErrorEnvelope
      type: object
    HTTPValidationError:
      properties:
        detail:
          items:
            $ref: '#/components/schemas/ValidationError'
          type: array
          title: Detail
      type: object
      title: HTTPValidationError
    ErrorBody:
      properties:
        code:
          type: string
          title: Code
          description: Stable machine-readable error code (snake_case).
        name:
          type: string
          title: Name
          description: Error class name (PascalCase).
        message:
          type: string
          title: Message
          description: Human-readable explanation.
        context:
          additionalProperties: true
          type: object
          title: Context
          description: Error-specific structured context (ids, limits, hints).
      type: object
      required:
        - code
        - name
        - message
      title: ErrorBody
    ValidationError:
      properties:
        loc:
          items:
            anyOf:
              - type: string
              - type: integer
          type: array
          title: Location
        msg:
          type: string
          title: Message
        type:
          type: string
          title: Error Type
      type: object
      required:
        - loc
        - msg
        - type
      title: ValidationError
  securitySchemes:
    SessionToken:
      type: http
      scheme: bearer

````