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

# Subir un archivo de evidencia a una disputa

> Transmite un archivo de evidencia (pdf, png, jpeg o csv) al almacenamiento de objetos con alcance de tenant y registra la clave de objeto resultante en la disputa como un nuevo ítem de evidencia. El comentario llega como parámetro de query y los bytes del archivo como el cuerpo de la solicitud. El tenant se resuelve del JWT y la disputa de la ruta — nunca del cuerpo. Falla de forma segura (503) cuando el almacenamiento de objetos no está configurado; rechaza cuerpos sobredimensionados (413) y tipos de contenido no soportados (415).



## OpenAPI

````yaml es/openapi/v3-current/matcher.yaml post /v1/disputes/{disputeId}/evidence/upload
openapi: 3.1.0
info:
  title: Matcher APIs
  description: >-
    Referencia completa de la API para el motor de conciliación Matcher, que
    proporciona conciliación automatizada de transacciones entre Midaz Ledger y
    sistemas externos.
  version: 4.1.0
  license:
    name: Elastic License 2.0
    url: https://www.elastic.co/licensing/elastic-license
servers:
  - url: https://matcher.sandbox.lerian.net
security: []
paths:
  /v1/disputes/{disputeId}/evidence/upload:
    post:
      tags:
        - Exception
      summary: Subir un archivo de evidencia a una disputa
      description: >-
        Transmite un archivo de evidencia (pdf, png, jpeg o csv) al
        almacenamiento de objetos con alcance de tenant y registra la clave de
        objeto resultante en la disputa como un nuevo ítem de evidencia. El
        comentario llega como parámetro de query y los bytes del archivo como el
        cuerpo de la solicitud. El tenant se resuelve del JWT y la disputa de la
        ruta — nunca del cuerpo. Falla de forma segura (503) cuando el
        almacenamiento de objetos no está configurado; rechaza cuerpos
        sobredimensionados (413) y tipos de contenido no soportados (415).
      operationId: uploadEvidence
      parameters:
        - description: Dispute ID (UUID)
          in: path
          name: disputeId
          required: true
          schema:
            description: ID de disputa (UUID)
            examples:
              - 550e8400-e29b-41d4-a716-446655440001
            format: uuid
            type: string
        - description: Comment describing the uploaded evidence
          explode: false
          in: query
          name: comment
          schema:
            description: Comentario que describe la evidencia subida
            examples:
              - Bank statement showing correct amount
            maxLength: 1000
            minLength: 1
            type: string
        - description: >-
            Evidence media type: application/pdf, image/png, image/jpeg, or
            text/csv
          in: header
          name: Content-Type
          schema:
            description: >-
              Tipo de medio de evidencia: application/pdf, image/png, image/jpeg
              o text/csv
            examples:
              - application/pdf
            type: string
      requestBody:
        content:
          application/octet-stream:
            schema:
              contentMediaType: application/octet-stream
              format: binary
              type: string
        required: true
      responses:
        '201':
          content:
            application/json:
              schema:
                $ref: '#/components/schemas/DisputeResponse'
          description: Creado
        default:
          content:
            application/problem+json:
              schema:
                $ref: '#/components/schemas/Detail'
          description: Error
      security:
        - BearerAuth: []
components:
  schemas:
    DisputeResponse:
      description: Detalles de la disputa
      properties:
        category:
          description: Categoría de la disputa
          enum:
            - BANK_FEE_ERROR
            - UNRECOGNIZED_CHARGE
            - DUPLICATE_TRANSACTION
            - OTHER
          example: BANK_FEE_ERROR
          type: string
        createdAt:
          description: Marca de tiempo de creación en formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
        description:
          description: Descripción de la disputa
          example: Transaction amount differs from expected
          type: string
        evidence:
          description: Evidencia presentada para esta disputa
          items:
            $ref: '#/components/schemas/EvidenceResponse'
          type: array
        exceptionId:
          description: ID de excepción a la que corresponde esta disputa
          example: 019c96a0-10d2-7134-ba5f-664142ee7052
          type: string
        id:
          description: Identificador único de la disputa
          example: 019c96a0-10d2-7193-8841-0d7347efd09a
          type: string
        openedBy:
          description: Usuario que abrió la disputa
          example: user@example.com
          type: string
        reopenReason:
          description: Motivo de reapertura si fue reabierta
          example: New evidence discovered
          type: string
        resolution:
          description: Descripción de la resolución cuando se cierra
          example: Counterparty confirmed error
          type: string
        state:
          description: Estado actual
          enum:
            - DRAFT
            - OPEN
            - PENDING_EVIDENCE
            - WON
            - LOST
          example: OPEN
          type: string
        updatedAt:
          description: Marca de tiempo de última actualización en formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
      type: object
    Detail:
      additionalProperties: false
      properties:
        code:
          description: >-
            Código de error de dominio estable y legible por máquina con alcance
            al servicio emisor (formato: <SERVICE>-NNNN).
          examples:
            - ERR-0001
          type: string
        detail:
          description: >-
            Una explicación legible por humanos específica de esta ocurrencia
            del problema.
          examples:
            - Property foo is required but is missing.
          type: string
        errors:
          description: Lista opcional de detalles de errores individuales
          items:
            $ref: '#/components/schemas/ErrorDetail'
          type:
            - array
            - 'null'
        instance:
          description: >-
            Una referencia URI que identifica la ocurrencia específica del
            problema.
          examples:
            - https://example.com/error-log/abc123
          format: uri
          type: string
        status:
          description: Código de estado HTTP
          examples:
            - 400
          format: int64
          type: integer
        title:
          description: >-
            Un resumen breve y legible por humanos del tipo de problema. Este
            valor no debería cambiar entre ocurrencias del error.
          examples:
            - Bad Request
          type: string
        type:
          default: about:blank
          description: >-
            Una referencia URI a documentación legible por humanos para el
            error.
          examples:
            - https://example.com/errors/example
          format: uri
          type: string
      type: object
    EvidenceResponse:
      description: Detalles de la evidencia
      properties:
        comment:
          description: Comentario que describe la evidencia
          example: Bank statement attached
          type: string
        disputeId:
          description: ID de disputa a la que pertenece esta evidencia
          example: 019c96a0-10d2-7193-8841-0d7347efd09a
          type: string
        fileUrl:
          description: URL al archivo de evidencia
          example: https://storage.example.com/evidence/doc123.pdf
          type: string
        id:
          description: Identificador único de la evidencia
          example: 019c96a0-0c0d-7915-84b9-e497bfee9916
          type: string
        submittedAt:
          description: Cuándo se presentó la evidencia en formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
        submittedBy:
          description: Usuario que presentó la evidencia
          example: user@example.com
          type: string
      type: object
    ErrorDetail:
      additionalProperties: false
      properties:
        location:
          description: >-
            Dónde ocurrió el error, p. ej. 'body.items[3].tags' o
            'path.thing-id'
          type: string
        message:
          description: Texto del mensaje de error
          type: string
        value:
          description: El valor en la ubicación indicada
      type: object
  securitySchemes:
    BearerAuth:
      type: http
      scheme: bearer
      bearerFormat: JWT
      description: 'Autenticación con token Bearer (formato: "Bearer {token}")'

````