Canvas (macOS 앱)

macOS 앱은 WKWebView를 사용하여 에이전트가 제어하는 Canvas 패널을 내장합니다. 이는 HTML/CSS/JS, A2UI, 작은 인터랙티브 UI 표면을 위한 경량 비주얼 워크스페이스입니다.

Canvas 위치

Canvas 상태는 Application Support에 저장됩니다:

  • ~/Library/Application Support/OpenClaw/canvas/<session>/...

Canvas 패널은 커스텀 URL 스킴을 통해 해당 파일들을 제공합니다:

  • openclaw-canvas://<session>/<path>

예시:

  • openclaw-canvas://main/<canvasRoot>/main/index.html
  • openclaw-canvas://main/assets/app.css<canvasRoot>/main/assets/app.css
  • openclaw-canvas://main/widgets/todo/<canvasRoot>/main/widgets/todo/index.html

루트에 index.html이 없으면, 앱은 내장된 스캐폴드 페이지를 표시합니다.

패널 동작

  • 메뉴 바(또는 마우스 커서) 근처에 고정된 테두리 없는 크기 조절 가능한 패널.
  • 세션별로 크기/위치를 기억합니다.
  • 로컬 canvas 파일이 변경되면 자동으로 리로드됩니다.
  • 한 번에 하나의 Canvas 패널만 표시됩니다 (필요에 따라 세션 전환).

Settings → Allow Canvas에서 Canvas를 비활성화할 수 있습니다. 비활성화되면, canvas 노드 명령은 CANVAS_DISABLED를 반환합니다.

에이전트 API 인터페이스

Canvas는 Gateway WebSocket을 통해 노출되므로, 에이전트는 다음을 수행할 수 있습니다:

  • 패널 표시/숨김
  • 경로 또는 URL로 이동
  • JavaScript 실행
  • 스냅샷 이미지 캡처

CLI 예시:

openclaw nodes canvas present --node <id>
openclaw nodes canvas navigate --node <id> --url "/"
openclaw nodes canvas eval --node <id> --js "document.title"
openclaw nodes canvas snapshot --node <id>

참고사항:

  • canvas.navigate로컬 canvas 경로, http(s) URL, file:// URL을 허용합니다.
  • "/"를 전달하면, Canvas는 로컬 스캐폴드 또는 index.html을 표시합니다.

Canvas의 A2UI

A2UI는 Gateway canvas 호스트에 의해 호스팅되며 Canvas 패널 내부에 렌더링됩니다. Gateway가 Canvas 호스트를 광고하면, macOS 앱은 첫 번째 열기 시 A2UI 호스트 페이지로 자동으로 이동합니다.

기본 A2UI 호스트 URL:

http://<gateway-host>:18793/__openclaw__/a2ui/

A2UI 명령 (v0.8)

Canvas는 현재 A2UI v0.8 서버→클라이언트 메시지를 허용합니다:

  • beginRendering
  • surfaceUpdate
  • dataModelUpdate
  • deleteSurface

createSurface (v0.9)는 지원되지 않습니다.

CLI 예시:

cat > /tmp/a2ui-v0.8.jsonl <<'EOFA2'
{"surfaceUpdate":{"surfaceId":"main","components":[{"id":"root","component":{"Column":{"children":{"explicitList":["title","content"]}}}},{"id":"title","component":{"Text":{"text":{"literalString":"Canvas (A2UI v0.8)"},"usageHint":"h1"}}},{"id":"content","component":{"Text":{"text":{"literalString":"If you can read this, A2UI push works."},"usageHint":"body"}}}]}}
{"beginRendering":{"surfaceId":"main","root":"root"}}
EOFA2

openclaw nodes canvas a2ui push --jsonl /tmp/a2ui-v0.8.jsonl --node <id>

빠른 확인:

openclaw nodes canvas a2ui push --node <id> --text "Hello from A2UI"

Canvas에서 에이전트 실행 트리거하기

Canvas는 딥 링크를 통해 새로운 에이전트 실행을 트리거할 수 있습니다:

  • openclaw://agent?...

예시 (JS):

window.location.href = "openclaw://agent?message=Review%20this%20design";

유효한 키가 제공되지 않으면 앱이 확인을 요청합니다.

보안 참고사항

  • Canvas 스킴은 디렉토리 탐색을 차단합니다; 파일은 세션 루트 아래에 있어야 합니다.
  • 로컬 Canvas 콘텐츠는 커스텀 스킴을 사용합니다 (루프백 서버 불필요).
  • 외부 http(s) URL은 명시적으로 이동할 때만 허용됩니다.