API Analisar imprimibilidade

Analise um modelo 3D quanto à imprimibilidade FDM — estanqueidade, volume, furos, arestas non-manifold e faces degeneradas.


POST/openapi/v1/print/analyze

Criar uma tarefa de Analisar imprimibilidade

Este endpoint cria uma nova tarefa de análise de imprimibilidade. A tarefa avalia um modelo 3D e relata suas métricas de imprimibilidade.

Se a tarefa de entrada já tiver a imprimibilidade em cache, a tarefa retornada estará pronta imediatamente e o primeiro GET nela retornará o resultado da análise sem passar pelo worker.

Parâmetros

  • Name
    model_url
    Type
    string
    Obrigatório
    Description

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

Retorna

A propriedade result da resposta contém o id da tarefa de análise de 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 foram fornecidos.
    • UUID inválido: input_task_id não é um UUID válido.
    • URL de modelo inválida: model_url está malformada, usa um esquema não compatível ou tem uma extensão de arquivo não compatível.
    • Arquivo de modelo muito grande: o corpo de model_url excedeu 100 MB.
    • Tarefa não bem-sucedida: a tarefa referenciada ainda está pendente, em progress ou falhou.
  • Name
    401 - Unauthorized
    Description

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

  • Name
    403 - Forbidden
    Description

    A tarefa existe, mas pertence a um usuário diferente.

  • Name
    404 - Not Found
    Description

    Causas comuns:

    • A tarefa não existe ou foi excluída.
    • A tarefa usa um modelo anterior ao Meshy 6, ou seu mode não produz um asset 3D.
    • O arquivo de modelo subjacente não está mais disponível no armazenamento.
  • Name
    429 - Too Many Requests
    Description

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

Request

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

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

Response

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

GET/openapi/v1/print/analyze/:id

Recuperar uma tarefa de Analisar imprimibilidade

Este endpoint recupera uma tarefa de análise de imprimibilidade pelo seu ID.

Parâmetros

  • Name
    id
    Type
    path
    Description

    O ID da tarefa de análise de imprimibilidade a ser recuperada.

Retorna

O Objeto de tarefa de Analisar imprimibilidade. O campo printability é null até que a tarefa alcance SUCCEEDED.

Request

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

Response

{
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "print-analyze",
  "status": "SUCCEEDED",
  "progress": 100,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000001000,
  "expires_at": 1715725401000,
  "task_error": null,
  "printability": {
    "_version": "v1",
    "status": "warning",
    "issue_count": 1,
    "error_count": 0,
    "warning_count": 1,
    "metrics": {
      "is_watertight": true,
      "volume": 1.316167354292668,
      "non_manifold_edges": 0,
      "degenerate_faces": 43242,
      "holes": 0
    },
    "evaluated_at": 1700000001000
  },
  "consumed_credits": 0
}

DELETE/openapi/v1/print/analyze/:id

Excluir uma tarefa de Analisar imprimibilidade

Este endpoint exclui permanentemente uma tarefa de Analisar imprimibilidade e seu resultado em cache. Esta ação é irreversível.

Parâmetros de caminho

  • Name
    id
    Type
    path
    Description

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

Retornos

Retorna 200 OK em caso de sucesso.

Request

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

Response

// Returns 200 Ok on success.

GET/openapi/v1/print/analyze

Listar tarefas de Analisar imprimibilidade

Este endpoint permite recuperar uma lista de tarefas de Analisar 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 Analisar imprimibilidade.

Request

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

Response

[
  {
    "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
    "type": "print-analyze",
    "status": "SUCCEEDED",
    "progress": 100,
    "preceding_tasks": 0,
    "created_at": 1699999999000,
    "started_at": 1700000000000,
    "finished_at": 1700000001000,
    "expires_at": 1715725401000,
    "task_error": null,
    "printability": {
      "_version": "v1",
      "status": "warning",
      "issue_count": 1,
      "error_count": 0,
      "warning_count": 1,
      "metrics": {
        "is_watertight": true,
        "volume": 1.316167354292668,
        "non_manifold_edges": 0,
        "degenerate_faces": 43242,
        "holes": 0
      },
      "evaluated_at": 1700000001000
    },
    "consumed_credits": 0
  }
]

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

Transmitir em stream uma tarefa de Analisar imprimibilidade

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

Parâmetros

  • Name
    id
    Type
    path
    Description

    Identificador exclusivo da tarefa de analisar imprimibilidade a ser transmitida em stream.

Retorna

Retorna um stream de Objetos de tarefa de Analisar imprimibilidade como Server-Sent Events.

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

Request

GET
/openapi/v1/print/analyze/a43b5c6d-7e8f-901a-234b-567c890d1e2f/stream
curl -N https://api.meshy.ai/openapi/v1/print/analyze/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-analyze",
  "status": "SUCCEEDED",
  "progress": 100,
  "preceding_tasks": 0,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000001000,
  "expires_at": 1715725401000,
  "task_error": null,
  "printability": {
    "_version": "v1",
    "status": "warning",
    "issue_count": 1,
    "error_count": 0,
    "warning_count": 1,
    "metrics": {
      "is_watertight": true,
      "volume": 1.316167354292668,
      "non_manifold_edges": 0,
      "degenerate_faces": 43242,
      "holes": 0
    },
    "evaluated_at": 1700000001000
  },
  "consumed_credits": 0
}

O objeto da tarefa Analisar imprimibilidade

  • Name
    id
    Type
    string
    Description

    Identificador único 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 analyze-printability. O valor é print-analyze.

  • 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. Quando a tarefa for concluída com sucesso, isto se tornará 100.

  • Name
    preceding_tasks
    Type
    integer
    Description

    A contagem de tarefas precedentes.

  • 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 finalizada, em milissegundos. Se a tarefa ainda não foi finalizada, esta propriedade será 0.

  • Name
    expires_at
    Type
    timestamp
    Description

    Carimbo de data/hora de quando o resultado da tarefa expirará do sistema, em milissegundos. 0 se a tarefa ainda não foi finalizada.

  • 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
    printability
    Type
    object
    Description

    Resultado da avaliação de imprimibilidade. null até que a tarefa atinja SUCCEEDED.

    • Name
      _version
      Type
      string
      Description

      Versão do esquema do resultado de imprimibilidade. Atualmente v1.

    • Name
      status
      Type
      string
      Description

      Status geral. Um de:

      • healthy: sem erros e sem avisos.
      • warning: pelo menos um aviso, sem erros.
      • error: pelo menos um erro.
      • unknown: o modelo não pôde ser analisado.
    • Name
      issue_count
      Type
      integer
      Description

      Contagem total de problemas, igual a error_count + warning_count.

    • Name
      error_count
      Type
      integer
      Description

      Número de problemas de nível de erro. Erros são gerados quando o modelo não é watertight, tem volume não positivo ou tem arestas non-manifold.

    • Name
      warning_count
      Type
      integer
      Description

      Número de problemas de nível de aviso. Avisos são gerados quando o modelo contém faces degeneradas ou furos.

    • Name
      metrics
      Type
      object
      Description

      Métricas brutas de geometria retornadas pelo avaliador.

      • Name
        is_watertight
        Type
        boolean
        Description

        true quando a malha não tem arestas de limite (ou seja, está fechada).

      • Name
        volume
        Type
        number
        Description

        Volume do modelo em metros cúbicos.

      • Name
        non_manifold_edges
        Type
        integer
        Description

        Contagem de arestas non-manifold.

      • Name
        degenerate_faces
        Type
        integer
        Description

        Contagem de faces degeneradas (faces de área zero ou inválidas).

      • Name
        holes
        Type
        integer
        Description

        Contagem de furos (loops de limite) na malha.

    • Name
      evaluated_at
      Type
      timestamp
      Description

      Carimbo de data/hora de quando a análise foi computada, em milissegundos desde a época.

  • Name
    consumed_credits
    Type
    integer
    Description

    Sempre 0. Este endpoint é gratuito.

The Analyze Printability Task Object

{
  "id": "0193bfc5-ee4f-73f8-8525-44b398884ce9",
  "type": "print-analyze",
  "status": "SUCCEEDED",
  "progress": 100,
  "preceding_tasks": 0,
  "created_at": 1699999999000,
  "started_at": 1700000000000,
  "finished_at": 1700000001000,
  "expires_at": 1715725401000,
  "task_error": null,
  "printability": {
    "_version": "v1",
    "status": "warning",
    "issue_count": 1,
    "error_count": 0,
    "warning_count": 1,
    "metrics": {
      "is_watertight": true,
      "volume": 1.316167354292668,
      "non_manifold_edges": 0,
      "degenerate_faces": 43242,
      "holes": 0
    },
    "evaluated_at": 1700000001000
  },
  "consumed_credits": 0
}