Poll (Vereinheitlicht)
Integrationsleitfaden für mobile App
Poll (Vereinheitlicht)
Der bevorzugte Endpoint für die Android-Service-Schleife. Ein einzelner POST ersetzt separate Aufrufe an heartbeat, pending_messages, get_config und Befehlsabruf.
Recommended: Use
poll as your primary background-service loop. It replaces pending_messages, heartbeat, get_config, and command fetching in a single request.
Anfragekörper (all fields optional)
| Feld | Typ | Beschreibung |
|---|---|---|
| service_active | boolean | true wenn der Hintergrunddienst läuft. |
| sms_count | integer | Gesamte SMS seit letztem Reset. |
| fail_count | integer | Gesamte fehlgeschlagene Nachrichten seit letztem Reset. |
| whatsapp_enabled | boolean | true wenn WhatsApp auf dem Gerät verbunden ist. |
| is_default_sms | boolean | true wenn diese App der Standard-SMS-Handler ist. |
| fcm_token | string | Aktualisiertes FCM-Token (nur senden wenn es sich ändert). |
| ack_ids | integer[] | Array von Befehls-IDs zum Bestätigen und Löschen vor dem Empfang neuer. |
| sms_limit | integer | Maximale SMS-Elemente in dieser Antwort (1-10, Standard 1). |
| wa_limit | integer | Maximale WhatsApp-Elemente in dieser Antwort (1-10, Standard 10). |
Beispielanfrage
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
}'
Antwort
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
| Feld | Typ | Beschreibung |
|---|---|---|
| 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 | Beschreibung |
|---|---|
| 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). |
Bei jedem Poll setzt der Server Nachrichten, die seit mehr als 5 Minuten in
processing stecken, automatisch auf pending zurück.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)
}