Mainstream messaging
Migration de Matrix
Passez du précédent Plugin public matrix à l’implémentation actuelle.
Pour la plupart des utilisateurs, la mise à niveau se fait sur place :
- le Plugin reste
@openclaw/matrix - le canal reste
matrix - votre configuration reste sous
channels.matrix - les identifiants mis en cache restent sous
~/.openclaw/credentials/matrix/ - l’état d’exécution reste sous
~/.openclaw/matrix/
Vous n’avez pas besoin de renommer les clés de configuration ni de réinstaller le Plugin sous un nouveau nom.
Ce que la migration fait automatiquement
Lorsque le Gateway démarre, et lorsque vous exécutez openclaw doctor --fix, OpenClaw tente de réparer automatiquement l’ancien état Matrix.
Avant qu’une étape de migration Matrix exploitable ne modifie l’état sur disque, OpenClaw crée ou réutilise un instantané de récupération ciblé.
Lorsque vous utilisez openclaw update, le déclencheur exact dépend de la façon dont OpenClaw est installé :
- les installations depuis les sources exécutent
openclaw doctor --fixpendant le flux de mise à jour, puis redémarrent le Gateway par défaut - les installations via un gestionnaire de paquets mettent à jour le paquet, exécutent un passage doctor non interactif, puis s’appuient sur le redémarrage par défaut du Gateway afin que le démarrage puisse terminer la migration Matrix
- si vous utilisez
openclaw update --no-restart, la migration Matrix prise en charge au démarrage est différée jusqu’à ce que vous exécutiez plus tardopenclaw doctor --fixet redémarriez le Gateway
La migration automatique couvre :
- la création ou la réutilisation d’un instantané de pré-migration sous
~/Backups/openclaw-migrations/ - la réutilisation de vos identifiants Matrix mis en cache
- la conservation de la même sélection de compte et de la configuration
channels.matrix - le déplacement du plus ancien magasin de synchronisation Matrix plat vers l’emplacement actuel limité au compte
- le déplacement du plus ancien magasin de chiffrement Matrix plat vers l’emplacement actuel limité au compte lorsque le compte cible peut être résolu en toute sécurité
- l’extraction d’une clé de déchiffrement de sauvegarde de clés de salle Matrix précédemment enregistrée depuis l’ancien magasin de chiffrement rust, lorsque cette clé existe localement
- la réutilisation de la racine de stockage par hachage de jeton la plus complète pour le même compte Matrix, serveur d’accueil et utilisateur lorsque le jeton d’accès change plus tard
- l’analyse des racines de stockage par hachage de jeton voisines à la recherche de métadonnées de restauration d’état chiffré en attente lorsque le jeton d’accès Matrix a changé mais que l’identité de compte/appareil est restée la même
- la restauration des clés de salle sauvegardées dans le nouveau magasin de chiffrement au prochain démarrage de Matrix
Détails de l’instantané :
- OpenClaw écrit un fichier marqueur à
~/.openclaw/matrix/migration-snapshot.jsonaprès un instantané réussi afin que les passages de démarrage et de réparation ultérieurs puissent réutiliser la même archive. - Ces instantanés automatiques de migration Matrix sauvegardent uniquement la configuration et l’état (
includeWorkspace: false). - Si Matrix n’a qu’un état de migration avec avertissements uniquement, par exemple parce que
userIdouaccessTokenmanque encore, OpenClaw ne crée pas encore l’instantané, car aucune mutation Matrix n’est exploitable. - Si l’étape d’instantané échoue, OpenClaw ignore la migration Matrix pour cette exécution au lieu de modifier l’état sans point de récupération.
À propos des mises à niveau multi-comptes :
- le plus ancien magasin Matrix plat (
~/.openclaw/matrix/bot-storage.jsonet~/.openclaw/matrix/crypto/) provenait d’une disposition à magasin unique, OpenClaw ne peut donc le migrer que vers une seule cible de compte Matrix résolue - les anciens magasins Matrix déjà limités au compte sont détectés et préparés pour chaque compte Matrix configuré
Ce que la migration ne peut pas faire automatiquement
Le précédent Plugin public Matrix ne créait pas automatiquement de sauvegardes de clés de salle Matrix. Il persistait l’état de chiffrement local et demandait la vérification de l’appareil, mais il ne garantissait pas que vos clés de salle étaient sauvegardées sur le serveur d’accueil.
Cela signifie que certaines installations chiffrées ne peuvent être migrées que partiellement.
OpenClaw ne peut pas récupérer automatiquement :
- les clés de salle uniquement locales qui n’ont jamais été sauvegardées
- l’état chiffré lorsque le compte Matrix cible ne peut pas encore être résolu parce que
homeserver,userIdouaccessTokenne sont toujours pas disponibles - la migration automatique d’un magasin Matrix plat partagé lorsque plusieurs comptes Matrix sont configurés mais que
channels.matrix.defaultAccountn’est pas défini - les installations avec chemin de Plugin personnalisé qui sont épinglées à un chemin de dépôt au lieu du paquet Matrix standard
- une clé de récupération manquante lorsque l’ancien magasin contenait des clés sauvegardées mais ne conservait pas la clé de déchiffrement localement
Portée actuelle des avertissements :
- les installations avec chemin de Plugin Matrix personnalisé sont signalées à la fois par le démarrage du Gateway et par
openclaw doctor
Si votre ancienne installation avait un historique chiffré uniquement local qui n’a jamais été sauvegardé, certains messages chiffrés plus anciens peuvent rester illisibles après la mise à niveau.
Flux de mise à niveau recommandé
-
Mettez à jour OpenClaw et le Plugin Matrix normalement. Préférez un simple
openclaw updatesans--no-restartafin que le démarrage puisse terminer immédiatement la migration Matrix. -
Exécutez :
openclaw doctor --fixSi Matrix a un travail de migration exploitable, doctor créera ou réutilisera d’abord l’instantané de pré-migration et affichera le chemin de l’archive.
-
Démarrez ou redémarrez le Gateway.
-
Vérifiez l’état actuel de vérification et de sauvegarde :
openclaw matrix verify status openclaw matrix verify backup status -
Placez la clé de récupération du compte Matrix que vous réparez dans une variable d’environnement propre au compte. Pour un seul compte par défaut,
MATRIX_RECOVERY_KEYconvient. Pour plusieurs comptes, utilisez une variable par compte, par exempleMATRIX_RECOVERY_KEY_ASSISTANT, et ajoutez--account assistantà la commande. -
Si OpenClaw vous indique qu’une clé de récupération est nécessaire, exécutez la commande pour le compte correspondant :
printf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdin printf '%s\n' "$MATRIX_RECOVERY_KEY_ASSISTANT" | openclaw matrix verify backup restore --recovery-key-stdin --account assistant -
Si cet appareil n’est toujours pas vérifié, exécutez la commande pour le compte correspondant :
printf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin printf '%s\n' "$MATRIX_RECOVERY_KEY_ASSISTANT" | openclaw matrix verify device --recovery-key-stdin --account assistantSi la clé de récupération est acceptée et que la sauvegarde est utilisable, mais que
Cross-signing verifiedvaut toujoursno, terminez l’auto-vérification depuis un autre client Matrix :openclaw matrix verify selfAcceptez la demande dans un autre client Matrix, comparez les émojis ou les nombres décimaux, et saisissez
yesuniquement lorsqu’ils correspondent. La commande se termine avec succès uniquement après queCross-signing verifieddevientyes. -
Si vous abandonnez volontairement l’ancien historique irrécupérable et voulez une nouvelle base de sauvegarde pour les futurs messages, exécutez :
openclaw matrix verify backup reset --yes -
Si aucune sauvegarde de clés côté serveur n’existe encore, créez-en une pour les futures récupérations :
openclaw matrix verify bootstrap
Fonctionnement de la migration chiffrée
La migration chiffrée est un processus en deux étapes :
- Le démarrage ou
openclaw doctor --fixcrée ou réutilise l’instantané de pré-migration si la migration chiffrée est exploitable. - Le démarrage ou
openclaw doctor --fixinspecte l’ancien magasin de chiffrement Matrix via l’installation active du Plugin Matrix. - Si une clé de déchiffrement de sauvegarde est trouvée, OpenClaw l’écrit dans le nouveau flux de clé de récupération et marque la restauration des clés de salle comme en attente.
- Au prochain démarrage de Matrix, OpenClaw restaure automatiquement les clés de salle sauvegardées dans le nouveau magasin de chiffrement.
Si l’ancien magasin signale des clés de salle qui n’ont jamais été sauvegardées, OpenClaw émet un avertissement au lieu de prétendre que la récupération a réussi.
Messages courants et leur signification
Messages de mise à niveau et de détection
Matrix plugin upgraded in place.
- Signification : l’ancien état Matrix sur disque a été détecté et migré vers la disposition actuelle.
- Action à effectuer : rien, sauf si la même sortie inclut également des avertissements.
Matrix migration snapshot created before applying Matrix upgrades.
- Signification : OpenClaw a créé une archive de récupération avant de modifier l’état Matrix.
- Action à effectuer : conservez le chemin d’archive affiché jusqu’à ce que vous confirmiez que la migration a réussi.
Matrix migration snapshot reused before applying Matrix upgrades.
- Signification : OpenClaw a trouvé un marqueur d’instantané de migration Matrix existant et a réutilisé cette archive au lieu de créer une sauvegarde en double.
- Action à effectuer : conservez le chemin d’archive affiché jusqu’à ce que vous confirmiez que la migration a réussi.
Legacy Matrix state detected at ... but channels.matrix is not configured yet.
- Signification : un ancien état Matrix existe, mais OpenClaw ne peut pas l’associer à un compte Matrix actuel parce que Matrix n’est pas configuré.
- Action à effectuer : configurez
channels.matrix, puis réexécutezopenclaw doctor --fixou redémarrez le Gateway.
Legacy Matrix state detected at ... but the new account-scoped target could not be resolved yet (need homeserver, userId, and access token for channels.matrix...).
- Signification : OpenClaw a trouvé un ancien état, mais ne peut toujours pas déterminer la racine exacte de compte/appareil actuelle.
- Action à effectuer : démarrez le Gateway une fois avec une connexion Matrix fonctionnelle, ou réexécutez
openclaw doctor --fixaprès l’existence d’identifiants mis en cache.
Legacy Matrix state detected at ... but multiple Matrix accounts are configured and channels.matrix.defaultAccount is not set.
- Signification : OpenClaw a trouvé un magasin Matrix plat partagé, mais refuse de deviner quel compte Matrix nommé doit le recevoir.
- Action à effectuer : définissez
channels.matrix.defaultAccountsur le compte prévu, puis réexécutezopenclaw doctor --fixou redémarrez le Gateway.
Matrix legacy sync store not migrated because the target already exists (...)
- Signification : le nouvel emplacement limité au compte contient déjà un magasin de synchronisation ou de chiffrement, OpenClaw ne l’a donc pas écrasé automatiquement.
- Action à effectuer : vérifiez que le compte actuel est le bon avant de supprimer ou de déplacer manuellement la cible en conflit.
Failed migrating Matrix legacy sync store (...) or Failed migrating Matrix legacy crypto store (...)
- Signification : OpenClaw a tenté de déplacer l’ancien état Matrix, mais l’opération sur le système de fichiers a échoué.
- Action à effectuer : inspectez les permissions du système de fichiers et l’état du disque, puis réexécutez
openclaw doctor --fix.
Legacy Matrix encrypted state detected at ... but channels.matrix is not configured yet.
- Signification : OpenClaw a trouvé un ancien magasin Matrix chiffré, mais il n’existe aucune configuration Matrix actuelle à laquelle l’attacher.
- Action à effectuer : configurez
channels.matrix, puis réexécutezopenclaw doctor --fixou redémarrez le Gateway.
Legacy Matrix encrypted state detected at ... but the account-scoped target could not be resolved yet (need homeserver, userId, and access token for channels.matrix...).
- Signification : le magasin chiffré existe, mais OpenClaw ne peut pas décider en toute sécurité à quel compte/appareil actuel il appartient.
- Action à effectuer : démarrez le Gateway une fois avec une connexion Matrix fonctionnelle, ou réexécutez
openclaw doctor --fixaprès la disponibilité des identifiants mis en cache.
Legacy Matrix encrypted state detected at ... but multiple Matrix accounts are configured and channels.matrix.defaultAccount is not set.
- Signification : OpenClaw a trouvé un magasin de chiffrement hérité plat partagé, mais refuse de deviner quel compte Matrix nommé doit le recevoir.
- Action à effectuer : définissez
channels.matrix.defaultAccountsur le compte prévu, puis réexécutezopenclaw doctor --fixou redémarrez le Gateway.
Matrix migration warnings are present, but no on-disk Matrix mutation is actionable yet. No pre-migration snapshot was needed.
- Signification : OpenClaw a détecté un ancien état Matrix, mais la migration est toujours bloquée par des données d’identité ou d’identifiants manquantes.
- Action à effectuer : terminez la connexion Matrix ou la configuration, puis réexécutez
openclaw doctor --fixou redémarrez le Gateway.
Legacy Matrix encrypted state was detected, but the Matrix plugin helper is unavailable. Install or repair @openclaw/matrix so OpenClaw can inspect the old rust crypto store before upgrading.
- Signification : OpenClaw a trouvé un ancien état Matrix chiffré, mais n’a pas pu charger le point d’entrée d’assistance depuis le Plugin Matrix qui inspecte normalement ce magasin.
- Action à effectuer : réinstallez ou réparez le Plugin Matrix (
openclaw plugins install @openclaw/matrix, ouopenclaw plugins install ./path/to/local/matrix-pluginpour une copie de dépôt), puis réexécutezopenclaw doctor --fixou redémarrez le Gateway.
Matrix plugin helper path is unsafe: ... Reinstall @openclaw/matrix and try again.
- Signification : OpenClaw a trouvé un chemin de fichier d’assistance qui sort de la racine du Plugin ou échoue aux vérifications de limites du Plugin ; il a donc refusé de l’importer.
- Que faire : réinstallez le Plugin Matrix depuis un chemin de confiance, puis relancez
openclaw doctor --fixou redémarrez le Gateway.
- Failed creating a Matrix migration snapshot before repair: ...
- Skipping Matrix migration changes for now. Resolve the snapshot failure, then rerun "openclaw doctor --fix".
- Signification : OpenClaw a refusé de modifier l’état Matrix, car il n’a pas pu créer d’abord l’instantané de récupération.
- Que faire : résolvez l’erreur de sauvegarde, puis relancez
openclaw doctor --fixou redémarrez le Gateway.
Failed migrating legacy Matrix client storage: ...
- Signification : la solution de repli côté client Matrix a trouvé un ancien stockage plat, mais le déplacement a échoué. OpenClaw interrompt désormais cette solution de repli au lieu de démarrer silencieusement avec un nouveau stockage.
- Que faire : inspectez les autorisations du système de fichiers ou les conflits, gardez l’ancien état intact, puis réessayez après avoir corrigé l’erreur.
Matrix is installed from a custom path: ...
- Signification : Matrix est épinglé à une installation par chemin, donc les mises à jour principales ne le remplacent pas automatiquement par le paquet Matrix standard du dépôt.
- Que faire : réinstallez avec
openclaw plugins install @openclaw/matrixlorsque vous voulez revenir au Plugin Matrix par défaut.
Messages de récupération d’état chiffré
matrix: restored X/Y room key(s) from legacy encrypted-state backup
- Signification : les clés de salon sauvegardées ont été restaurées avec succès dans le nouveau stockage crypto.
- Que faire : généralement rien.
matrix: N legacy local-only room key(s) were never backed up and could not be restored automatically
- Signification : certaines anciennes clés de salon n’existaient que dans l’ancien stockage local et n’avaient jamais été téléversées dans la sauvegarde Matrix.
- Que faire : attendez-vous à ce qu’une partie de l’ancien historique chiffré reste indisponible, sauf si vous pouvez récupérer ces clés manuellement depuis un autre client vérifié.
Legacy Matrix encrypted state for account "..." has backed-up room keys, but no local backup decryption key was found. Ask the operator to run "openclaw matrix verify backup restore --recovery-key-stdin" after upgrade if they have the recovery key.
- Signification : une sauvegarde existe, mais OpenClaw n’a pas pu récupérer automatiquement la clé de récupération.
- Que faire : exécutez
printf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdin.
Failed inspecting legacy Matrix encrypted state for account "..." (...): ...
- Signification : OpenClaw a trouvé l’ancien stockage chiffré, mais il n’a pas pu l’inspecter de manière suffisamment sûre pour préparer la récupération.
- Que faire : relancez
openclaw doctor --fix. Si cela se répète, gardez l’ancien répertoire d’état intact et récupérez avec un autre client Matrix vérifié ainsi queprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdin.
Legacy Matrix backup key was found for account "...", but .../recovery-key.json already contains a different recovery key. Leaving the existing file unchanged.
- Signification : OpenClaw a détecté un conflit de clé de sauvegarde et a refusé d’écraser automatiquement le fichier de clé de récupération actuel.
- Que faire : vérifiez quelle clé de récupération est correcte avant de réessayer toute commande de restauration.
Legacy Matrix encrypted state for account "..." cannot be fully converted automatically because the old rust crypto store does not expose all local room keys for export.
- Signification : il s’agit de la limite stricte de l’ancien format de stockage.
- Que faire : les clés sauvegardées peuvent toujours être restaurées, mais l’historique chiffré disponible uniquement localement peut rester indisponible.
matrix: failed restoring room keys from legacy encrypted-state backup: ...
- Signification : le nouveau Plugin a tenté une restauration, mais Matrix a renvoyé une erreur.
- Que faire : exécutez
openclaw matrix verify backup status, puis réessayez avecprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdinsi nécessaire.
Messages de récupération manuelle
Backup key is not loaded on this device. Run 'openclaw matrix verify backup restore' to load it and restore old room keys.
- Signification : OpenClaw sait que vous devriez avoir une clé de sauvegarde, mais elle n’est pas active sur cet appareil.
- Que faire : exécutez
openclaw matrix verify backup restore, ou définissezMATRIX_RECOVERY_KEYet exécutezprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdinsi nécessaire.
Store a recovery key with 'openclaw matrix verify device --recovery-key-stdin', then run 'openclaw matrix verify backup restore'.
- Signification : cet appareil ne possède actuellement pas la clé de récupération stockée.
- Que faire : définissez
MATRIX_RECOVERY_KEY, exécutezprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin, puis restaurez la sauvegarde.
Backup key mismatch on this device. Re-run 'openclaw matrix verify device --recovery-key-stdin' with the matching recovery key.
- Signification : la clé stockée ne correspond pas à la sauvegarde Matrix active.
- Que faire : définissez
MATRIX_RECOVERY_KEYavec la clé correcte et exécutezprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin.
Si vous acceptez de perdre l’ancien historique chiffré irrécupérable, vous pouvez plutôt réinitialiser la
base de référence de sauvegarde actuelle avec openclaw matrix verify backup reset --yes. Lorsque le
secret de sauvegarde stocké est endommagé, cette réinitialisation peut aussi recréer le stockage de secrets afin que la
nouvelle clé de sauvegarde puisse se charger correctement après le redémarrage.
Backup trust chain is not verified on this device. Re-run 'openclaw matrix verify device --recovery-key-stdin'.
- Signification : la sauvegarde existe, mais cet appareil ne fait pas encore suffisamment confiance à la chaîne de signature croisée.
- Que faire : définissez
MATRIX_RECOVERY_KEYet exécutezprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin.
Matrix recovery key is required
- Signification : vous avez tenté une étape de récupération sans fournir de clé de récupération alors qu’elle était requise.
- Que faire : relancez la commande avec
--recovery-key-stdin, par exempleprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin.
Invalid Matrix recovery key: ...
- Signification : la clé fournie n’a pas pu être analysée ou ne correspondait pas au format attendu.
- Que faire : réessayez avec la clé de récupération exacte provenant de votre client Matrix ou de votre fichier de clé de récupération.
Matrix recovery key was applied, but this device still lacks full Matrix identity trust.
- Signification : OpenClaw a pu appliquer la clé de récupération, mais Matrix n’a toujours pas
établi une confiance complète dans l’identité par signature croisée pour cet appareil. Consultez la
sortie de la commande pour
Recovery key accepted,Backup usable,Cross-signing verifiedetDevice verified by owner. - Que faire : exécutez
openclaw matrix verify self, acceptez la demande dans un autre client Matrix, comparez le SAS et saisissezyesuniquement lorsqu’il correspond. La commande attend la confiance complète dans l’identité Matrix avant de signaler la réussite. Utilisezprintf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify bootstrap --recovery-key-stdin --force-reset-cross-signinguniquement lorsque vous voulez intentionnellement remplacer l’identité de signature croisée actuelle.
Matrix key backup is not active on this device after loading from secret storage.
- Signification : le stockage de secrets n’a pas produit de session de sauvegarde active sur cet appareil.
- Que faire : vérifiez d’abord l’appareil, puis revérifiez avec
openclaw matrix verify backup status.
Matrix crypto backend cannot load backup keys from secret storage. Verify this device with 'openclaw matrix verify device --recovery-key-stdin' first.
- Signification : cet appareil ne peut pas restaurer depuis le stockage de secrets tant que la vérification de l’appareil n’est pas terminée.
- Que faire : exécutez d’abord
printf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify device --recovery-key-stdin.
Messages d’installation de Plugin personnalisé
Matrix is installed from a custom path that no longer exists: ...
- Signification : votre enregistrement d’installation de Plugin pointe vers un chemin local qui n’existe plus.
- Que faire : réinstallez avec
openclaw plugins install @openclaw/matrix, ou si vous exécutez depuis un checkout de dépôt,openclaw plugins install ./path/to/local/matrix-plugin.
Si l’historique chiffré ne revient toujours pas
Exécutez ces vérifications dans l’ordre :
openclaw matrix verify status --verbose
openclaw matrix verify backup status --verbose
printf '%s\n' "$MATRIX_RECOVERY_KEY" | openclaw matrix verify backup restore --recovery-key-stdin --verbose
Si la sauvegarde se restaure avec succès, mais que certains anciens salons ont toujours un historique manquant, ces clés manquantes n’ont probablement jamais été sauvegardées par le Plugin précédent.
Si vous voulez repartir à neuf pour les futurs messages
Si vous acceptez de perdre l’ancien historique chiffré irrécupérable et voulez seulement une base de référence de sauvegarde propre pour la suite, exécutez ces commandes dans l’ordre :
openclaw matrix verify backup reset --yes
openclaw matrix verify backup status --verbose
openclaw matrix verify status
Si l’appareil n’est toujours pas vérifié après cela, terminez la vérification depuis votre client Matrix en comparant les emoji SAS ou les codes décimaux et en confirmant qu’ils correspondent.
Connexe
- Matrix : configuration du canal.
- Règles push Matrix : routage des notifications.
- Doctor : contrôle d’intégrité et déclencheur de migration automatique.
- Guide de migration : tous les chemins de migration (déplacements de machine, importations intersystèmes).
- Plugins : installation et enregistrement de Plugin.