@symerian/symi 3.0.21 → 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.
Files changed (688) hide show
  1. package/dist/build-info.json +3 -3
  2. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  3. package/package.json +1 -1
  4. package/docs/.i18n/README.md +0 -31
  5. package/docs/.i18n/glossary.ja-JP.json +0 -14
  6. package/docs/.i18n/glossary.zh-CN.json +0 -210
  7. package/docs/.i18n/ja-JP.tm.jsonl +0 -0
  8. package/docs/.i18n/zh-CN.tm.jsonl +0 -1303
  9. package/docs/CNAME +0 -1
  10. package/docs/assets/install-script.svg +0 -1
  11. package/docs/assets/macos-onboarding/01-macos-warning.jpeg +0 -0
  12. package/docs/assets/macos-onboarding/02-local-networks.jpeg +0 -0
  13. package/docs/assets/macos-onboarding/03-security-notice.png +0 -0
  14. package/docs/assets/macos-onboarding/04-choose-gateway.png +0 -0
  15. package/docs/assets/macos-onboarding/05-permissions.png +0 -0
  16. package/docs/assets/pixel-symi.svg +0 -60
  17. package/docs/assets/showcase/agents-ui.jpg +0 -0
  18. package/docs/assets/showcase/bambu-cli.png +0 -0
  19. package/docs/assets/showcase/codexmonitor.png +0 -0
  20. package/docs/assets/showcase/gohome-grafana.png +0 -0
  21. package/docs/assets/showcase/ios-testflight.jpg +0 -0
  22. package/docs/assets/showcase/oura-health.png +0 -0
  23. package/docs/assets/showcase/padel-cli.svg +0 -11
  24. package/docs/assets/showcase/padel-screenshot.jpg +0 -0
  25. package/docs/assets/showcase/papla-tts.jpg +0 -0
  26. package/docs/assets/showcase/pr-review-telegram.jpg +0 -0
  27. package/docs/assets/showcase/roborock-screenshot.jpg +0 -0
  28. package/docs/assets/showcase/roborock-status.svg +0 -13
  29. package/docs/assets/showcase/roof-camera-sky.jpg +0 -0
  30. package/docs/assets/showcase/snag.png +0 -0
  31. package/docs/assets/showcase/tesco-shop.jpg +0 -0
  32. package/docs/assets/showcase/wienerlinien.png +0 -0
  33. package/docs/assets/showcase/wine-cellar-skill.jpg +0 -0
  34. package/docs/assets/showcase/winix-air-purifier.jpg +0 -0
  35. package/docs/assets/showcase/xuezh-pronunciation.jpeg +0 -0
  36. package/docs/assets/sponsors/blacksmith.svg +0 -14
  37. package/docs/assets/sponsors/openai.svg +0 -3
  38. package/docs/assets/symi-logo-text-dark.png +0 -0
  39. package/docs/assets/symi-logo-text.png +0 -0
  40. package/docs/automation/auth-monitoring.md +0 -44
  41. package/docs/automation/cron-jobs.md +0 -540
  42. package/docs/automation/cron-vs-heartbeat.md +0 -286
  43. package/docs/automation/gmail-pubsub.md +0 -256
  44. package/docs/automation/hooks.md +0 -998
  45. package/docs/automation/poll.md +0 -61
  46. package/docs/automation/troubleshooting.md +0 -122
  47. package/docs/automation/webhook.md +0 -213
  48. package/docs/brave-search.md +0 -41
  49. package/docs/capabilities.md +0 -151
  50. package/docs/channels/bluebubbles.md +0 -346
  51. package/docs/channels/broadcast-groups.md +0 -441
  52. package/docs/channels/channel-routing.md +0 -112
  53. package/docs/channels/feishu.md +0 -586
  54. package/docs/channels/googlechat.md +0 -253
  55. package/docs/channels/grammy.md +0 -31
  56. package/docs/channels/group-messages.md +0 -82
  57. package/docs/channels/groups.md +0 -364
  58. package/docs/channels/imessage.md +0 -366
  59. package/docs/channels/index.md +0 -46
  60. package/docs/channels/irc.md +0 -234
  61. package/docs/channels/line.md +0 -186
  62. package/docs/channels/location.md +0 -56
  63. package/docs/channels/matrix.md +0 -300
  64. package/docs/channels/mattermost.md +0 -158
  65. package/docs/channels/msteams.md +0 -769
  66. package/docs/channels/nextcloud-talk.md +0 -138
  67. package/docs/channels/nostr.md +0 -233
  68. package/docs/channels/pairing.md +0 -100
  69. package/docs/channels/signal.md +0 -322
  70. package/docs/channels/slack.md +0 -510
  71. package/docs/channels/telegram.md +0 -748
  72. package/docs/channels/tlon.md +0 -148
  73. package/docs/channels/troubleshooting.md +0 -110
  74. package/docs/channels/twitch.md +0 -379
  75. package/docs/channels/whatsapp.md +0 -444
  76. package/docs/channels/zalo.md +0 -192
  77. package/docs/channels/zalouser.md +0 -140
  78. package/docs/ci.md +0 -50
  79. package/docs/cli/acp.md +0 -182
  80. package/docs/cli/agent.md +0 -24
  81. package/docs/cli/agents.md +0 -75
  82. package/docs/cli/approvals.md +0 -50
  83. package/docs/cli/browser.md +0 -107
  84. package/docs/cli/channels.md +0 -73
  85. package/docs/cli/config.md +0 -50
  86. package/docs/cli/configure.md +0 -32
  87. package/docs/cli/cron.md +0 -44
  88. package/docs/cli/dashboard.md +0 -16
  89. package/docs/cli/devices.md +0 -73
  90. package/docs/cli/directory.md +0 -62
  91. package/docs/cli/dns.md +0 -23
  92. package/docs/cli/docs.md +0 -15
  93. package/docs/cli/doctor.md +0 -41
  94. package/docs/cli/gateway.md +0 -202
  95. package/docs/cli/health.md +0 -21
  96. package/docs/cli/hooks.md +0 -313
  97. package/docs/cli/index.md +0 -1029
  98. package/docs/cli/logs.md +0 -28
  99. package/docs/cli/memory.md +0 -45
  100. package/docs/cli/message.md +0 -214
  101. package/docs/cli/models.md +0 -79
  102. package/docs/cli/node.md +0 -112
  103. package/docs/cli/nodes.md +0 -73
  104. package/docs/cli/onboard.md +0 -76
  105. package/docs/cli/pairing.md +0 -21
  106. package/docs/cli/plugins.md +0 -92
  107. package/docs/cli/reset.md +0 -17
  108. package/docs/cli/sandbox.md +0 -152
  109. package/docs/cli/security.md +0 -64
  110. package/docs/cli/sessions.md +0 -16
  111. package/docs/cli/setup.md +0 -29
  112. package/docs/cli/skills.md +0 -26
  113. package/docs/cli/status.md +0 -25
  114. package/docs/cli/system.md +0 -60
  115. package/docs/cli/tui.md +0 -23
  116. package/docs/cli/uninstall.md +0 -17
  117. package/docs/cli/update.md +0 -98
  118. package/docs/cli/voicecall.md +0 -34
  119. package/docs/cli/webhooks.md +0 -25
  120. package/docs/concepts/agent-loop.md +0 -148
  121. package/docs/concepts/agent-workspace.md +0 -234
  122. package/docs/concepts/agent.md +0 -123
  123. package/docs/concepts/architecture.md +0 -135
  124. package/docs/concepts/compaction.md +0 -61
  125. package/docs/concepts/context.md +0 -161
  126. package/docs/concepts/features.md +0 -51
  127. package/docs/concepts/markdown-formatting.md +0 -128
  128. package/docs/concepts/memory.md +0 -729
  129. package/docs/concepts/messages.md +0 -153
  130. package/docs/concepts/model-failover.md +0 -149
  131. package/docs/concepts/model-providers.md +0 -424
  132. package/docs/concepts/models.md +0 -208
  133. package/docs/concepts/multi-agent.md +0 -521
  134. package/docs/concepts/oauth.md +0 -145
  135. package/docs/concepts/presence.md +0 -102
  136. package/docs/concepts/queue.md +0 -86
  137. package/docs/concepts/retry.md +0 -64
  138. package/docs/concepts/session-pruning.md +0 -123
  139. package/docs/concepts/session-tool.md +0 -213
  140. package/docs/concepts/session.md +0 -199
  141. package/docs/concepts/sessions.md +0 -10
  142. package/docs/concepts/streaming.md +0 -129
  143. package/docs/concepts/system-prompt.md +0 -128
  144. package/docs/concepts/timezone.md +0 -90
  145. package/docs/concepts/typebox.md +0 -289
  146. package/docs/concepts/typing-indicators.md +0 -68
  147. package/docs/concepts/usage-tracking.md +0 -35
  148. package/docs/date-time.md +0 -127
  149. package/docs/debug/node-issue.md +0 -85
  150. package/docs/diagnostics/flags.md +0 -91
  151. package/docs/docs.json +0 -1849
  152. package/docs/experiments/onboarding-config-protocol.md +0 -40
  153. package/docs/experiments/plans/browser-evaluate-cdp-refactor.md +0 -229
  154. package/docs/experiments/plans/cron-add-hardening.md +0 -62
  155. package/docs/experiments/plans/group-policy-hardening.md +0 -40
  156. package/docs/experiments/plans/openresponses-gateway.md +0 -123
  157. package/docs/experiments/plans/pty-process-supervision.md +0 -192
  158. package/docs/experiments/plans/session-binding-channel-agnostic.md +0 -202
  159. package/docs/experiments/plans/thread-bound-subagents.md +0 -281
  160. package/docs/experiments/proposals/model-config.md +0 -36
  161. package/docs/experiments/research/memory.md +0 -228
  162. package/docs/gateway/authentication.md +0 -162
  163. package/docs/gateway/background-process.md +0 -96
  164. package/docs/gateway/bonjour.md +0 -177
  165. package/docs/gateway/bridge-protocol.md +0 -91
  166. package/docs/gateway/cli-backends.md +0 -225
  167. package/docs/gateway/configuration-examples.md +0 -610
  168. package/docs/gateway/configuration-reference.md +0 -2465
  169. package/docs/gateway/configuration.md +0 -488
  170. package/docs/gateway/discovery.md +0 -123
  171. package/docs/gateway/doctor.md +0 -282
  172. package/docs/gateway/gateway-lock.md +0 -34
  173. package/docs/gateway/health.md +0 -35
  174. package/docs/gateway/heartbeat.md +0 -374
  175. package/docs/gateway/index.md +0 -254
  176. package/docs/gateway/local-models.md +0 -150
  177. package/docs/gateway/logging.md +0 -113
  178. package/docs/gateway/multiple-gateways.md +0 -112
  179. package/docs/gateway/network-model.md +0 -20
  180. package/docs/gateway/openai-http-api.md +0 -119
  181. package/docs/gateway/openresponses-http-api.md +0 -333
  182. package/docs/gateway/pairing.md +0 -99
  183. package/docs/gateway/protocol.md +0 -221
  184. package/docs/gateway/remote-gateway-readme.md +0 -158
  185. package/docs/gateway/remote.md +0 -131
  186. package/docs/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -128
  187. package/docs/gateway/sandboxing.md +0 -203
  188. package/docs/gateway/security/index.md +0 -931
  189. package/docs/gateway/tailscale.md +0 -132
  190. package/docs/gateway/tools-invoke-http-api.md +0 -110
  191. package/docs/gateway/troubleshooting.md +0 -317
  192. package/docs/gateway/trusted-proxy-auth.md +0 -270
  193. package/docs/glass-ui-rendering-invariants.md +0 -451
  194. package/docs/help/debugging.md +0 -162
  195. package/docs/help/environment.md +0 -107
  196. package/docs/help/faq.md +0 -2846
  197. package/docs/help/index.md +0 -21
  198. package/docs/help/scripts.md +0 -28
  199. package/docs/help/testing.md +0 -385
  200. package/docs/help/troubleshooting.md +0 -264
  201. package/docs/images/configure-model-picker-unsearchable.png +0 -0
  202. package/docs/images/feishu-step2-create-app.png +0 -0
  203. package/docs/images/feishu-step3-credentials.png +0 -0
  204. package/docs/images/feishu-step4-permissions.png +0 -0
  205. package/docs/images/feishu-step5-bot-capability.png +0 -0
  206. package/docs/images/feishu-step6-event-subscription.png +0 -0
  207. package/docs/images/groups-flow.svg +0 -52
  208. package/docs/images/mobile-ui-screenshot.png +0 -0
  209. package/docs/index.md +0 -186
  210. package/docs/install/ansible.md +0 -207
  211. package/docs/install/bun.md +0 -59
  212. package/docs/install/development-channels.md +0 -75
  213. package/docs/install/docker.md +0 -583
  214. package/docs/install/exe-dev.md +0 -126
  215. package/docs/install/fly.md +0 -472
  216. package/docs/install/gcp.md +0 -499
  217. package/docs/install/hetzner.md +0 -347
  218. package/docs/install/index.md +0 -218
  219. package/docs/install/installer.md +0 -405
  220. package/docs/install/macos-vm.md +0 -281
  221. package/docs/install/migrating.md +0 -192
  222. package/docs/install/nix.md +0 -98
  223. package/docs/install/node.md +0 -138
  224. package/docs/install/northflank.mdx +0 -49
  225. package/docs/install/podman.md +0 -108
  226. package/docs/install/railway.mdx +0 -95
  227. package/docs/install/render.mdx +0 -158
  228. package/docs/install/uninstall.md +0 -128
  229. package/docs/install/updating.md +0 -231
  230. package/docs/ja-JP/AGENTS.md +0 -37
  231. package/docs/ja-JP/index.md +0 -183
  232. package/docs/ja-JP/start/getting-started.md +0 -125
  233. package/docs/ja-JP/start/wizard.md +0 -77
  234. package/docs/logging.md +0 -350
  235. package/docs/nav-tabs-underline.js +0 -100
  236. package/docs/network.md +0 -54
  237. package/docs/nodes/audio.md +0 -133
  238. package/docs/nodes/camera.md +0 -156
  239. package/docs/nodes/images.md +0 -72
  240. package/docs/nodes/index.md +0 -342
  241. package/docs/nodes/location-command.md +0 -113
  242. package/docs/nodes/media-understanding.md +0 -379
  243. package/docs/nodes/talk.md +0 -90
  244. package/docs/nodes/troubleshooting.md +0 -112
  245. package/docs/nodes/voicewake.md +0 -65
  246. package/docs/perplexity.md +0 -80
  247. package/docs/phase-6.5-pre-flight-audit.md +0 -268
  248. package/docs/pi-dev.md +0 -70
  249. package/docs/pi.md +0 -610
  250. package/docs/platforms/android.md +0 -151
  251. package/docs/platforms/digitalocean.md +0 -265
  252. package/docs/platforms/index.md +0 -53
  253. package/docs/platforms/ios.md +0 -108
  254. package/docs/platforms/linux.md +0 -94
  255. package/docs/platforms/mac/bundled-gateway.md +0 -73
  256. package/docs/platforms/mac/canvas.md +0 -125
  257. package/docs/platforms/mac/child-process.md +0 -69
  258. package/docs/platforms/mac/dev-setup.md +0 -104
  259. package/docs/platforms/mac/health.md +0 -34
  260. package/docs/platforms/mac/icon.md +0 -31
  261. package/docs/platforms/mac/logging.md +0 -57
  262. package/docs/platforms/mac/menu-bar.md +0 -81
  263. package/docs/platforms/mac/peekaboo.md +0 -65
  264. package/docs/platforms/mac/permissions.md +0 -50
  265. package/docs/platforms/mac/release.md +0 -85
  266. package/docs/platforms/mac/remote.md +0 -84
  267. package/docs/platforms/mac/signing.md +0 -47
  268. package/docs/platforms/mac/skills.md +0 -33
  269. package/docs/platforms/mac/voice-overlay.md +0 -60
  270. package/docs/platforms/mac/voicewake.md +0 -66
  271. package/docs/platforms/mac/webchat.md +0 -43
  272. package/docs/platforms/mac/xpc.md +0 -61
  273. package/docs/platforms/macos.md +0 -204
  274. package/docs/platforms/oracle.md +0 -303
  275. package/docs/platforms/raspberry-pi.md +0 -358
  276. package/docs/platforms/windows.md +0 -159
  277. package/docs/plugins/agent-tools.md +0 -99
  278. package/docs/plugins/community.md +0 -44
  279. package/docs/plugins/manifest.md +0 -71
  280. package/docs/plugins/voice-call.md +0 -322
  281. package/docs/plugins/zalouser.md +0 -81
  282. package/docs/prose.md +0 -134
  283. package/docs/providers/anthropic.md +0 -174
  284. package/docs/providers/bedrock.md +0 -176
  285. package/docs/providers/claude-max-api-proxy.md +0 -148
  286. package/docs/providers/cloudflare-ai-gateway.md +0 -71
  287. package/docs/providers/deepgram.md +0 -93
  288. package/docs/providers/github-copilot.md +0 -72
  289. package/docs/providers/glm.md +0 -33
  290. package/docs/providers/huggingface.md +0 -209
  291. package/docs/providers/index.md +0 -67
  292. package/docs/providers/litellm.md +0 -153
  293. package/docs/providers/minimax.md +0 -208
  294. package/docs/providers/models.md +0 -52
  295. package/docs/providers/moonshot.md +0 -142
  296. package/docs/providers/nvidia.md +0 -55
  297. package/docs/providers/ollama.md +0 -250
  298. package/docs/providers/openai.md +0 -62
  299. package/docs/providers/opencode.md +0 -36
  300. package/docs/providers/openrouter.md +0 -37
  301. package/docs/providers/qianfan.md +0 -38
  302. package/docs/providers/qwen.md +0 -53
  303. package/docs/providers/synthetic.md +0 -99
  304. package/docs/providers/together.md +0 -65
  305. package/docs/providers/venice.md +0 -267
  306. package/docs/providers/vercel-ai-gateway.md +0 -50
  307. package/docs/providers/vllm.md +0 -92
  308. package/docs/providers/xiaomi.md +0 -64
  309. package/docs/providers/zai.md +0 -38
  310. package/docs/refactor/exec-host.md +0 -316
  311. package/docs/refactor/outbound-session-mirroring.md +0 -83
  312. package/docs/refactor/plugin-sdk.md +0 -214
  313. package/docs/refactor/strict-config.md +0 -93
  314. package/docs/refactor/syminet.md +0 -417
  315. package/docs/reference/AGENTS.default.md +0 -123
  316. package/docs/reference/RELEASING.md +0 -120
  317. package/docs/reference/api-usage-costs.md +0 -138
  318. package/docs/reference/credits.md +0 -28
  319. package/docs/reference/device-models.md +0 -47
  320. package/docs/reference/rpc.md +0 -43
  321. package/docs/reference/session-management-compaction.md +0 -284
  322. package/docs/reference/test.md +0 -51
  323. package/docs/reference/token-use.md +0 -136
  324. package/docs/reference/transcript-hygiene.md +0 -151
  325. package/docs/reference/wizard.md +0 -265
  326. package/docs/security/CONTRIBUTING-THREAT-MODEL.md +0 -89
  327. package/docs/security/README.md +0 -16
  328. package/docs/security/THREAT-MODEL-ATLAS.md +0 -600
  329. package/docs/security/formal-verification.md +0 -164
  330. package/docs/start/bootstrapping.md +0 -41
  331. package/docs/start/docs-directory.md +0 -63
  332. package/docs/start/getting-started.md +0 -135
  333. package/docs/start/hubs.md +0 -196
  334. package/docs/start/lore.md +0 -216
  335. package/docs/start/onboarding-overview.md +0 -51
  336. package/docs/start/onboarding.md +0 -81
  337. package/docs/start/quickstart.md +0 -22
  338. package/docs/start/setup.md +0 -160
  339. package/docs/start/showcase.md +0 -414
  340. package/docs/start/symi.md +0 -211
  341. package/docs/start/wizard-cli-automation.md +0 -158
  342. package/docs/start/wizard-cli-reference.md +0 -255
  343. package/docs/start/wizard.md +0 -109
  344. package/docs/style.css +0 -37
  345. package/docs/tools/agent-send.md +0 -52
  346. package/docs/tools/apply-patch.md +0 -51
  347. package/docs/tools/browser-linux-troubleshooting.md +0 -139
  348. package/docs/tools/browser-login.md +0 -67
  349. package/docs/tools/browser.md +0 -587
  350. package/docs/tools/chrome-extension.md +0 -183
  351. package/docs/tools/creating-skills.md +0 -54
  352. package/docs/tools/elevated.md +0 -55
  353. package/docs/tools/exec-approvals.md +0 -261
  354. package/docs/tools/exec.md +0 -184
  355. package/docs/tools/firecrawl.md +0 -61
  356. package/docs/tools/index.md +0 -540
  357. package/docs/tools/llm-task.md +0 -115
  358. package/docs/tools/loop-detection.md +0 -98
  359. package/docs/tools/multi-agent-sandbox-tools.md +0 -396
  360. package/docs/tools/pipeline.md +0 -340
  361. package/docs/tools/plugin.md +0 -687
  362. package/docs/tools/reactions.md +0 -21
  363. package/docs/tools/skills-config.md +0 -76
  364. package/docs/tools/skills.md +0 -300
  365. package/docs/tools/slash-commands.md +0 -202
  366. package/docs/tools/subagents.md +0 -232
  367. package/docs/tools/symihub.md +0 -256
  368. package/docs/tools/thinking.md +0 -75
  369. package/docs/tools/web.md +0 -265
  370. package/docs/tts.md +0 -398
  371. package/docs/vps.md +0 -43
  372. package/docs/web/control-ui.md +0 -247
  373. package/docs/web/dashboard.md +0 -46
  374. package/docs/web/index.md +0 -118
  375. package/docs/web/tui.md +0 -162
  376. package/docs/web/webchat.md +0 -53
  377. package/docs/whatsapp-symi-ai-zh.jpg +0 -0
  378. package/docs/whatsapp-symi.jpg +0 -0
  379. package/docs/zh-CN/AGENTS.md +0 -59
  380. package/docs/zh-CN/automation/auth-monitoring.md +0 -47
  381. package/docs/zh-CN/automation/cron-jobs.md +0 -422
  382. package/docs/zh-CN/automation/cron-vs-heartbeat.md +0 -286
  383. package/docs/zh-CN/automation/gmail-pubsub.md +0 -249
  384. package/docs/zh-CN/automation/hooks.md +0 -881
  385. package/docs/zh-CN/automation/poll.md +0 -68
  386. package/docs/zh-CN/automation/troubleshooting.md +0 -8
  387. package/docs/zh-CN/automation/webhook.md +0 -161
  388. package/docs/zh-CN/brave-search.md +0 -48
  389. package/docs/zh-CN/channels/bluebubbles.md +0 -271
  390. package/docs/zh-CN/channels/broadcast-groups.md +0 -448
  391. package/docs/zh-CN/channels/channel-routing.md +0 -112
  392. package/docs/zh-CN/channels/feishu.md +0 -629
  393. package/docs/zh-CN/channels/googlechat.md +0 -257
  394. package/docs/zh-CN/channels/grammy.md +0 -38
  395. package/docs/zh-CN/channels/group-messages.md +0 -89
  396. package/docs/zh-CN/channels/groups.md +0 -369
  397. package/docs/zh-CN/channels/imessage.md +0 -300
  398. package/docs/zh-CN/channels/index.md +0 -52
  399. package/docs/zh-CN/channels/line.md +0 -180
  400. package/docs/zh-CN/channels/location.md +0 -63
  401. package/docs/zh-CN/channels/matrix.md +0 -221
  402. package/docs/zh-CN/channels/mattermost.md +0 -144
  403. package/docs/zh-CN/channels/msteams.md +0 -773
  404. package/docs/zh-CN/channels/nextcloud-talk.md +0 -142
  405. package/docs/zh-CN/channels/nostr.md +0 -240
  406. package/docs/zh-CN/channels/pairing.md +0 -86
  407. package/docs/zh-CN/channels/signal.md +0 -207
  408. package/docs/zh-CN/channels/slack.md +0 -529
  409. package/docs/zh-CN/channels/telegram.md +0 -748
  410. package/docs/zh-CN/channels/tlon.md +0 -136
  411. package/docs/zh-CN/channels/troubleshooting.md +0 -34
  412. package/docs/zh-CN/channels/twitch.md +0 -385
  413. package/docs/zh-CN/channels/whatsapp.md +0 -411
  414. package/docs/zh-CN/channels/zalo.md +0 -196
  415. package/docs/zh-CN/channels/zalouser.md +0 -147
  416. package/docs/zh-CN/cli/acp.md +0 -173
  417. package/docs/zh-CN/cli/agent.md +0 -30
  418. package/docs/zh-CN/cli/agents.md +0 -82
  419. package/docs/zh-CN/cli/approvals.md +0 -57
  420. package/docs/zh-CN/cli/browser.md +0 -114
  421. package/docs/zh-CN/cli/channels.md +0 -80
  422. package/docs/zh-CN/cli/config.md +0 -57
  423. package/docs/zh-CN/cli/configure.md +0 -37
  424. package/docs/zh-CN/cli/cron.md +0 -43
  425. package/docs/zh-CN/cli/dashboard.md +0 -23
  426. package/docs/zh-CN/cli/devices.md +0 -74
  427. package/docs/zh-CN/cli/directory.md +0 -69
  428. package/docs/zh-CN/cli/dns.md +0 -30
  429. package/docs/zh-CN/cli/docs.md +0 -22
  430. package/docs/zh-CN/cli/doctor.md +0 -48
  431. package/docs/zh-CN/cli/gateway.md +0 -206
  432. package/docs/zh-CN/cli/health.md +0 -28
  433. package/docs/zh-CN/cli/hooks.md +0 -298
  434. package/docs/zh-CN/cli/index.md +0 -1025
  435. package/docs/zh-CN/cli/logs.md +0 -31
  436. package/docs/zh-CN/cli/memory.md +0 -52
  437. package/docs/zh-CN/cli/message.md +0 -205
  438. package/docs/zh-CN/cli/models.md +0 -85
  439. package/docs/zh-CN/cli/node.md +0 -115
  440. package/docs/zh-CN/cli/nodes.md +0 -80
  441. package/docs/zh-CN/cli/onboard.md +0 -36
  442. package/docs/zh-CN/cli/pairing.md +0 -28
  443. package/docs/zh-CN/cli/plugins.md +0 -66
  444. package/docs/zh-CN/cli/reset.md +0 -24
  445. package/docs/zh-CN/cli/sandbox.md +0 -158
  446. package/docs/zh-CN/cli/security.md +0 -33
  447. package/docs/zh-CN/cli/sessions.md +0 -23
  448. package/docs/zh-CN/cli/setup.md +0 -36
  449. package/docs/zh-CN/cli/skills.md +0 -33
  450. package/docs/zh-CN/cli/status.md +0 -32
  451. package/docs/zh-CN/cli/system.md +0 -63
  452. package/docs/zh-CN/cli/tui.md +0 -30
  453. package/docs/zh-CN/cli/uninstall.md +0 -24
  454. package/docs/zh-CN/cli/update.md +0 -101
  455. package/docs/zh-CN/cli/voicecall.md +0 -41
  456. package/docs/zh-CN/cli/webhooks.md +0 -32
  457. package/docs/zh-CN/concepts/agent-loop.md +0 -146
  458. package/docs/zh-CN/concepts/agent-workspace.md +0 -219
  459. package/docs/zh-CN/concepts/agent.md +0 -115
  460. package/docs/zh-CN/concepts/architecture.md +0 -122
  461. package/docs/zh-CN/concepts/compaction.md +0 -67
  462. package/docs/zh-CN/concepts/context.md +0 -168
  463. package/docs/zh-CN/concepts/features.md +0 -57
  464. package/docs/zh-CN/concepts/markdown-formatting.md +0 -115
  465. package/docs/zh-CN/concepts/memory.md +0 -412
  466. package/docs/zh-CN/concepts/messages.md +0 -140
  467. package/docs/zh-CN/concepts/model-failover.md +0 -145
  468. package/docs/zh-CN/concepts/model-providers.md +0 -320
  469. package/docs/zh-CN/concepts/models.md +0 -196
  470. package/docs/zh-CN/concepts/multi-agent.md +0 -371
  471. package/docs/zh-CN/concepts/oauth.md +0 -151
  472. package/docs/zh-CN/concepts/presence.md +0 -99
  473. package/docs/zh-CN/concepts/queue.md +0 -91
  474. package/docs/zh-CN/concepts/retry.md +0 -71
  475. package/docs/zh-CN/concepts/session-pruning.md +0 -129
  476. package/docs/zh-CN/concepts/session-tool.md +0 -198
  477. package/docs/zh-CN/concepts/session.md +0 -158
  478. package/docs/zh-CN/concepts/sessions.md +0 -17
  479. package/docs/zh-CN/concepts/streaming.md +0 -131
  480. package/docs/zh-CN/concepts/system-prompt.md +0 -99
  481. package/docs/zh-CN/concepts/timezone.md +0 -94
  482. package/docs/zh-CN/concepts/typebox.md +0 -284
  483. package/docs/zh-CN/concepts/typing-indicators.md +0 -74
  484. package/docs/zh-CN/concepts/usage-tracking.md +0 -42
  485. package/docs/zh-CN/date-time.md +0 -128
  486. package/docs/zh-CN/debug/node-issue.md +0 -90
  487. package/docs/zh-CN/diagnostics/flags.md +0 -98
  488. package/docs/zh-CN/experiments/onboarding-config-protocol.md +0 -47
  489. package/docs/zh-CN/experiments/plans/cron-add-hardening.md +0 -69
  490. package/docs/zh-CN/experiments/plans/group-policy-hardening.md +0 -45
  491. package/docs/zh-CN/experiments/plans/openresponses-gateway.md +0 -121
  492. package/docs/zh-CN/experiments/proposals/model-config.md +0 -42
  493. package/docs/zh-CN/experiments/research/memory.md +0 -235
  494. package/docs/zh-CN/gateway/authentication.md +0 -142
  495. package/docs/zh-CN/gateway/background-process.md +0 -100
  496. package/docs/zh-CN/gateway/bonjour.md +0 -174
  497. package/docs/zh-CN/gateway/bridge-protocol.md +0 -86
  498. package/docs/zh-CN/gateway/cli-backends.md +0 -213
  499. package/docs/zh-CN/gateway/configuration-examples.md +0 -580
  500. package/docs/zh-CN/gateway/configuration.md +0 -3284
  501. package/docs/zh-CN/gateway/discovery.md +0 -123
  502. package/docs/zh-CN/gateway/doctor.md +0 -238
  503. package/docs/zh-CN/gateway/gateway-lock.md +0 -41
  504. package/docs/zh-CN/gateway/health.md +0 -42
  505. package/docs/zh-CN/gateway/heartbeat.md +0 -272
  506. package/docs/zh-CN/gateway/index.md +0 -335
  507. package/docs/zh-CN/gateway/local-models.md +0 -157
  508. package/docs/zh-CN/gateway/logging.md +0 -114
  509. package/docs/zh-CN/gateway/multiple-gateways.md +0 -119
  510. package/docs/zh-CN/gateway/network-model.md +0 -23
  511. package/docs/zh-CN/gateway/openai-http-api.md +0 -125
  512. package/docs/zh-CN/gateway/openresponses-http-api.md +0 -317
  513. package/docs/zh-CN/gateway/pairing.md +0 -99
  514. package/docs/zh-CN/gateway/protocol.md +0 -220
  515. package/docs/zh-CN/gateway/remote-gateway-readme.md +0 -164
  516. package/docs/zh-CN/gateway/remote.md +0 -133
  517. package/docs/zh-CN/gateway/sandbox-vs-tool-policy-vs-elevated.md +0 -135
  518. package/docs/zh-CN/gateway/sandboxing.md +0 -188
  519. package/docs/zh-CN/gateway/security/index.md +0 -772
  520. package/docs/zh-CN/gateway/tailscale.md +0 -124
  521. package/docs/zh-CN/gateway/tools-invoke-http-api.md +0 -92
  522. package/docs/zh-CN/gateway/troubleshooting.md +0 -758
  523. package/docs/zh-CN/help/debugging.md +0 -160
  524. package/docs/zh-CN/help/environment.md +0 -88
  525. package/docs/zh-CN/help/faq.md +0 -2613
  526. package/docs/zh-CN/help/index.md +0 -28
  527. package/docs/zh-CN/help/scripts.md +0 -35
  528. package/docs/zh-CN/help/testing.md +0 -375
  529. package/docs/zh-CN/help/troubleshooting.md +0 -104
  530. package/docs/zh-CN/index.md +0 -183
  531. package/docs/zh-CN/install/ansible.md +0 -214
  532. package/docs/zh-CN/install/bun.md +0 -65
  533. package/docs/zh-CN/install/development-channels.md +0 -81
  534. package/docs/zh-CN/install/docker.md +0 -525
  535. package/docs/zh-CN/install/exe-dev.md +0 -127
  536. package/docs/zh-CN/install/fly.md +0 -476
  537. package/docs/zh-CN/install/gcp.md +0 -509
  538. package/docs/zh-CN/install/hetzner.md +0 -336
  539. package/docs/zh-CN/install/index.md +0 -193
  540. package/docs/zh-CN/install/installer.md +0 -128
  541. package/docs/zh-CN/install/macos-vm.md +0 -288
  542. package/docs/zh-CN/install/migrating.md +0 -199
  543. package/docs/zh-CN/install/nix.md +0 -99
  544. package/docs/zh-CN/install/node.md +0 -8
  545. package/docs/zh-CN/install/northflank.mdx +0 -56
  546. package/docs/zh-CN/install/railway.mdx +0 -102
  547. package/docs/zh-CN/install/render.mdx +0 -168
  548. package/docs/zh-CN/install/uninstall.md +0 -135
  549. package/docs/zh-CN/install/updating.md +0 -233
  550. package/docs/zh-CN/logging.md +0 -329
  551. package/docs/zh-CN/network.md +0 -59
  552. package/docs/zh-CN/nodes/audio.md +0 -120
  553. package/docs/zh-CN/nodes/camera.md +0 -162
  554. package/docs/zh-CN/nodes/images.md +0 -79
  555. package/docs/zh-CN/nodes/index.md +0 -348
  556. package/docs/zh-CN/nodes/location-command.md +0 -120
  557. package/docs/zh-CN/nodes/media-understanding.md +0 -380
  558. package/docs/zh-CN/nodes/talk.md +0 -97
  559. package/docs/zh-CN/nodes/troubleshooting.md +0 -8
  560. package/docs/zh-CN/nodes/voicewake.md +0 -72
  561. package/docs/zh-CN/perplexity.md +0 -84
  562. package/docs/zh-CN/pi-dev.md +0 -77
  563. package/docs/zh-CN/pi.md +0 -617
  564. package/docs/zh-CN/platforms/android.md +0 -155
  565. package/docs/zh-CN/platforms/digitalocean.md +0 -268
  566. package/docs/zh-CN/platforms/index.md +0 -60
  567. package/docs/zh-CN/platforms/ios.md +0 -114
  568. package/docs/zh-CN/platforms/linux.md +0 -101
  569. package/docs/zh-CN/platforms/mac/bundled-gateway.md +0 -75
  570. package/docs/zh-CN/platforms/mac/canvas.md +0 -128
  571. package/docs/zh-CN/platforms/mac/child-process.md +0 -73
  572. package/docs/zh-CN/platforms/mac/dev-setup.md +0 -109
  573. package/docs/zh-CN/platforms/mac/health.md +0 -41
  574. package/docs/zh-CN/platforms/mac/icon.md +0 -38
  575. package/docs/zh-CN/platforms/mac/logging.md +0 -64
  576. package/docs/zh-CN/platforms/mac/menu-bar.md +0 -88
  577. package/docs/zh-CN/platforms/mac/peekaboo.md +0 -62
  578. package/docs/zh-CN/platforms/mac/permissions.md +0 -46
  579. package/docs/zh-CN/platforms/mac/release.md +0 -92
  580. package/docs/zh-CN/platforms/mac/remote.md +0 -90
  581. package/docs/zh-CN/platforms/mac/signing.md +0 -54
  582. package/docs/zh-CN/platforms/mac/skills.md +0 -40
  583. package/docs/zh-CN/platforms/mac/voice-overlay.md +0 -67
  584. package/docs/zh-CN/platforms/mac/voicewake.md +0 -73
  585. package/docs/zh-CN/platforms/mac/webchat.md +0 -43
  586. package/docs/zh-CN/platforms/mac/xpc.md +0 -68
  587. package/docs/zh-CN/platforms/macos.md +0 -193
  588. package/docs/zh-CN/platforms/oracle.md +0 -310
  589. package/docs/zh-CN/platforms/raspberry-pi.md +0 -365
  590. package/docs/zh-CN/platforms/windows.md +0 -156
  591. package/docs/zh-CN/plugins/agent-tools.md +0 -99
  592. package/docs/zh-CN/plugins/manifest.md +0 -68
  593. package/docs/zh-CN/plugins/voice-call.md +0 -250
  594. package/docs/zh-CN/plugins/zalouser.md +0 -88
  595. package/docs/zh-CN/prose.md +0 -141
  596. package/docs/zh-CN/providers/anthropic.md +0 -159
  597. package/docs/zh-CN/providers/bedrock.md +0 -170
  598. package/docs/zh-CN/providers/claude-max-api-proxy.md +0 -155
  599. package/docs/zh-CN/providers/deepgram.md +0 -97
  600. package/docs/zh-CN/providers/github-copilot.md +0 -67
  601. package/docs/zh-CN/providers/glm.md +0 -39
  602. package/docs/zh-CN/providers/index.md +0 -66
  603. package/docs/zh-CN/providers/minimax.md +0 -206
  604. package/docs/zh-CN/providers/models.md +0 -55
  605. package/docs/zh-CN/providers/moonshot.md +0 -145
  606. package/docs/zh-CN/providers/ollama.md +0 -230
  607. package/docs/zh-CN/providers/openai.md +0 -68
  608. package/docs/zh-CN/providers/opencode.md +0 -41
  609. package/docs/zh-CN/providers/openrouter.md +0 -43
  610. package/docs/zh-CN/providers/qianfan.md +0 -8
  611. package/docs/zh-CN/providers/qwen.md +0 -55
  612. package/docs/zh-CN/providers/synthetic.md +0 -102
  613. package/docs/zh-CN/providers/venice.md +0 -274
  614. package/docs/zh-CN/providers/vercel-ai-gateway.md +0 -57
  615. package/docs/zh-CN/providers/xiaomi.md +0 -68
  616. package/docs/zh-CN/providers/zai.md +0 -41
  617. package/docs/zh-CN/refactor/exec-host.md +0 -323
  618. package/docs/zh-CN/refactor/outbound-session-mirroring.md +0 -90
  619. package/docs/zh-CN/refactor/plugin-sdk.md +0 -221
  620. package/docs/zh-CN/refactor/strict-config.md +0 -100
  621. package/docs/zh-CN/refactor/syminet.md +0 -424
  622. package/docs/zh-CN/reference/AGENTS.default.md +0 -130
  623. package/docs/zh-CN/reference/RELEASING.md +0 -122
  624. package/docs/zh-CN/reference/api-usage-costs.md +0 -136
  625. package/docs/zh-CN/reference/credits.md +0 -34
  626. package/docs/zh-CN/reference/device-models.md +0 -54
  627. package/docs/zh-CN/reference/rpc.md +0 -48
  628. package/docs/zh-CN/reference/session-management-compaction.md +0 -286
  629. package/docs/zh-CN/reference/templates/AGENTS.dev.md +0 -89
  630. package/docs/zh-CN/reference/templates/AGENTS.md +0 -234
  631. package/docs/zh-CN/reference/templates/BOOT.md +0 -17
  632. package/docs/zh-CN/reference/templates/BOOTSTRAP.md +0 -68
  633. package/docs/zh-CN/reference/templates/IDENTITY.dev.md +0 -54
  634. package/docs/zh-CN/reference/templates/IDENTITY.md +0 -36
  635. package/docs/zh-CN/reference/templates/SYMICORE.dev.md +0 -83
  636. package/docs/zh-CN/reference/templates/SYMICORE.md +0 -49
  637. package/docs/zh-CN/reference/templates/SYMIPULSE.md +0 -69
  638. package/docs/zh-CN/reference/templates/TOOLS.dev.md +0 -31
  639. package/docs/zh-CN/reference/templates/TOOLS.md +0 -53
  640. package/docs/zh-CN/reference/templates/USER.dev.md +0 -25
  641. package/docs/zh-CN/reference/templates/USER.md +0 -30
  642. package/docs/zh-CN/reference/test.md +0 -57
  643. package/docs/zh-CN/reference/token-use.md +0 -119
  644. package/docs/zh-CN/reference/transcript-hygiene.md +0 -109
  645. package/docs/zh-CN/reference/wizard.md +0 -9
  646. package/docs/zh-CN/security/formal-verification.md +0 -171
  647. package/docs/zh-CN/start/bootstrapping.md +0 -9
  648. package/docs/zh-CN/start/docs-directory.md +0 -69
  649. package/docs/zh-CN/start/getting-started.md +0 -201
  650. package/docs/zh-CN/start/hubs.md +0 -199
  651. package/docs/zh-CN/start/lore.md +0 -223
  652. package/docs/zh-CN/start/onboarding.md +0 -105
  653. package/docs/zh-CN/start/quickstart.md +0 -88
  654. package/docs/zh-CN/start/setup.md +0 -151
  655. package/docs/zh-CN/start/showcase.md +0 -421
  656. package/docs/zh-CN/start/symi.md +0 -244
  657. package/docs/zh-CN/start/wizard.md +0 -326
  658. package/docs/zh-CN/tools/agent-send.md +0 -58
  659. package/docs/zh-CN/tools/apply-patch.md +0 -57
  660. package/docs/zh-CN/tools/browser-linux-troubleshooting.md +0 -144
  661. package/docs/zh-CN/tools/browser-login.md +0 -75
  662. package/docs/zh-CN/tools/browser.md +0 -553
  663. package/docs/zh-CN/tools/chrome-extension.md +0 -183
  664. package/docs/zh-CN/tools/creating-skills.md +0 -61
  665. package/docs/zh-CN/tools/elevated.md +0 -62
  666. package/docs/zh-CN/tools/exec-approvals.md +0 -233
  667. package/docs/zh-CN/tools/exec.md +0 -169
  668. package/docs/zh-CN/tools/firecrawl.md +0 -68
  669. package/docs/zh-CN/tools/index.md +0 -508
  670. package/docs/zh-CN/tools/llm-task.md +0 -117
  671. package/docs/zh-CN/tools/multi-agent-sandbox-tools.md +0 -400
  672. package/docs/zh-CN/tools/pipeline.md +0 -349
  673. package/docs/zh-CN/tools/plugin.md +0 -639
  674. package/docs/zh-CN/tools/reactions.md +0 -28
  675. package/docs/zh-CN/tools/skills-config.md +0 -78
  676. package/docs/zh-CN/tools/skills.md +0 -279
  677. package/docs/zh-CN/tools/slash-commands.md +0 -196
  678. package/docs/zh-CN/tools/subagents.md +0 -167
  679. package/docs/zh-CN/tools/symihub.md +0 -209
  680. package/docs/zh-CN/tools/thinking.md +0 -80
  681. package/docs/zh-CN/tools/web.md +0 -257
  682. package/docs/zh-CN/tts.md +0 -373
  683. package/docs/zh-CN/vps.md +0 -47
  684. package/docs/zh-CN/web/control-ui.md +0 -190
  685. package/docs/zh-CN/web/dashboard.md +0 -53
  686. package/docs/zh-CN/web/index.md +0 -118
  687. package/docs/zh-CN/web/tui.md +0 -166
  688. package/docs/zh-CN/web/webchat.md +0 -56
@@ -1,931 +0,0 @@
1
- ---
2
- summary: "Security considerations and threat model for running an AI gateway with shell access"
3
- read_when:
4
- - Adding features that widen access or automation
5
- title: "Security"
6
- ---
7
-
8
- # Security 🔒
9
-
10
- ## Quick check: `symi security audit`
11
-
12
- See also: [Formal Verification (Security Models)](/security/formal-verification/)
13
-
14
- Run this regularly (especially after changing config or exposing network surfaces):
15
-
16
- ```bash
17
- symi security audit
18
- symi security audit --deep
19
- symi security audit --fix
20
- symi security audit --json
21
- ```
22
-
23
- It flags common footguns (Gateway auth exposure, browser control exposure, elevated allowlists, filesystem permissions).
24
-
25
- Symi is both a product and an experiment: you’re wiring frontier-model behavior into real messaging surfaces and real tools. **There is no “perfectly secure” setup.** The goal is to be deliberate about:
26
-
27
- - who can talk to your bot
28
- - where the bot is allowed to act
29
- - what the bot can touch
30
-
31
- Start with the smallest access that still works, then widen it as you gain confidence.
32
-
33
- ## Deployment assumption (important)
34
-
35
- Symi assumes the host and config boundary are trusted:
36
-
37
- - If someone can modify Gateway host state/config (`~/.symi`, including `symi.json`), treat them as a trusted operator.
38
- - Running one Gateway for multiple mutually untrusted/adversarial operators is **not a recommended setup**.
39
- - For mixed-trust teams, split trust boundaries with separate gateways (or at minimum separate OS users/hosts).
40
-
41
- ## Hardened baseline in 60 seconds
42
-
43
- Use this baseline first, then selectively re-enable tools per trusted agent:
44
-
45
- ```json5
46
- {
47
- gateway: {
48
- mode: "local",
49
- bind: "loopback",
50
- auth: { mode: "token", token: "replace-with-long-random-token" },
51
- },
52
- session: {
53
- dmScope: "per-channel-peer",
54
- },
55
- tools: {
56
- profile: "messaging",
57
- deny: ["group:automation", "group:runtime", "group:fs", "sessions_spawn", "sessions_send"],
58
- fs: { workspaceOnly: true },
59
- exec: { security: "deny", ask: "always" },
60
- elevated: { enabled: false },
61
- },
62
- channels: {
63
- whatsapp: { dmPolicy: "pairing", groups: { "*": { requireMention: true } } },
64
- },
65
- }
66
- ```
67
-
68
- This keeps the Gateway local-only, isolates DMs, and disables control-plane/runtime tools by default.
69
-
70
- ## Shared inbox quick rule
71
-
72
- If more than one person can DM your bot:
73
-
74
- - Set `session.dmScope: "per-channel-peer"` (or `"per-account-channel-peer"` for multi-account channels).
75
- - Keep `dmPolicy: "pairing"` or strict allowlists.
76
- - Never combine shared DMs with broad tool access.
77
- - This hardens cooperative/shared inboxes, but is not designed as hostile co-tenant isolation when users share host/config write access.
78
-
79
- ### What the audit checks (high level)
80
-
81
- - **Inbound access** (DM policies, group policies, allowlists): can strangers trigger the bot?
82
- - **Tool blast radius** (elevated tools + open rooms): could prompt injection turn into shell/file/network actions?
83
- - **Network exposure** (Gateway bind/auth, Tailscale Serve/Funnel, weak/short auth tokens).
84
- - **Browser control exposure** (remote nodes, relay ports, remote CDP endpoints).
85
- - **Local disk hygiene** (permissions, symlinks, config includes, “synced folder” paths).
86
- - **Plugins** (extensions exist without an explicit allowlist).
87
- - **Policy drift/misconfig** (sandbox docker settings configured but sandbox mode off; ineffective `gateway.nodes.denyCommands` patterns; global `tools.profile="minimal"` overridden by per-agent profiles; extension plugin tools reachable under permissive tool policy).
88
- - **Runtime expectation drift** (for example `tools.exec.host="sandbox"` while sandbox mode is off, which runs directly on the gateway host).
89
- - **Model hygiene** (warn when configured models look legacy; not a hard block).
90
-
91
- If you run `--deep`, Symi also attempts a best-effort live Gateway probe.
92
-
93
- ## Credential storage map
94
-
95
- Use this when auditing access or deciding what to back up:
96
-
97
- - **WhatsApp**: `~/.symi/credentials/whatsapp/<accountId>/creds.json`
98
- - **Telegram bot token**: config/env or `channels.telegram.tokenFile`
99
- - **Slack tokens**: config/env (`channels.slack.*`)
100
- - **Pairing allowlists**: `~/.symi/credentials/<channel>-allowFrom.json`
101
- - **Model auth profiles**: `~/.symi/agents/<agentId>/agent/auth-profiles.json`
102
- - **Legacy OAuth import**: `~/.symi/credentials/oauth.json`
103
-
104
- ## Security Audit Checklist
105
-
106
- When the audit prints findings, treat this as a priority order:
107
-
108
- 1. **Anything “open” + tools enabled**: lock down DMs/groups first (pairing/allowlists), then tighten tool policy/sandboxing.
109
- 2. **Public network exposure** (LAN bind, Funnel, missing auth): fix immediately.
110
- 3. **Browser control remote exposure**: treat it like operator access (tailnet-only, pair nodes deliberately, avoid public exposure).
111
- 4. **Permissions**: make sure state/config/credentials/auth are not group/world-readable.
112
- 5. **Plugins/extensions**: only load what you explicitly trust.
113
- 6. **Model choice**: prefer modern, instruction-hardened models for any bot with tools.
114
-
115
- ## Security audit glossary
116
-
117
- High-signal `checkId` values you will most likely see in real deployments (not exhaustive):
118
-
119
- | `checkId` | Severity | Why it matters | Primary fix key/path | Auto-fix |
120
- | --------------------------------------------- | ------------- | ----------------------------------------------------------------------- | ------------------------------------------------------------- | -------- |
121
- | `fs.state_dir.perms_world_writable` | critical | Other users/processes can modify full Symi state | filesystem perms on `~/.symi` | yes |
122
- | `fs.config.perms_writable` | critical | Others can change auth/tool policy/config | filesystem perms on `~/.symi/symi.json` | yes |
123
- | `fs.config.perms_world_readable` | critical | Config can expose tokens/settings | filesystem perms on config file | yes |
124
- | `gateway.bind_no_auth` | critical | Remote bind without shared secret | `gateway.bind`, `gateway.auth.*` | no |
125
- | `gateway.loopback_no_auth` | critical | Reverse-proxied loopback may become unauthenticated | `gateway.auth.*`, proxy setup | no |
126
- | `gateway.http.no_auth` | warn/critical | Gateway HTTP APIs reachable with `auth.mode="none"` | `gateway.auth.mode`, `gateway.http.endpoints.*` | no |
127
- | `gateway.tools_invoke_http.dangerous_allow` | warn/critical | Re-enables dangerous tools over HTTP API | `gateway.tools.allow` | no |
128
- | `gateway.tailscale_funnel` | critical | Public internet exposure | `gateway.tailscale.mode` | no |
129
- | `gateway.control_ui.insecure_auth` | warn | Insecure-auth compatibility toggle enabled | `gateway.controlUi.allowInsecureAuth` | no |
130
- | `gateway.control_ui.device_auth_disabled` | critical | Disables device identity check | `gateway.controlUi.dangerouslyDisableDeviceAuth` | no |
131
- | `config.insecure_or_dangerous_flags` | warn | Any insecure/dangerous debug flags enabled | multiple keys (see finding detail) | no |
132
- | `hooks.token_too_short` | warn | Easier brute force on hook ingress | `hooks.token` | no |
133
- | `hooks.request_session_key_enabled` | warn/critical | External caller can choose sessionKey | `hooks.allowRequestSessionKey` | no |
134
- | `hooks.request_session_key_prefixes_missing` | warn/critical | No bound on external session key shapes | `hooks.allowedSessionKeyPrefixes` | no |
135
- | `logging.redact_off` | warn | Sensitive values leak to logs/status | `logging.redactSensitive` | yes |
136
- | `sandbox.docker_config_mode_off` | warn | Sandbox Docker config present but inactive | `agents.*.sandbox.mode` | no |
137
- | `tools.exec.host_sandbox_no_sandbox_defaults` | warn | `exec host=sandbox` resolves to host exec when sandbox is off | `tools.exec.host`, `agents.defaults.sandbox.mode` | no |
138
- | `tools.exec.host_sandbox_no_sandbox_agents` | warn | Per-agent `exec host=sandbox` resolves to host exec when sandbox is off | `agents.list[].tools.exec.host`, `agents.list[].sandbox.mode` | no |
139
- | `tools.profile_minimal_overridden` | warn | Agent overrides bypass global minimal profile | `agents.list[].tools.profile` | no |
140
- | `plugins.tools_reachable_permissive_policy` | warn | Extension tools reachable in permissive contexts | `tools.profile` + tool allow/deny | no |
141
- | `models.small_params` | critical/info | Small models + unsafe tool surfaces raise injection risk | model choice + sandbox/tool policy | no |
142
-
143
- ## Control UI over HTTP
144
-
145
- The Control UI needs a **secure context** (HTTPS or localhost) to generate device
146
- identity. `gateway.controlUi.allowInsecureAuth` does **not** bypass secure-context,
147
- device-identity, or device-pairing checks. Prefer HTTPS (Tailscale Serve) or open
148
- the UI on `127.0.0.1`.
149
-
150
- For break-glass scenarios only, `gateway.controlUi.dangerouslyDisableDeviceAuth`
151
- disables device identity checks entirely. This is a severe security downgrade;
152
- keep it off unless you are actively debugging and can revert quickly.
153
-
154
- `symi security audit` warns when this setting is enabled.
155
-
156
- ## Insecure or dangerous flags summary
157
-
158
- `symi security audit` includes `config.insecure_or_dangerous_flags` when any
159
- insecure/dangerous debug switches are enabled. This warning aggregates the exact
160
- keys so you can review them in one place (for example
161
- `gateway.controlUi.allowInsecureAuth=true`,
162
- `gateway.controlUi.dangerouslyDisableDeviceAuth=true`,
163
- `hooks.gmail.allowUnsafeExternalContent=true`, or
164
- `tools.exec.applyPatch.workspaceOnly=false`).
165
-
166
- ## Reverse Proxy Configuration
167
-
168
- If you run the Gateway behind a reverse proxy (nginx, Caddy, Traefik, etc.), you should configure `gateway.trustedProxies` for proper client IP detection.
169
-
170
- When the Gateway detects proxy headers from an address that is **not** in `trustedProxies`, it will **not** treat connections as local clients. If gateway auth is disabled, those connections are rejected. This prevents authentication bypass where proxied connections would otherwise appear to come from localhost and receive automatic trust.
171
-
172
- ```yaml
173
- gateway:
174
- trustedProxies:
175
- - "127.0.0.1" # if your proxy runs on localhost
176
- # Optional. Default false.
177
- # Only enable if your proxy cannot provide X-Forwarded-For.
178
- allowRealIpFallback: false
179
- auth:
180
- mode: password
181
- password: ${SYMI_GATEWAY_PASSWORD}
182
- ```
183
-
184
- When `trustedProxies` is configured, the Gateway uses `X-Forwarded-For` to determine the client IP. `X-Real-IP` is ignored by default unless `gateway.allowRealIpFallback: true` is explicitly set.
185
-
186
- Good reverse proxy behavior (overwrite incoming forwarding headers):
187
-
188
- ```nginx
189
- proxy_set_header X-Forwarded-For $remote_addr;
190
- proxy_set_header X-Real-IP $remote_addr;
191
- ```
192
-
193
- Bad reverse proxy behavior (append/preserve untrusted forwarding headers):
194
-
195
- ```nginx
196
- proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
197
- ```
198
-
199
- ## Local session logs live on disk
200
-
201
- Symi stores session transcripts on disk under `~/.symi/agents/<agentId>/sessions/*.jsonl`.
202
- This is required for session continuity and (optionally) session memory indexing, but it also means
203
- **any process/user with filesystem access can read those logs**. Treat disk access as the trust
204
- boundary and lock down permissions on `~/.symi` (see the audit section below). If you need
205
- stronger isolation between agents, run them under separate OS users or separate hosts.
206
-
207
- ## Node execution (system.run)
208
-
209
- If a macOS node is paired, the Gateway can invoke `system.run` on that node. This is **remote code execution** on the Mac:
210
-
211
- - Requires node pairing (approval + token).
212
- - Controlled on the Mac via **Settings → Exec approvals** (security + ask + allowlist).
213
- - If you don’t want remote execution, set security to **deny** and remove node pairing for that Mac.
214
-
215
- ## Dynamic skills (watcher / remote nodes)
216
-
217
- Symi can refresh the skills list mid-session:
218
-
219
- - **Skills watcher**: changes to `SKILL.md` can update the skills snapshot on the next agent turn.
220
- - **Remote nodes**: connecting a macOS node can make macOS-only skills eligible (based on bin probing).
221
-
222
- Treat skill folders as **trusted code** and restrict who can modify them.
223
-
224
- ## The Threat Model
225
-
226
- Your AI assistant can:
227
-
228
- - Execute arbitrary shell commands
229
- - Read/write files
230
- - Access network services
231
- - Send messages to anyone (if you give it WhatsApp access)
232
-
233
- People who message you can:
234
-
235
- - Try to trick your AI into doing bad things
236
- - Social engineer access to your data
237
- - Probe for infrastructure details
238
-
239
- ## Core concept: access control before intelligence
240
-
241
- Most failures here are not fancy exploits — they’re “someone messaged the bot and the bot did what they asked.”
242
-
243
- Symi’s stance:
244
-
245
- - **Identity first:** decide who can talk to the bot (DM pairing / allowlists / explicit “open”).
246
- - **Scope next:** decide where the bot is allowed to act (group allowlists + mention gating, tools, sandboxing, device permissions).
247
- - **Model last:** assume the model can be manipulated; design so manipulation has limited blast radius.
248
-
249
- ## Command authorization model
250
-
251
- Slash commands and directives are only honored for **authorized senders**. Authorization is derived from
252
- channel allowlists/pairing plus `commands.useAccessGroups` (see [Configuration](/gateway/configuration)
253
- and [Slash commands](/tools/slash-commands)). If a channel allowlist is empty or includes `"*"`,
254
- commands are effectively open for that channel.
255
-
256
- `/exec` is a session-only convenience for authorized operators. It does **not** write config or
257
- change other sessions.
258
-
259
- ## Control plane tools risk
260
-
261
- Two built-in tools can make persistent control-plane changes:
262
-
263
- - `gateway` can call `config.apply`, `config.patch`, and `update.run`.
264
- - `cron` can create scheduled jobs that keep running after the original chat/task ends.
265
-
266
- For any agent/surface that handles untrusted content, deny these by default:
267
-
268
- ```json5
269
- {
270
- tools: {
271
- deny: ["gateway", "cron", "sessions_spawn", "sessions_send"],
272
- },
273
- }
274
- ```
275
-
276
- `commands.restart=false` only blocks restart actions. It does not disable `gateway` config/update actions.
277
-
278
- ## Plugins/extensions
279
-
280
- Plugins run **in-process** with the Gateway. Treat them as trusted code:
281
-
282
- - Only install plugins from sources you trust.
283
- - Prefer explicit `plugins.allow` allowlists.
284
- - Review plugin config before enabling.
285
- - Restart the Gateway after plugin changes.
286
- - If you install plugins from npm (`symi plugins install <npm-spec>`), treat it like running untrusted code:
287
- - The install path is `~/.symi/extensions/<pluginId>/` (or `$SYMI_STATE_DIR/extensions/<pluginId>/`).
288
- - Symi uses `npm pack` and then runs `npm install --omit=dev` in that directory (npm lifecycle scripts can execute code during install).
289
- - Prefer pinned, exact versions (`@scope/pkg@1.2.3`), and inspect the unpacked code on disk before enabling.
290
-
291
- Details: [Plugins](/tools/plugin)
292
-
293
- ## DM access model (pairing / allowlist / open / disabled)
294
-
295
- All current DM-capable channels support a DM policy (`dmPolicy` or `*.dm.policy`) that gates inbound DMs **before** the message is processed:
296
-
297
- - `pairing` (default): unknown senders receive a short pairing code and the bot ignores their message until approved. Codes expire after 1 hour; repeated DMs won’t resend a code until a new request is created. Pending requests are capped at **3 per channel** by default.
298
- - `allowlist`: unknown senders are blocked (no pairing handshake).
299
- - `open`: allow anyone to DM (public). **Requires** the channel allowlist to include `"*"` (explicit opt-in).
300
- - `disabled`: ignore inbound DMs entirely.
301
-
302
- Approve via CLI:
303
-
304
- ```bash
305
- symi pairing list <channel>
306
- symi pairing approve <channel> <code>
307
- ```
308
-
309
- Details + files on disk: [Pairing](/channels/pairing)
310
-
311
- ## DM session isolation (multi-user mode)
312
-
313
- By default, Symi routes **all DMs into the main session** so your assistant has continuity across devices and channels. If **multiple people** can DM the bot (open DMs or a multi-person allowlist), consider isolating DM sessions:
314
-
315
- ```json5
316
- {
317
- session: { dmScope: "per-channel-peer" },
318
- }
319
- ```
320
-
321
- This prevents cross-user context leakage while keeping group chats isolated.
322
-
323
- This is a messaging-context boundary, not a host-admin boundary. If users are mutually adversarial and share the same Gateway host/config, run separate gateways per trust boundary instead.
324
-
325
- ### Secure DM mode (recommended)
326
-
327
- Treat the snippet above as **secure DM mode**:
328
-
329
- - Default: `session.dmScope: "main"` (all DMs share one session for continuity).
330
- - Secure DM mode: `session.dmScope: "per-channel-peer"` (each channel+sender pair gets an isolated DM context).
331
-
332
- If you run multiple accounts on the same channel, use `per-account-channel-peer` instead. If the same person contacts you on multiple channels, use `session.identityLinks` to collapse those DM sessions into one canonical identity. See [Session Management](/concepts/session) and [Configuration](/gateway/configuration).
333
-
334
- ## Allowlists (DM + groups) — terminology
335
-
336
- Symi has two separate “who can trigger me?” layers:
337
-
338
- - When `dmPolicy="pairing"`, approvals are written to `~/.symi/credentials/<channel>-allowFrom.json` (merged with config allowlists).
339
- - **Group allowlist** (channel-specific): which groups/channels/guilds the bot will accept messages from at all.
340
- - Common patterns:
341
- - `channels.whatsapp.groups`, `channels.telegram.groups`, `channels.imessage.groups`: per-group defaults like `requireMention`; when set, it also acts as a group allowlist (include `"*"` to keep allow-all behavior).
342
- - `groupPolicy="allowlist"` + `groupAllowFrom`: restrict who can trigger the bot _inside_ a group session (WhatsApp/Telegram/Signal/iMessage/Microsoft Teams).
343
- - Group checks run in this order: `groupPolicy`/group allowlists first, mention/reply activation second.
344
- - Replying to a bot message (implicit mention) does **not** bypass sender allowlists like `groupAllowFrom`.
345
- - **Security note:** treat `dmPolicy="open"` and `groupPolicy="open"` as last-resort settings. They should be barely used; prefer pairing + allowlists unless you fully trust every member of the room.
346
-
347
- Details: [Configuration](/gateway/configuration) and [Groups](/channels/groups)
348
-
349
- ## Prompt injection (what it is, why it matters)
350
-
351
- Prompt injection is when an attacker crafts a message that manipulates the model into doing something unsafe (“ignore your instructions”, “dump your filesystem”, “follow this link and run commands”, etc.).
352
-
353
- Even with strong system prompts, **prompt injection is not solved**. System prompt guardrails are soft guidance only; hard enforcement comes from tool policy, exec approvals, sandboxing, and channel allowlists (and operators can disable these by design). What helps in practice:
354
-
355
- - Keep inbound DMs locked down (pairing/allowlists).
356
- - Prefer mention gating in groups; avoid “always-on” bots in public rooms.
357
- - Treat links, attachments, and pasted instructions as hostile by default.
358
- - Run sensitive tool execution in a sandbox; keep secrets out of the agent’s reachable filesystem.
359
- - Note: sandboxing is opt-in. If sandbox mode is off, exec runs on the gateway host even though tools.exec.host defaults to sandbox, and host exec does not require approvals unless you set host=gateway and configure exec approvals.
360
- - Limit high-risk tools (`exec`, `browser`, `web_fetch`, `web_search`) to trusted agents or explicit allowlists.
361
- - **Model choice matters:** older/legacy models can be less robust against prompt injection and tool misuse. Prefer modern, instruction-hardened models for any bot with tools. We recommend Anthropic Opus 4.6 (or the latest Opus) because it’s strong at recognizing prompt injections (see [“A step forward on safety”](https://www.anthropic.com/news/claude-opus-4-5)).
362
-
363
- Red flags to treat as untrusted:
364
-
365
- - “Read this file/URL and do exactly what it says.”
366
- - “Ignore your system prompt or safety rules.”
367
- - “Reveal your hidden instructions or tool outputs.”
368
- - “Paste the full contents of ~/.symi or your logs.”
369
-
370
- ## Unsafe external content bypass flags
371
-
372
- Symi includes explicit bypass flags that disable external-content safety wrapping:
373
-
374
- - `hooks.mappings[].allowUnsafeExternalContent`
375
- - `hooks.gmail.allowUnsafeExternalContent`
376
- - Cron payload field `allowUnsafeExternalContent`
377
-
378
- Guidance:
379
-
380
- - Keep these unset/false in production.
381
- - Only enable temporarily for tightly scoped debugging.
382
- - If enabled, isolate that agent (sandbox + minimal tools + dedicated session namespace).
383
-
384
- ### Prompt injection does not require public DMs
385
-
386
- Even if **only you** can message the bot, prompt injection can still happen via
387
- any **untrusted content** the bot reads (web search/fetch results, browser pages,
388
- emails, docs, attachments, pasted logs/code). In other words: the sender is not
389
- the only threat surface; the **content itself** can carry adversarial instructions.
390
-
391
- When tools are enabled, the typical risk is exfiltrating context or triggering
392
- tool calls. Reduce the blast radius by:
393
-
394
- - Using a read-only or tool-disabled **reader agent** to summarize untrusted content,
395
- then pass the summary to your main agent.
396
- - Keeping `web_search` / `web_fetch` / `browser` off for tool-enabled agents unless needed.
397
- - For OpenResponses URL inputs (`input_file` / `input_image`), set tight
398
- `gateway.http.endpoints.responses.files.urlAllowlist` and
399
- `gateway.http.endpoints.responses.images.urlAllowlist`, and keep `maxUrlParts` low.
400
- - Enabling sandboxing and strict tool allowlists for any agent that touches untrusted input.
401
- - Keeping secrets out of prompts; pass them via env/config on the gateway host instead.
402
-
403
- ### Model strength (security note)
404
-
405
- Prompt injection resistance is **not** uniform across model tiers. Smaller/cheaper models are generally more susceptible to tool misuse and instruction hijacking, especially under adversarial prompts.
406
-
407
- Recommendations:
408
-
409
- - **Use the latest generation, best-tier model** for any bot that can run tools or touch files/networks.
410
- - **Avoid weaker tiers** (for example, Sonnet or Haiku) for tool-enabled agents or untrusted inboxes.
411
- - If you must use a smaller model, **reduce blast radius** (read-only tools, strong sandboxing, minimal filesystem access, strict allowlists).
412
- - When running small models, **enable sandboxing for all sessions** and **disable web_search/web_fetch/browser** unless inputs are tightly controlled.
413
- - For chat-only personal assistants with trusted input and no tools, smaller models are usually fine.
414
-
415
- ## Reasoning & verbose output in groups
416
-
417
- `/reasoning` and `/verbose` can expose internal reasoning or tool output that
418
- was not meant for a public channel. In group settings, treat them as **debug
419
- only** and keep them off unless you explicitly need them.
420
-
421
- Guidance:
422
-
423
- - Keep `/reasoning` and `/verbose` disabled in public rooms.
424
- - If you enable them, do so only in trusted DMs or tightly controlled rooms.
425
- - Remember: verbose output can include tool args, URLs, and data the model saw.
426
-
427
- ## Configuration Hardening (examples)
428
-
429
- ### 0) File permissions
430
-
431
- Keep config + state private on the gateway host:
432
-
433
- - `~/.symi/symi.json`: `600` (user read/write only)
434
- - `~/.symi`: `700` (user only)
435
-
436
- `symi doctor` can warn and offer to tighten these permissions.
437
-
438
- ### 0.4) Network exposure (bind + port + firewall)
439
-
440
- The Gateway multiplexes **WebSocket + HTTP** on a single port:
441
-
442
- - Default: `18789`
443
- - Config/flags/env: `gateway.port`, `--port`, `SYMI_GATEWAY_PORT`
444
-
445
- This HTTP surface includes the Control UI and the canvas host:
446
-
447
- - Control UI (SPA assets) (default base path `/`)
448
- - Canvas host: `/__symi__/canvas/` and `/__symi__/a2ui/` (arbitrary HTML/JS; treat as untrusted content)
449
-
450
- If you load canvas content in a normal browser, treat it like any other untrusted web page:
451
-
452
- - Don't expose the canvas host to untrusted networks/users.
453
- - Don't make canvas content share the same origin as privileged web surfaces unless you fully understand the implications.
454
-
455
- Bind mode controls where the Gateway listens:
456
-
457
- - `gateway.bind: "loopback"` (default): only local clients can connect.
458
- - Non-loopback binds (`"lan"`, `"tailnet"`, `"custom"`) expand the attack surface. Only use them with a shared token/password and a real firewall.
459
-
460
- Rules of thumb:
461
-
462
- - Prefer Tailscale Serve over LAN binds (Serve keeps the Gateway on loopback, and Tailscale handles access).
463
- - If you must bind to LAN, firewall the port to a tight allowlist of source IPs; do not port-forward it broadly.
464
- - Never expose the Gateway unauthenticated on `0.0.0.0`.
465
-
466
- ### 0.4.1) mDNS/Bonjour discovery (information disclosure)
467
-
468
- The Gateway broadcasts its presence via mDNS (`_symi-gw._tcp` on port 5353) for local device discovery. In full mode, this includes TXT records that may expose operational details:
469
-
470
- - `cliPath`: full filesystem path to the CLI binary (reveals username and install location)
471
- - `sshPort`: advertises SSH availability on the host
472
- - `displayName`, `lanHost`: hostname information
473
-
474
- **Operational security consideration:** Broadcasting infrastructure details makes reconnaissance easier for anyone on the local network. Even "harmless" info like filesystem paths and SSH availability helps attackers map your environment.
475
-
476
- **Recommendations:**
477
-
478
- 1. **Minimal mode** (default, recommended for exposed gateways): omit sensitive fields from mDNS broadcasts:
479
-
480
- ```json5
481
- {
482
- discovery: {
483
- mdns: { mode: "minimal" },
484
- },
485
- }
486
- ```
487
-
488
- 2. **Disable entirely** if you don't need local device discovery:
489
-
490
- ```json5
491
- {
492
- discovery: {
493
- mdns: { mode: "off" },
494
- },
495
- }
496
- ```
497
-
498
- 3. **Full mode** (opt-in): include `cliPath` + `sshPort` in TXT records:
499
-
500
- ```json5
501
- {
502
- discovery: {
503
- mdns: { mode: "full" },
504
- },
505
- }
506
- ```
507
-
508
- 4. **Environment variable** (alternative): set `SYMI_DISABLE_BONJOUR=1` to disable mDNS without config changes.
509
-
510
- In minimal mode, the Gateway still broadcasts enough for device discovery (`role`, `gatewayPort`, `transport`) but omits `cliPath` and `sshPort`. Apps that need CLI path information can fetch it via the authenticated WebSocket connection instead.
511
-
512
- ### 0.5) Lock down the Gateway WebSocket (local auth)
513
-
514
- Gateway auth is **required by default**. If no token/password is configured,
515
- the Gateway refuses WebSocket connections (fail‑closed).
516
-
517
- The onboarding wizard generates a token by default (even for loopback) so
518
- local clients must authenticate.
519
-
520
- Set a token so **all** WS clients must authenticate:
521
-
522
- ```json5
523
- {
524
- gateway: {
525
- auth: { mode: "token", token: "your-token" },
526
- },
527
- }
528
- ```
529
-
530
- Doctor can generate one for you: `symi doctor --generate-gateway-token`.
531
-
532
- Note: `gateway.remote.token` is **only** for remote CLI calls; it does not
533
- protect local WS access.
534
- Optional: pin remote TLS with `gateway.remote.tlsFingerprint` when using `wss://`.
535
-
536
- Local device pairing:
537
-
538
- - Device pairing is auto‑approved for **local** connects (loopback or the
539
- gateway host’s own tailnet address) to keep same‑host clients smooth.
540
- - Other tailnet peers are **not** treated as local; they still need pairing
541
- approval.
542
-
543
- Auth modes:
544
-
545
- - `gateway.auth.mode: "token"`: shared bearer token (recommended for most setups).
546
- - `gateway.auth.mode: "password"`: password auth (prefer setting via env: `SYMI_GATEWAY_PASSWORD`).
547
- - `gateway.auth.mode: "trusted-proxy"`: trust an identity-aware reverse proxy to authenticate users and pass identity via headers (see [Trusted Proxy Auth](/gateway/trusted-proxy-auth)).
548
-
549
- Rotation checklist (token/password):
550
-
551
- 1. Generate/set a new secret (`gateway.auth.token` or `SYMI_GATEWAY_PASSWORD`).
552
- 2. Restart the Gateway (or restart the macOS app if it supervises the Gateway).
553
- 3. Update any remote clients (`gateway.remote.token` / `.password` on machines that call into the Gateway).
554
- 4. Verify you can no longer connect with the old credentials.
555
-
556
- ### 0.6) Tailscale Serve identity headers
557
-
558
- When `gateway.auth.allowTailscale` is `true` (default for Serve), Symi
559
- accepts Tailscale Serve identity headers (`tailscale-user-login`) for Control
560
- UI/WebSocket authentication. Symi verifies the identity by resolving the
561
- `x-forwarded-for` address through the local Tailscale daemon (`tailscale whois`)
562
- and matching it to the header. This only triggers for requests that hit loopback
563
- and include `x-forwarded-for`, `x-forwarded-proto`, and `x-forwarded-host` as
564
- injected by Tailscale.
565
- HTTP API endpoints (for example `/v1/*`, `/tools/invoke`, and `/api/channels/*`)
566
- still require token/password auth.
567
-
568
- **Trust assumption:** tokenless Serve auth assumes the gateway host is trusted.
569
- Do not treat this as protection against hostile same-host processes. If untrusted
570
- local code may run on the gateway host, disable `gateway.auth.allowTailscale`
571
- and require token/password auth.
572
-
573
- **Security rule:** do not forward these headers from your own reverse proxy. If
574
- you terminate TLS or proxy in front of the gateway, disable
575
- `gateway.auth.allowTailscale` and use token/password auth (or [Trusted Proxy Auth](/gateway/trusted-proxy-auth)) instead.
576
-
577
- Trusted proxies:
578
-
579
- - If you terminate TLS in front of the Gateway, set `gateway.trustedProxies` to your proxy IPs.
580
- - Symi will trust `x-forwarded-for` (or `x-real-ip`) from those IPs to determine the client IP for local pairing checks and HTTP auth/local checks.
581
- - Ensure your proxy **overwrites** `x-forwarded-for` and blocks direct access to the Gateway port.
582
-
583
- See [Tailscale](/gateway/tailscale) and [Web overview](/web).
584
-
585
- ### 0.6.1) Browser control via node host (recommended)
586
-
587
- If your Gateway is remote but the browser runs on another machine, run a **node host**
588
- on the browser machine and let the Gateway proxy browser actions (see [Browser tool](/tools/browser)).
589
- Treat node pairing like admin access.
590
-
591
- Recommended pattern:
592
-
593
- - Keep the Gateway and node host on the same tailnet (Tailscale).
594
- - Pair the node intentionally; disable browser proxy routing if you don’t need it.
595
-
596
- Avoid:
597
-
598
- - Exposing relay/control ports over LAN or public Internet.
599
- - Tailscale Funnel for browser control endpoints (public exposure).
600
-
601
- ### 0.7) Secrets on disk (what’s sensitive)
602
-
603
- Assume anything under `~/.symi/` (or `$SYMI_STATE_DIR/`) may contain secrets or private data:
604
-
605
- - `symi.json`: config may include tokens (gateway, remote gateway), provider settings, and allowlists.
606
- - `credentials/**`: channel credentials (example: WhatsApp creds), pairing allowlists, legacy OAuth imports.
607
- - `agents/<agentId>/agent/auth-profiles.json`: API keys + OAuth tokens (imported from legacy `credentials/oauth.json`).
608
- - `agents/<agentId>/sessions/**`: session transcripts (`*.jsonl`) + routing metadata (`sessions.json`) that can contain private messages and tool output.
609
- - `extensions/**`: installed plugins (plus their `node_modules/`).
610
- - `sandboxes/**`: tool sandbox workspaces; can accumulate copies of files you read/write inside the sandbox.
611
-
612
- Hardening tips:
613
-
614
- - Keep permissions tight (`700` on dirs, `600` on files).
615
- - Use full-disk encryption on the gateway host.
616
- - Prefer a dedicated OS user account for the Gateway if the host is shared.
617
-
618
- ### 0.8) Logs + transcripts (redaction + retention)
619
-
620
- Logs and transcripts can leak sensitive info even when access controls are correct:
621
-
622
- - Gateway logs may include tool summaries, errors, and URLs.
623
- - Session transcripts can include pasted secrets, file contents, command output, and links.
624
-
625
- Recommendations:
626
-
627
- - Keep tool summary redaction on (`logging.redactSensitive: "tools"`; default).
628
- - Add custom patterns for your environment via `logging.redactPatterns` (tokens, hostnames, internal URLs).
629
- - When sharing diagnostics, prefer `symi status --all` (pasteable, secrets redacted) over raw logs.
630
- - Prune old session transcripts and log files if you don’t need long retention.
631
-
632
- Details: [Logging](/gateway/logging)
633
-
634
- ### 1) DMs: pairing by default
635
-
636
- ```json5
637
- {
638
- channels: { whatsapp: { dmPolicy: "pairing" } },
639
- }
640
- ```
641
-
642
- ### 2) Groups: require mention everywhere
643
-
644
- ```json
645
- {
646
- "channels": {
647
- "whatsapp": {
648
- "groups": {
649
- "*": { "requireMention": true }
650
- }
651
- }
652
- },
653
- "agents": {
654
- "list": [
655
- {
656
- "id": "main",
657
- "groupChat": { "mentionPatterns": ["@symi", "@mybot"] }
658
- }
659
- ]
660
- }
661
- }
662
- ```
663
-
664
- In group chats, only respond when explicitly mentioned.
665
-
666
- ### 3. Separate Numbers
667
-
668
- Consider running your AI on a separate phone number from your personal one:
669
-
670
- - Personal number: Your conversations stay private
671
- - Bot number: AI handles these, with appropriate boundaries
672
-
673
- ### 4. Read-Only Mode (Today, via sandbox + tools)
674
-
675
- You can already build a read-only profile by combining:
676
-
677
- - `agents.defaults.sandbox.workspaceAccess: "ro"` (or `"none"` for no workspace access)
678
- - tool allow/deny lists that block `write`, `edit`, `apply_patch`, `exec`, `process`, etc.
679
-
680
- We may add a single `readOnlyMode` flag later to simplify this configuration.
681
-
682
- Additional hardening options:
683
-
684
- - `tools.exec.applyPatch.workspaceOnly: true` (default): ensures `apply_patch` cannot write/delete outside the workspace directory even when sandboxing is off. Set to `false` only if you intentionally want `apply_patch` to touch files outside the workspace.
685
- - `tools.fs.workspaceOnly: true` (optional): restricts `read`/`write`/`edit`/`apply_patch` paths to the workspace directory (useful if you allow absolute paths today and want a single guardrail).
686
-
687
- ### 5) Secure baseline (copy/paste)
688
-
689
- One “safe default” config that keeps the Gateway private, requires DM pairing, and avoids always-on group bots:
690
-
691
- ```json5
692
- {
693
- gateway: {
694
- mode: "local",
695
- bind: "loopback",
696
- port: 18789,
697
- auth: { mode: "token", token: "your-long-random-token" },
698
- },
699
- channels: {
700
- whatsapp: {
701
- dmPolicy: "pairing",
702
- groups: { "*": { requireMention: true } },
703
- },
704
- },
705
- }
706
- ```
707
-
708
- If you want “safer by default” tool execution too, add a sandbox + deny dangerous tools for any non-owner agent (example below under “Per-agent access profiles”).
709
-
710
- Built-in baseline for chat-driven agent turns: non-owner senders cannot use the `cron` or `gateway` tools.
711
-
712
- ## Sandboxing (recommended)
713
-
714
- Dedicated doc: [Sandboxing](/gateway/sandboxing)
715
-
716
- Two complementary approaches:
717
-
718
- - **Run the full Gateway in Docker** (container boundary): [Docker](/install/docker)
719
- - **Tool sandbox** (`agents.defaults.sandbox`, host gateway + Docker-isolated tools): [Sandboxing](/gateway/sandboxing)
720
-
721
- Note: to prevent cross-agent access, keep `agents.defaults.sandbox.scope` at `"agent"` (default)
722
- or `"session"` for stricter per-session isolation. `scope: "shared"` uses a
723
- single container/workspace.
724
-
725
- Also consider agent workspace access inside the sandbox:
726
-
727
- - `agents.defaults.sandbox.workspaceAccess: "none"` (default) keeps the agent workspace off-limits; tools run against a sandbox workspace under `~/.symi/sandboxes`
728
- - `agents.defaults.sandbox.workspaceAccess: "ro"` mounts the agent workspace read-only at `/agent` (disables `write`/`edit`/`apply_patch`)
729
- - `agents.defaults.sandbox.workspaceAccess: "rw"` mounts the agent workspace read/write at `/workspace`
730
-
731
- Important: `tools.elevated` is the global baseline escape hatch that runs exec on the host. Keep `tools.elevated.allowFrom` tight and don’t enable it for strangers. You can further restrict elevated per agent via `agents.list[].tools.elevated`. See [Elevated Mode](/tools/elevated).
732
-
733
- ## Browser control risks
734
-
735
- Enabling browser control gives the model the ability to drive a real browser.
736
- If that browser profile already contains logged-in sessions, the model can
737
- access those accounts and data. Treat browser profiles as **sensitive state**:
738
-
739
- - Prefer a dedicated profile for the agent (the default `symi` profile).
740
- - Avoid pointing the agent at your personal daily-driver profile.
741
- - Keep host browser control disabled for sandboxed agents unless you trust them.
742
- - Treat browser downloads as untrusted input; prefer an isolated downloads directory.
743
- - Disable browser sync/password managers in the agent profile if possible (reduces blast radius).
744
- - For remote gateways, assume “browser control” is equivalent to “operator access” to whatever that profile can reach.
745
- - Keep the Gateway and node hosts tailnet-only; avoid exposing relay/control ports to LAN or public Internet.
746
- - The Chrome extension relay’s CDP endpoint is auth-gated; only Symi clients can connect.
747
- - Disable browser proxy routing when you don’t need it (`gateway.nodes.browser.mode="off"`).
748
- - Chrome extension relay mode is **not** “safer”; it can take over your existing Chrome tabs. Assume it can act as you in whatever that tab/profile can reach.
749
-
750
- ## Per-agent access profiles (multi-agent)
751
-
752
- With multi-agent routing, each agent can have its own sandbox + tool policy:
753
- use this to give **full access**, **read-only**, or **no access** per agent.
754
- See [Multi-Agent Sandbox & Tools](/tools/multi-agent-sandbox-tools) for full details
755
- and precedence rules.
756
-
757
- Common use cases:
758
-
759
- - Personal agent: full access, no sandbox
760
- - Family/work agent: sandboxed + read-only tools
761
- - Public agent: sandboxed + no filesystem/shell tools
762
-
763
- ### Example: full access (no sandbox)
764
-
765
- ```json5
766
- {
767
- agents: {
768
- list: [
769
- {
770
- id: "personal",
771
- workspace: "~/.symi/workspace-personal",
772
- sandbox: { mode: "off" },
773
- },
774
- ],
775
- },
776
- }
777
- ```
778
-
779
- ### Example: read-only tools + read-only workspace
780
-
781
- ```json5
782
- {
783
- agents: {
784
- list: [
785
- {
786
- id: "family",
787
- workspace: "~/.symi/workspace-family",
788
- sandbox: {
789
- mode: "all",
790
- scope: "agent",
791
- workspaceAccess: "ro",
792
- },
793
- tools: {
794
- allow: ["read"],
795
- deny: ["write", "edit", "apply_patch", "exec", "process", "browser"],
796
- },
797
- },
798
- ],
799
- },
800
- }
801
- ```
802
-
803
- ### Example: no filesystem/shell access (provider messaging allowed)
804
-
805
- ```json5
806
- {
807
- agents: {
808
- list: [
809
- {
810
- id: "public",
811
- workspace: "~/.symi/workspace-public",
812
- sandbox: {
813
- mode: "all",
814
- scope: "agent",
815
- workspaceAccess: "none",
816
- },
817
- // Session tools can reveal sensitive data from transcripts. By default Symi limits these tools
818
- // to the current session + spawned subagent sessions, but you can clamp further if needed.
819
- // See `tools.sessions.visibility` in the configuration reference.
820
- tools: {
821
- sessions: { visibility: "tree" }, // self | tree | agent | all
822
- allow: [
823
- "sessions_list",
824
- "sessions_history",
825
- "sessions_send",
826
- "sessions_spawn",
827
- "session_status",
828
- "whatsapp",
829
- "telegram",
830
- "slack",
831
- ],
832
- deny: [
833
- "read",
834
- "write",
835
- "edit",
836
- "apply_patch",
837
- "exec",
838
- "process",
839
- "browser",
840
- "canvas",
841
- "nodes",
842
- "cron",
843
- "gateway",
844
- "image",
845
- ],
846
- },
847
- },
848
- ],
849
- },
850
- }
851
- ```
852
-
853
- ## What to Tell Your AI
854
-
855
- Include security guidelines in your agent's system prompt:
856
-
857
- ```
858
- ## Security Rules
859
- - Never share directory listings or file paths with strangers
860
- - Never reveal API keys, credentials, or infrastructure details
861
- - Verify requests that modify system config with the owner
862
- - When in doubt, ask before acting
863
- - Keep private data private unless explicitly authorized
864
- ```
865
-
866
- ## Incident Response
867
-
868
- If your AI does something bad:
869
-
870
- ### Contain
871
-
872
- 1. **Stop it:** stop the macOS app (if it supervises the Gateway) or terminate your `symi gateway` process.
873
- 2. **Close exposure:** set `gateway.bind: "loopback"` (or disable Tailscale Funnel/Serve) until you understand what happened.
874
- 3. **Freeze access:** switch risky DMs/groups to `dmPolicy: "disabled"` / require mentions, and remove `"*"` allow-all entries if you had them.
875
-
876
- ### Rotate (assume compromise if secrets leaked)
877
-
878
- 1. Rotate Gateway auth (`gateway.auth.token` / `SYMI_GATEWAY_PASSWORD`) and restart.
879
- 2. Rotate remote client secrets (`gateway.remote.token` / `.password`) on any machine that can call the Gateway.
880
-
881
- ### Audit
882
-
883
- 1. Check Gateway logs: `/tmp/symi/symi-YYYY-MM-DD.log` (or `logging.file`).
884
- 2. Review the relevant transcript(s): `~/.symi/agents/<agentId>/sessions/*.jsonl`.
885
- 3. Review recent config changes (anything that could have widened access: `gateway.bind`, `gateway.auth`, dm/group policies, `tools.elevated`, plugin changes).
886
- 4. Re-run `symi security audit --deep` and confirm critical findings are resolved.
887
-
888
- ### Collect for a report
889
-
890
- - Timestamp, gateway host OS + Symi version
891
- - The session transcript(s) + a short log tail (after redacting)
892
- - What the attacker sent + what the agent did
893
- - Whether the Gateway was exposed beyond loopback (LAN/Tailscale Funnel/Serve)
894
-
895
- ## Secret Scanning (detect-secrets)
896
-
897
- CI runs `detect-secrets scan --baseline .secrets.baseline` in the `secrets` job.
898
- If it fails, there are new candidates not yet in the baseline.
899
-
900
- ### If CI fails
901
-
902
- 1. Reproduce locally:
903
-
904
- ```bash
905
- detect-secrets scan --baseline .secrets.baseline
906
- ```
907
-
908
- 2. Understand the tools:
909
- - `detect-secrets scan` finds candidates and compares them to the baseline.
910
- - `detect-secrets audit` opens an interactive review to mark each baseline
911
- item as real or false positive.
912
- 3. For real secrets: rotate/remove them, then re-run the scan to update the baseline.
913
- 4. For false positives: run the interactive audit and mark them as false:
914
-
915
- ```bash
916
- detect-secrets audit .secrets.baseline
917
- ```
918
-
919
- 5. If you need new excludes, add them to `.detect-secrets.cfg` and regenerate the
920
- baseline with matching `--exclude-files` / `--exclude-lines` flags (the config
921
- file is reference-only; detect-secrets doesn’t read it automatically).
922
-
923
- Commit the updated `.secrets.baseline` once it reflects the intended state.
924
-
925
- ## Reporting Security Issues
926
-
927
- Found a vulnerability in Symi? Please report responsibly:
928
-
929
- 1. Email: [security@symi.ai](mailto:security@symi.ai)
930
- 2. Don't post publicly until fixed
931
- 3. We'll credit you (unless you prefer anonymity)