Documentation Index
Fetch the complete documentation index at: https://docs.openclaw.ai/llms.txt
Use this file to discover all available pages before exploring further.
openclaw doctor è lo strumento di riparazione e migrazione per OpenClaw. Corregge configurazioni/stati obsoleti, verifica lo stato di salute e fornisce passaggi di riparazione attuabili.
Avvio rapido
Modalità headless e di automazione
- --yes
- --repair
- --repair --force
- --non-interactive
- --deep
Cosa fa (riepilogo)
Salute, UI e aggiornamenti
Salute, UI e aggiornamenti
- Aggiornamento preliminare opzionale per installazioni git (solo interattivo).
- Controllo di aggiornamento del protocollo UI (ricompila Control UI quando lo schema del protocollo è più recente).
- Controllo di salute + richiesta di riavvio.
- Riepilogo dello stato Skills (idonee/mancanti/bloccate) e stato dei plugin.
Configurazione e migrazioni
Configurazione e migrazioni
- Normalizzazione della configurazione per valori legacy.
- Migrazione della configurazione Talk dai campi flat legacy
talk.*atalk.provider+talk.providers.<provider>. - Controlli di migrazione del browser per configurazioni legacy dell’estensione Chrome e prontezza Chrome MCP.
- Avvisi sugli override del provider OpenCode (
models.providers.opencode/models.providers.opencode-go). - Avvisi di shadowing OAuth Codex (
models.providers.openai-codex). - Controllo dei prerequisiti TLS OAuth per profili OpenAI Codex OAuth.
- Avvisi allowlist Plugin/strumenti quando
plugins.allowè restrittivo ma la policy degli strumenti richiede ancora wildcard o strumenti di proprietà del plugin. - Migrazione dello stato legacy su disco (sessions/dir agent/WhatsApp auth).
- Migrazione delle chiavi legacy del contratto manifest del plugin (
speechProviders,realtimeTranscriptionProviders,realtimeVoiceProviders,mediaUnderstandingProviders,imageGenerationProviders,videoGenerationProviders,webFetchProviders,webSearchProviders→contracts). - Migrazione dello store Cron legacy (
jobId,schedule.cron, campi delivery/payload di primo livello, payloadprovider, job fallback Webhook semplicinotify: true). - Pulizia della runtime-policy legacy dell’intero agente; la runtime policy provider/modello è il selettore di route attivo.
- Pulizia della configurazione plugin obsoleta quando i plugin sono abilitati; quando
plugins.enabled=false, i riferimenti plugin obsoleti sono trattati come configurazione di contenimento inerte e vengono preservati.
Stato e integrità
Stato e integrità
- Ispezione dei file di lock delle sessioni e pulizia dei lock obsoleti.
- Riparazione delle trascrizioni di sessione per rami di riscrittura prompt duplicati creati dalle build 2026.4.24 interessate.
- Rilevamento tombstone per recupero da riavvio di subagent bloccati, con supporto
--fixper cancellare flag di recupero interrotto obsoleti in modo che l’avvio non continui a trattare il figlio come restart-aborted. - Controlli di integrità dello stato e dei permessi (sessioni, trascrizioni, dir stato).
- Controlli dei permessi del file di configurazione (chmod 600) durante l’esecuzione locale.
- Salute auth dei modelli: controlla la scadenza OAuth, può aggiornare token in scadenza e segnala stati di cooldown/disabilitazione dei profili auth.
- Rilevamento di dir workspace aggiuntive (
~/openclaw).
Gateway, servizi e supervisor
Gateway, servizi e supervisor
- Riparazione dell’immagine sandbox quando il sandboxing è abilitato.
- Migrazione dei servizi legacy e rilevamento Gateway aggiuntivo.
- Migrazione dello stato legacy del canale Matrix (in modalità
--fix/--repair). - Controlli runtime Gateway (servizio installato ma non in esecuzione; etichetta launchd in cache).
- Avvisi sullo stato dei canali (sondati dal Gateway in esecuzione).
- I controlli dei permessi specifici del canale vivono sotto
openclaw channels capabilities; ad esempio, i permessi dei canali vocali Discord vengono verificati conopenclaw channels capabilities --channel discord --target channel:<channel-id>. - Controlli di reattività WhatsApp per salute degradata dell’event loop Gateway con client TUI locali ancora in esecuzione;
--fixarresta solo client TUI locali verificati. - Riparazione delle route Codex per riferimenti modello legacy
openai-codex/*nei modelli primari, fallback, override heartbeat/subagent/compaction, hook, override modello di canale e pin route di sessione;--fixli riscrive inopenai/*, rimuove pin runtime obsoleti di sessione/intero agente e lascia i riferimenti agente OpenAI canonici sull’harness Codex predefinito. - Audit della configurazione supervisor (launchd/systemd/schtasks) con riparazione opzionale.
- Pulizia dell’ambiente proxy incorporato per servizi Gateway che hanno catturato valori shell
HTTP_PROXY/HTTPS_PROXY/NO_PROXYdurante installazione o aggiornamento. - Controlli delle best practice runtime Gateway (Node vs Bun, percorsi dei version-manager).
- Diagnostica delle collisioni di porta Gateway (predefinita
18789).
Auth, sicurezza e pairing
Auth, sicurezza e pairing
- Avvisi di sicurezza per policy DM aperte.
- Controlli auth Gateway per la modalità token locale (offre la generazione di token quando non esiste alcuna sorgente token; non sovrascrive configurazioni token SecretRef).
- Rilevamento di problemi di associazione dispositivo (richieste di prima associazione in sospeso, upgrade ruolo/scope in sospeso, deriva della cache token dispositivo locale obsoleta e deriva auth dei record associati).
Workspace e shell
Workspace e shell
- Controllo systemd linger su Linux.
- Controllo dimensione del file bootstrap workspace (avvisi di troncamento/quasi limite per file di contesto).
- Controllo prontezza Skills per l’agente predefinito; segnala Skills consentite con binari, env, config o requisiti OS mancanti, e
--fixpuò disabilitare Skills non disponibili inskills.entries. - Controllo stato completamento shell e installazione/upgrade automatici.
- Controllo prontezza provider embedding per ricerca memoria (modello locale, chiave API remota o binario QMD).
- Controlli installazione da sorgente (mancata corrispondenza workspace pnpm, asset UI mancanti, binario tsx mancante).
- Scrive configurazione aggiornata + metadati wizard.
Backfill e reset UI Dreams
La scena Dreams di Control UI include azioni Backfill, Reset e Clear Grounded per il workflow di Dreaming grounded. Queste azioni usano metodi RPC in stile Gateway doctor, ma non fanno parte della riparazione/migrazione CLIopenclaw doctor.
Cosa fanno:
- Backfill analizza i file storici
memory/YYYY-MM-DD.mdnel workspace attivo, esegue il passaggio diario REM grounded e scrive voci di backfill reversibili inDREAMS.md. - Reset rimuove solo quelle voci diario di backfill marcate da
DREAMS.md. - Clear Grounded rimuove solo voci short-term staged esclusivamente grounded che provengono da replay storico e non hanno ancora accumulato richiamo live o supporto giornaliero.
- non modificano
MEMORY.md - non eseguono migrazioni doctor complete
- non eseguono automaticamente lo stage dei candidati grounded nello store di promozione short-term live a meno che tu non esegua prima esplicitamente il percorso CLI staged
DREAMS.md come superficie di revisione.
Comportamento dettagliato e motivazione
0. Aggiornamento opzionale (installazioni git)
0. Aggiornamento opzionale (installazioni git)
1. Normalizzazione della configurazione
1. Normalizzazione della configurazione
messages.ackReaction senza un override specifico del canale), doctor le normalizza nello schema corrente.Questo include i campi flat Talk legacy. La configurazione pubblica corrente di Talk speech è talk.provider + talk.providers.<provider>, e la configurazione voce realtime è talk.realtime.*. Doctor riscrive le vecchie forme talk.voiceId / talk.voiceAliases / talk.modelId / talk.outputFormat / talk.apiKey nella mappa provider, e riscrive i selettori realtime legacy di primo livello (talk.mode, talk.transport, talk.brain, talk.model, talk.voice) in talk.realtime.Doctor avvisa anche quando plugins.allow non è vuoto e la policy degli strumenti usa
wildcard o voci strumento di proprietà del plugin. tools.allow: ["*"] corrisponde solo agli strumenti
dei plugin che vengono effettivamente caricati; non aggira la allowlist esclusiva dei plugin.
Doctor scrive plugins.bundledDiscovery: "compat" per configurazioni allowlist legacy
migrate per preservare il comportamento esistente dei provider bundled, e
poi punta all’impostazione più rigorosa "allowlist".2. Migrazioni di chiavi di configurazione legacy
2. Migrazioni di chiavi di configurazione legacy
openclaw doctor.Doctor:- Spiegherà quali chiavi legacy sono state trovate.
- Mostrerà la migrazione applicata.
- Riscriverà
~/.openclaw/openclaw.jsoncon lo schema aggiornato.
openclaw doctor --fix; non riscrive openclaw.json all’avvio. Anche le migrazioni dello store dei job Cron sono gestite da openclaw doctor --fix.Migrazioni correnti:routing.allowFrom→channels.whatsapp.allowFromrouting.groupChat.requireMention→channels.whatsapp/telegram/imessage.groups."*".requireMentionrouting.groupChat.historyLimit→messages.groupChat.historyLimitrouting.groupChat.mentionPatterns→messages.groupChat.mentionPatternschannels.telegram.requireMention→channels.telegram.groups."*".requireMention- configurazioni dei canali configurati senza criterio di risposta visibile →
messages.groupChat.visibleReplies: "message_tool" routing.queue→messages.queuerouting.bindings→bindingsdi livello superiorerouting.agents/routing.defaultAgentId→agents.list+agents.list[].defaulttalk.voiceId/talk.voiceAliases/talk.modelId/talk.outputFormat/talk.apiKeylegacy →talk.provider+talk.providers.<provider>- selettori Talk realtime legacy di livello superiore (
talk.mode/talk.transport/talk.brain/talk.model/talk.voice) +talk.provider/talk.providers→talk.realtime routing.agentToAgent→tools.agentToAgentrouting.transcribeAudio→tools.media.audio.modelsmessages.tts.<provider>(openai/elevenlabs/microsoft/edge) →messages.tts.providers.<provider>messages.tts.provider: "edge"emessages.tts.providers.edge→messages.tts.provider: "microsoft"emessages.tts.providers.microsoftchannels.discord.voice.tts.<provider>(openai/elevenlabs/microsoft/edge) →channels.discord.voice.tts.providers.<provider>channels.discord.accounts.<id>.voice.tts.<provider>(openai/elevenlabs/microsoft/edge) →channels.discord.accounts.<id>.voice.tts.providers.<provider>plugins.entries.voice-call.config.tts.<provider>(openai/elevenlabs/microsoft/edge) →plugins.entries.voice-call.config.tts.providers.<provider>plugins.entries.voice-call.config.tts.provider: "edge"eplugins.entries.voice-call.config.tts.providers.edge→provider: "microsoft"eproviders.microsoftplugins.entries.voice-call.config.provider: "log"→"mock"plugins.entries.voice-call.config.twilio.from→plugins.entries.voice-call.config.fromNumberplugins.entries.voice-call.config.streaming.sttProvider→plugins.entries.voice-call.config.streaming.providerplugins.entries.voice-call.config.streaming.openaiApiKey|sttModel|silenceDurationMs|vadThreshold→plugins.entries.voice-call.config.streaming.providers.openai.*bindings[].match.accountID→bindings[].match.accountId- Per i canali con
accountsdenominati ma valori di canale di livello superiore per account singolo ancora presenti, sposta quei valori con ambito account nell’account promosso scelto per quel canale (accounts.defaultper la maggior parte dei canali; Matrix può conservare una destinazione denominata/predefinita corrispondente già esistente) identity→agents.list[].identityagent.*→agents.defaults+tools.*(tools/elevated/exec/sandbox/subagents)agent.model/allowedModels/modelAliases/modelFallbacks/imageModelFallbacks→agents.defaults.models+agents.defaults.model.primary/fallbacks+agents.defaults.imageModel.primary/fallbacks- rimuovi
agents.defaults.llm; usamodels.providers.<id>.timeoutSecondsper i timeout di provider/modelli lenti browser.ssrfPolicy.allowPrivateNetwork→browser.ssrfPolicy.dangerouslyAllowPrivateNetworkbrowser.profiles.*.driver: "extension"→"existing-session"- rimuovi
browser.relayBindHost(impostazione legacy del relay dell’estensione) models.providers.*.api: "openai"legacy →"openai-completions"(l’avvio del Gateway salta anche i provider il cuiapiè impostato su un valore enum futuro o sconosciuto invece di fallire in modo chiuso)- rimuovi
plugins.entries.codex.config.codexDynamicToolsProfile; il server dell’app Codex mantiene sempre nativi gli strumenti workspace nativi di Codex
- Se due o più voci
channels.<channel>.accountssono configurate senzachannels.<channel>.defaultAccountoaccounts.default, doctor avvisa che il routing di fallback può scegliere un account imprevisto. - Se
channels.<channel>.defaultAccountè impostato su un ID account sconosciuto, doctor avvisa ed elenca gli ID account configurati.
2b. Override dei provider OpenCode
2b. Override dei provider OpenCode
models.providers.opencode, opencode-zen o opencode-go, questo sostituisce il catalogo OpenCode integrato da @earendil-works/pi-ai. Ciò può forzare i modelli sull’API sbagliata o azzerare i costi. Doctor avvisa così puoi rimuovere l’override e ripristinare il routing API per modello + i costi.2c. Migrazione del browser e preparazione a Chrome MCP
2c. Migrazione del browser e preparazione a Chrome MCP
browser.profiles.*.driver: "extension"diventa"existing-session"browser.relayBindHostviene rimosso
defaultProfile: "user" o un profilo existing-session configurato:- controlla se Google Chrome è installato sullo stesso host per i profili di connessione automatica predefiniti
- controlla la versione di Chrome rilevata e avvisa quando è inferiore a Chrome 144
- ti ricorda di abilitare il debug remoto nella pagina di ispezione del browser (per esempio
chrome://inspect/#remote-debugging,brave://inspect/#remote-debuggingoedge://inspect/#remote-debugging)
- un browser basato su Chromium 144+ sull’host del gateway/node
- il browser in esecuzione localmente
- debug remoto abilitato in quel browser
- approvazione del primo prompt di consenso al collegamento nel browser
responsebody, esportazione PDF, intercettazione dei download e azioni batch richiedono ancora un browser gestito o un profilo CDP raw.Questo controllo non si applica a Docker, sandbox, remote-browser o altri flussi headless. Questi continuano a usare CDP raw.2d. Prerequisiti OAuth TLS
2d. Prerequisiti OAuth TLS
UNABLE_TO_GET_ISSUER_CERT_LOCALLY, certificato scaduto o certificato autofirmato), doctor stampa indicazioni di correzione specifiche per la piattaforma. Su macOS con un Node Homebrew, la correzione di solito è brew postinstall ca-certificates. Con --deep, la verifica viene eseguita anche se il gateway è integro.2e. Override dei provider OAuth Codex
2e. Override dei provider OAuth Codex
models.providers.openai-codex, queste possono oscurare il percorso del provider OAuth Codex integrato che le versioni più recenti usano automaticamente. Doctor avvisa quando rileva quelle vecchie impostazioni di trasporto insieme a Codex OAuth, così puoi rimuovere o riscrivere l’override di trasporto obsoleto e recuperare il comportamento integrato di routing/fallback. Proxy personalizzati e override solo degli header sono ancora supportati e non attivano questo avviso.2f. Riparazione delle route Codex
2f. Riparazione delle route Codex
openai-codex/*. Il routing dell’harness Codex nativo usa riferimenti modello canonici openai/*; i turni degli agenti OpenAI passano attraverso l’harness del server dell’app Codex invece del percorso OpenAI di OpenClaw PI.In modalità --fix / --repair, doctor riscrive i riferimenti interessati dell’agente predefinito e dei singoli agenti, inclusi modelli primari, fallback, override heartbeat/subagent/compaction, hook, override dei modelli di canale e stato di route persistente obsoleto delle sessioni:openai-codex/gpt-*diventaopenai/gpt-*.- L’intento Codex passa a voci
agentRuntime.id: "codex"con ambito provider/modello per i riferimenti modello degli agenti riparati, così i profili authopenai-codex:...possono ancora essere selezionati dopo che il riferimento modello diventaopenai/*. - La configurazione runtime obsoleta dell’intero agente e i pin runtime persistenti delle sessioni vengono rimossi perché la selezione runtime ha ambito provider/modello.
- La policy runtime provider/modello esistente viene conservata, a meno che il riferimento modello legacy riparato non richieda il routing Codex per mantenere il vecchio percorso auth.
- Gli elenchi di fallback dei modelli esistenti vengono conservati con le rispettive voci legacy riscritte; le impostazioni per modello copiate si spostano dalla chiave legacy alla chiave canonica
openai/*. modelProvider/providerOverride,model/modelOverride, avvisi di fallback e pin dei profili auth persistenti delle sessioni vengono riparati in tutti gli store sessione agente scoperti./codex ...significa “controlla o associa una conversazione Codex nativa dalla chat.”/acp ...oruntime: "acp"significa “usa l’adapter ACP/acpx esterno.”
2g. Pulizia delle route di sessione
2g. Pulizia delle route di sessione
openclaw doctor --fix può cancellare stato obsoleto auto-creato come pin modello modelOverrideSource: "auto", metadati modello runtime, ID harness fissati, associazioni sessione CLI e override automatici dei profili auth quando la relativa route proprietaria non è più configurata. Le scelte esplicite dell’utente o dei modelli sessione legacy vengono segnalate per revisione manuale e lasciate intatte; cambiale con /model ..., /new oppure reimposta la sessione quando quella route non è più desiderata.3. Migrazioni dello stato legacy (layout del disco)
3. Migrazioni dello stato legacy (layout del disco)
- Store sessioni + trascrizioni:
- da
~/.openclaw/sessions/a~/.openclaw/agents/<agentId>/sessions/
- da
- Directory agente:
- da
~/.openclaw/agent/a~/.openclaw/agents/<agentId>/agent/
- da
- Stato auth WhatsApp (Baileys):
- da
~/.openclaw/credentials/*.jsonlegacy (eccettooauth.json) - a
~/.openclaw/credentials/whatsapp/<accountId>/...(ID account predefinito:default)
- da
openclaw doctor. La normalizzazione provider/mappa provider di Talk ora confronta per uguaglianza strutturale, quindi differenze solo nell’ordine delle chiavi non attivano più modifiche no-op ripetute con doctor --fix.3a. Migrazioni dei manifest Plugin legacy
3a. Migrazioni dei manifest Plugin legacy
speechProviders, realtimeTranscriptionProviders, realtimeVoiceProviders, mediaUnderstandingProviders, imageGenerationProviders, videoGenerationProviders, webFetchProviders, webSearchProviders). Quando le trova, offre di spostarle nell’oggetto contracts e riscrivere il file manifest sul posto. Questa migrazione è idempotente; se la chiave contracts ha già gli stessi valori, la chiave legacy viene rimossa senza duplicare i dati.3b. Migrazioni dello store cron legacy
3b. Migrazioni dello store cron legacy
~/.openclaw/cron/jobs.json per impostazione predefinita, oppure cron.store quando è sovrascritto) alla ricerca di vecchie forme di job che lo scheduler accetta ancora per compatibilità.Le pulizie cron attuali includono:jobId→idschedule.cron→schedule.expr- campi del payload di primo livello (
message,model,thinking, …) →payload - campi di consegna di primo livello (
deliver,channel,to,provider, …) →delivery - alias di consegna
providerdel payload →delivery.channelesplicito - processi di fallback Webhook legacy semplici con
notify: true→delivery.mode="webhook"esplicito condelivery.to=cron.webhook
notify: true quando può farlo senza cambiare il comportamento. Se un processo combina il fallback notify legacy con una modalità di consegna non Webhook esistente, doctor emette un avviso e lascia quel processo alla revisione manuale.Su Linux, doctor emette anche un avviso quando la crontab dell’utente invoca ancora il legacy ~/.openclaw/bin/ensure-whatsapp.sh. Questo script locale dell’host non è mantenuto dall’OpenClaw attuale e può scrivere falsi messaggi Gateway inactive in ~/.openclaw/logs/whatsapp-health.log quando cron non riesce a raggiungere il bus utente systemd. Rimuovi la voce crontab obsoleta con crontab -e; usa openclaw channels status --probe, openclaw doctor e openclaw gateway status per i controlli di integrità attuali.3c. Pulizia dei blocchi di sessione
3c. Pulizia dei blocchi di sessione
--fix / --repair rimuove automaticamente i file di lock obsoleti; altrimenti stampa una nota e ti indica di rieseguirlo con --fix.3d. Riparazione dei rami del transcript di sessione
3d. Riparazione dei rami del transcript di sessione
--fix / --repair, doctor esegue il backup di ogni file interessato accanto all’originale e riscrive il transcript sul ramo attivo, così la cronologia del Gateway e i lettori di memoria non vedono più turni duplicati.4. Controlli di integrità dello stato (persistenza delle sessioni, instradamento e sicurezza)
4. Controlli di integrità dello stato (persistenza delle sessioni, instradamento e sicurezza)
- Directory di stato mancante: avvisa di una perdita di stato catastrofica, chiede di ricreare la directory e ricorda che non può recuperare i dati mancanti.
- Permessi della directory di stato: verifica la scrivibilità; offre di riparare i permessi (ed emette un suggerimento
chownquando rileva una discrepanza di proprietario/gruppo). - Directory di stato sincronizzata sul cloud macOS: avvisa quando lo stato si risolve sotto iCloud Drive (
~/Library/Mobile Documents/com~apple~CloudDocs/...) o~/Library/CloudStorage/...perché i percorsi basati sulla sincronizzazione possono causare I/O più lento e race di lock/sincronizzazione. - Directory di stato Linux su SD o eMMC: avvisa quando lo stato si risolve in una sorgente di mount
mmcblk*, perché l’I/O casuale basato su SD o eMMC può essere più lento e usurarsi più rapidamente con le scritture di sessioni e credenziali. - Directory delle sessioni mancanti:
sessions/e la directory dello store delle sessioni sono obbligatorie per persistere la cronologia ed evitare crashENOENT. - Disallineamento del transcript: avvisa quando le voci di sessione recenti hanno file transcript mancanti.
- Sessione principale “JSONL a 1 riga”: segnala quando il transcript principale ha una sola riga (la cronologia non si sta accumulando).
- Più directory di stato: avvisa quando esistono più cartelle
~/.openclawin directory home diverse o quandoOPENCLAW_STATE_DIRpunta altrove (la cronologia può dividersi tra installazioni). - Promemoria modalità remota: se
gateway.mode=remote, doctor ricorda di eseguirlo sull’host remoto (lo stato vive lì). - Permessi del file di configurazione: avvisa se
~/.openclaw/openclaw.jsonè leggibile da gruppo/mondo e offre di restringere a600.
5. Integrità autenticazione modello (scadenza OAuth)
5. Integrità autenticazione modello (scadenza OAuth)
--non-interactive salta i tentativi di refresh.Quando un refresh OAuth fallisce in modo permanente (per esempio refresh_token_reused, invalid_grant, o un provider indica di effettuare di nuovo l’accesso), doctor segnala che è necessaria una nuova autenticazione e stampa il comando esatto openclaw models auth login --provider ... da eseguire.Doctor segnala anche i profili auth temporaneamente inutilizzabili a causa di:- cooldown brevi (limiti di frequenza/timeout/errori di autenticazione)
- disabilitazioni più lunghe (errori di fatturazione/credito)
6. Validazione del modello degli hook
6. Validazione del modello degli hook
hooks.gmail.model è impostato, doctor valida il riferimento al modello rispetto al catalogo e all’allowlist e avvisa quando non si risolve o non è consentito.7. Riparazione dell'immagine sandbox
7. Riparazione dell'immagine sandbox
7b. Pulizia installazione Plugin
7b. Pulizia installazione Plugin
openclaw doctor --fix / openclaw doctor --repair. Questo copre radici di dipendenze generate obsolete, vecchie directory install-stage, detriti locali dei pacchetti da codice precedente di riparazione delle dipendenze dei bundled Plugin, e copie npm gestite orfane o recuperate di Plugin @openclaw/* bundled che possono oscurare il manifest bundled attuale. Doctor ricollega anche il pacchetto host openclaw nei Plugin npm gestiti che dichiarano peerDependencies.openclaw, così gli import runtime locali al pacchetto come openclaw/plugin-sdk/* continuano a risolversi dopo aggiornamenti o riparazioni npm.Doctor può anche reinstallare Plugin scaricabili mancanti quando la configurazione li riferimento ma il registro locale dei Plugin non li trova. Gli esempi includono plugins.entries materiali, impostazioni configurate di canale/provider/ricerca e runtime degli agenti configurati. Durante gli aggiornamenti di pacchetto, doctor evita di eseguire la riparazione dei Plugin tramite package manager mentre il pacchetto core viene sostituito; esegui di nuovo openclaw doctor --fix dopo l’aggiornamento se un Plugin configurato necessita ancora di recupero. L’avvio del Gateway e il ricaricamento della configurazione non eseguono package manager; le installazioni dei Plugin restano lavoro esplicito di doctor/install/update.8. Migrazioni del servizio Gateway e suggerimenti di pulizia
8. Migrazioni del servizio Gateway e suggerimenti di pulizia
openclaw gateway status --deep o openclaw doctor --deep, quindi rimuovi il duplicato o imposta OPENCLAW_SERVICE_REPAIR_POLICY=external quando un supervisore di sistema possiede il ciclo di vita del Gateway.8b. Migrazione Matrix all'avvio
8b. Migrazione Matrix all'avvio
--fix / --repair) crea uno snapshot pre-migrazione e poi esegue i passaggi di migrazione best-effort: migrazione dello stato Matrix legacy e preparazione dello stato cifrato legacy. Entrambi i passaggi non sono fatali; gli errori vengono registrati e l’avvio continua. In modalità sola lettura (openclaw doctor senza --fix) questo controllo viene saltato interamente.8c. Associazione dei dispositivi e deriva dell'autenticazione
8c. Associazione dei dispositivi e deriva dell'autenticazione
- richieste di prima associazione in sospeso
- upgrade di ruolo in sospeso per dispositivi già associati
- upgrade di ambito in sospeso per dispositivi già associati
- riparazioni di mismatch della chiave pubblica in cui l’id del dispositivo corrisponde ancora ma l’identità del dispositivo non corrisponde più al record approvato
- record associati privi di un token attivo per un ruolo approvato
- token associati i cui ambiti derivano al di fuori della baseline di associazione approvata
- voci locali nella cache dei token dispositivo per la macchina attuale che precedono una rotazione del token lato Gateway o trasportano metadati di ambito obsoleti
- ispeziona le richieste in sospeso con
openclaw devices list - approva la richiesta esatta con
openclaw devices approve <requestId> - ruota un token nuovo con
openclaw devices rotate --device <deviceId> --role <role> - rimuovi e riapprova un record obsoleto con
openclaw devices remove <deviceId>
9. Avvisi di sicurezza
9. Avvisi di sicurezza
10. systemd linger (Linux)
10. systemd linger (Linux)
11. Stato del workspace (Skills, Plugin e directory legacy)
11. Stato del workspace (Skills, Plugin e directory legacy)
- Stato Skills: conta Skills idonee, con requisiti mancanti e bloccate dall’allowlist.
- Directory workspace legacy: avvisa quando
~/openclawo altre directory workspace legacy esistono insieme al workspace attuale. - Stato Plugin: conta Plugin abilitati/disabilitati/con errore; elenca gli ID dei Plugin per eventuali errori; segnala le capacità dei Plugin del bundle.
- Avvisi di compatibilità Plugin: segnala i Plugin che hanno problemi di compatibilità con il runtime attuale.
- Diagnostica Plugin: espone eventuali avvisi o errori in fase di caricamento emessi dal registro dei Plugin.
11b. Dimensione del file bootstrap
11b. Dimensione del file bootstrap
AGENTS.md, CLAUDE.md o altri file di contesto iniettati) sono vicini o superiori al budget di caratteri configurato. Segnala per ogni file i conteggi di caratteri grezzi rispetto a quelli iniettati, la percentuale di troncamento, la causa del troncamento (max/file o max/total) e i caratteri iniettati totali come frazione del budget totale. Quando i file vengono troncati o sono vicini al limite, doctor stampa suggerimenti per regolare agents.defaults.bootstrapMaxChars e agents.defaults.bootstrapTotalMaxChars.11d. Pulizia dei Plugin canale obsoleti
11d. Pulizia dei Plugin canale obsoleti
openclaw doctor --fix rimuove un Plugin canale mancante, rimuove anche la configurazione sospesa con ambito canale che faceva riferimento a quel Plugin: voci channels.<id>, target Heartbeat che nominavano il canale e override agents.*.models["<channel>/*"]. Questo previene loop di avvio del Gateway in cui il runtime del canale è scomparso ma la configurazione chiede ancora al gateway di collegarsi a esso.11c. Completamento shell
11c. Completamento shell
- Se il profilo shell usa un pattern di completamento dinamico lento (
source <(openclaw completion ...)), doctor lo aggiorna alla variante più veloce con file in cache. - Se il completamento è configurato nel profilo ma il file di cache manca, doctor rigenera automaticamente la cache.
- Se non è configurato alcun completamento, doctor chiede di installarlo (solo in modalità interattiva; saltato con
--non-interactive).
openclaw completion --write-state per rigenerare manualmente la cache.12. Controlli di autenticazione Gateway (token locale)
12. Controlli di autenticazione Gateway (token locale)
- Se la modalità token richiede un token e non esiste alcuna sorgente token, doctor propone di generarne uno.
- Se
gateway.auth.tokenè gestito tramite SecretRef ma non disponibile, doctor avvisa e non lo sovrascrive con testo in chiaro. openclaw doctor --generate-gateway-tokenforza la generazione solo quando non è configurato alcun token SecretRef.
12b. Riparazioni di sola lettura consapevoli di SecretRef
12b. Riparazioni di sola lettura consapevoli di SecretRef
openclaw doctor --fixora usa lo stesso modello di riepilogo SecretRef di sola lettura dei comandi della famiglia status per riparazioni mirate della configurazione.- Esempio: la riparazione di Telegram
allowFrom/groupAllowFrom@usernameprova a usare le credenziali del bot configurate quando disponibili. - Se il token del bot Telegram è configurato tramite SecretRef ma non disponibile nel percorso del comando corrente, doctor segnala che la credenziale è configurata-ma-non-disponibile e salta la risoluzione automatica invece di arrestarsi in modo anomalo o indicare erroneamente il token come mancante.
13. Controllo di integrità Gateway + riavvio
13. Controllo di integrità Gateway + riavvio
13b. Preparazione della ricerca in memoria
13b. Preparazione della ricerca in memoria
- Backend QMD: verifica se il binario
qmdè disponibile e avviabile. In caso contrario, stampa indicazioni di correzione che includono il pacchetto npm e un’opzione per il percorso manuale del binario. - Provider locale esplicito: controlla la presenza di un file modello locale o di un URL di modello remoto/scaricabile riconosciuto. Se manca, suggerisce di passare a un provider remoto.
- Provider remoto esplicito (
openai,voyage, ecc.): verifica che una chiave API sia presente nell’ambiente o nell’archivio di autenticazione. Stampa suggerimenti di correzione attuabili se manca. - Provider automatico: controlla prima la disponibilità del modello locale, poi prova ogni provider remoto nell’ordine di selezione automatica.
openclaw memory status --deep per verificare la preparazione degli embedding a runtime.14. Avvisi sullo stato dei canali
14. Avvisi sullo stato dei canali
15. Audit + riparazione della configurazione del supervisore
15. Audit + riparazione della configurazione del supervisore
openclaw doctorchiede conferma prima di riscrivere la configurazione del supervisore.openclaw doctor --yesaccetta le richieste di riparazione predefinite.openclaw doctor --repairapplica le correzioni consigliate senza richieste.openclaw doctor --repair --forcesovrascrive le configurazioni personalizzate del supervisore.OPENCLAW_SERVICE_REPAIR_POLICY=externalmantiene doctor in sola lettura per il ciclo di vita del servizio Gateway. Segnala comunque l’integrità del servizio ed esegue riparazioni non relative al servizio, ma salta installazione/avvio/riavvio/bootstrap del servizio, riscritture della configurazione del supervisore e pulizia dei servizi legacy perché un supervisore esterno possiede quel ciclo di vita.- Su Linux, doctor non riscrive i metadati di comando/entrypoint mentre l’unità systemd Gateway corrispondente è attiva. Inoltre ignora le unità extra inattive non legacy simili al Gateway durante la scansione dei servizi duplicati, così i file di servizio companion non generano rumore di pulizia.
- Se l’autenticazione con token richiede un token e
gateway.auth.tokenè gestito tramite SecretRef, l’installazione/riparazione del servizio doctor valida il SecretRef ma non persiste i valori del token in testo in chiaro risolti nei metadati dell’ambiente del servizio supervisore. - Doctor rileva valori di ambiente del servizio gestiti con
.env/SecretRef che installazioni LaunchAgent, systemd o Windows Scheduled Task precedenti incorporavano inline e riscrive i metadati del servizio affinché quei valori vengano caricati dalla sorgente runtime invece che dalla definizione del supervisore. - Doctor rileva quando il comando del servizio imposta ancora un vecchio
--portdopo modifiche agateway.porte riscrive i metadati del servizio alla porta corrente. - Se l’autenticazione con token richiede un token e il SecretRef del token configurato non è risolto, doctor blocca il percorso di installazione/riparazione con indicazioni attuabili.
- Se sia
gateway.auth.tokensiagateway.auth.passwordsono configurati egateway.auth.modenon è impostato, doctor blocca installazione/riparazione finché la modalità non viene impostata esplicitamente. - Per le unità user-systemd Linux, i controlli di drift dei token di doctor ora includono sia le sorgenti
Environment=siaEnvironmentFile=quando confrontano i metadati di autenticazione del servizio. - Le riparazioni del servizio doctor rifiutano di riscrivere, arrestare o riavviare un servizio Gateway da un binario OpenClaw precedente quando la configurazione è stata scritta l’ultima volta da una versione più recente. Vedi Risoluzione dei problemi del Gateway.
- Puoi sempre forzare una riscrittura completa tramite
openclaw gateway install --force.
16. Diagnostica runtime + porta del Gateway
16. Diagnostica runtime + porta del Gateway
18789) e segnala le cause probabili (Gateway già in esecuzione, tunnel SSH).17. Best practice runtime del Gateway
17. Best practice runtime del Gateway
nvm, fnm, volta, asdf, ecc.). I canali WhatsApp + Telegram richiedono Node, e i percorsi dei version manager possono interrompersi dopo gli aggiornamenti perché il servizio non carica l’inizializzazione della shell. Doctor propone di migrare a un’installazione Node di sistema quando disponibile (Homebrew/apt/choco).I LaunchAgent macOS appena installati o riparati usano un PATH di sistema canonico (/opt/homebrew/bin:/opt/homebrew/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin) invece di copiare il PATH della shell interattiva, così i binari di sistema gestiti da Homebrew rimangono disponibili mentre Volta, asdf, fnm, pnpm e altre directory dei version manager non cambiano quale Node viene risolto dai processi figlio. I servizi Linux mantengono ancora radici di ambiente esplicite (NVM_DIR, FNM_DIR, VOLTA_HOME, ASDF_DATA_DIR, BUN_INSTALL, PNPM_HOME) e directory user-bin stabili, ma le directory di fallback dei version manager dedotte vengono scritte nel PATH del servizio solo quando tali directory esistono su disco.18. Scrittura della configurazione + metadati della procedura guidata
18. Scrittura della configurazione + metadati della procedura guidata
19. Suggerimenti per l'area di lavoro (backup + sistema di memoria)
19. Suggerimenti per l'area di lavoro (backup + sistema di memoria)