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

# Confirm vault upload result

> Confirm whether a direct-to-S3 vault upload succeeded or failed. This endpoint emits vault.upload.completed or vault.upload.failed events and is idempotent for repeated confirmations.



## OpenAPI

````yaml /openapi.json post /vault/{id}/upload/{objectId}/confirm
openapi: 3.1.0
info:
  title: Case.dev API
  description: >-
    The AI-native platform for legal technology. Build smarter legal
    applications with our suite of AI-powered APIs.
  version: 1.0.0
  contact:
    name: Case.dev Support
    email: support@casemark.com
    url: https://case.dev
  license:
    name: Proprietary
    url: https://case.dev/terms
servers:
  - url: https://api.case.dev
    description: Production
security:
  - bearerAuth: []
tags:
  - name: Vaults
    description: Secure document storage with semantic search and GraphRAG
  - name: Memory
    description: >-
      Persistent memory for AI agents with semantic search and 12 generic
      indexed tag fields
  - name: OCR
    description: Extract text from PDFs, images, and scanned documents
  - name: Voice
    description: Audio transcription and text-to-speech
  - name: LLMs
    description: Access 40+ language models through a unified API
  - name: Search
    description: Web search, AI answers, and deep research
  - name: Mail
    description: Managed inboxes for agent email workflows
  - name: Media
    description: Transcript retrieval and captioned media clip generation
  - name: Legal
    description: Legal research tools including citation verification
  - name: Privilege
    description: Privilege detection for e-discovery and litigation workflows
  - name: Compute
    description: Serverless GPU and CPU infrastructure
  - name: Format
    description: Document formatting and template rendering (MD/JSON to PDF/DOCX)
  - name: SuperDoc
    description: Document conversion and template automation
  - name: Webhooks
    description: Webhook endpoint management
  - name: System
    description: Public system metadata and discovery endpoints
  - name: Usage
    description: Usage reporting and webhook subscriptions
  - name: Database
    description: Serverless PostgreSQL databases with instant branching
  - name: Translation
    description: Language detection and translation for multilingual legal workflows
  - name: Skills
    description: Search and read legal AI skills for agents
  - name: Agents
    description: >-
      Create, manage, and execute AI agents with tool access, sandbox
      environments, and async run workflows
  - name: Matters
    description: Matter-native legal workspaces and orchestration primitives
  - name: Applications Projects
    description: Web application project management
  - name: Applications Deployments
    description: Web application deployment management
  - name: Applications Domains
    description: Custom domain configuration for applications
  - name: Applications Env Vars
    description: Environment variable management for applications
paths:
  /vault/{id}/upload/{objectId}/confirm:
    post:
      tags:
        - Vaults
      summary: Confirm vault upload result
      description: >-
        Confirm whether a direct-to-S3 vault upload succeeded or failed. This
        endpoint emits vault.upload.completed or vault.upload.failed events and
        is idempotent for repeated confirmations.
      operationId: confirmVaultUpload
      parameters:
        - name: id
          in: path
          required: true
          schema:
            type: string
          description: Vault ID
        - name: objectId
          in: path
          required: true
          schema:
            type: string
          description: Vault object ID
      requestBody:
        required: true
        content:
          application/json:
            schema:
              oneOf:
                - title: VaultConfirmUploadSuccess
                  type: object
                  required:
                    - success
                    - sizeBytes
                  properties:
                    success:
                      type: boolean
                      enum:
                        - true
                      description: Whether the upload succeeded
                    sizeBytes:
                      type: integer
                      minimum: 1
                      maximum: 5368709120
                      description: Uploaded file size in bytes
                    etag:
                      type: string
                      description: >-
                        S3 ETag for the uploaded object (optional if client
                        cannot access ETag header)
                    autoIngest:
                      type: boolean
                      default: false
                      description: >-
                        When true and the object was uploaded with auto_index,
                        trigger ingestion immediately after a successful
                        confirmation (no separate ingest call needed). The
                        ingest outcome is reported in the `ingest` response
                        field; an ingest failure does not fail the confirmation.
                - title: VaultConfirmUploadFailure
                  type: object
                  required:
                    - success
                    - errorCode
                    - errorMessage
                  properties:
                    success:
                      type: boolean
                      enum:
                        - false
                      description: Whether the upload succeeded
                    errorCode:
                      type: string
                      description: Client-side error code
                    errorMessage:
                      type: string
                      description: Client-side error message
      responses:
        '200':
          description: Confirmation recorded
          content:
            application/json:
              schema:
                type: object
                properties:
                  vaultId:
                    type: string
                  objectId:
                    type: string
                  status:
                    type: string
                    enum:
                      - completed
                      - failed
                  alreadyConfirmed:
                    type: boolean
                  ingest:
                    type: object
                    description: >-
                      Present when autoIngest was requested on a successful
                      confirmation
                    properties:
                      triggered:
                        type: boolean
                      workflowId:
                        type: string
                        nullable: true
                      error:
                        type: string
              example:
                vaultId: vault_123
                objectId: obj_456
                status: completed
                alreadyConfirmed: false
        '400':
          description: Invalid request body
        '401':
          description: Authentication failed - invalid API key
        '403':
          description: Access denied - API key lacks vault service permissions
        '404':
          description: Vault or object not found
components:
  securitySchemes:
    bearerAuth:
      type: http
      scheme: bearer
      bearerFormat: API Key
      description: API key starting with `sk_case_`

````