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/notify

Authentification

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_here

Paramètres de chemin

ParamètreTypeRequisDéfautDescription
order_idstringOui-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ètreTypeRequisDéfautDescription
channelsstring[]Oui-Canaux de notification à utiliser: "email", "sms", "whatsapp". Au moins un canal est requis pour éviter les notifications accidentelles.
use_shopify_order_idbooleanNonfalseDé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

ChampTypeDescription
messagestringMessage de confirmation
order_idstringUUID de la commande
notifications_sentobjectObjet contenant le statut de notification pour chaque canal

Champs d'objet de notifications envoyées

ChampTypeDescription
emailstringStatut de notification email: "sent", "skipped", ou "failed"
smsstringStatut de notification SMS: "sent", "skipped", ou "failed"
whatsappstringStatut 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 minute
  • X-RateLimit-Remaining-Minute: Requêtes restantes dans la minute en cours
  • X-RateLimit-Reset-Minute: Horodatage Unix de réinitialisation de la fenêtre minute
  • X-RateLimit-Limit-Day: Nombre maximum de requêtes par jour
  • X-RateLimit-Remaining-Day: Requêtes restantes dans le jour en cours
  • X-RateLimit-Reset-Day: Horodatage Unix de réinitialisation de la fenêtre jour
  • Retry-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"
  }
}