Zalo
Statut : expérimental. Les DMs sont pris en charge. La section Capabilities ci-dessous reflète le comportement actuel du bot Marketplace.
Plugin intégré
Section intitulée « Plugin intégré »Zalo est fourni en tant que plugin intégré dans les versions actuelles d’OpenClaw, donc les versions empaquetées normales n’ont pas besoin d’une installation séparée.
Si vous utilisez une version antérieure ou une installation personnalisée qui exclut Zalo, installez le package npm directement :
- Installer via CLI :
openclaw plugins install @openclaw/zalo - Version épinglée :
openclaw plugins install @openclaw/[email protected] - Ou depuis une source checkout :
openclaw plugins install ./path/to/local/zalo-plugin - Détails : Plugins
Configuration rapide (débutant)
Section intitulée « Configuration rapide (débutant) »- Assurez-vous que le plugin Zalo est disponible.
- Les versions empaquetées actuelles d’OpenClaw l’incluent déjà.
- Les installations anciennes/personnalisées peuvent l’ajouter manuellement avec les commandes ci-dessus.
- Définir le jeton :
- Env :
ZALO_BOT_TOKEN=... - Ou config :
channels.zalo.accounts.default.botToken: "...".
- Env :
- Redémarrez la passerelle (ou terminez la configuration).
- L’accès DM est couplé par défaut ; approuvez le code de couplage lors du premier contact.
Configuration minimale :
{ channels: { zalo: { enabled: true, accounts: { default: { botToken: "12345689:abc-xyz", dmPolicy: "pairing", }, }, }, },}Ce que c’est
Section intitulée « Ce que c’est »Zalo est une application de messagerie axée sur le Vietnam ; son Bot API permet à la Gateway d’exécuter un bot pour des conversations 1:1. C’est un bon choix pour le support ou les notifications où vous souhaitez un routage déterministe vers Zalo.
Cette page reflète le comportement actuel d’OpenClaw pour les bots Marketplace / Zalo Bot Creator. Les bots Zalo Official Account (OA) sont une surface de produit Zalo différente et peuvent se comporter différemment.
- Un channel Zalo Bot API appartenant au Gateway.
- Routage déterministe : les réponses reviennent vers Zalo ; le modèle ne choisit jamais les channels.
- Les DMs partagent la session principale de l’agent.
- La section Capabilities ci-dessous montre le support actuel du bot Marketplace.
Configuration (chemin rapide)
Section intitulée « Configuration (chemin rapide) »1) Créer un jeton de bot (Zalo Bot Platform)
Section intitulée « 1) Créer un jeton de bot (Zalo Bot Platform) »- Allez sur https://bot.zaloplatforms.com et connectez-vous.
- Créez un nouveau bot et configurez ses paramètres.
- Copiez le jeton complet du bot (généralement
numeric_id:secret). Pour les bots Marketplace, le jeton d’exécution utilisable peut apparaître dans le message de bienvenue du bot après sa création.
2) Configurer le jeton (env ou config)
Section intitulée « 2) Configurer le jeton (env ou config) »Exemple :
{ channels: { zalo: { enabled: true, accounts: { default: { botToken: "12345689:abc-xyz", dmPolicy: "pairing", }, }, }, },}Si vous passez ultérieurement à une surface de bot Zalo où les groupes sont disponibles, vous pouvez ajouter une configuration spécifique aux groupes telle que groupPolicy et groupAllowFrom explicitement. Pour le comportement actuel du bot Marketplace, voir Capabilities.
Option Env : ZALO_BOT_TOKEN=... (fonctionne uniquement pour le compte par défaut).
Support multi-compte : utilisez channels.zalo.accounts avec des jetons par compte et name en option.
- Redémarrez la passerelle. Zalo démarre lorsqu’un jeton est résolu (env ou config).
- L’accès DM est par défaut couplé. Approuvez le code lors du premier contact du bot.
Fonctionnement (comportement)
Section intitulée « Fonctionnement (comportement) »- Les messages entrants sont normalisés dans l’enveloppe de channel partagée avec des espaces réservés pour les médias.
- Les réponses sont toujours renvoyées vers le même chat Zalo.
- Long-polling par défaut ; mode webhook disponible avec
channels.zalo.webhookUrl.
- Le texte sortant est découpé en tranches de 2000 caractères (limite de l’Zalo API).
- Les téléchargements/téléversements de médias sont limités par
channels.zalo.mediaMaxMb(défaut 5). - Le streaming est bloqué par défaut car la limite de 2000 caractères rend le streaming moins utile.
Contrôle d’accès (DMs)
Section intitulée « Contrôle d’accès (DMs) »Accès DM
Section intitulée « Accès DM »- Défaut :
channels.zalo.dmPolicy = "pairing". Les expéditeurs inconnus reçoivent un code d’appariement ; les messages sont ignorés jusqu’à approbation (les codes expirent après 1 heure). - Approuver via :
openclaw pairing list zaloopenclaw pairing approve zalo <CODE>
- L’appariement est l’échange de jetons par défaut. Détails : Pairing
channels.zalo.allowFromaccepte les ID utilisateur numériques (aucune recherche de nom d’utilisateur disponible).
Contrôle d’accès (Groupes)
Section intitulée « Contrôle d’accès (Groupes) »Pour les bots Zalo Bot Creator / Marketplace, la prise en charge des groupes n’était pas disponible en pratique car le bot ne pouvait pas être ajouté à un groupe du tout.
Cela signifie que les clés de configuration liées aux groupes ci-dessous existent dans le schéma, mais n’étaient pas utilisables pour les bots Marketplace :
channels.zalo.groupPolicycontrôle la gestion des entrées de groupe :open | allowlist | disabled.channels.zalo.groupAllowFromrestreint quels ID d’expéditeur peuvent déclencher le bot dans les groupes.- Si
groupAllowFromn’est pas défini, Zalo revient àallowFrompour les vérifications de l’expéditeur. - Note d’exécution : si
channels.zaloest manquant, l’exécution revient toujours àgroupPolicy="allowlist"pour la sécurité.
Les valeurs de stratégie de groupe ( lorsque l’accès au groupe est disponible sur votre interface de bot ) sont :
groupPolicy: "disabled"— bloque tous les messages de groupe.groupPolicy: "open"— autorise n’importe quel membre du groupe (limité par mention).groupPolicy: "allowlist"— défaut fermé pour l’échec ; seuls les expéditeurs autorisés sont acceptés.
Si vous utilisez une autre interface de produit bot Zalo et que vous avez vérifié le fonctionnement des groupes, documentez-le séparément plutôt que de supposer qu’il correspond au flux des bots Marketplace.
Long-polling vs webhook
Section intitulée « Long-polling vs webhook »- Par défaut : long-polling (aucune URL publique requise).
- Mode Webhook : définissez
channels.zalo.webhookUrletchannels.zalo.webhookSecret.- Le secret du webhook doit comporter entre 8 et 256 caractères.
- L’URL du webhook doit utiliser HTTPS.
- Zalo envoie des événements avec l’en-tête
X-Bot-Api-Secret-Tokenpour vérification. - Le Gateway HTTP gère les requêtes webhook à
channels.zalo.webhookPath(correspond par défaut au chemin de l’URL du webhook). - Les requêtes doivent utiliser
Content-Type: application/json(ou les types de média+json). - Les événements en double (
event_name + message_id) sont ignorés pendant une courte fenêtre de relecture. - Le trafic en rafale est limité par chemin/source et peut renvoyer une erreur HTTP 429.
Remarque : getUpdates (polling) et le webhook sont mutuellement exclusifs selon la documentation de l’Zalo API.
Types de messages pris en charge
Section intitulée « Types de messages pris en charge »Pour un aperçu rapide du support, voir Capabilities. Les notes ci-dessous ajoutent des détails là où le comportement nécessite un contexte supplémentaire.
- Messages texte : Prise en charge complète avec découpage par tranches de 2000 caractères.
- URL simples dans le texte : Se comportent comme une saisie de texte normale.
- Aperçus de liens / cartes de liens enrichies : Voir le statut du Marketplace-bot dans Capabilities ; ils ne déclenchaient pas de manière fiable une réponse.
- Messages image : Voir le statut du Marketplace-bot dans Capabilities ; le traitement des images entrantes n’était pas fiable (indicateur de frappe sans réponse finale).
- Autocollants : Voir le statut du Marketplace-bot dans Capabilities.
- Notes vocales / fichiers audio / vidéo / pièces jointes génériques : Voir le statut du Marketplace-bot dans Capabilities.
- Types non pris en charge : Enregistrés (par exemple, messages d’utilisateurs protégés).
Fonctionnalités
Section intitulée « Fonctionnalités »Ce tableau résume le comportement actuel des Zalo Bot Creator / Marketplace bot dans OpenClaw.
| Fonctionnalité | Statut |
|---|---|
| Messages directs | ✅ Pris en charge |
| Groupes | ❌ Non disponible pour les bots Marketplace |
| Média (images entrantes) | ⚠️ Limité / à vérifier dans votre environnement |
| Média (images sortantes) | ⚠️ Non testé à nouveau pour les bots Marketplace |
| URL simples dans le texte | ✅ Pris en charge |
| Aperçus de liens | ⚠️ Peu fiable pour les bots Marketplace |
| Réactions | ❌ Non pris en charge |
| Autocollants | ⚠️ Pas de réponse de l’agent pour les bots Marketplace |
| Notes vocales / audio / vidéo | ⚠️ Pas de réponse de l’agent pour les bots Marketplace |
| Pièces jointes de fichiers | ⚠️ Pas de réponse de l’agent pour les bots Marketplace |
| Discussions (Threads) | ❌ Non pris en charge |
| Sondages | ❌ Non pris en charge |
| Commandes natives | ❌ Non pris en charge |
| Streaming | ⚠️ Bloqué (limite de 2000 caractères) |
Cibles de livraison (CLI/cron)
Section intitulée « Cibles de livraison (CLI/cron) »- Utilisez un identifiant de conversation comme cible.
- Exemple :
openclaw message send --channel zalo --target 123456789 --message "hi".
Dépannage
Section intitulée « Dépannage »Le bot ne répond pas :
- Vérifiez que le jeton est valide :
openclaw channels status --probe - Vérifiez que l’expéditeur est approuvé (appairage ou allowFrom)
- Vérifiez les journaux de la passerelle :
openclaw logs --follow
Le webhook ne reçoit pas d’événements :
- Assurez-vous que l’URL du webhook utilise HTTPS
- Vérifiez que le jeton secret comporte de 8 à 256 caractères
- Confirmez que le point de terminaison HTTP de la passerelle est accessible sur le chemin configuré
- Vérifiez que le polling getUpdates n’est pas en cours d’exécution (ils sont mutuellement exclusifs)
Référence de configuration (Zalo)
Section intitulée « Référence de configuration (Zalo) »Configuration complète : Configuration
Les clés plates de premier niveau (channels.zalo.botToken, channels.zalo.dmPolicy et similaires) sont une abréviation héritée pour compte unique. Préférez channels.zalo.accounts.<id>.* pour les nouvelles configurations. Les deux formes sont encore documentées ici car elles existent dans le schéma.
Options du fournisseur :
channels.zalo.enabled: activer/désactiver le démarrage du canal.channels.zalo.botToken: jeton de bot provenant de Zalo Bot Platform.channels.zalo.tokenFile: lire le jeton à partir d’un chemin de fichier ordinaire. Les liens symboliques sont rejetés.channels.zalo.dmPolicy:pairing | allowlist | open | disabled(par défaut : appairage).channels.zalo.allowFrom: liste d’autorisation DM (identifiants utilisateur).opennécessite"*". L’assistant demandera les identifiants numériques.channels.zalo.groupPolicy:open | allowlist | disabled(par défaut : liste d’autorisation). Présent dans la configuration ; voir Capabilities et Access control (Groups) pour le comportement actuel du bot Marketplace.channels.zalo.groupAllowFrom: liste d’autorisation des expéditeurs de groupe (identifiants utilisateur). Revient àallowFromsi non défini.channels.zalo.mediaMaxMb: limite de média entrant/sortant (Mo, par défaut 5).channels.zalo.webhookUrl: activer le mode webhook (HTTPS requis).channels.zalo.webhookSecret: secret du webhook (8-256 caractères).channels.zalo.webhookPath: chemin du webhook sur le serveur HTTP de la passerelle.channels.zalo.proxy: URL du proxy pour les requêtes API.
Options multi-comptes :
channels.zalo.accounts.<id>.botToken: jeton par compte.channels.zalo.accounts.<id>.tokenFile: fichier de jeton ordinaire par compte. Les liens symboliques sont rejetés.channels.zalo.accounts.<id>.name: nom d’affichage.channels.zalo.accounts.<id>.enabled: activer/désactiver le compte.channels.zalo.accounts.<id>.dmPolicy: stratégie DM par compte.channels.zalo.accounts.<id>.allowFrom: liste d’autorisation par compte.channels.zalo.accounts.<id>.groupPolicy: stratégie de groupe par compte. Présent dans la configuration ; voir Capabilities et Access control (Groups) pour le comportement actuel du bot Marketplace.channels.zalo.accounts.<id>.groupAllowFrom: liste d’autorisation des expéditeurs de groupe par compte.channels.zalo.accounts.<id>.webhookUrl: URL de webhook par compte.channels.zalo.accounts.<id>.webhookSecret: secret de webhook par compte.channels.zalo.accounts.<id>.webhookPath: chemin de webhook par compte.channels.zalo.accounts.<id>.proxy: URL de proxy par compte.
Connexes
Section intitulée « Connexes »- Vue d’ensemble des canaux — tous les canaux pris en charge
- Appariement — authentification et flux d’appariement DM
- Groupes — comportement des discussions de groupe et filtrage des mentions
- Routage de canal — routage de session pour les messages
- Sécurité — modèle d’accès et durcissement