@symerian/symi 3.0.20 → 3.0.22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{audio-preflight-BaCdNfrk.js → audio-preflight-D7BVT-ls.js} +4 -4
- package/dist/build-info.json +3 -3
- package/dist/canvas-host/a2ui/.bundle.hash +1 -1
- package/dist/{chrome-UfmVM0xR.js → chrome-B5CO2vB5.js} +7 -7
- package/dist/{deliver-BqXdac6W.js → deliver-CrwjsDwv.js} +1 -1
- package/dist/extensionAPI.js +7 -7
- package/dist/{image-DIWsXYcW.js → image-Csu7WcLW.js} +1 -1
- package/dist/{manager-DW3SxcPr.js → manager-BkkVjTO8.js} +1 -1
- package/dist/{pi-embedded-BNch0U5F.js → pi-embedded-Dhp64z5l.js} +16 -16
- package/dist/{pi-embedded-helpers-IkHl02JF.js → pi-embedded-helpers-840E4hop.js} +4 -4
- package/dist/{pw-ai-nMkA-oDJ.js → pw-ai-CBgJf_RR.js} +1 -1
- package/dist/{runner-DNEC58JI.js → runner-BbFKo1ne.js} +1 -1
- package/dist/{synthesis-BWAr0sZ9.js → synthesis-DoEM0E8_.js} +7 -7
- package/dist/{web-7a-m_UxL.js → web-BYXJn-Ps.js} +7 -7
- package/package.json +1 -1
- package/docs/.i18n/README.md +0 -31
- package/docs/.i18n/glossary.ja-JP.json +0 -14
- package/docs/.i18n/glossary.zh-CN.json +0 -210
- package/docs/.i18n/ja-JP.tm.jsonl +0 -0
- package/docs/.i18n/zh-CN.tm.jsonl +0 -1303
- package/docs/CNAME +0 -1
- package/docs/assets/install-script.svg +0 -1
- package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
- package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
- package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
- package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
- package/docs/assets/macos-onboarding/05-permissions.png +0 -0
- package/docs/assets/pixel-symi.svg +0 -60
- package/docs/assets/showcase/agents-ui.jpg +0 -0
- package/docs/assets/showcase/bambu-cli.png +0 -0
- package/docs/assets/showcase/codexmonitor.png +0 -0
- package/docs/assets/showcase/gohome-grafana.png +0 -0
- package/docs/assets/showcase/ios-testflight.jpg +0 -0
- package/docs/assets/showcase/oura-health.png +0 -0
- package/docs/assets/showcase/padel-cli.svg +0 -11
- package/docs/assets/showcase/padel-screenshot.jpg +0 -0
- package/docs/assets/showcase/papla-tts.jpg +0 -0
- package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
- package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
- package/docs/assets/showcase/roborock-status.svg +0 -13
- package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
- package/docs/assets/showcase/snag.png +0 -0
- package/docs/assets/showcase/tesco-shop.jpg +0 -0
- package/docs/assets/showcase/wienerlinien.png +0 -0
- package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
- package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
- package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
- package/docs/assets/sponsors/blacksmith.svg +0 -14
- package/docs/assets/sponsors/openai.svg +0 -3
- package/docs/assets/symi-logo-text-dark.png +0 -0
- package/docs/assets/symi-logo-text.png +0 -0
- package/docs/automation/auth-monitoring.md +0 -44
- package/docs/automation/cron-jobs.md +0 -540
- package/docs/automation/cron-vs-heartbeat.md +0 -286
- package/docs/automation/gmail-pubsub.md +0 -256
- package/docs/automation/hooks.md +0 -998
- package/docs/automation/poll.md +0 -61
- package/docs/automation/troubleshooting.md +0 -122
- package/docs/automation/webhook.md +0 -213
- package/docs/brave-search.md +0 -41
- package/docs/capabilities.md +0 -151
- package/docs/channels/bluebubbles.md +0 -346
- package/docs/channels/broadcast-groups.md +0 -441
- package/docs/channels/channel-routing.md +0 -112
- package/docs/channels/feishu.md +0 -586
- package/docs/channels/googlechat.md +0 -253
- package/docs/channels/grammy.md +0 -31
- package/docs/channels/group-messages.md +0 -82
- package/docs/channels/groups.md +0 -364
- package/docs/channels/imessage.md +0 -366
- package/docs/channels/index.md +0 -46
- package/docs/channels/irc.md +0 -234
- package/docs/channels/line.md +0 -186
- package/docs/channels/location.md +0 -56
- package/docs/channels/matrix.md +0 -300
- package/docs/channels/mattermost.md +0 -158
- package/docs/channels/msteams.md +0 -769
- package/docs/channels/nextcloud-talk.md +0 -138
- package/docs/channels/nostr.md +0 -233
- package/docs/channels/pairing.md +0 -100
- package/docs/channels/signal.md +0 -322
- package/docs/channels/slack.md +0 -510
- package/docs/channels/telegram.md +0 -748
- package/docs/channels/tlon.md +0 -148
- package/docs/channels/troubleshooting.md +0 -110
- package/docs/channels/twitch.md +0 -379
- package/docs/channels/whatsapp.md +0 -444
- package/docs/channels/zalo.md +0 -192
- package/docs/channels/zalouser.md +0 -140
- package/docs/ci.md +0 -50
- package/docs/cli/acp.md +0 -182
- package/docs/cli/agent.md +0 -24
- package/docs/cli/agents.md +0 -75
- package/docs/cli/approvals.md +0 -50
- package/docs/cli/browser.md +0 -107
- package/docs/cli/channels.md +0 -73
- package/docs/cli/config.md +0 -50
- package/docs/cli/configure.md +0 -32
- package/docs/cli/cron.md +0 -44
- package/docs/cli/dashboard.md +0 -16
- package/docs/cli/devices.md +0 -73
- package/docs/cli/directory.md +0 -62
- package/docs/cli/dns.md +0 -23
- package/docs/cli/docs.md +0 -15
- package/docs/cli/doctor.md +0 -41
- package/docs/cli/gateway.md +0 -202
- package/docs/cli/health.md +0 -21
- package/docs/cli/hooks.md +0 -313
- package/docs/cli/index.md +0 -1029
- package/docs/cli/logs.md +0 -28
- package/docs/cli/memory.md +0 -45
- package/docs/cli/message.md +0 -214
- package/docs/cli/models.md +0 -79
- package/docs/cli/node.md +0 -112
- package/docs/cli/nodes.md +0 -73
- package/docs/cli/onboard.md +0 -76
- package/docs/cli/pairing.md +0 -21
- package/docs/cli/plugins.md +0 -92
- package/docs/cli/reset.md +0 -17
- package/docs/cli/sandbox.md +0 -152
- package/docs/cli/security.md +0 -64
- package/docs/cli/sessions.md +0 -16
- package/docs/cli/setup.md +0 -29
- package/docs/cli/skills.md +0 -26
- package/docs/cli/status.md +0 -25
- package/docs/cli/system.md +0 -60
- package/docs/cli/tui.md +0 -23
- package/docs/cli/uninstall.md +0 -17
- package/docs/cli/update.md +0 -98
- package/docs/cli/voicecall.md +0 -34
- package/docs/cli/webhooks.md +0 -25
- package/docs/concepts/agent-loop.md +0 -148
- package/docs/concepts/agent-workspace.md +0 -234
- package/docs/concepts/agent.md +0 -123
- package/docs/concepts/architecture.md +0 -135
- package/docs/concepts/compaction.md +0 -61
- package/docs/concepts/context.md +0 -161
- package/docs/concepts/features.md +0 -51
- package/docs/concepts/markdown-formatting.md +0 -128
- package/docs/concepts/memory.md +0 -729
- package/docs/concepts/messages.md +0 -153
- package/docs/concepts/model-failover.md +0 -149
- package/docs/concepts/model-providers.md +0 -424
- package/docs/concepts/models.md +0 -208
- package/docs/concepts/multi-agent.md +0 -521
- package/docs/concepts/oauth.md +0 -145
- package/docs/concepts/presence.md +0 -102
- package/docs/concepts/queue.md +0 -86
- package/docs/concepts/retry.md +0 -64
- package/docs/concepts/session-pruning.md +0 -123
- package/docs/concepts/session-tool.md +0 -213
- package/docs/concepts/session.md +0 -199
- package/docs/concepts/sessions.md +0 -10
- package/docs/concepts/streaming.md +0 -129
- package/docs/concepts/system-prompt.md +0 -128
- package/docs/concepts/timezone.md +0 -90
- package/docs/concepts/typebox.md +0 -289
- package/docs/concepts/typing-indicators.md +0 -68
- package/docs/concepts/usage-tracking.md +0 -35
- package/docs/date-time.md +0 -127
- package/docs/debug/node-issue.md +0 -85
- package/docs/diagnostics/flags.md +0 -91
- package/docs/docs.json +0 -1849
- package/docs/experiments/onboarding-config-protocol.md +0 -40
- package/docs/experiments/plans/browser-evaluate-cdp-refactor.md +0 -229
- package/docs/experiments/plans/cron-add-hardening.md +0 -62
- package/docs/experiments/plans/group-policy-hardening.md +0 -40
- package/docs/experiments/plans/openresponses-gateway.md +0 -123
- package/docs/experiments/plans/pty-process-supervision.md +0 -192
- package/docs/experiments/plans/session-binding-channel-agnostic.md +0 -202
- package/docs/experiments/plans/thread-bound-subagents.md +0 -281
- package/docs/experiments/proposals/model-config.md +0 -36
- package/docs/experiments/research/memory.md +0 -228
- package/docs/gateway/authentication.md +0 -162
- package/docs/gateway/background-process.md +0 -96
- package/docs/gateway/bonjour.md +0 -177
- package/docs/gateway/bridge-protocol.md +0 -91
- package/docs/gateway/cli-backends.md +0 -225
- package/docs/gateway/configuration-examples.md +0 -610
- package/docs/gateway/configuration-reference.md +0 -2465
- package/docs/gateway/configuration.md +0 -488
- package/docs/gateway/discovery.md +0 -123
- package/docs/gateway/doctor.md +0 -282
- package/docs/gateway/gateway-lock.md +0 -34
- package/docs/gateway/health.md +0 -35
- package/docs/gateway/heartbeat.md +0 -374
- package/docs/gateway/index.md +0 -254
- package/docs/gateway/local-models.md +0 -150
- package/docs/gateway/logging.md +0 -113
- package/docs/gateway/multiple-gateways.md +0 -112
- package/docs/gateway/network-model.md +0 -20
- package/docs/gateway/openai-http-api.md +0 -119
- package/docs/gateway/openresponses-http-api.md +0 -333
- package/docs/gateway/pairing.md +0 -99
- package/docs/gateway/protocol.md +0 -221
- package/docs/gateway/remote-gateway-readme.md +0 -158
- package/docs/gateway/remote.md +0 -131
- package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -128
- package/docs/gateway/sandboxing.md +0 -203
- package/docs/gateway/security/index.md +0 -931
- package/docs/gateway/tailscale.md +0 -132
- package/docs/gateway/tools-invoke-http-api.md +0 -110
- package/docs/gateway/troubleshooting.md +0 -317
- package/docs/gateway/trusted-proxy-auth.md +0 -270
- package/docs/glass-ui-rendering-invariants.md +0 -451
- package/docs/help/debugging.md +0 -162
- package/docs/help/environment.md +0 -107
- package/docs/help/faq.md +0 -2846
- package/docs/help/index.md +0 -21
- package/docs/help/scripts.md +0 -28
- package/docs/help/testing.md +0 -385
- package/docs/help/troubleshooting.md +0 -264
- package/docs/images/configure-model-picker-unsearchable.png +0 -0
- package/docs/images/feishu-step2-create-app.png +0 -0
- package/docs/images/feishu-step3-credentials.png +0 -0
- package/docs/images/feishu-step4-permissions.png +0 -0
- package/docs/images/feishu-step5-bot-capability.png +0 -0
- package/docs/images/feishu-step6-event-subscription.png +0 -0
- package/docs/images/groups-flow.svg +0 -52
- package/docs/images/mobile-ui-screenshot.png +0 -0
- package/docs/index.md +0 -186
- package/docs/install/ansible.md +0 -207
- package/docs/install/bun.md +0 -59
- package/docs/install/development-channels.md +0 -75
- package/docs/install/docker.md +0 -583
- package/docs/install/exe-dev.md +0 -126
- package/docs/install/fly.md +0 -472
- package/docs/install/gcp.md +0 -499
- package/docs/install/hetzner.md +0 -347
- package/docs/install/index.md +0 -218
- package/docs/install/installer.md +0 -405
- package/docs/install/macos-vm.md +0 -281
- package/docs/install/migrating.md +0 -192
- package/docs/install/nix.md +0 -98
- package/docs/install/node.md +0 -138
- package/docs/install/northflank.mdx +0 -49
- package/docs/install/podman.md +0 -108
- package/docs/install/railway.mdx +0 -95
- package/docs/install/render.mdx +0 -158
- package/docs/install/uninstall.md +0 -128
- package/docs/install/updating.md +0 -231
- package/docs/ja-JP/AGENTS.md +0 -37
- package/docs/ja-JP/index.md +0 -183
- package/docs/ja-JP/start/getting-started.md +0 -125
- package/docs/ja-JP/start/wizard.md +0 -77
- package/docs/logging.md +0 -350
- package/docs/nav-tabs-underline.js +0 -100
- package/docs/network.md +0 -54
- package/docs/nodes/audio.md +0 -133
- package/docs/nodes/camera.md +0 -156
- package/docs/nodes/images.md +0 -72
- package/docs/nodes/index.md +0 -342
- package/docs/nodes/location-command.md +0 -113
- package/docs/nodes/media-understanding.md +0 -379
- package/docs/nodes/talk.md +0 -90
- package/docs/nodes/troubleshooting.md +0 -112
- package/docs/nodes/voicewake.md +0 -65
- package/docs/perplexity.md +0 -80
- package/docs/phase-6.5-pre-flight-audit.md +0 -268
- package/docs/pi-dev.md +0 -70
- package/docs/pi.md +0 -610
- package/docs/platforms/android.md +0 -151
- package/docs/platforms/digitalocean.md +0 -265
- package/docs/platforms/index.md +0 -53
- package/docs/platforms/ios.md +0 -108
- package/docs/platforms/linux.md +0 -94
- package/docs/platforms/mac/bundled-gateway.md +0 -73
- package/docs/platforms/mac/canvas.md +0 -125
- package/docs/platforms/mac/child-process.md +0 -69
- package/docs/platforms/mac/dev-setup.md +0 -104
- package/docs/platforms/mac/health.md +0 -34
- package/docs/platforms/mac/icon.md +0 -31
- package/docs/platforms/mac/logging.md +0 -57
- package/docs/platforms/mac/menu-bar.md +0 -81
- package/docs/platforms/mac/peekaboo.md +0 -65
- package/docs/platforms/mac/permissions.md +0 -50
- package/docs/platforms/mac/release.md +0 -85
- package/docs/platforms/mac/remote.md +0 -84
- package/docs/platforms/mac/signing.md +0 -47
- package/docs/platforms/mac/skills.md +0 -33
- package/docs/platforms/mac/voice-overlay.md +0 -60
- package/docs/platforms/mac/voicewake.md +0 -66
- package/docs/platforms/mac/webchat.md +0 -43
- package/docs/platforms/mac/xpc.md +0 -61
- package/docs/platforms/macos.md +0 -204
- package/docs/platforms/oracle.md +0 -303
- package/docs/platforms/raspberry-pi.md +0 -358
- package/docs/platforms/windows.md +0 -159
- package/docs/plugins/agent-tools.md +0 -99
- package/docs/plugins/community.md +0 -44
- package/docs/plugins/manifest.md +0 -71
- package/docs/plugins/voice-call.md +0 -322
- package/docs/plugins/zalouser.md +0 -81
- package/docs/prose.md +0 -134
- package/docs/providers/anthropic.md +0 -174
- package/docs/providers/bedrock.md +0 -176
- package/docs/providers/claude-max-api-proxy.md +0 -148
- package/docs/providers/cloudflare-ai-gateway.md +0 -71
- package/docs/providers/deepgram.md +0 -93
- package/docs/providers/github-copilot.md +0 -72
- package/docs/providers/glm.md +0 -33
- package/docs/providers/huggingface.md +0 -209
- package/docs/providers/index.md +0 -67
- package/docs/providers/litellm.md +0 -153
- package/docs/providers/minimax.md +0 -208
- package/docs/providers/models.md +0 -52
- package/docs/providers/moonshot.md +0 -142
- package/docs/providers/nvidia.md +0 -55
- package/docs/providers/ollama.md +0 -250
- package/docs/providers/openai.md +0 -62
- package/docs/providers/opencode.md +0 -36
- package/docs/providers/openrouter.md +0 -37
- package/docs/providers/qianfan.md +0 -38
- package/docs/providers/qwen.md +0 -53
- package/docs/providers/synthetic.md +0 -99
- package/docs/providers/together.md +0 -65
- package/docs/providers/venice.md +0 -267
- package/docs/providers/vercel-ai-gateway.md +0 -50
- package/docs/providers/vllm.md +0 -92
- package/docs/providers/xiaomi.md +0 -64
- package/docs/providers/zai.md +0 -38
- package/docs/refactor/exec-host.md +0 -316
- package/docs/refactor/outbound-session-mirroring.md +0 -83
- package/docs/refactor/plugin-sdk.md +0 -214
- package/docs/refactor/strict-config.md +0 -93
- package/docs/refactor/syminet.md +0 -417
- package/docs/reference/AGENTS.default.md +0 -123
- package/docs/reference/RELEASING.md +0 -120
- package/docs/reference/api-usage-costs.md +0 -138
- package/docs/reference/credits.md +0 -28
- package/docs/reference/device-models.md +0 -47
- package/docs/reference/rpc.md +0 -43
- package/docs/reference/session-management-compaction.md +0 -284
- package/docs/reference/test.md +0 -51
- package/docs/reference/token-use.md +0 -136
- package/docs/reference/transcript-hygiene.md +0 -151
- package/docs/reference/wizard.md +0 -265
- package/docs/security/CONTRIBUTING-THREAT-MODEL.md +0 -89
- package/docs/security/README.md +0 -16
- package/docs/security/THREAT-MODEL-ATLAS.md +0 -600
- package/docs/security/formal-verification.md +0 -164
- package/docs/start/bootstrapping.md +0 -41
- package/docs/start/docs-directory.md +0 -63
- package/docs/start/getting-started.md +0 -135
- package/docs/start/hubs.md +0 -196
- package/docs/start/lore.md +0 -216
- package/docs/start/onboarding-overview.md +0 -51
- package/docs/start/onboarding.md +0 -81
- package/docs/start/quickstart.md +0 -22
- package/docs/start/setup.md +0 -160
- package/docs/start/showcase.md +0 -414
- package/docs/start/symi.md +0 -211
- package/docs/start/wizard-cli-automation.md +0 -158
- package/docs/start/wizard-cli-reference.md +0 -255
- package/docs/start/wizard.md +0 -109
- package/docs/style.css +0 -37
- package/docs/tools/agent-send.md +0 -52
- package/docs/tools/apply-patch.md +0 -51
- package/docs/tools/browser-linux-troubleshooting.md +0 -139
- package/docs/tools/browser-login.md +0 -67
- package/docs/tools/browser.md +0 -587
- package/docs/tools/chrome-extension.md +0 -183
- package/docs/tools/creating-skills.md +0 -54
- package/docs/tools/elevated.md +0 -55
- package/docs/tools/exec-approvals.md +0 -261
- package/docs/tools/exec.md +0 -184
- package/docs/tools/firecrawl.md +0 -61
- package/docs/tools/index.md +0 -540
- package/docs/tools/llm-task.md +0 -115
- package/docs/tools/loop-detection.md +0 -98
- package/docs/tools/multi-agent-sandbox-tools.md +0 -396
- package/docs/tools/pipeline.md +0 -340
- package/docs/tools/plugin.md +0 -687
- package/docs/tools/reactions.md +0 -21
- package/docs/tools/skills-config.md +0 -76
- package/docs/tools/skills.md +0 -300
- package/docs/tools/slash-commands.md +0 -202
- package/docs/tools/subagents.md +0 -232
- package/docs/tools/symihub.md +0 -256
- package/docs/tools/thinking.md +0 -75
- package/docs/tools/web.md +0 -265
- package/docs/tts.md +0 -398
- package/docs/vps.md +0 -43
- package/docs/web/control-ui.md +0 -247
- package/docs/web/dashboard.md +0 -46
- package/docs/web/index.md +0 -118
- package/docs/web/tui.md +0 -162
- package/docs/web/webchat.md +0 -53
- package/docs/whatsapp-symi-ai-zh.jpg +0 -0
- package/docs/whatsapp-symi.jpg +0 -0
- package/docs/zh-CN/AGENTS.md +0 -59
- package/docs/zh-CN/automation/auth-monitoring.md +0 -47
- package/docs/zh-CN/automation/cron-jobs.md +0 -422
- package/docs/zh-CN/automation/cron-vs-heartbeat.md +0 -286
- package/docs/zh-CN/automation/gmail-pubsub.md +0 -249
- package/docs/zh-CN/automation/hooks.md +0 -881
- package/docs/zh-CN/automation/poll.md +0 -68
- package/docs/zh-CN/automation/troubleshooting.md +0 -8
- package/docs/zh-CN/automation/webhook.md +0 -161
- package/docs/zh-CN/brave-search.md +0 -48
- package/docs/zh-CN/channels/bluebubbles.md +0 -271
- package/docs/zh-CN/channels/broadcast-groups.md +0 -448
- package/docs/zh-CN/channels/channel-routing.md +0 -112
- package/docs/zh-CN/channels/feishu.md +0 -629
- package/docs/zh-CN/channels/googlechat.md +0 -257
- package/docs/zh-CN/channels/grammy.md +0 -38
- package/docs/zh-CN/channels/group-messages.md +0 -89
- package/docs/zh-CN/channels/groups.md +0 -369
- package/docs/zh-CN/channels/imessage.md +0 -300
- package/docs/zh-CN/channels/index.md +0 -52
- package/docs/zh-CN/channels/line.md +0 -180
- package/docs/zh-CN/channels/location.md +0 -63
- package/docs/zh-CN/channels/matrix.md +0 -221
- package/docs/zh-CN/channels/mattermost.md +0 -144
- package/docs/zh-CN/channels/msteams.md +0 -773
- package/docs/zh-CN/channels/nextcloud-talk.md +0 -142
- package/docs/zh-CN/channels/nostr.md +0 -240
- package/docs/zh-CN/channels/pairing.md +0 -86
- package/docs/zh-CN/channels/signal.md +0 -207
- package/docs/zh-CN/channels/slack.md +0 -529
- package/docs/zh-CN/channels/telegram.md +0 -748
- package/docs/zh-CN/channels/tlon.md +0 -136
- package/docs/zh-CN/channels/troubleshooting.md +0 -34
- package/docs/zh-CN/channels/twitch.md +0 -385
- package/docs/zh-CN/channels/whatsapp.md +0 -411
- package/docs/zh-CN/channels/zalo.md +0 -196
- package/docs/zh-CN/channels/zalouser.md +0 -147
- package/docs/zh-CN/cli/acp.md +0 -173
- package/docs/zh-CN/cli/agent.md +0 -30
- package/docs/zh-CN/cli/agents.md +0 -82
- package/docs/zh-CN/cli/approvals.md +0 -57
- package/docs/zh-CN/cli/browser.md +0 -114
- package/docs/zh-CN/cli/channels.md +0 -80
- package/docs/zh-CN/cli/config.md +0 -57
- package/docs/zh-CN/cli/configure.md +0 -37
- package/docs/zh-CN/cli/cron.md +0 -43
- package/docs/zh-CN/cli/dashboard.md +0 -23
- package/docs/zh-CN/cli/devices.md +0 -74
- package/docs/zh-CN/cli/directory.md +0 -69
- package/docs/zh-CN/cli/dns.md +0 -30
- package/docs/zh-CN/cli/docs.md +0 -22
- package/docs/zh-CN/cli/doctor.md +0 -48
- package/docs/zh-CN/cli/gateway.md +0 -206
- package/docs/zh-CN/cli/health.md +0 -28
- package/docs/zh-CN/cli/hooks.md +0 -298
- package/docs/zh-CN/cli/index.md +0 -1025
- package/docs/zh-CN/cli/logs.md +0 -31
- package/docs/zh-CN/cli/memory.md +0 -52
- package/docs/zh-CN/cli/message.md +0 -205
- package/docs/zh-CN/cli/models.md +0 -85
- package/docs/zh-CN/cli/node.md +0 -115
- package/docs/zh-CN/cli/nodes.md +0 -80
- package/docs/zh-CN/cli/onboard.md +0 -36
- package/docs/zh-CN/cli/pairing.md +0 -28
- package/docs/zh-CN/cli/plugins.md +0 -66
- package/docs/zh-CN/cli/reset.md +0 -24
- package/docs/zh-CN/cli/sandbox.md +0 -158
- package/docs/zh-CN/cli/security.md +0 -33
- package/docs/zh-CN/cli/sessions.md +0 -23
- package/docs/zh-CN/cli/setup.md +0 -36
- package/docs/zh-CN/cli/skills.md +0 -33
- package/docs/zh-CN/cli/status.md +0 -32
- package/docs/zh-CN/cli/system.md +0 -63
- package/docs/zh-CN/cli/tui.md +0 -30
- package/docs/zh-CN/cli/uninstall.md +0 -24
- package/docs/zh-CN/cli/update.md +0 -101
- package/docs/zh-CN/cli/voicecall.md +0 -41
- package/docs/zh-CN/cli/webhooks.md +0 -32
- package/docs/zh-CN/concepts/agent-loop.md +0 -146
- package/docs/zh-CN/concepts/agent-workspace.md +0 -219
- package/docs/zh-CN/concepts/agent.md +0 -115
- package/docs/zh-CN/concepts/architecture.md +0 -122
- package/docs/zh-CN/concepts/compaction.md +0 -67
- package/docs/zh-CN/concepts/context.md +0 -168
- package/docs/zh-CN/concepts/features.md +0 -57
- package/docs/zh-CN/concepts/markdown-formatting.md +0 -115
- package/docs/zh-CN/concepts/memory.md +0 -412
- package/docs/zh-CN/concepts/messages.md +0 -140
- package/docs/zh-CN/concepts/model-failover.md +0 -145
- package/docs/zh-CN/concepts/model-providers.md +0 -320
- package/docs/zh-CN/concepts/models.md +0 -196
- package/docs/zh-CN/concepts/multi-agent.md +0 -371
- package/docs/zh-CN/concepts/oauth.md +0 -151
- package/docs/zh-CN/concepts/presence.md +0 -99
- package/docs/zh-CN/concepts/queue.md +0 -91
- package/docs/zh-CN/concepts/retry.md +0 -71
- package/docs/zh-CN/concepts/session-pruning.md +0 -129
- package/docs/zh-CN/concepts/session-tool.md +0 -198
- package/docs/zh-CN/concepts/session.md +0 -158
- package/docs/zh-CN/concepts/sessions.md +0 -17
- package/docs/zh-CN/concepts/streaming.md +0 -131
- package/docs/zh-CN/concepts/system-prompt.md +0 -99
- package/docs/zh-CN/concepts/timezone.md +0 -94
- package/docs/zh-CN/concepts/typebox.md +0 -284
- package/docs/zh-CN/concepts/typing-indicators.md +0 -74
- package/docs/zh-CN/concepts/usage-tracking.md +0 -42
- package/docs/zh-CN/date-time.md +0 -128
- package/docs/zh-CN/debug/node-issue.md +0 -90
- package/docs/zh-CN/diagnostics/flags.md +0 -98
- package/docs/zh-CN/experiments/onboarding-config-protocol.md +0 -47
- package/docs/zh-CN/experiments/plans/cron-add-hardening.md +0 -69
- package/docs/zh-CN/experiments/plans/group-policy-hardening.md +0 -45
- package/docs/zh-CN/experiments/plans/openresponses-gateway.md +0 -121
- package/docs/zh-CN/experiments/proposals/model-config.md +0 -42
- package/docs/zh-CN/experiments/research/memory.md +0 -235
- package/docs/zh-CN/gateway/authentication.md +0 -142
- package/docs/zh-CN/gateway/background-process.md +0 -100
- package/docs/zh-CN/gateway/bonjour.md +0 -174
- package/docs/zh-CN/gateway/bridge-protocol.md +0 -86
- package/docs/zh-CN/gateway/cli-backends.md +0 -213
- package/docs/zh-CN/gateway/configuration-examples.md +0 -580
- package/docs/zh-CN/gateway/configuration.md +0 -3284
- package/docs/zh-CN/gateway/discovery.md +0 -123
- package/docs/zh-CN/gateway/doctor.md +0 -238
- package/docs/zh-CN/gateway/gateway-lock.md +0 -41
- package/docs/zh-CN/gateway/health.md +0 -42
- package/docs/zh-CN/gateway/heartbeat.md +0 -272
- package/docs/zh-CN/gateway/index.md +0 -335
- package/docs/zh-CN/gateway/local-models.md +0 -157
- package/docs/zh-CN/gateway/logging.md +0 -114
- package/docs/zh-CN/gateway/multiple-gateways.md +0 -119
- package/docs/zh-CN/gateway/network-model.md +0 -23
- package/docs/zh-CN/gateway/openai-http-api.md +0 -125
- package/docs/zh-CN/gateway/openresponses-http-api.md +0 -317
- package/docs/zh-CN/gateway/pairing.md +0 -99
- package/docs/zh-CN/gateway/protocol.md +0 -220
- package/docs/zh-CN/gateway/remote-gateway-readme.md +0 -164
- package/docs/zh-CN/gateway/remote.md +0 -133
- package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -135
- package/docs/zh-CN/gateway/sandboxing.md +0 -188
- package/docs/zh-CN/gateway/security/index.md +0 -772
- package/docs/zh-CN/gateway/tailscale.md +0 -124
- package/docs/zh-CN/gateway/tools-invoke-http-api.md +0 -92
- package/docs/zh-CN/gateway/troubleshooting.md +0 -758
- package/docs/zh-CN/help/debugging.md +0 -160
- package/docs/zh-CN/help/environment.md +0 -88
- package/docs/zh-CN/help/faq.md +0 -2613
- package/docs/zh-CN/help/index.md +0 -28
- package/docs/zh-CN/help/scripts.md +0 -35
- package/docs/zh-CN/help/testing.md +0 -375
- package/docs/zh-CN/help/troubleshooting.md +0 -104
- package/docs/zh-CN/index.md +0 -183
- package/docs/zh-CN/install/ansible.md +0 -214
- package/docs/zh-CN/install/bun.md +0 -65
- package/docs/zh-CN/install/development-channels.md +0 -81
- package/docs/zh-CN/install/docker.md +0 -525
- package/docs/zh-CN/install/exe-dev.md +0 -127
- package/docs/zh-CN/install/fly.md +0 -476
- package/docs/zh-CN/install/gcp.md +0 -509
- package/docs/zh-CN/install/hetzner.md +0 -336
- package/docs/zh-CN/install/index.md +0 -193
- package/docs/zh-CN/install/installer.md +0 -128
- package/docs/zh-CN/install/macos-vm.md +0 -288
- package/docs/zh-CN/install/migrating.md +0 -199
- package/docs/zh-CN/install/nix.md +0 -99
- package/docs/zh-CN/install/node.md +0 -8
- package/docs/zh-CN/install/northflank.mdx +0 -56
- package/docs/zh-CN/install/railway.mdx +0 -102
- package/docs/zh-CN/install/render.mdx +0 -168
- package/docs/zh-CN/install/uninstall.md +0 -135
- package/docs/zh-CN/install/updating.md +0 -233
- package/docs/zh-CN/logging.md +0 -329
- package/docs/zh-CN/network.md +0 -59
- package/docs/zh-CN/nodes/audio.md +0 -120
- package/docs/zh-CN/nodes/camera.md +0 -162
- package/docs/zh-CN/nodes/images.md +0 -79
- package/docs/zh-CN/nodes/index.md +0 -348
- package/docs/zh-CN/nodes/location-command.md +0 -120
- package/docs/zh-CN/nodes/media-understanding.md +0 -380
- package/docs/zh-CN/nodes/talk.md +0 -97
- package/docs/zh-CN/nodes/troubleshooting.md +0 -8
- package/docs/zh-CN/nodes/voicewake.md +0 -72
- package/docs/zh-CN/perplexity.md +0 -84
- package/docs/zh-CN/pi-dev.md +0 -77
- package/docs/zh-CN/pi.md +0 -617
- package/docs/zh-CN/platforms/android.md +0 -155
- package/docs/zh-CN/platforms/digitalocean.md +0 -268
- package/docs/zh-CN/platforms/index.md +0 -60
- package/docs/zh-CN/platforms/ios.md +0 -114
- package/docs/zh-CN/platforms/linux.md +0 -101
- package/docs/zh-CN/platforms/mac/bundled-gateway.md +0 -75
- package/docs/zh-CN/platforms/mac/canvas.md +0 -128
- package/docs/zh-CN/platforms/mac/child-process.md +0 -73
- package/docs/zh-CN/platforms/mac/dev-setup.md +0 -109
- package/docs/zh-CN/platforms/mac/health.md +0 -41
- package/docs/zh-CN/platforms/mac/icon.md +0 -38
- package/docs/zh-CN/platforms/mac/logging.md +0 -64
- package/docs/zh-CN/platforms/mac/menu-bar.md +0 -88
- package/docs/zh-CN/platforms/mac/peekaboo.md +0 -62
- package/docs/zh-CN/platforms/mac/permissions.md +0 -46
- package/docs/zh-CN/platforms/mac/release.md +0 -92
- package/docs/zh-CN/platforms/mac/remote.md +0 -90
- package/docs/zh-CN/platforms/mac/signing.md +0 -54
- package/docs/zh-CN/platforms/mac/skills.md +0 -40
- package/docs/zh-CN/platforms/mac/voice-overlay.md +0 -67
- package/docs/zh-CN/platforms/mac/voicewake.md +0 -73
- package/docs/zh-CN/platforms/mac/webchat.md +0 -43
- package/docs/zh-CN/platforms/mac/xpc.md +0 -68
- package/docs/zh-CN/platforms/macos.md +0 -193
- package/docs/zh-CN/platforms/oracle.md +0 -310
- package/docs/zh-CN/platforms/raspberry-pi.md +0 -365
- package/docs/zh-CN/platforms/windows.md +0 -156
- package/docs/zh-CN/plugins/agent-tools.md +0 -99
- package/docs/zh-CN/plugins/manifest.md +0 -68
- package/docs/zh-CN/plugins/voice-call.md +0 -250
- package/docs/zh-CN/plugins/zalouser.md +0 -88
- package/docs/zh-CN/prose.md +0 -141
- package/docs/zh-CN/providers/anthropic.md +0 -159
- package/docs/zh-CN/providers/bedrock.md +0 -170
- package/docs/zh-CN/providers/claude-max-api-proxy.md +0 -155
- package/docs/zh-CN/providers/deepgram.md +0 -97
- package/docs/zh-CN/providers/github-copilot.md +0 -67
- package/docs/zh-CN/providers/glm.md +0 -39
- package/docs/zh-CN/providers/index.md +0 -66
- package/docs/zh-CN/providers/minimax.md +0 -206
- package/docs/zh-CN/providers/models.md +0 -55
- package/docs/zh-CN/providers/moonshot.md +0 -145
- package/docs/zh-CN/providers/ollama.md +0 -230
- package/docs/zh-CN/providers/openai.md +0 -68
- package/docs/zh-CN/providers/opencode.md +0 -41
- package/docs/zh-CN/providers/openrouter.md +0 -43
- package/docs/zh-CN/providers/qianfan.md +0 -8
- package/docs/zh-CN/providers/qwen.md +0 -55
- package/docs/zh-CN/providers/synthetic.md +0 -102
- package/docs/zh-CN/providers/venice.md +0 -274
- package/docs/zh-CN/providers/vercel-ai-gateway.md +0 -57
- package/docs/zh-CN/providers/xiaomi.md +0 -68
- package/docs/zh-CN/providers/zai.md +0 -41
- package/docs/zh-CN/refactor/exec-host.md +0 -323
- package/docs/zh-CN/refactor/outbound-session-mirroring.md +0 -90
- package/docs/zh-CN/refactor/plugin-sdk.md +0 -221
- package/docs/zh-CN/refactor/strict-config.md +0 -100
- package/docs/zh-CN/refactor/syminet.md +0 -424
- package/docs/zh-CN/reference/AGENTS.default.md +0 -130
- package/docs/zh-CN/reference/RELEASING.md +0 -122
- package/docs/zh-CN/reference/api-usage-costs.md +0 -136
- package/docs/zh-CN/reference/credits.md +0 -34
- package/docs/zh-CN/reference/device-models.md +0 -54
- package/docs/zh-CN/reference/rpc.md +0 -48
- package/docs/zh-CN/reference/session-management-compaction.md +0 -286
- package/docs/zh-CN/reference/templates/AGENTS.dev.md +0 -89
- package/docs/zh-CN/reference/templates/AGENTS.md +0 -234
- package/docs/zh-CN/reference/templates/BOOT.md +0 -17
- package/docs/zh-CN/reference/templates/BOOTSTRAP.md +0 -68
- package/docs/zh-CN/reference/templates/IDENTITY.dev.md +0 -54
- package/docs/zh-CN/reference/templates/IDENTITY.md +0 -36
- package/docs/zh-CN/reference/templates/SYMICORE.dev.md +0 -83
- package/docs/zh-CN/reference/templates/SYMICORE.md +0 -49
- package/docs/zh-CN/reference/templates/SYMIPULSE.md +0 -69
- package/docs/zh-CN/reference/templates/TOOLS.dev.md +0 -31
- package/docs/zh-CN/reference/templates/TOOLS.md +0 -53
- package/docs/zh-CN/reference/templates/USER.dev.md +0 -25
- package/docs/zh-CN/reference/templates/USER.md +0 -30
- package/docs/zh-CN/reference/test.md +0 -57
- package/docs/zh-CN/reference/token-use.md +0 -119
- package/docs/zh-CN/reference/transcript-hygiene.md +0 -109
- package/docs/zh-CN/reference/wizard.md +0 -9
- package/docs/zh-CN/security/formal-verification.md +0 -171
- package/docs/zh-CN/start/bootstrapping.md +0 -9
- package/docs/zh-CN/start/docs-directory.md +0 -69
- package/docs/zh-CN/start/getting-started.md +0 -201
- package/docs/zh-CN/start/hubs.md +0 -199
- package/docs/zh-CN/start/lore.md +0 -223
- package/docs/zh-CN/start/onboarding.md +0 -105
- package/docs/zh-CN/start/quickstart.md +0 -88
- package/docs/zh-CN/start/setup.md +0 -151
- package/docs/zh-CN/start/showcase.md +0 -421
- package/docs/zh-CN/start/symi.md +0 -244
- package/docs/zh-CN/start/wizard.md +0 -326
- package/docs/zh-CN/tools/agent-send.md +0 -58
- package/docs/zh-CN/tools/apply-patch.md +0 -57
- package/docs/zh-CN/tools/browser-linux-troubleshooting.md +0 -144
- package/docs/zh-CN/tools/browser-login.md +0 -75
- package/docs/zh-CN/tools/browser.md +0 -553
- package/docs/zh-CN/tools/chrome-extension.md +0 -183
- package/docs/zh-CN/tools/creating-skills.md +0 -61
- package/docs/zh-CN/tools/elevated.md +0 -62
- package/docs/zh-CN/tools/exec-approvals.md +0 -233
- package/docs/zh-CN/tools/exec.md +0 -169
- package/docs/zh-CN/tools/firecrawl.md +0 -68
- package/docs/zh-CN/tools/index.md +0 -508
- package/docs/zh-CN/tools/llm-task.md +0 -117
- package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +0 -400
- package/docs/zh-CN/tools/pipeline.md +0 -349
- package/docs/zh-CN/tools/plugin.md +0 -639
- package/docs/zh-CN/tools/reactions.md +0 -28
- package/docs/zh-CN/tools/skills-config.md +0 -78
- package/docs/zh-CN/tools/skills.md +0 -279
- package/docs/zh-CN/tools/slash-commands.md +0 -196
- package/docs/zh-CN/tools/subagents.md +0 -167
- package/docs/zh-CN/tools/symihub.md +0 -209
- package/docs/zh-CN/tools/thinking.md +0 -80
- package/docs/zh-CN/tools/web.md +0 -257
- package/docs/zh-CN/tts.md +0 -373
- package/docs/zh-CN/vps.md +0 -47
- package/docs/zh-CN/web/control-ui.md +0 -190
- package/docs/zh-CN/web/dashboard.md +0 -53
- package/docs/zh-CN/web/index.md +0 -118
- package/docs/zh-CN/web/tui.md +0 -166
- package/docs/zh-CN/web/webchat.md +0 -56
- package/extensions/imessage/index.ts +0 -17
- package/extensions/imessage/node_modules/.bin/symi +0 -21
- package/extensions/imessage/package.json +0 -15
- package/extensions/imessage/src/channel.outbound.test.ts +0 -66
- package/extensions/imessage/src/channel.ts +0 -298
- package/extensions/imessage/src/runtime.ts +0 -14
- package/extensions/imessage/symi.plugin.json +0 -9
- package/extensions/line/index.ts +0 -19
- package/extensions/line/node_modules/.bin/symi +0 -21
- package/extensions/line/package.json +0 -30
- package/extensions/line/src/card-command.ts +0 -344
- package/extensions/line/src/channel.logout.test.ts +0 -133
- package/extensions/line/src/channel.sendPayload.test.ts +0 -312
- package/extensions/line/src/channel.startup.test.ts +0 -133
- package/extensions/line/src/channel.ts +0 -801
- package/extensions/line/src/runtime.ts +0 -14
- package/extensions/line/symi.plugin.json +0 -9
- package/extensions/signal/index.ts +0 -17
- package/extensions/signal/node_modules/.bin/symi +0 -21
- package/extensions/signal/package.json +0 -15
- package/extensions/signal/src/channel.ts +0 -302
- package/extensions/signal/src/runtime.ts +0 -14
- package/extensions/signal/symi.plugin.json +0 -9
- package/extensions/telegram/index.ts +0 -17
- package/extensions/telegram/node_modules/.bin/symi +0 -21
- package/extensions/telegram/package.json +0 -15
- package/extensions/telegram/src/channel.test.ts +0 -125
- package/extensions/telegram/src/channel.ts +0 -560
- package/extensions/telegram/src/runtime.ts +0 -14
- package/extensions/telegram/symi.plugin.json +0 -9
- package/extensions/whatsapp/index.ts +0 -17
- package/extensions/whatsapp/node_modules/.bin/symi +0 -21
- package/extensions/whatsapp/package.json +0 -15
- package/extensions/whatsapp/src/channel.ts +0 -465
- package/extensions/whatsapp/src/resolve-target.test.ts +0 -170
- package/extensions/whatsapp/src/runtime.ts +0 -14
- package/extensions/whatsapp/symi.plugin.json +0 -9
package/docs/tools/browser.md
DELETED
|
@@ -1,587 +0,0 @@
|
|
|
1
|
-
---
|
|
2
|
-
summary: "Integrated browser control service + action commands"
|
|
3
|
-
read_when:
|
|
4
|
-
- Adding agent-controlled browser automation
|
|
5
|
-
- Debugging why symi is interfering with your own Chrome
|
|
6
|
-
- Implementing browser settings + lifecycle in the macOS app
|
|
7
|
-
title: "Browser (Symi-managed)"
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# Browser (symi-managed)
|
|
11
|
-
|
|
12
|
-
Symi can run a **dedicated Chrome/Brave/Edge/Chromium profile** that the agent controls.
|
|
13
|
-
It is isolated from your personal browser and is managed through a small local
|
|
14
|
-
control service inside the Gateway (loopback only).
|
|
15
|
-
|
|
16
|
-
Beginner view:
|
|
17
|
-
|
|
18
|
-
- Think of it as a **separate, agent-only browser**.
|
|
19
|
-
- The `symi` profile does **not** touch your personal browser profile.
|
|
20
|
-
- The agent can **open tabs, read pages, click, and type** in a safe lane.
|
|
21
|
-
- The default `chrome` profile uses the **system default Chromium browser** via the
|
|
22
|
-
extension relay; switch to `symi` for the isolated managed browser.
|
|
23
|
-
|
|
24
|
-
## What you get
|
|
25
|
-
|
|
26
|
-
- A separate browser profile named **symi** (orange accent by default).
|
|
27
|
-
- Deterministic tab control (list/open/focus/close).
|
|
28
|
-
- Agent actions (click/type/drag/select), snapshots, screenshots, PDFs.
|
|
29
|
-
- Optional multi-profile support (`symi`, `work`, `remote`, ...).
|
|
30
|
-
|
|
31
|
-
This browser is **not** your daily driver. It is a safe, isolated surface for
|
|
32
|
-
agent automation and verification.
|
|
33
|
-
|
|
34
|
-
## Quick start
|
|
35
|
-
|
|
36
|
-
```bash
|
|
37
|
-
symi browser --browser-profile symi status
|
|
38
|
-
symi browser --browser-profile symi start
|
|
39
|
-
symi browser --browser-profile symi open https://example.com
|
|
40
|
-
symi browser --browser-profile symi snapshot
|
|
41
|
-
```
|
|
42
|
-
|
|
43
|
-
If you get “Browser disabled”, enable it in config (see below) and restart the
|
|
44
|
-
Gateway.
|
|
45
|
-
|
|
46
|
-
## Profiles: `symi` vs `chrome`
|
|
47
|
-
|
|
48
|
-
- `symi`: managed, isolated browser (no extension required).
|
|
49
|
-
- `chrome`: extension relay to your **system browser** (requires the Symi
|
|
50
|
-
extension to be attached to a tab).
|
|
51
|
-
|
|
52
|
-
Set `browser.defaultProfile: "symi"` if you want managed mode by default.
|
|
53
|
-
|
|
54
|
-
## Configuration
|
|
55
|
-
|
|
56
|
-
Browser settings live in `~/.symi/symi.json`.
|
|
57
|
-
|
|
58
|
-
```json5
|
|
59
|
-
{
|
|
60
|
-
browser: {
|
|
61
|
-
enabled: true, // default: true
|
|
62
|
-
// cdpUrl: "http://127.0.0.1:18792", // legacy single-profile override
|
|
63
|
-
remoteCdpTimeoutMs: 1500, // remote CDP HTTP timeout (ms)
|
|
64
|
-
remoteCdpHandshakeTimeoutMs: 3000, // remote CDP WebSocket handshake timeout (ms)
|
|
65
|
-
defaultProfile: "chrome",
|
|
66
|
-
color: "#FF4500",
|
|
67
|
-
headless: false,
|
|
68
|
-
noSandbox: false,
|
|
69
|
-
attachOnly: false,
|
|
70
|
-
executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser",
|
|
71
|
-
profiles: {
|
|
72
|
-
symi: { cdpPort: 18800, color: "#FF4500" },
|
|
73
|
-
work: { cdpPort: 18801, color: "#0066CC" },
|
|
74
|
-
remote: { cdpUrl: "http://10.0.0.42:9222", color: "#00AA00" },
|
|
75
|
-
},
|
|
76
|
-
},
|
|
77
|
-
}
|
|
78
|
-
```
|
|
79
|
-
|
|
80
|
-
Notes:
|
|
81
|
-
|
|
82
|
-
- The browser control service binds to loopback on a port derived from `gateway.port`
|
|
83
|
-
(default: `18791`, which is gateway + 2). The relay uses the next port (`18792`).
|
|
84
|
-
- If you override the Gateway port (`gateway.port` or `SYMI_GATEWAY_PORT`),
|
|
85
|
-
the derived browser ports shift to stay in the same “family”.
|
|
86
|
-
- `cdpUrl` defaults to the relay port when unset.
|
|
87
|
-
- `remoteCdpTimeoutMs` applies to remote (non-loopback) CDP reachability checks.
|
|
88
|
-
- `remoteCdpHandshakeTimeoutMs` applies to remote CDP WebSocket reachability checks.
|
|
89
|
-
- `attachOnly: true` means “never launch a local browser; only attach if it is already running.”
|
|
90
|
-
- `color` + per-profile `color` tint the browser UI so you can see which profile is active.
|
|
91
|
-
- Default profile is `chrome` (extension relay). Use `defaultProfile: "symi"` for the managed browser.
|
|
92
|
-
- Auto-detect order: system default browser if Chromium-based; otherwise Chrome → Brave → Edge → Chromium → Chrome Canary.
|
|
93
|
-
- Local `symi` profiles auto-assign `cdpPort`/`cdpUrl` — set those only for remote CDP.
|
|
94
|
-
|
|
95
|
-
## Use Brave (or another Chromium-based browser)
|
|
96
|
-
|
|
97
|
-
If your **system default** browser is Chromium-based (Chrome/Brave/Edge/etc),
|
|
98
|
-
Symi uses it automatically. Set `browser.executablePath` to override
|
|
99
|
-
auto-detection:
|
|
100
|
-
|
|
101
|
-
CLI example:
|
|
102
|
-
|
|
103
|
-
```bash
|
|
104
|
-
symi config set browser.executablePath "/usr/bin/google-chrome"
|
|
105
|
-
```
|
|
106
|
-
|
|
107
|
-
```json5
|
|
108
|
-
// macOS
|
|
109
|
-
{
|
|
110
|
-
browser: {
|
|
111
|
-
executablePath: "/Applications/Brave Browser.app/Contents/MacOS/Brave Browser"
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
// Windows
|
|
116
|
-
{
|
|
117
|
-
browser: {
|
|
118
|
-
executablePath: "C:\\Program Files\\BraveSoftware\\Brave-Browser\\Application\\brave.exe"
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
// Linux
|
|
123
|
-
{
|
|
124
|
-
browser: {
|
|
125
|
-
executablePath: "/usr/bin/brave-browser"
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
```
|
|
129
|
-
|
|
130
|
-
## Local vs remote control
|
|
131
|
-
|
|
132
|
-
- **Local control (default):** the Gateway starts the loopback control service and can launch a local browser.
|
|
133
|
-
- **Remote control (node host):** run a node host on the machine that has the browser; the Gateway proxies browser actions to it.
|
|
134
|
-
- **Remote CDP:** set `browser.profiles.<name>.cdpUrl` (or `browser.cdpUrl`) to
|
|
135
|
-
attach to a remote Chromium-based browser. In this case, Symi will not launch a local browser.
|
|
136
|
-
|
|
137
|
-
Remote CDP URLs can include auth:
|
|
138
|
-
|
|
139
|
-
- Query tokens (e.g., `https://provider.example?token=<token>`)
|
|
140
|
-
- HTTP Basic auth (e.g., `https://user:pass@provider.example`)
|
|
141
|
-
|
|
142
|
-
Symi preserves the auth when calling `/json/*` endpoints and when connecting
|
|
143
|
-
to the CDP WebSocket. Prefer environment variables or secrets managers for
|
|
144
|
-
tokens instead of committing them to config files.
|
|
145
|
-
|
|
146
|
-
## Node browser proxy (zero-config default)
|
|
147
|
-
|
|
148
|
-
If you run a **node host** on the machine that has your browser, Symi can
|
|
149
|
-
auto-route browser tool calls to that node without any extra browser config.
|
|
150
|
-
This is the default path for remote gateways.
|
|
151
|
-
|
|
152
|
-
Notes:
|
|
153
|
-
|
|
154
|
-
- The node host exposes its local browser control server via a **proxy command**.
|
|
155
|
-
- Profiles come from the node’s own `browser.profiles` config (same as local).
|
|
156
|
-
- Disable if you don’t want it:
|
|
157
|
-
- On the node: `nodeHost.browserProxy.enabled=false`
|
|
158
|
-
- On the gateway: `gateway.nodes.browser.mode="off"`
|
|
159
|
-
|
|
160
|
-
## Browserless (hosted remote CDP)
|
|
161
|
-
|
|
162
|
-
[Browserless](https://browserless.io) is a hosted Chromium service that exposes
|
|
163
|
-
CDP endpoints over HTTPS. You can point a Symi browser profile at a
|
|
164
|
-
Browserless region endpoint and authenticate with your API key.
|
|
165
|
-
|
|
166
|
-
Example:
|
|
167
|
-
|
|
168
|
-
```json5
|
|
169
|
-
{
|
|
170
|
-
browser: {
|
|
171
|
-
enabled: true,
|
|
172
|
-
defaultProfile: "browserless",
|
|
173
|
-
remoteCdpTimeoutMs: 2000,
|
|
174
|
-
remoteCdpHandshakeTimeoutMs: 4000,
|
|
175
|
-
profiles: {
|
|
176
|
-
browserless: {
|
|
177
|
-
cdpUrl: "https://production-sfo.browserless.io?token=<BROWSERLESS_API_KEY>",
|
|
178
|
-
color: "#00AA00",
|
|
179
|
-
},
|
|
180
|
-
},
|
|
181
|
-
},
|
|
182
|
-
}
|
|
183
|
-
```
|
|
184
|
-
|
|
185
|
-
Notes:
|
|
186
|
-
|
|
187
|
-
- Replace `<BROWSERLESS_API_KEY>` with your real Browserless token.
|
|
188
|
-
- Choose the region endpoint that matches your Browserless account (see their docs).
|
|
189
|
-
|
|
190
|
-
## Security
|
|
191
|
-
|
|
192
|
-
Key ideas:
|
|
193
|
-
|
|
194
|
-
- Browser control is loopback-only; access flows through the Gateway’s auth or node pairing.
|
|
195
|
-
- If browser control is enabled and no auth is configured, Symi auto-generates `gateway.auth.token` on startup and persists it to config.
|
|
196
|
-
- Keep the Gateway and any node hosts on a private network (Tailscale); avoid public exposure.
|
|
197
|
-
- Treat remote CDP URLs/tokens as secrets; prefer env vars or a secrets manager.
|
|
198
|
-
|
|
199
|
-
Remote CDP tips:
|
|
200
|
-
|
|
201
|
-
- Prefer HTTPS endpoints and short-lived tokens where possible.
|
|
202
|
-
- Avoid embedding long-lived tokens directly in config files.
|
|
203
|
-
|
|
204
|
-
## Profiles (multi-browser)
|
|
205
|
-
|
|
206
|
-
Symi supports multiple named profiles (routing configs). Profiles can be:
|
|
207
|
-
|
|
208
|
-
- **symi-managed**: a dedicated Chromium-based browser instance with its own user data directory + CDP port
|
|
209
|
-
- **remote**: an explicit CDP URL (Chromium-based browser running elsewhere)
|
|
210
|
-
- **extension relay**: your existing Chrome tab(s) via the local relay + Chrome extension
|
|
211
|
-
|
|
212
|
-
Defaults:
|
|
213
|
-
|
|
214
|
-
- The `symi` profile is auto-created if missing.
|
|
215
|
-
- The `chrome` profile is built-in for the Chrome extension relay (points at `http://127.0.0.1:18792` by default).
|
|
216
|
-
- Local CDP ports allocate from **18800–18899** by default.
|
|
217
|
-
- Deleting a profile moves its local data directory to Trash.
|
|
218
|
-
|
|
219
|
-
All control endpoints accept `?profile=<name>`; the CLI uses `--browser-profile`.
|
|
220
|
-
|
|
221
|
-
## Chrome extension relay (use your existing Chrome)
|
|
222
|
-
|
|
223
|
-
Symi can also drive **your existing Chrome tabs** (no separate “symi” Chrome instance) via a local CDP relay + a Chrome extension.
|
|
224
|
-
|
|
225
|
-
Full guide: [Chrome extension](/tools/chrome-extension)
|
|
226
|
-
|
|
227
|
-
Flow:
|
|
228
|
-
|
|
229
|
-
- The Gateway runs locally (same machine) or a node host runs on the browser machine.
|
|
230
|
-
- A local **relay server** listens at a loopback `cdpUrl` (default: `http://127.0.0.1:18792`).
|
|
231
|
-
- You click the **Symi Browser Relay** extension icon on a tab to attach (it does not auto-attach).
|
|
232
|
-
- The agent controls that tab via the normal `browser` tool, by selecting the right profile.
|
|
233
|
-
|
|
234
|
-
If the Gateway runs elsewhere, run a node host on the browser machine so the Gateway can proxy browser actions.
|
|
235
|
-
|
|
236
|
-
### Sandboxed sessions
|
|
237
|
-
|
|
238
|
-
If the agent session is sandboxed, the `browser` tool may default to `target="sandbox"` (sandbox browser).
|
|
239
|
-
Chrome extension relay takeover requires host browser control, so either:
|
|
240
|
-
|
|
241
|
-
- run the session unsandboxed, or
|
|
242
|
-
- set `agents.defaults.sandbox.browser.allowHostControl: true` and use `target="host"` when calling the tool.
|
|
243
|
-
|
|
244
|
-
### Setup
|
|
245
|
-
|
|
246
|
-
1. Load the extension (dev/unpacked):
|
|
247
|
-
|
|
248
|
-
```bash
|
|
249
|
-
symi browser extension install
|
|
250
|
-
```
|
|
251
|
-
|
|
252
|
-
- Chrome → `chrome://extensions` → enable “Developer mode”
|
|
253
|
-
- “Load unpacked” → select the directory printed by `symi browser extension path`
|
|
254
|
-
- Pin the extension, then click it on the tab you want to control (badge shows `ON`).
|
|
255
|
-
|
|
256
|
-
2. Use it:
|
|
257
|
-
|
|
258
|
-
- CLI: `symi browser --browser-profile chrome tabs`
|
|
259
|
-
- Agent tool: `browser` with `profile="chrome"`
|
|
260
|
-
|
|
261
|
-
Optional: if you want a different name or relay port, create your own profile:
|
|
262
|
-
|
|
263
|
-
```bash
|
|
264
|
-
symi browser create-profile \
|
|
265
|
-
--name my-chrome \
|
|
266
|
-
--driver extension \
|
|
267
|
-
--cdp-url http://127.0.0.1:18792 \
|
|
268
|
-
--color "#00AA00"
|
|
269
|
-
```
|
|
270
|
-
|
|
271
|
-
Notes:
|
|
272
|
-
|
|
273
|
-
- This mode relies on Playwright-on-CDP for most operations (screenshots/snapshots/actions).
|
|
274
|
-
- Detach by clicking the extension icon again.
|
|
275
|
-
|
|
276
|
-
## Isolation guarantees
|
|
277
|
-
|
|
278
|
-
- **Dedicated user data dir**: never touches your personal browser profile.
|
|
279
|
-
- **Dedicated ports**: avoids `9222` to prevent collisions with dev workflows.
|
|
280
|
-
- **Deterministic tab control**: target tabs by `targetId`, not “last tab”.
|
|
281
|
-
|
|
282
|
-
## Browser selection
|
|
283
|
-
|
|
284
|
-
When launching locally, Symi picks the first available:
|
|
285
|
-
|
|
286
|
-
1. Chrome
|
|
287
|
-
2. Brave
|
|
288
|
-
3. Edge
|
|
289
|
-
4. Chromium
|
|
290
|
-
5. Chrome Canary
|
|
291
|
-
|
|
292
|
-
You can override with `browser.executablePath`.
|
|
293
|
-
|
|
294
|
-
Platforms:
|
|
295
|
-
|
|
296
|
-
- macOS: checks `/Applications` and `~/Applications`.
|
|
297
|
-
- Linux: looks for `google-chrome`, `brave`, `microsoft-edge`, `chromium`, etc.
|
|
298
|
-
- Windows: checks common install locations.
|
|
299
|
-
|
|
300
|
-
## Control API (optional)
|
|
301
|
-
|
|
302
|
-
For local integrations only, the Gateway exposes a small loopback HTTP API:
|
|
303
|
-
|
|
304
|
-
- Status/start/stop: `GET /`, `POST /start`, `POST /stop`
|
|
305
|
-
- Tabs: `GET /tabs`, `POST /tabs/open`, `POST /tabs/focus`, `DELETE /tabs/:targetId`
|
|
306
|
-
- Snapshot/screenshot: `GET /snapshot`, `POST /screenshot`
|
|
307
|
-
- Actions: `POST /navigate`, `POST /act`
|
|
308
|
-
- Hooks: `POST /hooks/file-chooser`, `POST /hooks/dialog`
|
|
309
|
-
- Downloads: `POST /download`, `POST /wait/download`
|
|
310
|
-
- Debugging: `GET /console`, `POST /pdf`
|
|
311
|
-
- Debugging: `GET /errors`, `GET /requests`, `POST /trace/start`, `POST /trace/stop`, `POST /highlight`
|
|
312
|
-
- Network: `POST /response/body`
|
|
313
|
-
- State: `GET /cookies`, `POST /cookies/set`, `POST /cookies/clear`
|
|
314
|
-
- State: `GET /storage/:kind`, `POST /storage/:kind/set`, `POST /storage/:kind/clear`
|
|
315
|
-
- Settings: `POST /set/offline`, `POST /set/headers`, `POST /set/credentials`, `POST /set/geolocation`, `POST /set/media`, `POST /set/timezone`, `POST /set/locale`, `POST /set/device`
|
|
316
|
-
|
|
317
|
-
All endpoints accept `?profile=<name>`.
|
|
318
|
-
|
|
319
|
-
If gateway auth is configured, browser HTTP routes require auth too:
|
|
320
|
-
|
|
321
|
-
- `Authorization: Bearer <gateway token>`
|
|
322
|
-
- `x-symi-password: <gateway password>` or HTTP Basic auth with that password
|
|
323
|
-
|
|
324
|
-
### Playwright requirement
|
|
325
|
-
|
|
326
|
-
Some features (navigate/act/AI snapshot/role snapshot, element screenshots, PDF) require
|
|
327
|
-
Playwright. If Playwright isn’t installed, those endpoints return a clear 501
|
|
328
|
-
error. ARIA snapshots and basic screenshots still work for symi-managed Chrome.
|
|
329
|
-
For the Chrome extension relay driver, ARIA snapshots and screenshots require Playwright.
|
|
330
|
-
|
|
331
|
-
If you see `Playwright is not available in this gateway build`, install the full
|
|
332
|
-
Playwright package (not `playwright-core`) and restart the gateway, or reinstall
|
|
333
|
-
Symi with browser support.
|
|
334
|
-
|
|
335
|
-
#### Docker Playwright install
|
|
336
|
-
|
|
337
|
-
If your Gateway runs in Docker, avoid `npx playwright` (npm override conflicts).
|
|
338
|
-
Use the bundled CLI instead:
|
|
339
|
-
|
|
340
|
-
```bash
|
|
341
|
-
docker compose run --rm symi-cli \
|
|
342
|
-
node /app/node_modules/playwright-core/cli.js install chromium
|
|
343
|
-
```
|
|
344
|
-
|
|
345
|
-
To persist browser downloads, set `PLAYWRIGHT_BROWSERS_PATH` (for example,
|
|
346
|
-
`/home/node/.cache/ms-playwright`) and make sure `/home/node` is persisted via
|
|
347
|
-
`SYMI_HOME_VOLUME` or a bind mount. See [Docker](/install/docker).
|
|
348
|
-
|
|
349
|
-
## How it works (internal)
|
|
350
|
-
|
|
351
|
-
High-level flow:
|
|
352
|
-
|
|
353
|
-
- A small **control server** accepts HTTP requests.
|
|
354
|
-
- It connects to Chromium-based browsers (Chrome/Brave/Edge/Chromium) via **CDP**.
|
|
355
|
-
- For advanced actions (click/type/snapshot/PDF), it uses **Playwright** on top
|
|
356
|
-
of CDP.
|
|
357
|
-
- When Playwright is missing, only non-Playwright operations are available.
|
|
358
|
-
|
|
359
|
-
This design keeps the agent on a stable, deterministic interface while letting
|
|
360
|
-
you swap local/remote browsers and profiles.
|
|
361
|
-
|
|
362
|
-
## CLI quick reference
|
|
363
|
-
|
|
364
|
-
All commands accept `--browser-profile <name>` to target a specific profile.
|
|
365
|
-
All commands also accept `--json` for machine-readable output (stable payloads).
|
|
366
|
-
|
|
367
|
-
Basics:
|
|
368
|
-
|
|
369
|
-
- `symi browser status`
|
|
370
|
-
- `symi browser start`
|
|
371
|
-
- `symi browser stop`
|
|
372
|
-
- `symi browser tabs`
|
|
373
|
-
- `symi browser tab`
|
|
374
|
-
- `symi browser tab new`
|
|
375
|
-
- `symi browser tab select 2`
|
|
376
|
-
- `symi browser tab close 2`
|
|
377
|
-
- `symi browser open https://example.com`
|
|
378
|
-
- `symi browser focus abcd1234`
|
|
379
|
-
- `symi browser close abcd1234`
|
|
380
|
-
|
|
381
|
-
Inspection:
|
|
382
|
-
|
|
383
|
-
- `symi browser screenshot`
|
|
384
|
-
- `symi browser screenshot --full-page`
|
|
385
|
-
- `symi browser screenshot --ref 12`
|
|
386
|
-
- `symi browser screenshot --ref e12`
|
|
387
|
-
- `symi browser snapshot`
|
|
388
|
-
- `symi browser snapshot --format aria --limit 200`
|
|
389
|
-
- `symi browser snapshot --interactive --compact --depth 6`
|
|
390
|
-
- `symi browser snapshot --efficient`
|
|
391
|
-
- `symi browser snapshot --labels`
|
|
392
|
-
- `symi browser snapshot --selector "#main" --interactive`
|
|
393
|
-
- `symi browser snapshot --frame "iframe#main" --interactive`
|
|
394
|
-
- `symi browser console --level error`
|
|
395
|
-
- `symi browser errors --clear`
|
|
396
|
-
- `symi browser requests --filter api --clear`
|
|
397
|
-
- `symi browser pdf`
|
|
398
|
-
- `symi browser responsebody "**/api" --max-chars 5000`
|
|
399
|
-
|
|
400
|
-
Actions:
|
|
401
|
-
|
|
402
|
-
- `symi browser navigate https://example.com`
|
|
403
|
-
- `symi browser resize 1280 720`
|
|
404
|
-
- `symi browser click 12 --double`
|
|
405
|
-
- `symi browser click e12 --double`
|
|
406
|
-
- `symi browser type 23 "hello" --submit`
|
|
407
|
-
- `symi browser press Enter`
|
|
408
|
-
- `symi browser hover 44`
|
|
409
|
-
- `symi browser scrollintoview e12`
|
|
410
|
-
- `symi browser drag 10 11`
|
|
411
|
-
- `symi browser select 9 OptionA OptionB`
|
|
412
|
-
- `symi browser download e12 report.pdf`
|
|
413
|
-
- `symi browser waitfordownload report.pdf`
|
|
414
|
-
- `symi browser upload /tmp/symi/uploads/file.pdf`
|
|
415
|
-
- `symi browser fill --fields '[{"ref":"1","type":"text","value":"Ada"}]'`
|
|
416
|
-
- `symi browser dialog --accept`
|
|
417
|
-
- `symi browser wait --text "Done"`
|
|
418
|
-
- `symi browser wait "#main" --url "**/dash" --load networkidle --fn "window.ready===true"`
|
|
419
|
-
- `symi browser evaluate --fn '(el) => el.textContent' --ref 7`
|
|
420
|
-
- `symi browser highlight e12`
|
|
421
|
-
- `symi browser trace start`
|
|
422
|
-
- `symi browser trace stop`
|
|
423
|
-
|
|
424
|
-
State:
|
|
425
|
-
|
|
426
|
-
- `symi browser cookies`
|
|
427
|
-
- `symi browser cookies set session abc123 --url "https://example.com"`
|
|
428
|
-
- `symi browser cookies clear`
|
|
429
|
-
- `symi browser storage local get`
|
|
430
|
-
- `symi browser storage local set theme dark`
|
|
431
|
-
- `symi browser storage session clear`
|
|
432
|
-
- `symi browser set offline on`
|
|
433
|
-
- `symi browser set headers --headers-json '{"X-Debug":"1"}'`
|
|
434
|
-
- `symi browser set credentials user pass`
|
|
435
|
-
- `symi browser set credentials --clear`
|
|
436
|
-
- `symi browser set geo 37.7749 -122.4194 --origin "https://example.com"`
|
|
437
|
-
- `symi browser set geo --clear`
|
|
438
|
-
- `symi browser set media dark`
|
|
439
|
-
- `symi browser set timezone America/New_York`
|
|
440
|
-
- `symi browser set locale en-US`
|
|
441
|
-
- `symi browser set device "iPhone 14"`
|
|
442
|
-
|
|
443
|
-
Notes:
|
|
444
|
-
|
|
445
|
-
- `upload` and `dialog` are **arming** calls; run them before the click/press
|
|
446
|
-
that triggers the chooser/dialog.
|
|
447
|
-
- Download and trace output paths are constrained to Symi temp roots:
|
|
448
|
-
- traces: `/tmp/symi` (fallback: `${os.tmpdir()}/symi`)
|
|
449
|
-
- downloads: `/tmp/symi/downloads` (fallback: `${os.tmpdir()}/symi/downloads`)
|
|
450
|
-
- Upload paths are constrained to an Symi temp uploads root:
|
|
451
|
-
- uploads: `/tmp/symi/uploads` (fallback: `${os.tmpdir()}/symi/uploads`)
|
|
452
|
-
- `upload` can also set file inputs directly via `--input-ref` or `--element`.
|
|
453
|
-
- `snapshot`:
|
|
454
|
-
- `--format ai` (default when Playwright is installed): returns an AI snapshot with numeric refs (`aria-ref="<n>"`).
|
|
455
|
-
- `--format aria`: returns the accessibility tree (no refs; inspection only).
|
|
456
|
-
- `--efficient` (or `--mode efficient`): compact role snapshot preset (interactive + compact + depth + lower maxChars).
|
|
457
|
-
- Config default (tool/CLI only): set `browser.snapshotDefaults.mode: "efficient"` to use efficient snapshots when the caller does not pass a mode (see [Gateway configuration](/gateway/configuration#browser-symi-managed-browser)).
|
|
458
|
-
- Role snapshot options (`--interactive`, `--compact`, `--depth`, `--selector`) force a role-based snapshot with refs like `ref=e12`.
|
|
459
|
-
- `--frame "<iframe selector>"` scopes role snapshots to an iframe (pairs with role refs like `e12`).
|
|
460
|
-
- `--interactive` outputs a flat, easy-to-pick list of interactive elements (best for driving actions).
|
|
461
|
-
- `--labels` adds a viewport-only screenshot with overlayed ref labels (prints `MEDIA:<path>`).
|
|
462
|
-
- `click`/`type`/etc require a `ref` from `snapshot` (either numeric `12` or role ref `e12`).
|
|
463
|
-
CSS selectors are intentionally not supported for actions.
|
|
464
|
-
|
|
465
|
-
## Snapshots and refs
|
|
466
|
-
|
|
467
|
-
Symi supports two “snapshot” styles:
|
|
468
|
-
|
|
469
|
-
- **AI snapshot (numeric refs)**: `symi browser snapshot` (default; `--format ai`)
|
|
470
|
-
- Output: a text snapshot that includes numeric refs.
|
|
471
|
-
- Actions: `symi browser click 12`, `symi browser type 23 "hello"`.
|
|
472
|
-
- Internally, the ref is resolved via Playwright’s `aria-ref`.
|
|
473
|
-
|
|
474
|
-
- **Role snapshot (role refs like `e12`)**: `symi browser snapshot --interactive` (or `--compact`, `--depth`, `--selector`, `--frame`)
|
|
475
|
-
- Output: a role-based list/tree with `[ref=e12]` (and optional `[nth=1]`).
|
|
476
|
-
- Actions: `symi browser click e12`, `symi browser highlight e12`.
|
|
477
|
-
- Internally, the ref is resolved via `getByRole(...)` (plus `nth()` for duplicates).
|
|
478
|
-
- Add `--labels` to include a viewport screenshot with overlayed `e12` labels.
|
|
479
|
-
|
|
480
|
-
Ref behavior:
|
|
481
|
-
|
|
482
|
-
- Refs are **not stable across navigations**; if something fails, re-run `snapshot` and use a fresh ref.
|
|
483
|
-
- If the role snapshot was taken with `--frame`, role refs are scoped to that iframe until the next role snapshot.
|
|
484
|
-
|
|
485
|
-
## Wait power-ups
|
|
486
|
-
|
|
487
|
-
You can wait on more than just time/text:
|
|
488
|
-
|
|
489
|
-
- Wait for URL (globs supported by Playwright):
|
|
490
|
-
- `symi browser wait --url "**/dash"`
|
|
491
|
-
- Wait for load state:
|
|
492
|
-
- `symi browser wait --load networkidle`
|
|
493
|
-
- Wait for a JS predicate:
|
|
494
|
-
- `symi browser wait --fn "window.ready===true"`
|
|
495
|
-
- Wait for a selector to become visible:
|
|
496
|
-
- `symi browser wait "#main"`
|
|
497
|
-
|
|
498
|
-
These can be combined:
|
|
499
|
-
|
|
500
|
-
```bash
|
|
501
|
-
symi browser wait "#main" \
|
|
502
|
-
--url "**/dash" \
|
|
503
|
-
--load networkidle \
|
|
504
|
-
--fn "window.ready===true" \
|
|
505
|
-
--timeout-ms 15000
|
|
506
|
-
```
|
|
507
|
-
|
|
508
|
-
## Debug workflows
|
|
509
|
-
|
|
510
|
-
When an action fails (e.g. “not visible”, “strict mode violation”, “covered”):
|
|
511
|
-
|
|
512
|
-
1. `symi browser snapshot --interactive`
|
|
513
|
-
2. Use `click <ref>` / `type <ref>` (prefer role refs in interactive mode)
|
|
514
|
-
3. If it still fails: `symi browser highlight <ref>` to see what Playwright is targeting
|
|
515
|
-
4. If the page behaves oddly:
|
|
516
|
-
- `symi browser errors --clear`
|
|
517
|
-
- `symi browser requests --filter api --clear`
|
|
518
|
-
5. For deep debugging: record a trace:
|
|
519
|
-
- `symi browser trace start`
|
|
520
|
-
- reproduce the issue
|
|
521
|
-
- `symi browser trace stop` (prints `TRACE:<path>`)
|
|
522
|
-
|
|
523
|
-
## JSON output
|
|
524
|
-
|
|
525
|
-
`--json` is for scripting and structured tooling.
|
|
526
|
-
|
|
527
|
-
Examples:
|
|
528
|
-
|
|
529
|
-
```bash
|
|
530
|
-
symi browser status --json
|
|
531
|
-
symi browser snapshot --interactive --json
|
|
532
|
-
symi browser requests --filter api --json
|
|
533
|
-
symi browser cookies --json
|
|
534
|
-
```
|
|
535
|
-
|
|
536
|
-
Role snapshots in JSON include `refs` plus a small `stats` block (lines/chars/refs/interactive) so tools can reason about payload size and density.
|
|
537
|
-
|
|
538
|
-
## State and environment knobs
|
|
539
|
-
|
|
540
|
-
These are useful for “make the site behave like X” workflows:
|
|
541
|
-
|
|
542
|
-
- Cookies: `cookies`, `cookies set`, `cookies clear`
|
|
543
|
-
- Storage: `storage local|session get|set|clear`
|
|
544
|
-
- Offline: `set offline on|off`
|
|
545
|
-
- Headers: `set headers --headers-json '{"X-Debug":"1"}'` (legacy `set headers --json '{"X-Debug":"1"}'` remains supported)
|
|
546
|
-
- HTTP basic auth: `set credentials user pass` (or `--clear`)
|
|
547
|
-
- Geolocation: `set geo <lat> <lon> --origin "https://example.com"` (or `--clear`)
|
|
548
|
-
- Media: `set media dark|light|no-preference|none`
|
|
549
|
-
- Timezone / locale: `set timezone ...`, `set locale ...`
|
|
550
|
-
- Device / viewport:
|
|
551
|
-
- `set device "iPhone 14"` (Playwright device presets)
|
|
552
|
-
- `set viewport 1280 720`
|
|
553
|
-
|
|
554
|
-
## Security & privacy
|
|
555
|
-
|
|
556
|
-
- The symi browser profile may contain logged-in sessions; treat it as sensitive.
|
|
557
|
-
- `browser act kind=evaluate` / `symi browser evaluate` and `wait --fn`
|
|
558
|
-
execute arbitrary JavaScript in the page context. Prompt injection can steer
|
|
559
|
-
this. Disable it with `browser.evaluateEnabled=false` if you do not need it.
|
|
560
|
-
- For logins and anti-bot notes (X/Twitter, etc.), see [Browser login + X/Twitter posting](/tools/browser-login).
|
|
561
|
-
- Keep the Gateway/node host private (loopback or tailnet-only).
|
|
562
|
-
- Remote CDP endpoints are powerful; tunnel and protect them.
|
|
563
|
-
|
|
564
|
-
## Troubleshooting
|
|
565
|
-
|
|
566
|
-
For Linux-specific issues (especially snap Chromium), see
|
|
567
|
-
[Browser troubleshooting](/tools/browser-linux-troubleshooting).
|
|
568
|
-
|
|
569
|
-
## Agent tools + how control works
|
|
570
|
-
|
|
571
|
-
The agent gets **one tool** for browser automation:
|
|
572
|
-
|
|
573
|
-
- `browser` — status/start/stop/tabs/open/focus/close/snapshot/screenshot/navigate/act
|
|
574
|
-
|
|
575
|
-
How it maps:
|
|
576
|
-
|
|
577
|
-
- `browser snapshot` returns a stable UI tree (AI or ARIA).
|
|
578
|
-
- `browser act` uses the snapshot `ref` IDs to click/type/drag/select.
|
|
579
|
-
- `browser screenshot` captures pixels (full page or element).
|
|
580
|
-
- `browser` accepts:
|
|
581
|
-
- `profile` to choose a named browser profile (symi, chrome, or remote CDP).
|
|
582
|
-
- `target` (`sandbox` | `host` | `node`) to select where the browser lives.
|
|
583
|
-
- In sandboxed sessions, `target: "host"` requires `agents.defaults.sandbox.browser.allowHostControl=true`.
|
|
584
|
-
- If `target` is omitted: sandboxed sessions default to `sandbox`, non-sandbox sessions default to `host`.
|
|
585
|
-
- If a browser-capable node is connected, the tool may auto-route to it unless you pin `target="host"` or `target="node"`.
|
|
586
|
-
|
|
587
|
-
This keeps the agent deterministic and avoids brittle selectors.
|