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.
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
Apenas um de input_task_id ou model_url é obrigatório. Se ambos forem fornecidos, input_task_id terá prioridade.
As texturas existentes são removidas durante o reparo devido a alterações de geometria. Para adicionar texturas novamente, use a API Retexturizar no modelo reparado.
- Name
- input_task_id
- Type
- string
- Obrigatório
- Description
O ID de uma tarefa bem-sucedida que pertence a você. Tipos de tarefa compatíveis: Imagem para 3D, Multi-imagem para 3D, Texto para 3D, Remesh e Retexturizar. A tarefa deve ter um status de
SUCCEEDEDe deve ter produzido um asset GLB.
- 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 usarhttp,httpsou uma URLdata:(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 comoalpha_thumbnail_urlna resposta GET. O campothumbnail_urlexistente 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_idnemmodel_urlfoi fornecido. - UUID inválido:
input_task_idnão é um UUID válido. - URL de modelo inválida:
model_urlestá malformado, usa um esquema incompatível ou tem uma extensão de arquivo incompatível. - Arquivo de modelo grande demais: o corpo de
model_urlexcedeu 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.
- Parâmetro ausente: nem
- 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
# 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"
}
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
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
}
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
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.
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
1como padrão.
- Name
- page_size
- Type
- integer
- Description
Limite de tamanho da página. O padrão é
10itens. O máximo permitido é50itens.
- 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
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
}
]
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
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.
O valor deste campo só é significativo se o status da tarefa for
PENDING.
- 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.
0se 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 é
nullse 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_idfoi 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 comalpha_thumbnail: truee 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.
10depois que a tarefa atingeSUCCEEDED. Retorna0para tarefasFAILED(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
}