POST
Envoyer une notification
Forcer l'envoi de notifications client (email, SMS, WhatsApp) pour une commande spécifique.
Point de terminaison
Requête HTTP
POST /v1/orders/:order_id/notifyAuthentification
Ce point de terminaison nécessite une clé API valide avec la permission
canSendNotifications . La clé API doit être passée dans l'en-tête X-API-Key .En-tête requis
X-API-Key: your_api_key_hereParamètres de chemin
| Paramètre | Type | Requis | Défaut | Description |
|---|---|---|---|---|
order_id | string | Oui | - | Identifiant de commande (UUID par défaut, ou partie numérique de l'ID Shopify si use_shopify_order_id est activé dans le corps de la requête) |
Corps de la requête
| Paramètre | Type | Requis | Défaut | Description |
|---|---|---|---|---|
channels | string[] | Oui | - | Canaux de notification à utiliser: "email", "sms", "whatsapp". Au moins un canal est requis pour éviter les notifications accidentelles. |
use_shopify_order_id | boolean | Non | false | Définir à 'true' pour rechercher la commande en utilisant l'ID Shopify. Extraire le numéro du format GID Shopify (gid://shopify/Order/450789469 → 450789469) et l'utiliser dans le chemin URL |
Réponse
Retourne les résultats détaillés des notifications:
200 OK - Réponse de succès
{
"message": "Notification request processed",
"order_id": "550e8400-e29b-41d4-a716-446655440000",
"notifications_sent": {
"email": "sent",
"sms": "sent",
"whatsapp": "skipped"
}
}Champs de réponse
Objet de réponse racine
| Champ | Type | Description |
|---|---|---|
message | string | Message de confirmation |
order_id | string | UUID de la commande |
notifications_sent | object | Objet contenant le statut de notification pour chaque canal |
Champs d'objet de notifications envoyées
| Champ | Type | Description |
|---|---|---|
email | string | Statut de notification email: "sent", "skipped", ou "failed" |
sms | string | Statut de notification SMS: "sent", "skipped", ou "failed" |
whatsapp | string | Statut de notification WhatsApp: "sent", "skipped", ou "failed" |
Exemples
Requête de base
Requête cURL
curl -X POST "https://api.ultimate-custom-order-status.apps.msmtech.ca/api/v1/orders/550e8400-e29b-41d4-a716-446655440000/notify" \
-H "X-API-Key: your_api_key_here" \
-H "Content-Type: application/json" \
-d '{
"channels": ["email", "sms"]
}'Using Shopify Order ID
Requête cURL
curl -X POST "https://api.ultimate-custom-order-status.apps.msmtech.ca/api/v1/orders/5460132438316/notify" \
-H "X-API-Key: your_api_key_here" \
-H "Content-Type: application/json" \
-d '{
"channels": ["email"],
"use_shopify_order_id": true
}'Limitation de débit
Ce point de terminaison est soumis à des limites de débit par minute et par jour en fonction de votre clé API. Les informations de limite de débit sont renvoyées dans les en-têtes de réponse:
X-RateLimit-Limit-Minute: Nombre maximum de requêtes par minuteX-RateLimit-Remaining-Minute: Requêtes restantes dans la minute en coursX-RateLimit-Reset-Minute: Horodatage Unix de réinitialisation de la fenêtre minuteX-RateLimit-Limit-Day: Nombre maximum de requêtes par jourX-RateLimit-Remaining-Day: Requêtes restantes dans le jour en coursX-RateLimit-Reset-Day: Horodatage Unix de réinitialisation de la fenêtre jourRetry-After: Secondes à attendre avant de réessayer (en cas de limitation)
Réponses d'erreur
400 Mauvaise requête
Corps de requête invalide
400 Mauvaise requête
{
"error": "Validation failed",
"details": {
"errors": [...]
}
}401 Non autorisé
Clé API manquante ou invalide
401 Non autorisé
{
"error": "Unauthorized"
}403 Interdit
La clé API manque de permissions requises
403 Interdit
{
"error": "Insufficient permissions"
}404 Non trouvé
Commande non trouvée
404 Non trouvé
{
"error": "Order not found",
"details": {
"orderId": "550e8400-e29b-41d4-a716-446655440000"
}
}500 Erreur interne du serveur
Une erreur du serveur s'est produite
500 Erreur interne du serveur
{
"error": "Internal server error",
"details": {
"message": "Error description"
}
}