Le PluginDocumentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
imessage intégré accède désormais à la même surface d’API privée que BlueBubbles (react, edit, unsend, reply, sendWithEffect, gestion des groupes, pièces jointes) en pilotant steipete/imsg via JSON-RPC. Si vous utilisez déjà un Mac avec imsg installé, vous pouvez supprimer le serveur BlueBubbles et laisser le Plugin communiquer directement avec Messages.app.
La prise en charge de BlueBubbles a été supprimée. OpenClaw prend en charge iMessage uniquement via imsg. Ce guide explique comment migrer les anciennes configurations channels.bluebubbles vers channels.imessage ; aucun autre chemin de migration n’est pris en charge.
Quand cette migration est pertinente
- Vous exécutez déjà
imsgsur le même Mac (ou sur un Mac accessible via SSH) où Messages.app est connecté. - Vous voulez un composant en moins — pas de serveur BlueBubbles séparé, pas de point de terminaison REST à authentifier, pas de câblage Webhook. Un seul binaire CLI au lieu d’un serveur + une application cliente + un assistant.
- Vous utilisez une version macOS /
imsgprise en charge où la sonde d’API privée indiqueavailable: true.
Ce que fait imsg
imsg est une CLI macOS locale pour Messages. OpenClaw démarre imsg rpc comme processus enfant et communique en JSON-RPC via stdin/stdout. Il n’y a pas de serveur HTTP, d’URL Webhook, de démon en arrière-plan, d’agent de lancement ni de port à exposer.
- Les lectures proviennent de
~/Library/Messages/chat.dbau moyen d’un descripteur SQLite en lecture seule. - Les messages entrants en direct proviennent de
imsg watch/watch.subscribe, qui suit les événements du système de fichiers dechat.dbavec un repli par interrogation. - Les envois utilisent l’automatisation de Messages.app pour le texte normal et les fichiers.
- Les actions avancées utilisent
imsg launchpour injecter l’assistantimsgdans Messages.app. C’est ce qui débloque les accusés de lecture, les indicateurs de saisie, les envois enrichis, la modification, l’annulation d’envoi, la réponse en fil, les tapbacks et la gestion des groupes. - Les versions Linux peuvent inspecter un
chat.dbcopié, mais ne peuvent pas envoyer de messages, surveiller la base de données Mac en direct ni piloter Messages.app. Pour OpenClaw iMessage, exécutezimsgsur le Mac connecté ou via un wrapper SSH vers ce Mac.
Avant de commencer
-
Installez
imsgsur le Mac qui exécute Messages.app :Siimsg chatséchoue avecunable to open database file, une sortie vide ouauthorization denied, accordez l’Accès complet au disque au terminal, à l’éditeur, au processus Node, au service Gateway ou au processus parent SSH qui lanceimsg, puis rouvrez ce processus parent. -
Vérifiez les surfaces de lecture, de surveillance, d’envoi et RPC avant de modifier la configuration OpenClaw :
Remplacez
42par un véritable identifiant de discussion provenant deimsg chats. L’envoi nécessite l’autorisation d’automatisation pour Messages.app. Si OpenClaw s’exécute via SSH, exécutez ces commandes avec le même wrapper SSH ou le même contexte utilisateur que celui qu’OpenClaw utilisera. -
Activez le pont d’API privée lorsque vous avez besoin d’actions avancées :
imsg launchexige que SIP soit désactivé. L’envoi de base, l’historique et la surveillance fonctionnent sansimsg launch; les actions avancées ne fonctionnent pas. -
Vérifiez le pont via OpenClaw :
Vous voulez
imessage.privateApi.available: true. S’il indiquefalse, corrigez d’abord cela — consultez Détection des capacités. -
Créez un instantané de votre configuration :
Traduction de la configuration
iMessage et BlueBubbles partagent une grande partie de la configuration au niveau du canal. Les clés qui changent concernent surtout le transport (serveur REST contre CLI locale). Les clés de comportement (dmPolicy, groupPolicy, allowFrom, etc.) conservent la même signification.
| BlueBubbles | iMessage intégré | Remarques |
|---|---|---|
channels.bluebubbles.enabled | channels.imessage.enabled | Même sémantique. |
channels.bluebubbles.serverUrl | (supprimé) | Aucun serveur REST — le plugin lance imsg rpc via stdio. |
channels.bluebubbles.password | (supprimé) | Aucune authentification webhook nécessaire. |
| (implicite) | channels.imessage.cliPath | Chemin vers imsg (par défaut imsg) ; utilisez un script wrapper pour SSH. |
| (implicite) | channels.imessage.dbPath | Remplacement facultatif de chat.db de Messages.app ; détecté automatiquement si omis. |
| (implicite) | channels.imessage.remoteHost | host ou user@host — nécessaire uniquement lorsque cliPath est un wrapper SSH et que vous voulez récupérer des pièces jointes par SCP. |
channels.bluebubbles.dmPolicy | channels.imessage.dmPolicy | Mêmes valeurs (pairing / allowlist / open / disabled). |
channels.bluebubbles.allowFrom | channels.imessage.allowFrom | Les approbations d’appairage sont conservées par identifiant, pas par jeton. |
channels.bluebubbles.groupPolicy | channels.imessage.groupPolicy | Mêmes valeurs (allowlist / open / disabled). |
channels.bluebubbles.groupAllowFrom | channels.imessage.groupAllowFrom | Identique. |
channels.bluebubbles.groups | channels.imessage.groups | Copiez ceci textuellement, y compris toute entrée générique groups: { "*": { ... } }. Les paramètres par groupe requireMention, tools, toolsBySender sont conservés. Avec groupPolicy: "allowlist", un bloc groups vide ou manquant ignore silencieusement chaque message de groupe — voir « Piège du registre de groupes » ci-dessous. |
channels.bluebubbles.sendReadReceipts | channels.imessage.sendReadReceipts | Par défaut true. Avec le plugin intégré, cela ne se déclenche que lorsque la sonde d’API privée est active. |
channels.bluebubbles.includeAttachments | channels.imessage.includeAttachments | Même forme, même désactivation par défaut. Si des pièces jointes circulaient avec BlueBubbles, vous devez redéfinir explicitement ce paramètre sur le bloc iMessage — il n’est pas transféré implicitement, et les photos/médias entrants seront ignorés silencieusement sans ligne de journal Inbound message tant que vous ne le faites pas. |
channels.bluebubbles.attachmentRoots | channels.imessage.attachmentRoots | Racines locales ; mêmes règles de caractères génériques. |
| (N/A) | channels.imessage.remoteAttachmentRoots | Utilisé uniquement lorsque remoteHost est défini pour les récupérations SCP. |
channels.bluebubbles.mediaMaxMb | channels.imessage.mediaMaxMb | Par défaut 16 Mo sur iMessage (la valeur par défaut de BlueBubbles était 8 Mo). Définissez-le explicitement si vous voulez conserver la limite inférieure. |
channels.bluebubbles.textChunkLimit | channels.imessage.textChunkLimit | Par défaut 4000 sur les deux. |
channels.bluebubbles.coalesceSameSenderDms | channels.imessage.coalesceSameSenderDms | Même option à activer explicitement. DM uniquement — les discussions de groupe conservent l’envoi instantané message par message sur les deux canaux. Élargit le délai anti-rebond entrant par défaut à 2500 ms lorsqu’il est activé sans messages.inbound.byChannel.imessage explicite. Voir documentation iMessage § Regroupement des DM envoyés en plusieurs parties. |
channels.bluebubbles.enrichGroupParticipantsFromContacts | (N/A) | iMessage lit déjà les noms d’affichage des expéditeurs depuis chat.db. |
channels.bluebubbles.actions.* | channels.imessage.actions.* | Options par action : reactions, edit, unsend, reply, sendWithEffect, renameGroup, setGroupIcon, addParticipant, removeParticipant, leaveGroup, sendAttachment. |
channels.bluebubbles.accounts.*) se traduisent une pour une en channels.imessage.accounts.*.
Piège du registre de groupes
Le plugin iMessage intégré exécute deux contrôles distincts de liste d’autorisation de groupe l’un après l’autre. Les deux doivent réussir pour qu’un message de groupe atteigne l’agent :- Liste d’autorisation expéditeur / cible de discussion (
channels.imessage.groupAllowFrom) — vérifiée parisAllowedIMessageSender. Correspond aux messages entrants par identifiant d’expéditeur,chat_guid,chat_identifierouchat_id. Même forme que BlueBubbles. - Registre de groupes (
channels.imessage.groups) — vérifié parresolveChannelGroupPolicydepuisinbound-processing.ts:199. AvecgroupPolicy: "allowlist", ce contrôle exige soit :- une entrée générique
groups: { "*": { ... } }(définitallowAll = true), soit - une entrée explicite par
chat_idsousgroups.
- une entrée générique
warn afin que ce comportement ne soit plus silencieux au niveau de journalisation par défaut :
- Un
warnde démarrage unique par compte lorsquegroupPolicy: "allowlist"est défini mais quechannels.imessage.groupsest vide (aucun caractère générique"*", aucune entrée parchat_id) — déclenché avant l’arrivée de tout message. - Un
warnunique parchat_idla première fois qu’un groupe spécifique est ignoré à l’exécution, en nommant le chat_id et la clé exacte à ajouter àgroupspour l’autoriser.
groupAllowFrom et groupPolicy, mais omettent le bloc groups, parce que groups: { "*": { "requireMention": true } } de BlueBubbles ressemble à un paramètre de mention sans rapport. Il est en réalité essentiel pour le contrôle du registre.
La configuration minimale pour que les messages de groupe continuent de circuler après groupPolicy: "allowlist" :
requireMention: true sous * est inoffensif lorsqu’aucun motif de mention n’est configuré : le runtime définit canDetectMention = false et court-circuite l’abandon de mention à inbound-processing.ts:512. Avec des motifs de mention configurés (agents.list[].groupChat.mentionPatterns), cela fonctionne comme prévu.
Si les journaux du Gateway affichent imessage: dropping group message from chat_id=<id> ou la ligne de démarrage imessage: groupPolicy="allowlist" but channels.imessage.groups is empty, la porte 2 abandonne le message — ajoutez le bloc groups.
Étape par étape
-
Ajoutez un bloc iMessage à côté du bloc BlueBubbles existant. Conservez l’ancien bloc uniquement comme source de copie jusqu’à ce que le nouveau chemin soit vérifié :
-
Sonde d’essai à blanc — démarrez le Gateway et confirmez qu’iMessage indique un état sain :
Comme
imessage.enabledvaut encorefalse, aucun trafic iMessage entrant n’est encore routé — mais--probeexerce le pont, ce qui vous permet de détecter les problèmes d’autorisation ou d’installation avant le basculement. -
Basculez. Supprimez la configuration BlueBubbles et activez iMessage en une seule modification de configuration :
Redémarrez le Gateway. Le trafic iMessage entrant passe maintenant par le Plugin intégré.
- Vérifiez les DM. Envoyez un message direct à l’agent ; confirmez que la réponse arrive.
-
Vérifiez les groupes séparément. Les DM et les groupes empruntent des chemins de code différents — la réussite des DM ne prouve pas que les groupes sont routés. Envoyez un message à l’agent dans une conversation de groupe appairée et confirmez que la réponse arrive. Si le groupe devient silencieux (aucune réponse de l’agent, aucune erreur), vérifiez dans le journal du Gateway la présence de
imessage: dropping group message from chat_id=<id>ou de la ligne de démarrageimessage: groupPolicy="allowlist" but channels.imessage.groups is empty— toutes deux se déclenchent au niveau de journalisation par défaut. Si l’une ou l’autre apparaît, votre blocgroupsest manquant ou vide — consultez « Piège du registre de groupes » ci-dessus. -
Vérifiez la surface d’action — depuis un DM appairé, demandez à l’agent de réagir, modifier, annuler l’envoi, répondre, envoyer une photo et (dans un groupe) renommer le groupe / ajouter ou supprimer un participant. Chaque action doit arriver nativement dans Messages.app. Si l’une d’elles renvoie « iMessage
<action>requires the imsg private API bridge », exécutez à nouveauimsg launchet actualisezchannels status --probe. -
Supprimez le serveur et la configuration BlueBubbles une fois que les DM, groupes et actions iMessage sont vérifiés. OpenClaw n’utilisera pas
channels.bluebubbles.
Parité des actions en bref
| Action | BlueBubbles hérité | iMessage intégré |
|---|---|---|
| Envoyer du texte / repli SMS | ✅ | ✅ |
| Envoyer des médias (photo, vidéo, fichier, voix) | ✅ | ✅ |
Réponse en fil (reply_to_guid) | ✅ | ✅ (clôt #51892) |
Tapback (react) | ✅ | ✅ |
| Modifier / annuler l’envoi (destinataires macOS 13+) | ✅ | ✅ |
| Envoyer avec un effet d’écran | ✅ | ✅ (clôt une partie de #9394) |
| Texte enrichi gras / italique / souligné / barré | ✅ | ✅ (mise en forme par segments typés via attributedBody) |
| Renommer le groupe / définir l’icône du groupe | ✅ | ✅ |
| Ajouter / supprimer un participant, quitter le groupe | ✅ | ✅ |
| Accusés de lecture et indicateur de saisie | ✅ | ✅ (conditionné par la sonde d’API privée) |
| Coalescence des DM du même expéditeur | ✅ | ✅ (DM uniquement ; optionnel via channels.imessage.coalesceSameSenderDms) |
| Rattrapage des messages entrants reçus pendant l’arrêt du Gateway | ✅ (relecture Webhook + récupération de l’historique) | ✅ (optionnel via channels.imessage.catchup.enabled ; clôt #78649) |
channels.imessage.catchup.enabled vaut true, le Gateway exécute une passe chats.list + messages.history par conversation sur le même client JSON-RPC que celui utilisé par imsg watch, relit chaque ligne entrante manquée via le chemin de dispatch en direct (listes d’autorisation, stratégie de groupe, anti-rebond, cache d’écho) et persiste un curseur par compte afin que les démarrages suivants reprennent là où ils s’étaient arrêtés. Consultez Rattraper après une indisponibilité du Gateway pour le réglage.
Appairage, sessions et liaisons ACP
- Les approbations d’appairage sont conservées par identifiant. Vous n’avez pas besoin de réapprouver les expéditeurs connus —
channels.imessage.allowFromreconnaît les mêmes chaînes+15555550123/user@example.comqu’utilisait BlueBubbles. - Les sessions restent limitées par agent + conversation. Les DM se replient dans la session principale de l’agent avec le
session.dmScope=mainpar défaut ; les sessions de groupe restent isolées parchat_id. Les clés de session diffèrent (agent:<id>:imessage:group:<chat_id>par rapport à l’équivalent BlueBubbles) — l’ancien historique de conversation sous les clés de session BlueBubbles n’est pas transféré dans les sessions iMessage. - Les liaisons ACP qui référencent
match.channel: "bluebubbles"doivent être mises à jour vers"imessage". Les formes dematch.peer.id(chat_id:,chat_guid:,chat_identifier:, identifiant nu) sont identiques.
Aucun canal de rollback
Il n’existe aucun runtime BlueBubbles pris en charge vers lequel revenir. Si la vérification iMessage échoue, définissezchannels.imessage.enabled: false, redémarrez le Gateway, corrigez le blocage imsg, puis retentez le basculement.
Le cache de réponses se trouve à ~/.openclaw/state/imessage/reply-cache.jsonl (mode 0600, répertoire parent 0700). Vous pouvez le supprimer sans risque si vous voulez repartir de zéro.
Connexe
- iMessage — référence complète du canal iMessage, y compris la configuration
imsg launchet la détection des capacités. /channels/bluebubbles— URL héritée qui redirige vers ce guide de migration.- Appairage — authentification DM et flux d’appairage.
- Routage des canaux — comment le Gateway choisit un canal pour les réponses sortantes.