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

# Enviar um arquivo de evidência para uma disputa

> Faz streaming de um arquivo de evidência (pdf, png, jpeg ou csv) para armazenamento de objetos com escopo de tenant e registra a chave de objeto resultante na disputa como um novo item de evidência. O comentário chega como parâmetro de query e os bytes do arquivo como o corpo da requisição. O tenant é resolvido do JWT e a disputa do path — nunca do corpo. Falha fechada (503) quando o armazenamento de objetos não está configurado; rejeita corpos grandes demais (413) e tipos de conteúdo não suportados (415).



## OpenAPI

````yaml pt/openapi/v3-current/matcher.yaml post /v1/disputes/{disputeId}/evidence/upload
openapi: 3.1.0
info:
  title: Matcher APIs
  description: >-
    Referência completa de API para o motor de conciliação Matcher, que fornece
    conciliação automática de transações entre o Midaz Ledger e 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: Enviar um arquivo de evidência para uma disputa
      description: >-
        Faz streaming de um arquivo de evidência (pdf, png, jpeg ou csv) para
        armazenamento de objetos com escopo de tenant e registra a chave de
        objeto resultante na disputa como um novo item de evidência. O
        comentário chega como parâmetro de query e os bytes do arquivo como o
        corpo da requisição. O tenant é resolvido do JWT e a disputa do path —
        nunca do corpo. Falha fechada (503) quando o armazenamento de objetos
        não está configurado; rejeita corpos grandes demais (413) e tipos de
        conteúdo não suportados (415).
      operationId: uploadEvidence
      parameters:
        - description: Dispute ID (UUID)
          in: path
          name: disputeId
          required: true
          schema:
            description: ID da 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: Comentário descrevendo a evidência enviada
            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 mídia da evidência: application/pdf, image/png, image/jpeg
              ou 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: Criado
        default:
          content:
            application/problem+json:
              schema:
                $ref: '#/components/schemas/Detail'
          description: Erro
      security:
        - BearerAuth: []
components:
  schemas:
    DisputeResponse:
      description: Detalhes da disputa
      properties:
        category:
          description: Categoria da disputa
          enum:
            - BANK_FEE_ERROR
            - UNRECOGNIZED_CHARGE
            - DUPLICATE_TRANSACTION
            - OTHER
          example: BANK_FEE_ERROR
          type: string
        createdAt:
          description: Timestamp de criação no formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
        description:
          description: Descrição da disputa
          example: Transaction amount differs from expected
          type: string
        evidence:
          description: Evidências enviadas para esta disputa
          items:
            $ref: '#/components/schemas/EvidenceResponse'
          type: array
        exceptionId:
          description: ID da exceção à qual esta disputa se refere
          example: 019c96a0-10d2-7134-ba5f-664142ee7052
          type: string
        id:
          description: Identificador único da disputa
          example: 019c96a0-10d2-7193-8841-0d7347efd09a
          type: string
        openedBy:
          description: Usuário que abriu a disputa
          example: user@example.com
          type: string
        reopenReason:
          description: Motivo para reabertura, se reaberta
          example: New evidence discovered
          type: string
        resolution:
          description: Descrição da resolução ao ser encerrada
          example: Counterparty confirmed error
          type: string
        state:
          description: Estado atual
          enum:
            - DRAFT
            - OPEN
            - PENDING_EVIDENCE
            - WON
            - LOST
          example: OPEN
          type: string
        updatedAt:
          description: Timestamp da última atualização no formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
      type: object
    Detail:
      additionalProperties: false
      properties:
        code:
          description: >-
            Código de erro de domínio estável e legível por máquina com escopo
            no serviço emissor (formato: <SERVICE>-NNNN).
          examples:
            - ERR-0001
          type: string
        detail:
          description: >-
            Uma explicação legível por humanos específica para esta ocorrência
            do problema.
          examples:
            - Property foo is required but is missing.
          type: string
        errors:
          description: Lista opcional de detalhes de erro individuais
          items:
            $ref: '#/components/schemas/ErrorDetail'
          type:
            - array
            - 'null'
        instance:
          description: >-
            Uma referência URI que identifica a ocorrência específica do
            problema.
          examples:
            - https://example.com/error-log/abc123
          format: uri
          type: string
        status:
          description: Código de status HTTP
          examples:
            - 400
          format: int64
          type: integer
        title:
          description: >-
            Um resumo curto e legível por humanos do tipo do problema. Este
            valor não deve mudar entre ocorrências do erro.
          examples:
            - Bad Request
          type: string
        type:
          default: about:blank
          description: >-
            Uma referência URI para documentação legível por humanos sobre o
            erro.
          examples:
            - https://example.com/errors/example
          format: uri
          type: string
      type: object
    EvidenceResponse:
      description: Detalhes da evidência
      properties:
        comment:
          description: Comentário descrevendo a evidência
          example: Bank statement attached
          type: string
        disputeId:
          description: ID da disputa à qual esta evidência pertence
          example: 019c96a0-10d2-7193-8841-0d7347efd09a
          type: string
        fileUrl:
          description: URL para o arquivo de evidência
          example: https://storage.example.com/evidence/doc123.pdf
          type: string
        id:
          description: Identificador único da evidência
          example: 019c96a0-0c0d-7915-84b9-e497bfee9916
          type: string
        submittedAt:
          description: Quando a evidência foi enviada no formato RFC3339
          example: '2025-01-15T10:30:00.000Z'
          type: string
        submittedBy:
          description: Usuário que enviou a evidência
          example: user@example.com
          type: string
      type: object
    ErrorDetail:
      additionalProperties: false
      properties:
        location:
          description: 'Onde o erro ocorreu, ex.: ''body.items[3].tags'' ou ''path.thing-id'''
          type: string
        message:
          description: Texto da mensagem de erro
          type: string
        value:
          description: O valor na localização informada
      type: object
  securitySchemes:
    BearerAuth:
      type: http
      scheme: bearer
      bearerFormat: JWT
      description: 'Autenticação por Bearer token (formato: "Bearer {token}")'

````