Aller au contenu principal

API Templates SMS

Endpoints pour la gestion des modeles de messages SMS.

Endpoints

MethodeEndpointDescription
GET/api/sms-templatesListe des templates
POST/api/sms-templatesCreer un template
GET/api/sms-templates/{id}Detail d'un template
PUT/api/sms-templates/{id}Modifier un template
DELETE/api/sms-templates/{id}Supprimer un template

Liste des templates

GET /api/sms-templates

Parametres

ParametreTypeDescription
typeEvenementstringFiltrer par type
languestringFiltrer par langue
actifboolFiltrer par statut

Exemple

curl "https://sig.ucp-pch.org/api/sms-templates?langue=cr&actif=true" \
-H "Authorization: Bearer TOKEN"

Reponse

{
"success": true,
"data": [
{
"id": "550e8400-e29b-41d4-a716-446655440000",
"typeEvenement": "rappel_general",
"codLangue": "cr",
"contenu": "{nom}, lembra di kumpri bo paiementu na {date}.",
"actif": true,
"createdAt": "2026-01-15T10:00:00+00:00"
}
]
}

Creer un template

POST /api/sms-templates

Corps de requete

{
"typeEvenement": "rappel_general",
"codLangue": "cr",
"contenu": "{nom}, lembra di kumpri bo paiementu na {date}.",
"actif": true
}

Champs

ChampTypeObligatoireDescription
typeEvenementstringOuiType d'evenement
codLanguestringOuiCode langue (pt, cr, ff, etc.)
contenustringOuiContenu du message avec variables
actifboolNonActif par defaut

Types d'evenement valides

  • rappel_general
  • information
  • sensibilisation
  • convocation
  • paiement_success
  • paiement_failed
  • paiement_pending
  • paiement_reminder

Langues valides

CodeLangue
ptPortugues
crCrioulo
frFrancais
ffFula (Pulaar)
balBalanta
manMandinka
mjcManjaco
pboPapel
flaFelupe
bjgBijago
knfMancanha

Variables disponibles

VariableDescription
{nom}Nom du destinataire
{montant}Montant du transfert
{reference}Reference transaction
{date}Date de l'evenement
{cycle}Nom du cycle
{programme}Nom du programme

Reponse

{
"success": true,
"data": {
"id": "550e8400-e29b-41d4-a716-446655440001",
"typeEvenement": "rappel_general",
"codLangue": "cr",
"contenu": "{nom}, lembra di kumpri bo paiementu na {date}.",
"actif": true,
"createdAt": "2026-03-15T10:30:00+00:00"
}
}

Erreurs

CodeDescription
409Template existe deja pour ce type+langue
422Langue ou type invalide

Detail d'un template

GET /api/sms-templates/{id}

Reponse

{
"success": true,
"data": {
"id": "550e8400-e29b-41d4-a716-446655440000",
"typeEvenement": "rappel_general",
"codLangue": "cr",
"contenu": "{nom}, lembra di kumpri bo paiementu na {date}.",
"actif": true,
"createdAt": "2026-01-15T10:00:00+00:00",
"updatedAt": "2026-03-10T14:30:00+00:00"
}
}

Modifier un template

PUT /api/sms-templates/{id}

Corps de requete

{
"contenu": "{nom}, bo paiementu di {montant} sta pronto pa kobri. Data: {date}.",
"actif": true
}

Champs modifiables

ChampTypeDescription
contenustringNouveau contenu
actifboolStatut actif/inactif
remarque

Le type d'evenement et la langue ne sont pas modifiables. Creez un nouveau template si necessaire.

Reponse

{
"success": true,
"data": {
"id": "550e8400-e29b-41d4-a716-446655440000",
"typeEvenement": "rappel_general",
"codLangue": "cr",
"contenu": "{nom}, bo paiementu di {montant} sta pronto pa kobri. Data: {date}.",
"actif": true,
"updatedAt": "2026-03-15T11:00:00+00:00"
}
}

Supprimer un template

DELETE /api/sms-templates/{id}

Reponse

{
"success": true,
"message": "Template supprime"
}

Erreurs

CodeDescription
404Template non trouve
409Template utilise par des campagnes

Tester un template

POST /api/sms-templates/{id}/render

Permet de tester le rendu d'un template avec des donnees de test.

Corps de requete

{
"variables": {
"nom": "Mamadou Diallo",
"montant": "50,000 GNF",
"date": "15/03/2026",
"reference": "TRF-2026-001"
}
}

Reponse

{
"success": true,
"data": {
"message": "Mamadou Diallo, bo paiementu di 50,000 GNF sta pronto pa kobri. Data: 15/03/2026.",
"longueur": 78,
"nbSms": 1
}
}

Codes d'erreur

CodeDescription
400Requete invalide
401Non authentifie
403Permission refusee
404Template non trouve
409Conflit (doublon ou en cours d'utilisation)
422Erreur de validation

Permissions

EndpointPermission
GET (lecture)sms.templates_view
POST/PUT/DELETEsms.templates_edit