skills/react-core/references/debug-mode.md
This skill builds on copilotkit/provider-setup. Both debug surfaces are
props on CopilotKitProvider.
Two independent knobs:
showDevConsole mounts the visual web inspector (floating panel).debug controls console logging for the event pipeline.Both should be 'auto' / off in production.
"use client";
import { CopilotKitProvider } from "@copilotkit/react-core/v2";
export function Providers({ children }: { children: React.ReactNode }) {
return (
<CopilotKitProvider
runtimeUrl="/api/copilotkit"
showDevConsole="auto"
debug={{ events: true, lifecycle: true, verbose: false }}
>
{children}
</CopilotKitProvider>
);
}
showDevConsole="auto" enables the inspector only on localhost and
127.0.0.1. In production it evaluates to false.
debug: true enables events + lifecycle but keeps verbose off to avoid
leaking PII by default. For a bug repro, explicitly set verbose: true to
dump full message/tool-call payloads.
<CopilotKitProvider
runtimeUrl="/api/copilotkit"
debug={{ events: true, lifecycle: true, verbose: true }}
/>
<CopilotKitProvider
runtimeUrl="/api/copilotkit"
showDevConsole="auto"
inspectorDefaultAnchor="bottom-left"
/>
<CopilotKitProvider
runtimeUrl="/api/copilotkit"
showDevConsole={process.env.NODE_ENV !== "production"}
/>
showDevConsole={true} to productionWrong:
<CopilotKitProvider runtimeUrl="/api/copilotkit" showDevConsole={true} />
Correct:
<CopilotKitProvider runtimeUrl="/api/copilotkit" showDevConsole="auto" />
// "auto" enables only on localhost / 127.0.0.1
A hard true ships the Lit + markdown bundle to every end user and exposes
a developer panel in production. "auto" is the right default.
Source: packages/react-core/src/v2/providers/CopilotKitProvider.tsx:301-321
debug: true to log full payloadsWrong:
<CopilotKitProvider debug={true} />
// Then wondering why message contents aren't in the console
Correct:
<CopilotKitProvider debug={{ events: true, lifecycle: true, verbose: true }} />
debug: true is shorthand for { events: true, lifecycle: true, verbose: false }.
verbose defaults to false to avoid logging user message bodies / tool
arguments / state snapshots — it must be opted into explicitly.
Source: docs/snippets/shared/troubleshooting/debug-mode.mdx:85-93
DebugConfigWrong:
<CopilotKitProvider debug={{ events: true, network: true, errors: true }} />
Correct:
<CopilotKitProvider debug={{ events: true, lifecycle: true, verbose: true }} />
DebugConfig has exactly three fields: events, lifecycle, verbose.
Anything else is silently ignored by the type-narrowing at the provider.
Source: packages/react-core/src/v2/providers/CopilotKitProvider.tsx (DebugConfig type)
Wrong:
// App embedded in a sandboxed iframe with showDevConsole on
<CopilotKitProvider runtimeUrl="..." showDevConsole="auto" />
Correct:
<CopilotKitProvider
runtimeUrl="..."
showDevConsole={typeof window !== "undefined" && window.self === window.top}
/>
The inspector persists its anchor via localStorage. In sandboxed iframes
without storage access, the component throws on mount. Either disable in
iframes or whitelist storage in the sandbox attrs.
Source: packages/react-core/src/v2/components/CopilotKitInspector.tsx:16-53