API de Reparar imprimibilidade

Repare um modelo 3D para imprimibilidade FDM — corrija arestas non-manifold, faces degeneradas, furos e outros problemas de topology para que a malha esteja pronta para impressão.


POST/openapi/v1/print/repair

Criar uma tarefa de Reparar imprimibilidade

Este endpoint cria uma nova tarefa de Reparar imprimibilidade. A tarefa executa reparo de topology em um modelo 3D e retorna uma versão estanque, pronta para impressão.

O formato de saída corresponde ao formato de entrada. Se você enviar um .stl via model_url, o model_urls.stl da resposta conterá a malha reparada e os outros campos de formato ficarão vazios. O caminho input_task_id sempre lê o GLB da tarefa de origem, portanto a saída é .glb.

Parâmetros

  • Name
    model_url
    Type
    string
    Obrigatório
    Description

    URL de um modelo 3D a ser reparado. Formatos compatíveis: .glb, .stl, .obj. Tamanho máximo do arquivo: 100 MB. Deve usar http, https ou uma URL data: (URLs de dados ignoram verificações de extensão).

  • Name
    alpha_thumbnail
    Type
    boolean
    padrão false
    Description

    Quando definido como true, a tarefa também renderiza uma versão com fundo transparente (RGBA) da prévia e a retorna como alpha_thumbnail_url na resposta GET. O campo thumbnail_url existente permanece inalterado.

Retornos

A propriedade result da resposta contém o id da tarefa de Reparar imprimibilidade recém-criada.

Modos de falha

  • Name
    400 - Bad Request
    Description

    A solicitação não foi aceitável. Causas comuns:

    • Parâmetro ausente: nem input_task_id nem model_url foi fornecido.
    • UUID inválido: input_task_id não é um UUID válido.
    • URL de modelo inválida: model_url está malformado, usa um esquema incompatível ou tem uma extensão de arquivo incompatível.
    • Arquivo de modelo grande demais: o corpo de model_url excedeu 100 MB.
    • Tarefa não bem-sucedida: a tarefa referenciada ainda está pendente, em progress ou falhou.
    • GLB ausente: a tarefa referenciada não tem asset GLB para reparar.
  • Name
    401 - Unauthorized
    Description

    A autenticação falhou. Verifique sua chave de API.

  • Name
    402 - Payment Required
    Description

    Causas comuns:

    • Plano gratuito: a criação de tarefas exige um plano pago. Faça upgrade na página de assinatura.
    • Créditos insuficientes: o limite de créditos do espaço de trabalho foi atingido.
  • Name
    404 - Not Found
    Description

    A tarefa referenciada não existe ou pertence a um usuário diferente.

  • Name
    429 - Too Many Requests
    Description

    Você excedeu sua cota de tarefas pendentes ou o limite de taxa.

Request

POST
/openapi/v1/print/repair
# Repair an existing task
curl https://api.meshy.ai/openapi/v1/print/repair \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
    "input_task_id": "018a210d-8ba4-705c-b111-1f1776f7f578"
  }'

# Or repair a model URL directly
curl https://api.meshy.ai/openapi/v1/print/repair \
-X POST \
-H "Authorization: Bearer ${YOUR_API_KEY}" \
-H 'Content-Type: application/json' \
-d '{
    "model_url": "https://example.com/model.stl"
  }'

Response

{
  "result": "0193bfc5-ee4f-73f8-8525-44b398884ce9"
}

GET/openapi/v1/print/repair/:id

Recuperar uma tarefa de Reparar imprimibilidade

Este endpoint recupera uma tarefa de reparar imprimibilidade pelo seu ID.

Parâmetros

  • Name
    id
    Type
    path
    Description

    O ID da tarefa de reparar imprimibilidade a recuperar.

Retorna

O Objeto de tarefa de Reparar imprimibilidade. O bloco model_urls fica vazio até que a tarefa alcance SUCCEEDED. Apenas o campo model_urls correspondente ao formato de entrada é preenchido.

Request

GET
/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f
curl https://api.meshy.ai/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response

{
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "print-repair",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000030000,
  "expires_at": 1715725401000,
  "task_error": null,
  "model_urls": {
    "glb": "",
    "fbx": "",
    "obj": "",
    "stl": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.stl?Expires=***",
    "usdz": "",
    "3mf": "",
    "mtl": ""
  },
  "thumbnail_url": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/preview.png?Expires=***",
  "texture_urls": [],
  "consumed_credits": 10
}

DELETE/openapi/v1/print/repair/:id

Excluir uma tarefa de Reparar imprimibilidade

Este endpoint exclui permanentemente uma tarefa de reparar imprimibilidade e sua saída reparada. Esta ação é irreversível.

Parâmetros de caminho

  • Name
    id
    Type
    path
    Description

    O ID da tarefa de reparar imprimibilidade a ser excluída.

Retornos

Retorna 200 OK em caso de sucesso.

Request

DELETE
/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f
curl --request DELETE \
  --url https://api.meshy.ai/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f \
  -H "Authorization: Bearer ${YOUR_API_KEY}"

Response

// Returns 200 Ok on success.

GET/openapi/v1/print/repair

Listar tarefas de Reparar imprimibilidade

Este endpoint permite recuperar uma lista de tarefas de reparar imprimibilidade.

Parâmetros

Atributos opcionais

  • Name
    page_num
    Type
    integer
    Description

    Número da página para paginação. Começa e usa 1 como padrão.

  • Name
    page_size
    Type
    integer
    Description

    Limite de tamanho da página. O padrão é 10 itens. O máximo permitido é 50 itens.

  • Name
    sort_by
    Type
    string
    Description

    Campo pelo qual ordenar. Valores disponíveis:

    • +created_at: Ordenar por hora de criação em ordem crescente.
    • -created_at: Ordenar por hora de criação em ordem decrescente.

Retornos

Retorna uma lista paginada de objetos de tarefa de Reparar imprimibilidade.

Request

GET
/openapi/v1/print/repair
curl https://api.meshy.ai/openapi/v1/print/repair?page_size=10 \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response

[
  {
    "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
    "type": "print-repair",
    "status": "SUCCEEDED",
    "progress": 100,
    "preceding_tasks": 0,
    "created_at": 1699999999000,
    "started_at": 1700000000000,
    "finished_at": 1700000030000,
    "expires_at": 1715725401000,
    "task_error": null,
    "model_urls": {
      "glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
      "fbx": "",
      "obj": "",
      "stl": "",
      "usdz": "",
      "3mf": "",
      "mtl": ""
    },
    "thumbnail_url": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/preview.png?Expires=***",
    "texture_urls": [],
    "consumed_credits": 10
  }
]

GET/openapi/v1/print/repair/:id/stream

Transmitir uma tarefa de Reparar imprimibilidade

Este endpoint transmite atualizações em tempo real para uma tarefa de reparar imprimibilidade usando Server-Sent Events (SSE).

Parâmetros

  • Name
    id
    Type
    path
    Description

    Identificador único da tarefa de reparar imprimibilidade a ser transmitida.

Retorna

Retorna um fluxo de Objetos de tarefa de Reparar imprimibilidade como Server-Sent Events.

Para tarefas PENDING ou IN_PROGRESS, o fluxo de resposta incluirá apenas os campos necessários progress e status. O bloco model_urls é enviado somente quando a tarefa atinge SUCCEEDED.

Request

GET
/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f/stream
curl -N https://api.meshy.ai/openapi/v1/print/repair/a43b5c6d-7e8f-901a-234b-567c890d1e2f/stream \
-H "Authorization: Bearer ${YOUR_API_KEY}"

Response Stream

// Error event example
event: error
data: {
  "status_code": 404,
  "message": "Task not found"
}

// Message event examples illustrate task progress.
// For PENDING or IN_PROGRESS tasks, the response stream will not include all fields.
event: message
data: {
  "id": "a43b5c6d-7e8f-901a-234b-567c890d1e2f",
  "progress": 0,
  "status": "PENDING"
}

event: message
data: {
  "id": "a43b5c6d-7e8f-901a-234b-567c890d1e2f",
  "type": "print-repair",
  "status": "SUCCEEDED",
  "progress": 100,
  "preceding_tasks": 0,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000030000,
  "expires_at": 1715725401000,
  "task_error": null,
  "model_urls": {
    "glb": "https://assets.meshy.ai/***/tasks/a43b5c6d-7e8f-901a-234b-567c890d1e2f/output/model.glb?Expires=***",
    "fbx": "",
    "obj": "",
    "stl": "",
    "usdz": "",
    "3mf": "",
    "mtl": ""
  },
  "thumbnail_url": "https://assets.meshy.ai/***/tasks/a43b5c6d-7e8f-901a-234b-567c890d1e2f/output/preview.png?Expires=***",
  "texture_urls": [],
  "consumed_credits": 10
}

O objeto de tarefa Reparar imprimibilidade

  • Name
    id
    Type
    string
    Description

    Identificador exclusivo da tarefa. Embora usemos um UUID k-sortable para ids de tarefa como detalhe de implementação, você não deve fazer nenhuma suposição sobre o formato do id.

  • Name
    type
    Type
    string
    Description

    Tipo da tarefa de Reparar imprimibilidade. O valor é print-repair.

  • Name
    status
    Type
    string
    Description

    Status da tarefa. Os valores possíveis são um de PENDING, IN_PROGRESS, SUCCEEDED, FAILED, CANCELED.

  • Name
    progress
    Type
    integer
    Description

    progress da tarefa. Se a tarefa ainda não foi iniciada, esta propriedade será 0. Depois que a tarefa for bem-sucedida, isso se tornará 100.

  • Name
    preceding_tasks
    Type
    integer
    Description

    A contagem de tarefas anteriores.

  • Name
    created_at
    Type
    timestamp
    Description

    carimbo de data/hora de quando a tarefa foi criada, em milissegundos.

  • Name
    started_at
    Type
    timestamp
    Description

    carimbo de data/hora de quando a tarefa foi iniciada, em milissegundos. Se a tarefa ainda não foi iniciada, esta propriedade será 0.

  • Name
    finished_at
    Type
    timestamp
    Description

    carimbo de data/hora de quando a tarefa foi concluída, em milissegundos. Se a tarefa ainda não foi concluída, esta propriedade será 0.

  • Name
    expires_at
    Type
    timestamp
    Description

    carimbo de data/hora de quando o resultado da tarefa expirará no sistema, em milissegundos. 0 se a tarefa ainda não tiver sido concluída.

  • Name
    task_error
    Type
    object
    Description

    Informações de erro se a tarefa falhou. Esta propriedade é null se a tarefa não falhou. Consulte Erros para mais detalhes.

    • Name
      message
      Type
      string
      Description

      Mensagem de erro descrevendo o que deu errado.

  • Name
    model_urls
    Type
    object
    Description

    URLs baixáveis para o modelo 3D reparado. Somente o campo correspondente ao formato de entrada é preenchido; os outros campos de formato são strings vazias.

    • Name
      glb
      Type
      string
      Description

      URL baixável para o GLB reparado. Preenchido quando a entrada era um GLB ou quando input_task_id foi usado.

    • Name
      fbx
      Type
      string
      Description

      Reservado para saída FBX. Sempre uma string vazia para tarefas de Reparar imprimibilidade.

    • Name
      obj
      Type
      string
      Description

      URL baixável para o OBJ reparado. Preenchido quando a entrada era um upload de OBJ.

    • Name
      stl
      Type
      string
      Description

      URL baixável para o STL reparado. Preenchido quando a entrada era um upload de STL.

    • Name
      usdz
      Type
      string
      Description

      Reservado para saída USDZ. Sempre uma string vazia para tarefas de Reparar imprimibilidade.

    • Name
      3mf
      Type
      string
      Description

      Reservado para saída 3MF. Sempre uma string vazia para tarefas de Reparar imprimibilidade.

    • Name
      mtl
      Type
      string
      Description

      Reservado para saída MTL. Sempre uma string vazia para tarefas de Reparar imprimibilidade.

  • Name
    thumbnail_url
    Type
    string
    Description

    URL de uma imagem de pré-visualização renderizada a partir do modelo reparado.

  • Name
    alpha_thumbnail_url
    Type
    string
    Description

    URL baixável para uma versão com fundo transparente (RGBA) de thumbnail_url. Presente apenas quando a tarefa foi criada com alpha_thumbnail: true e a pré-visualização transparente foi renderizada com sucesso; caso contrário, este campo é omitido.

  • Name
    texture_urls
    Type
    array
    Description

    Sempre um array vazio. O reparo preserva apenas a geometria de entrada e não reprocessa texturas.

  • Name
    consumed_credits
    Type
    integer
    Description

    O número de créditos consumidos por esta tarefa. 10 depois que a tarefa atinge SUCCEEDED. Retorna 0 para tarefas FAILED (os créditos são reembolsados em caso de falha).

The Repair Printability Task Object

{
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "print-repair",
  "status": "SUCCEEDED",
  "progress": 100,
  "preceding_tasks": 0,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000030000,
  "expires_at": 1715725401000,
  "task_error": null,
  "model_urls": {
    "glb": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/model.glb?Expires=***",
    "fbx": "",
    "obj": "",
    "stl": "",
    "usdz": "",
    "3mf": "",
    "mtl": ""
  },
  "thumbnail_url": "https://assets.meshy.ai/***/tasks/0193bfc5-ee4f-73f8-8525-44b398884ce9/output/preview.png?Expires=***",
  "texture_urls": [],
  "consumed_credits": 10
}