API Réparer l'imprimabilité
Réparez un modèle 3D pour l'imprimabilité FDM — corrigez les arêtes non-manifold, les faces dégénérées, les trous et autres problèmes de topology afin que le maillage soit prêt pour l'impression.
Créer une tâche Réparer l'imprimabilité
Ce point de terminaison crée une nouvelle tâche de réparation de l'imprimabilité. La tâche exécute une réparation de topology sur un modèle 3D et renvoie une version étanche et prête pour l'impression.
Le format de sortie correspond au format d'entrée. Si vous soumettez un .stl via model_url, le model_urls.stl de la réponse contiendra le maillage réparé et les autres champs de format seront vides. Le chemin input_task_id lit toujours le GLB de la tâche source, donc la sortie est en .glb.
Paramètres
Un seul de input_task_id ou model_url est requis. Si les deux sont fournis, input_task_id prend la priorité.
Les textures existantes sont supprimées pendant la réparation en raison des changements de géométrie. Pour rajouter des textures, utilisez l'API Retexturisation sur le modèle réparé.
- Name
- input_task_id
- Type
- string
- Requis
- Description
L'ID d'une tâche réussie que vous possédez. Types de tâches pris en charge : Image en 3D, Multi-image en 3D, Texte en 3D, Remaillage et Retexturisation. La tâche doit avoir un statut
SUCCEEDEDet doit avoir produit un asset GLB.
- Name
- model_url
- Type
- string
- Requis
- Description
URL d'un modèle 3D à réparer. Formats pris en charge :
.glb,.stl,.obj. Taille maximale du fichier : 100 Mo. Doit utiliserhttp,httpsou une URLdata:(les URL data contournent les vérifications d'extension).
- Name
- alpha_thumbnail
- Type
- boolean
- défaut false
- Description
Lorsqu'il est défini sur
true, la tâche rend également une version avec arrière-plan transparent (RGBA) de l'aperçu et la renvoie commealpha_thumbnail_urldans la réponse GET. Le champthumbnail_urlexistant reste inchangé.
Retours
La propriété result de la réponse contient l'id de la tâche de réparation de l'imprimabilité nouvellement créée.
Modes d'échec
- Name
400 - Bad Request- Description
La requête était inacceptable. Causes courantes :
- Paramètre manquant : ni
input_task_idnimodel_urln'a été fourni. - UUID invalide :
input_task_idn'est pas un UUID valide. - URL de modèle invalide :
model_urlest mal formée, utilise un schéma non pris en charge ou possède une extension de fichier non prise en charge. - Fichier de modèle trop volumineux : le corps de
model_urla dépassé 100 Mo. - Tâche non réussie : la tâche référencée est toujours PENDING, en progress, ou FAILED.
- GLB manquant : la tâche référencée n'a aucun asset GLB à réparer.
- Paramètre manquant : ni
- Name
401 - Unauthorized- Description
L'authentification a échoué. Veuillez vérifier votre clé API.
- Name
402 - Payment Required- Description
Causes courantes :
- Offre gratuite : la création de tâche nécessite une offre payante. Passez à une offre supérieure sur la page d'abonnement.
- Crédits insuffisants : la limite de crédits de l'espace de travail a été atteinte.
- Name
404 - Not Found- Description
La tâche référencée n'existe pas ou appartient à un autre utilisateur.
- Name
429 - Too Many Requests- Description
Vous avez dépassé votre quota de tâches en attente ou la limite de débit.
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"
}
Récupérer une tâche Réparer l'imprimabilité
Ce point de terminaison récupère une tâche de réparation de l'imprimabilité par son ID.
Paramètres
- Name
- id
- Type
- path
- Description
L'ID de la tâche de réparation de l'imprimabilité à récupérer.
Retours
L'objet de tâche Réparer l'imprimabilité. Le bloc model_urls est vide jusqu'à ce que la tâche atteigne SUCCEEDED. Seul le champ model_urls correspondant au format d'entrée est renseigné.
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
}
Supprimer une tâche Réparer l'imprimabilité
Ce point de terminaison supprime définitivement une tâche Réparer l'imprimabilité et sa sortie réparée. Cette action est irréversible.
Paramètres de chemin
- Name
- id
- Type
- path
- Description
L'ID de la tâche Réparer l'imprimabilité à supprimer.
Renvoie
Renvoie 200 OK en cas de réussite.
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.
Lister les tâches Réparer l'imprimabilité
Ce point de terminaison vous permet de récupérer une liste de tâches de Réparer l'imprimabilité.
Paramètres
Attributs facultatifs
- Name
- page_num
- Type
- integer
- Description
Numéro de page pour la pagination. Commence et vaut par défaut
1.
- Name
- page_size
- Type
- integer
- Description
Limite de taille de page. Par défaut,
10éléments. Le maximum autorisé est de50éléments.
- Name
- sort_by
- Type
- string
- Description
Champ selon lequel trier. Valeurs disponibles :
+created_at: Trier par heure de création dans l'ordre croissant.-created_at: Trier par heure de création dans l'ordre décroissant.
Retour
Retourne une liste paginée d'objets de tâche Réparer l'imprimabilité.
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
}
]
Diffuser une tâche Réparer l'imprimabilité
Ce point de terminaison diffuse des mises à jour en temps réel pour une tâche de réparation d’imprimabilité à l’aide de Server-Sent Events (SSE).
Paramètres
- Name
- id
- Type
- path
- Description
Identifiant unique de la tâche de réparation d’imprimabilité à diffuser.
Retours
Retourne un flux d’objets de tâche Réparer l'imprimabilité sous forme de Server-Sent Events.
Pour les tâches PENDING ou IN_PROGRESS, le flux de réponse inclura uniquement les champs nécessaires progress et status. Le bloc model_urls n’est envoyé qu’une fois que la tâche atteint 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
}
Objet de tâche Réparer l'imprimabilité
- Name
- id
- Type
- string
- Description
Identifiant unique de la tâche. Bien que nous utilisions un UUID k-triable pour les identifiants de tâche comme détail d'implémentation, vous ne devez pas faire d'hypothèse sur le format de l'identifiant.
- Name
- type
- Type
- string
- Description
Type de la tâche Réparer l'imprimabilité. La valeur est
print-repair.
- Name
- status
- Type
- string
- Description
Statut de la tâche. Les valeurs possibles sont l'une des suivantes :
PENDING,IN_PROGRESS,SUCCEEDED,FAILED,CANCELED.
- Name
- progress
- Type
- integer
- Description
Progress de la tâche. Si la tâche n'a pas encore démarré, cette propriété sera
0. Une fois la tâche réussie, elle deviendra100.
- Name
- preceding_tasks
- Type
- integer
- Description
Le nombre de tâches précédentes.
La valeur de ce champ n'est significative que si le statut de la tâche est
PENDING.
- Name
- created_at
- Type
- timestamp
- Description
Horodatage de la création de la tâche, en millisecondes.
- Name
- started_at
- Type
- timestamp
- Description
Horodatage du démarrage de la tâche, en millisecondes. Si la tâche n'a pas encore démarré, cette propriété sera
0.
- Name
- finished_at
- Type
- timestamp
- Description
Horodatage de la fin de la tâche, en millisecondes. Si la tâche n'est pas encore terminée, cette propriété sera
0.
- Name
- expires_at
- Type
- timestamp
- Description
Horodatage auquel le résultat de la tâche expirera dans le système, en millisecondes.
0si la tâche n'est pas encore terminée.
- Name
- task_error
- Type
- object
- Description
Informations d'erreur si la tâche a échoué. Cette propriété est
nullsi la tâche n'a pas échoué. Consultez Erreurs pour plus de détails.- Name
message- Type
- string
- Description
Message d'erreur décrivant ce qui s'est mal passé.
- Name
- model_urls
- Type
- object
- Description
URL téléchargeables vers le modèle 3D réparé. Seul le champ correspondant au format d'entrée est renseigné ; les autres champs de format sont des chaînes vides.
- Name
glb- Type
- string
- Description
URL téléchargeable vers le GLB réparé. Renseignée lorsque l'entrée était un GLB ou lorsque
input_task_ida été utilisé.
- Name
fbx- Type
- string
- Description
Réservé à la sortie FBX. Toujours une chaîne vide pour les tâches Réparer l'imprimabilité.
- Name
obj- Type
- string
- Description
URL téléchargeable vers l'OBJ réparé. Renseignée lorsque l'entrée était un téléversement OBJ.
- Name
stl- Type
- string
- Description
URL téléchargeable vers le STL réparé. Renseignée lorsque l'entrée était un téléversement STL.
- Name
usdz- Type
- string
- Description
Réservé à la sortie USDZ. Toujours une chaîne vide pour les tâches Réparer l'imprimabilité.
- Name
3mf- Type
- string
- Description
Réservé à la sortie 3MF. Toujours une chaîne vide pour les tâches Réparer l'imprimabilité.
- Name
mtl- Type
- string
- Description
Réservé à la sortie MTL. Toujours une chaîne vide pour les tâches Réparer l'imprimabilité.
- Name
- thumbnail_url
- Type
- string
- Description
URL d'une image d'aperçu rendue à partir du modèle réparé.
- Name
- alpha_thumbnail_url
- Type
- string
- Description
URL téléchargeable vers une version à arrière-plan transparent (RGBA) de
thumbnail_url. Présente uniquement lorsque la tâche a été créée avecalpha_thumbnail: trueet que l'aperçu transparent a été rendu avec succès ; sinon, ce champ est omis.
- Name
- texture_urls
- Type
- array
- Description
Toujours un tableau vide. La réparation préserve uniquement la géométrie d'entrée et ne recuit pas les textures.
- Name
- consumed_credits
- Type
- integer
- Description
Le nombre de crédits consommés par cette tâche.
10une fois que la tâche a atteintSUCCEEDED. Renvoie0pour les tâchesFAILED(les crédits sont remboursés en cas d'échec).
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
}