Back to Copilotkit

CopilotKit Debug Mode (React)

skills/react-core/references/debug-mode.md

1.57.43.7 KB
Original Source

CopilotKit Debug Mode (React)

This skill builds on copilotkit/provider-setup. Both debug surfaces are props on CopilotKitProvider.

Two independent knobs:

  1. showDevConsole mounts the visual web inspector (floating panel).
  2. debug controls console logging for the event pipeline.

Both should be 'auto' / off in production.

Setup

tsx
"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.

Core Patterns

Full payload logging during a repro

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.

tsx
<CopilotKitProvider
  runtimeUrl="/api/copilotkit"
  debug={{ events: true, lifecycle: true, verbose: true }}
/>

Anchor the inspector on narrow viewports

tsx
<CopilotKitProvider
  runtimeUrl="/api/copilotkit"
  showDevConsole="auto"
  inspectorDefaultAnchor="bottom-left"
/>

Env-gate the inspector

tsx
<CopilotKitProvider
  runtimeUrl="/api/copilotkit"
  showDevConsole={process.env.NODE_ENV !== "production"}
/>

Common Mistakes

HIGH — Shipping showDevConsole={true} to production

Wrong:

tsx
<CopilotKitProvider runtimeUrl="/api/copilotkit" showDevConsole={true} />

Correct:

tsx
<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

MEDIUM — Expecting debug: true to log full payloads

Wrong:

tsx
<CopilotKitProvider debug={true} />
// Then wondering why message contents aren't in the console

Correct:

tsx
<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

MEDIUM — Passing fields that aren't in DebugConfig

Wrong:

tsx
<CopilotKitProvider debug={{ events: true, network: true, errors: true }} />

Correct:

tsx
<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)

MEDIUM — Inspector crashing in sandboxed iframes

Wrong:

tsx
// App embedded in a sandboxed iframe with showDevConsole on
<CopilotKitProvider runtimeUrl="..." showDevConsole="auto" />

Correct:

tsx
<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