Aller au contenu

Zalo

Statut : expérimental. Les DMs sont pris en charge. La section Capabilities ci-dessous reflète le comportement actuel des bots Marketplace.

Zalo est fourni sous forme de plugin et n’est pas inclus dans l’installation de base.

  • Installer via CLI : openclaw plugins install @openclaw/zalo
  • Ou sélectionnez Zalo lors de la configuration et confirmez la invite d’installation
  • Détails : Plugins
  1. Installer le plugin Zalo :
    • À partir d’une source extraite : openclaw plugins install ./path/to/local/zalo-plugin
    • À partir de npm (si publié) : openclaw plugins install @openclaw/zalo
    • Ou choisissez Zalo dans la configuration et confirmez la invite d’installation
  2. Définir le jeton :
    • Env : ZALO_BOT_TOKEN=...
    • Ou config : channels.zalo.accounts.default.botToken: "...".
  3. Redémarrez la passerelle (ou terminez la configuration).
  4. 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",
},
},
},
},
}

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 des bots Marketplace.
  1. Allez sur https://bot.zaloplatforms.com et connectez-vous.
  2. Créez un nouveau bot et configurez ses paramètres.
  3. 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.

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 des bots 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 facultatifs.

  1. Redémarrez la passerelle. Zalo démarre lorsqu’un jeton est résolu (env ou config).
  2. L’accès DM est par défaut couplé. Approuvez le code lors du premier contact du bot.
  • 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 (5 par défaut).
  • Le streaming est bloqué par défaut car la limite de 2000 caractères rend le streaming moins utile.
  • Par 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 zalo
    • openclaw pairing approve zalo <CODE>
  • L’appariement est l’échange de jetons par défaut. Détails : Appariement
  • channels.zalo.allowFrom accepte les ID utilisateur numériques (aucune recherche par nom d’utilisateur disponible).

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.groupPolicy contrôle le traitement des messages entrants du groupe : open | allowlist | disabled.
  • channels.zalo.groupAllowFrom restreint les ID d’expéditeur pouvant déclencher le bot dans les groupes.
  • Si groupAllowFrom n’est pas défini, Zalo revient à allowFrom pour les vérifications d’expéditeur.
  • Remarque d’exécution : si channels.zalo est entièrement manquant, l’exécution revient toujours à groupPolicy="allowlist" par 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" — permet à n’importe quel membre du groupe (limité par mention).
  • groupPolicy: "allowlist" — défaut sécurisé (fail-closed) ; 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.

  • Par défaut : long-polling (aucune URL publique requise).
  • Mode Webhook : définissez channels.zalo.webhookUrl et channels.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-Token pour vérification.
    • Gateway HTTP gère les demandes de webhook à channels.zalo.webhookPath (correspond par défaut au chemin de l’URL du webhook).
    • Les demandes doivent utiliser Content-Type: application/json (ou 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.

Pour un aperçu rapide de la prise en charge, consultez la section Fonctionnalités. Les notes ci-dessous apportent 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 riches : Consultez le statut du bot Marketplace dans la section Fonctionnalités ; ils ne déclenchaient pas de réponse de manière fiable.
  • Messages image : Consultez le statut du bot Marketplace dans la section Fonctionnalités ; le traitement des images entrantes n’était pas fiable (indicateur de frappe sans réponse finale).
  • Autocollants : Consultez le statut du bot Marketplace dans la section Fonctionnalités.
  • Notes vocales / fichiers audio / vidéo / pièces jointes génériques : Consultez le statut du bot Marketplace dans la section Fonctionnalités.
  • Types non pris en charge : Enregistrés (par exemple, messages d’utilisateurs protégé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)
  • Utilisez un identifiant de conversation comme cible.
  • Exemple : openclaw message send --channel zalo --target 123456789 --message "hi".

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)
  • Consultez 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)

Configuration complète : Configuration

Les clés plates de premier niveau (channels.zalo.botToken, channels.zalo.dmPolicy, et similaires) sont un raccourci hérité pour compte unique. Privilégiez 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 du bot depuis la plateforme Bot Zalo.
  • channels.zalo.tokenFile : lire le jeton depuis un chemin de fichier régulier. 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 utilisateurs). open né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 Capacités et Contrôle d’accès (Groupes) pour le comportement actuel du bot Marketplace.
  • channels.zalo.groupAllowFrom : liste d’autorisation des expéditeurs de groupe (identifiants utilisateurs). Revient à allowFrom si 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 régulier 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 : politique 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.