Poll (Unifié)
Guide d'intégration application mobile
Poll (Unifié)
L'endpoint préféré pour la boucle de service Android. Un seul POST remplace les appels séparés à heartbeat, pending_messages, get_config et la récupération des commandes.
Recommended: Use
poll as your primary background-service loop. It replaces pending_messages, heartbeat, get_config, and command fetching in a single request.
Corps de requête (all fields optional)
| Champ | Type | Description |
|---|---|---|
| service_active | boolean | true si le service en arrière-plan est en cours d'exécution. |
| sms_count | integer | Total des SMS envoyés depuis la dernière réinitialisation. |
| fail_count | integer | Total des messages échoués depuis la dernière réinitialisation. |
| whatsapp_enabled | boolean | true si WhatsApp est connecté sur l'appareil. |
| is_default_sms | boolean | true si cette application est le gestionnaire SMS par défaut. |
| fcm_token | string | Token FCM mis à jour (envoyez seulement quand il change). |
| ack_ids | integer[] | Tableau d'IDs de commandes à acquitter et supprimer avant d'en recevoir de nouvelles. |
| sms_limit | integer | Éléments SMS maximum à retourner dans cette réponse (1-10, défaut 1). |
| wa_limit | integer | Éléments WhatsApp maximum à retourner dans cette réponse (1-10, défaut 10). |
Exemple de requête
cURL
curl -X POST "https://api.rcszilla.com/?endpoint=poll" \
-H "Content-Type: application/json" \
-H "Authorization: Bearer YOUR-DEVICE-TOKEN" \
-d '{
"service_active": true,
"sms_count": 42,
"fail_count": 1,
"whatsapp_enabled": false,
"is_default_sms": true,
"ack_ids": [88, 89],
"sms_limit": 5,
"wa_limit": 10
}'
Réponse
JSON200 OK
{
"success": true,
"config": {
"retry_limit": "3",
"poll_interval_seconds": "5"
},
"commands": [
{"id": 90, "command": "restart_service", "payload": null}
],
"sms": [
{
"id": 103,
"channel": "sms",
"phone": "+40712345678",
"message": "Hello!",
"sim_slot": 0,
"device_id": 7,
"campaign_id": null,
"priority": 1,
"scheduled_at": null,
"created_at": "2026-04-29 10:05:00"
}
],
"whatsapp": [],
"ai_config": null
}
Response Fields
| Champ | Type | Description |
|---|---|---|
| config | object | Key/value device configuration set from the web panel. |
| commands | array | Pending commands for this device. ACK them via ack_ids on the next poll. |
| sms | array | Claimed SMS messages ready to send (same schema as pending_messages). |
| array | Claimed WhatsApp messages ready to send. | |
| ai_config | object|null | WhatsApp Gemini AI configuration (system prompt, keys, model settings). null if not configured. |
Command Payload
| command | Description |
|---|---|
| restart_service | App should restart its background SMS service. |
| set_default_sms | Prompt user to set app as default SMS handler. |
| update_config | Re-fetch config (payload contains changed keys). |
À chaque poll, le serveur réinitialise automatiquement les messages bloqués en
processing depuis plus de 5 minutes vers pending.Typical Service Loop (Android)
Kotlin (pseudocode)
while (serviceRunning) {
val resp = api.poll(
service_active = true,
sms_count = smsSentTotal,
ack_ids = pendingAckIds
)
pendingAckIds.clear()
for (cmd in resp.commands) handleCommand(cmd)
for (sms in resp.sms) sendSms(sms)
for (wa in resp.whatsapp) sendWhatsApp(wa)
Thread.sleep(pollIntervalMs)
}