winclaw 2026.3.21 → 2026.3.23

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 (201) hide show
  1. package/dist/{agents-_gcdm-kb.js → agents-Dc_S8rZ8.js} +4 -4
  2. package/dist/{agents.config-BkgsJJng.js → agents.config-BC6TW53i.js} +1 -1
  3. package/dist/{agents.config-Bw1hbsLj.js → agents.config-ZESYvAuZ.js} +1 -1
  4. package/dist/{auth-choice-sfRzFTug.js → auth-choice-CHCEiG_5.js} +1 -1
  5. package/dist/{auth-choice-i771W71t.js → auth-choice-CSZQYOpt.js} +1 -1
  6. package/dist/{banner-C-01b-if.js → banner-C3BSkrQk.js} +1 -1
  7. package/dist/build-info.json +2 -2
  8. package/dist/bundled/boot-md/handler.js +1 -1
  9. package/dist/bundled/session-memory/handler.js +1 -1
  10. package/dist/canvas-host/a2ui/.bundle.hash +1 -1
  11. package/dist/{channel-options-BAvRIwTX.js → channel-options-DG60shRM.js} +1 -1
  12. package/dist/{channel-options-it9Z3dNk.js → channel-options-XEKts1bm.js} +1 -1
  13. package/dist/{channel-web-BiIs0cCf.js → channel-web-XARrFQNi.js} +1 -1
  14. package/dist/{channel-web-CJ_jcZSw.js → channel-web-_2_SqIZ4.js} +1 -1
  15. package/dist/{channels-cli-CNbBNhlO.js → channels-cli-BEXYziVz.js} +6 -6
  16. package/dist/{channels-cli-miFqkj2-.js → channels-cli-ZssJjBmG.js} +6 -6
  17. package/dist/{cli-Da0pNyXg.js → cli-BZZG4J_j.js} +1 -1
  18. package/dist/{cli-BhZvhDWg.js → cli-CY_Senie.js} +1 -1
  19. package/dist/{command-registry-m8nfRV-J.js → command-registry-CWxe1f-O.js} +9 -9
  20. package/dist/{completion-cli-B-8mTxbh.js → completion-cli-BKoxA3-3.js} +2 -2
  21. package/dist/{completion-cli-c9ogb7DR.js → completion-cli-DisKMPGI.js} +1 -1
  22. package/dist/{config-cli-D2natFSq.js → config-cli-Bfwm9TCS.js} +1 -1
  23. package/dist/{config-cli-1ecjxVfC.js → config-cli-FMUUH4Ti.js} +1 -1
  24. package/dist/{configure-B-tOY-wa.js → configure-BJxly9Yt.js} +3 -3
  25. package/dist/{configure-BgqQPO5L.js → configure-DarTg7E_.js} +3 -3
  26. package/dist/{deps-send-whatsapp.runtime-BJV7VcRP.js → deps-send-whatsapp.runtime-CeFobiyN.js} +2 -2
  27. package/dist/{deps-send-whatsapp.runtime-DlmzDIzc.js → deps-send-whatsapp.runtime-D7OYrbTL.js} +2 -2
  28. package/dist/{deps-send-whatsapp.runtime-Dflrvnq-.js → deps-send-whatsapp.runtime-Dk3bVJzk.js} +3 -3
  29. package/dist/{deps-send-whatsapp.runtime-BHJLeHSL.js → deps-send-whatsapp.runtime-iiQJpw-8.js} +3 -3
  30. package/dist/{doctor-completion-DEdT-_9v.js → doctor-completion-BtQY4Eaa.js} +1 -1
  31. package/dist/{doctor-completion-C3SXIoSh.js → doctor-completion-t3rdrQev.js} +1 -1
  32. package/dist/entry.js +2 -2
  33. package/dist/extensionAPI.js +1 -1
  34. package/dist/{gateway-cli-C_4mlmOW.js → gateway-cli-BeABpkZ1.js} +11 -11
  35. package/dist/{gateway-cli-CL5LDNmu.js → gateway-cli-Juhp3APs.js} +11 -11
  36. package/dist/{health-C5a0wlfE.js → health-8quueFaP.js} +1 -1
  37. package/dist/{health-CqiwN5ZR.js → health-BoOzWD1m.js} +1 -1
  38. package/dist/{hooks-cli-C79J_WG7.js → hooks-cli-B475HcKz.js} +2 -2
  39. package/dist/{hooks-cli-DDWnA5Zx.js → hooks-cli-BcKW3j9V.js} +2 -2
  40. package/dist/index.js +6 -6
  41. package/dist/llm-slug-generator.js +1 -1
  42. package/dist/{models-Do96D4zT.js → models-FzoA9YFe.js} +2 -2
  43. package/dist/{models-cli-pblTciC_.js → models-cli-B9FoteUK.js} +3 -3
  44. package/dist/{models-cli-DOfsOmW1.js → models-cli-DPCSWjYD.js} +2 -2
  45. package/dist/{npm-resolution-Bd8dB7rI.js → npm-resolution-DUcSV3Er.js} +1 -1
  46. package/dist/{npm-resolution-DE7xcGkg.js → npm-resolution-Kay_MP5U.js} +1 -1
  47. package/dist/{onboard-CReGZ3G9.js → onboard-DSE0sFKG.js} +2 -2
  48. package/dist/{onboard-channels-DvpqJP6s.js → onboard-channels-DleZdwBe.js} +1 -1
  49. package/dist/{onboard-channels-ljMkIe7O.js → onboard-channels-DuQfbGvH.js} +1 -1
  50. package/dist/{onboard-CXyqQtlq.js → onboard-lgDkrSqS.js} +2 -2
  51. package/dist/{onboarding-BZWA8Nqq.js → onboarding-D713_nF-.js} +3 -3
  52. package/dist/{onboarding-CoH1hPY0.js → onboarding-tBrb0kFS.js} +3 -3
  53. package/dist/{onboarding.finalize-B1qRlV6H.js → onboarding.finalize-DenRnQtC.js} +5 -5
  54. package/dist/{onboarding.finalize-DzRWtkmA.js → onboarding.finalize-femvpEYf.js} +6 -6
  55. package/dist/{pi-embedded-DUO1eQ_J.js → pi-embedded-CPqoXbPh.js} +15 -15
  56. package/dist/{pi-embedded-xAf-RVi5.js → pi-embedded-yo67-7fx.js} +15 -15
  57. package/dist/{plugin-registry-DckyegZB.js → plugin-registry-ByrPvIy8.js} +1 -1
  58. package/dist/{plugin-registry-Cb_XRQUR.js → plugin-registry-C_HMboob.js} +1 -1
  59. package/dist/plugin-sdk/{channel-web-CfZNFYCV.js → channel-web-CZNn3YpA.js} +1 -1
  60. package/dist/plugin-sdk/{channel-web-D02gHjxz.js → channel-web-ut6coWO5.js} +1 -1
  61. package/dist/plugin-sdk/compat.js +50 -50
  62. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-DJlWl-wv.js → deps-send-whatsapp.runtime-7Y4jFeSR.js} +3 -3
  63. package/dist/plugin-sdk/{deps-send-whatsapp.runtime-BxQ5tZO2.js → deps-send-whatsapp.runtime-BYqY0Q9J.js} +3 -3
  64. package/dist/plugin-sdk/imessage.js +2 -2
  65. package/dist/plugin-sdk/index.js +2 -2
  66. package/dist/plugin-sdk/{reply-BEBnUyG7.js → reply-CHTGOm7N.js} +15 -15
  67. package/dist/plugin-sdk/{reply-Cx_4UtvJ.js → reply-CbZPef0p.js} +15 -15
  68. package/dist/plugin-sdk/slack.js +2 -2
  69. package/dist/plugin-sdk/{slash-dispatch.runtime-C74v1zF9.js → slash-dispatch.runtime-CU94t3bC.js} +1 -1
  70. package/dist/plugin-sdk/{slash-dispatch.runtime-DN7TWAWh.js → slash-dispatch.runtime-fens4sxk.js} +1 -1
  71. package/dist/plugin-sdk/{subagent-registry-runtime-CprGCjIU.js → subagent-registry-runtime-CwlC6o7G.js} +1 -1
  72. package/dist/plugin-sdk/{subagent-registry-runtime-9CC9qb9s.js → subagent-registry-runtime-DE56KyD-.js} +1 -1
  73. package/dist/plugin-sdk/telegram.js +2 -2
  74. package/dist/plugin-sdk/{web-D9wJfMr_.js → web-DSbskSAb.js} +2 -2
  75. package/dist/plugin-sdk/{web-D0OZnnn7.js → web-Oo_Fd7RA.js} +2 -2
  76. package/dist/plugin-sdk/whatsapp.js +2 -2
  77. package/dist/plugin-sdk/zalouser.js +2 -2
  78. package/dist/{plugins-cli-BWCjQEMr.js → plugins-cli-CI8xpqVq.js} +2 -2
  79. package/dist/{plugins-cli-C6Oo9R6E.js → plugins-cli-DQCpV91t.js} +2 -2
  80. package/dist/{program-CEJ6CsoR.js → program-N2SbF1HK.js} +7 -7
  81. package/dist/{program-context-EXWtPjXg.js → program-context-DMg-_LjD.js} +17 -17
  82. package/dist/{prompt-select-styled-D-f3R2mt.js → prompt-select-styled-BehogMCm.js} +4 -4
  83. package/dist/{prompt-select-styled-B_AHrNLY.js → prompt-select-styled-pMhNy-Rt.js} +4 -4
  84. package/dist/{provider-auth-helpers-CN4iPBfs.js → provider-auth-helpers-4bL3VgNE.js} +1 -1
  85. package/dist/{provider-auth-helpers-CiXbjGH-.js → provider-auth-helpers-Rpp9Sh_y.js} +1 -1
  86. package/dist/{push-apns-D7Si-92v.js → push-apns-CGUAuXgJ.js} +1 -1
  87. package/dist/{push-apns-BEZdCQsM.js → push-apns-hyDzrrIU.js} +1 -1
  88. package/dist/{register.agent-BDosszM8.js → register.agent-CFrG4s6H.js} +6 -6
  89. package/dist/{register.agent-BjxrirHi.js → register.agent-CTNWQCtt.js} +7 -7
  90. package/dist/{register.configure-MduIRRMt.js → register.configure-DIKLgW8P.js} +7 -7
  91. package/dist/{register.configure-C0B9vKwT.js → register.configure-Di8Uh5GB.js} +7 -7
  92. package/dist/{register.maintenance-CfnzY1OX.js → register.maintenance-Cc675Yxz.js} +7 -7
  93. package/dist/{register.maintenance-BfdiJ7KX.js → register.maintenance-GewLmA3i.js} +8 -8
  94. package/dist/{register.message-D4VYaBqq.js → register.message-BI_R0TJs.js} +2 -2
  95. package/dist/{register.message-BszoJEBm.js → register.message-CtBJO09g.js} +2 -2
  96. package/dist/{register.onboard-CbJU4Y-3.js → register.onboard-45htf4DA.js} +2 -2
  97. package/dist/{register.onboard-CjuT9fKW.js → register.onboard-Jv--xCKB.js} +2 -2
  98. package/dist/{register.setup-DZzf7J04.js → register.setup-Bm99k2pm.js} +2 -2
  99. package/dist/{register.setup-BTTBsCT0.js → register.setup-CqrPLejH.js} +2 -2
  100. package/dist/{register.status-health-sessions-C3Ji8sqv.js → register.status-health-sessions-BBDVWYvb.js} +3 -3
  101. package/dist/{register.status-health-sessions-BKcFfUR6.js → register.status-health-sessions-BmpJln2_.js} +3 -3
  102. package/dist/{register.subclis-2iN-TxPh.js → register.subclis-4LlGcEld.js} +9 -9
  103. package/dist/{reply-KTubTl9h.js → reply-a2GVvnP2.js} +15 -15
  104. package/dist/{run-main-BEtPk_9z.js → run-main-B3eIQkhk.js} +14 -14
  105. package/dist/{server-node-events-BozhXo6J.js → server-node-events-Bn6C-kB6.js} +2 -2
  106. package/dist/{server-node-events-CFcRS-lD.js → server-node-events-CbUk95yd.js} +2 -2
  107. package/dist/{slash-dispatch.runtime-D5Cl7j1v.js → slash-dispatch.runtime-B4quYJn4.js} +1 -1
  108. package/dist/{slash-dispatch.runtime-B0OIPdp3.js → slash-dispatch.runtime-BBH2jQsL.js} +1 -1
  109. package/dist/{slash-dispatch.runtime-DDLolsGY.js → slash-dispatch.runtime-BLQZdvZW.js} +1 -1
  110. package/dist/{slash-dispatch.runtime-DtN2NmXJ.js → slash-dispatch.runtime-wBORF-o1.js} +1 -1
  111. package/dist/{status-B5hylgEQ.js → status-BqpyCRc4.js} +2 -2
  112. package/dist/{status-DClHhy30.js → status-DHIaRvxs.js} +2 -2
  113. package/dist/{subagent-registry-iD-ynHA9.js → subagent-registry-CRAr7csi.js} +15 -15
  114. package/dist/{subagent-registry-runtime-DfMDVaOY.js → subagent-registry-runtime-BfYm3d-n.js} +1 -1
  115. package/dist/{subagent-registry-runtime-CdEy9DKy.js → subagent-registry-runtime-CnPoAflv.js} +1 -1
  116. package/dist/{subagent-registry-runtime-Cv_Xt2cx.js → subagent-registry-runtime-DQb8qzq2.js} +1 -1
  117. package/dist/{subagent-registry-runtime-LH0OBaWN.js → subagent-registry-runtime-sMbEjW_q.js} +1 -1
  118. package/dist/{update-cli-C1nysDmM.js → update-cli-Bk3xkEPl.js} +8 -8
  119. package/dist/{update-cli-Dj_9Bokl.js → update-cli-G1w1hdg4.js} +7 -7
  120. package/dist/{update-runner-BpzbDTnQ.js → update-runner-CgS5D8t8.js} +1 -1
  121. package/dist/{update-runner-BUoHYjl8.js → update-runner-TyDM6-ms.js} +1 -1
  122. package/dist/{web-DxHq9RWt.js → web-7w_9CsnG.js} +2 -2
  123. package/dist/{web-Dbqs3hbC.js → web-B790MBdK.js} +1 -1
  124. package/dist/{web-CodV11ZY.js → web-BPiSo--I.js} +1 -1
  125. package/dist/{web-YBvuT4WS.js → web-BmYQFz4q.js} +2 -2
  126. package/package.json +1 -1
  127. package/dist/plugin-sdk/accounts-B71rIfIG.js +0 -35
  128. package/dist/plugin-sdk/accounts-Bh_CxVlh.js +0 -46
  129. package/dist/plugin-sdk/accounts-BoD7489q.js +0 -288
  130. package/dist/plugin-sdk/active-listener-6CPAmAh-.js +0 -50
  131. package/dist/plugin-sdk/api-key-rotation-DEDhmJAk.js +0 -181
  132. package/dist/plugin-sdk/audio-preflight-CMPZ9BXN.js +0 -69
  133. package/dist/plugin-sdk/audio-transcription-runner-CdADoJed.js +0 -2176
  134. package/dist/plugin-sdk/audit-membership-runtime-CxP2fdgS.js +0 -58
  135. package/dist/plugin-sdk/channel-activity-9ivqqvRB.js +0 -94
  136. package/dist/plugin-sdk/channel-web-CHDoy_Ex.js +0 -2256
  137. package/dist/plugin-sdk/chrome-B1yeIHRg.js +0 -2415
  138. package/dist/plugin-sdk/commands-registry-D-wyzYid.js +0 -1125
  139. package/dist/plugin-sdk/config-CmS6HzGU.js +0 -17959
  140. package/dist/plugin-sdk/deliver-Cy287pZ5.js +0 -1719
  141. package/dist/plugin-sdk/deliver-runtime-BH3fUFW1.js +0 -32
  142. package/dist/plugin-sdk/deps-send-discord.runtime-CLboFQJz.js +0 -23
  143. package/dist/plugin-sdk/deps-send-imessage.runtime-BVlGKP96.js +0 -22
  144. package/dist/plugin-sdk/deps-send-signal.runtime-0640YmBr.js +0 -21
  145. package/dist/plugin-sdk/deps-send-slack.runtime-BqbFKjcg.js +0 -19
  146. package/dist/plugin-sdk/deps-send-telegram.runtime-1a2RXcA2.js +0 -24
  147. package/dist/plugin-sdk/deps-send-whatsapp.runtime-CpOH0wYd.js +0 -57
  148. package/dist/plugin-sdk/diagnostic-DGt5TnqW.js +0 -319
  149. package/dist/plugin-sdk/errors-D7zDdduc.js +0 -54
  150. package/dist/plugin-sdk/fetch-guard-BsatETDz.js +0 -156
  151. package/dist/plugin-sdk/fs-safe-ynDN1AOr.js +0 -352
  152. package/dist/plugin-sdk/image-6No3eiOM.js +0 -2314
  153. package/dist/plugin-sdk/image-ops-CmFoHyKE.js +0 -584
  154. package/dist/plugin-sdk/image-runtime-D57a2W4s.js +0 -25
  155. package/dist/plugin-sdk/ir-CX1ZjDTn.js +0 -1296
  156. package/dist/plugin-sdk/local-roots-DnE8988Y.js +0 -186
  157. package/dist/plugin-sdk/logger-cN8CgKqt.js +0 -1163
  158. package/dist/plugin-sdk/login-hk6_2GSM.js +0 -57
  159. package/dist/plugin-sdk/login-qr-UaVS_Rce.js +0 -320
  160. package/dist/plugin-sdk/manager-CBP2ZQ5W.js +0 -3929
  161. package/dist/plugin-sdk/manager-runtime-3rKbDrJp.js +0 -15
  162. package/dist/plugin-sdk/outbound-B0Ab6CJM.js +0 -212
  163. package/dist/plugin-sdk/outbound-attachment-CktA053B.js +0 -19
  164. package/dist/plugin-sdk/path-alias-guards-WXu8eYZ3.js +0 -43
  165. package/dist/plugin-sdk/paths-Brta7ydd.js +0 -166
  166. package/dist/plugin-sdk/pi-embedded-helpers-BfbOXbe6.js +0 -9627
  167. package/dist/plugin-sdk/pi-model-discovery-ruarR-_j.js +0 -134
  168. package/dist/plugin-sdk/pi-model-discovery-runtime-26px0QfL.js +0 -8
  169. package/dist/plugin-sdk/pi-tools.before-tool-call.runtime-VVLpfXqQ.js +0 -354
  170. package/dist/plugin-sdk/plugins-C995vsQz.js +0 -864
  171. package/dist/plugin-sdk/proxy-fetch-iSQrNgP-.js +0 -38
  172. package/dist/plugin-sdk/pw-ai-BJXHSS3q.js +0 -1938
  173. package/dist/plugin-sdk/qmd-manager-A7m15SeJ.js +0 -1448
  174. package/dist/plugin-sdk/query-expansion-DngcFbkC.js +0 -1011
  175. package/dist/plugin-sdk/redact-CIb5VTTO.js +0 -319
  176. package/dist/plugin-sdk/reply-vuWmM3Ra.js +0 -100211
  177. package/dist/plugin-sdk/resolve-outbound-target-CQ6hRY-h.js +0 -40
  178. package/dist/plugin-sdk/run-with-concurrency-BlfAoChN.js +0 -1994
  179. package/dist/plugin-sdk/runtime-whatsapp-login.runtime-YsrzSsFL.js +0 -10
  180. package/dist/plugin-sdk/runtime-whatsapp-outbound.runtime-DL6Ses5K.js +0 -19
  181. package/dist/plugin-sdk/send-BEy8EUzH.js +0 -414
  182. package/dist/plugin-sdk/send-CWP6COto.js +0 -3135
  183. package/dist/plugin-sdk/send-DQTgt3Cu.js +0 -540
  184. package/dist/plugin-sdk/send-DzpV-k17.js +0 -2587
  185. package/dist/plugin-sdk/send-HuIksBS6.js +0 -503
  186. package/dist/plugin-sdk/session-Cc3Y4mXL.js +0 -169
  187. package/dist/plugin-sdk/skill-commands-p8Zwjnwy.js +0 -353
  188. package/dist/plugin-sdk/skills-k8XpacZa.js +0 -1428
  189. package/dist/plugin-sdk/slash-commands.runtime-ynnr6oUR.js +0 -13
  190. package/dist/plugin-sdk/slash-dispatch.runtime-DOmMrwMj.js +0 -52
  191. package/dist/plugin-sdk/slash-skill-commands.runtime-eAk1jhVy.js +0 -16
  192. package/dist/plugin-sdk/ssrf-DZSsYJgJ.js +0 -202
  193. package/dist/plugin-sdk/store-Cn0oLCP4.js +0 -81
  194. package/dist/plugin-sdk/subagent-registry-runtime-CQ3m7TwQ.js +0 -52
  195. package/dist/plugin-sdk/tables-KWxXnbkq.js +0 -55
  196. package/dist/plugin-sdk/target-errors-Cr0q4o7K.js +0 -195
  197. package/dist/plugin-sdk/thinking-CfA6xbI_.js +0 -1206
  198. package/dist/plugin-sdk/tokens-B-D1YRTV.js +0 -52
  199. package/dist/plugin-sdk/tool-images-CVV7LNFW.js +0 -274
  200. package/dist/plugin-sdk/web-B1Svh1KM.js +0 -56
  201. package/dist/plugin-sdk/whatsapp-actions-CLNhBLJz.js +0 -80
@@ -1,353 +0,0 @@
1
- import { c as resolveAgentWorkspaceDir, r as listAgentIds, s as resolveAgentSkillsFilter } from "./run-with-concurrency-BlfAoChN.js";
2
- import { c as resolveStateDir } from "./paths-BEfQqXwE.js";
3
- import { E as resolveUserPath, L as logVerbose, a as createSubsystemLogger, f as CONFIG_DIR } from "./logger-cN8CgKqt.js";
4
- import { t as createAsyncLock } from "./json-files-Dhmud8Yn.js";
5
- import { o as resolvePluginSkillDirs, t as buildWorkspaceSkillCommandSpecs } from "./skills-k8XpacZa.js";
6
- import { i as listChatCommands } from "./commands-registry-D-wyzYid.js";
7
- import fs from "node:fs";
8
- import path from "node:path";
9
- import os from "node:os";
10
- import { randomBytes, randomUUID } from "node:crypto";
11
- import chokidar from "chokidar";
12
-
13
- //#region src/infra/pairing-files.ts
14
- function resolvePairingPaths(baseDir, subdir) {
15
- const root = baseDir ?? resolveStateDir();
16
- const dir = path.join(root, subdir);
17
- return {
18
- dir,
19
- pendingPath: path.join(dir, "pending.json"),
20
- pairedPath: path.join(dir, "paired.json")
21
- };
22
- }
23
- function pruneExpiredPending(pendingById, nowMs, ttlMs) {
24
- for (const [id, req] of Object.entries(pendingById)) if (nowMs - req.ts > ttlMs) delete pendingById[id];
25
- }
26
-
27
- //#endregion
28
- //#region src/infra/pairing-pending.ts
29
- async function rejectPendingPairingRequest(params) {
30
- const state = await params.loadState();
31
- const pending = state.pendingById[params.requestId];
32
- if (!pending) return null;
33
- delete state.pendingById[params.requestId];
34
- await params.persistState(state);
35
- return {
36
- requestId: params.requestId,
37
- [params.idKey]: params.getId(pending)
38
- };
39
- }
40
-
41
- //#endregion
42
- //#region src/infra/pairing-token.ts
43
- const PAIRING_TOKEN_BYTES = 32;
44
- function generatePairingToken() {
45
- return randomBytes(PAIRING_TOKEN_BYTES).toString("base64url");
46
- }
47
-
48
- //#endregion
49
- //#region src/agents/skills/refresh.ts
50
- const log$1 = createSubsystemLogger("gateway/skills");
51
- const listeners = /* @__PURE__ */ new Set();
52
- const workspaceVersions = /* @__PURE__ */ new Map();
53
- const watchers = /* @__PURE__ */ new Map();
54
- let globalVersion = 0;
55
- const DEFAULT_SKILLS_WATCH_IGNORED = [
56
- /(^|[\\/])\.git([\\/]|$)/,
57
- /(^|[\\/])node_modules([\\/]|$)/,
58
- /(^|[\\/])dist([\\/]|$)/,
59
- /(^|[\\/])\.venv([\\/]|$)/,
60
- /(^|[\\/])venv([\\/]|$)/,
61
- /(^|[\\/])__pycache__([\\/]|$)/,
62
- /(^|[\\/])\.mypy_cache([\\/]|$)/,
63
- /(^|[\\/])\.pytest_cache([\\/]|$)/,
64
- /(^|[\\/])build([\\/]|$)/,
65
- /(^|[\\/])\.cache([\\/]|$)/
66
- ];
67
- function bumpVersion(current) {
68
- const now = Date.now();
69
- return now <= current ? current + 1 : now;
70
- }
71
- function emit(event) {
72
- for (const listener of listeners) try {
73
- listener(event);
74
- } catch (err) {
75
- log$1.warn(`skills change listener failed: ${String(err)}`);
76
- }
77
- }
78
- function resolveWatchPaths(workspaceDir, config) {
79
- const paths = [];
80
- if (workspaceDir.trim()) {
81
- paths.push(path.join(workspaceDir, "skills"));
82
- paths.push(path.join(workspaceDir, ".agents", "skills"));
83
- }
84
- paths.push(path.join(CONFIG_DIR, "skills"));
85
- paths.push(path.join(os.homedir(), ".agents", "skills"));
86
- const extraDirs = (config?.skills?.load?.extraDirs ?? []).map((d) => typeof d === "string" ? d.trim() : "").filter(Boolean).map((dir) => resolveUserPath(dir));
87
- paths.push(...extraDirs);
88
- const pluginSkillDirs = resolvePluginSkillDirs({
89
- workspaceDir,
90
- config
91
- });
92
- paths.push(...pluginSkillDirs);
93
- return paths;
94
- }
95
- function toWatchGlobRoot(raw) {
96
- return raw.replaceAll("\\", "/").replace(/\/+$/, "");
97
- }
98
- function resolveWatchTargets(workspaceDir, config) {
99
- const targets = /* @__PURE__ */ new Set();
100
- for (const root of resolveWatchPaths(workspaceDir, config)) {
101
- const globRoot = toWatchGlobRoot(root);
102
- targets.add(`${globRoot}/SKILL.md`);
103
- targets.add(`${globRoot}/*/SKILL.md`);
104
- }
105
- return Array.from(targets).toSorted();
106
- }
107
- function bumpSkillsSnapshotVersion(params) {
108
- const reason = params?.reason ?? "manual";
109
- const changedPath = params?.changedPath;
110
- if (params?.workspaceDir) {
111
- const next = bumpVersion(workspaceVersions.get(params.workspaceDir) ?? 0);
112
- workspaceVersions.set(params.workspaceDir, next);
113
- emit({
114
- workspaceDir: params.workspaceDir,
115
- reason,
116
- changedPath
117
- });
118
- return next;
119
- }
120
- globalVersion = bumpVersion(globalVersion);
121
- emit({
122
- reason,
123
- changedPath
124
- });
125
- return globalVersion;
126
- }
127
- function getSkillsSnapshotVersion(workspaceDir) {
128
- if (!workspaceDir) return globalVersion;
129
- const local = workspaceVersions.get(workspaceDir) ?? 0;
130
- return Math.max(globalVersion, local);
131
- }
132
- function ensureSkillsWatcher(params) {
133
- const workspaceDir = params.workspaceDir.trim();
134
- if (!workspaceDir) return;
135
- const watchEnabled = params.config?.skills?.load?.watch !== false;
136
- const debounceMsRaw = params.config?.skills?.load?.watchDebounceMs;
137
- const debounceMs = typeof debounceMsRaw === "number" && Number.isFinite(debounceMsRaw) ? Math.max(0, debounceMsRaw) : 250;
138
- const existing = watchers.get(workspaceDir);
139
- if (!watchEnabled) {
140
- if (existing) {
141
- watchers.delete(workspaceDir);
142
- if (existing.timer) clearTimeout(existing.timer);
143
- existing.watcher.close().catch(() => {});
144
- }
145
- return;
146
- }
147
- const watchTargets = resolveWatchTargets(workspaceDir, params.config);
148
- const pathsKey = watchTargets.join("|");
149
- if (existing && existing.pathsKey === pathsKey && existing.debounceMs === debounceMs) return;
150
- if (existing) {
151
- watchers.delete(workspaceDir);
152
- if (existing.timer) clearTimeout(existing.timer);
153
- existing.watcher.close().catch(() => {});
154
- }
155
- const watcher = chokidar.watch(watchTargets, {
156
- ignoreInitial: true,
157
- awaitWriteFinish: {
158
- stabilityThreshold: debounceMs,
159
- pollInterval: 100
160
- },
161
- ignored: DEFAULT_SKILLS_WATCH_IGNORED
162
- });
163
- const state = {
164
- watcher,
165
- pathsKey,
166
- debounceMs
167
- };
168
- const schedule = (changedPath) => {
169
- state.pendingPath = changedPath ?? state.pendingPath;
170
- if (state.timer) clearTimeout(state.timer);
171
- state.timer = setTimeout(() => {
172
- const pendingPath = state.pendingPath;
173
- state.pendingPath = void 0;
174
- state.timer = void 0;
175
- bumpSkillsSnapshotVersion({
176
- workspaceDir,
177
- reason: "watch",
178
- changedPath: pendingPath
179
- });
180
- }, debounceMs);
181
- };
182
- watcher.on("add", (p) => schedule(p));
183
- watcher.on("change", (p) => schedule(p));
184
- watcher.on("unlink", (p) => schedule(p));
185
- watcher.on("error", (err) => {
186
- log$1.warn(`skills watcher error (${workspaceDir}): ${String(err)}`);
187
- });
188
- watchers.set(workspaceDir, state);
189
- }
190
-
191
- //#endregion
192
- //#region src/infra/node-pairing.ts
193
- const PENDING_TTL_MS = 300 * 1e3;
194
- const withLock = createAsyncLock();
195
-
196
- //#endregion
197
- //#region src/infra/skills-remote.ts
198
- const log = createSubsystemLogger("gateway/skills-remote");
199
- const remoteNodes = /* @__PURE__ */ new Map();
200
- function isMacPlatform(platform, deviceFamily) {
201
- const platformNorm = String(platform ?? "").trim().toLowerCase();
202
- const familyNorm = String(deviceFamily ?? "").trim().toLowerCase();
203
- if (platformNorm.includes("mac")) return true;
204
- if (platformNorm.includes("darwin")) return true;
205
- if (familyNorm === "mac") return true;
206
- return false;
207
- }
208
- function supportsSystemRun(commands) {
209
- return Array.isArray(commands) && commands.includes("system.run");
210
- }
211
- function getRemoteSkillEligibility() {
212
- const macNodes = [...remoteNodes.values()].filter((node) => isMacPlatform(node.platform, node.deviceFamily) && supportsSystemRun(node.commands));
213
- if (macNodes.length === 0) return;
214
- const bins = /* @__PURE__ */ new Set();
215
- for (const node of macNodes) for (const bin of node.bins) bins.add(bin);
216
- const labels = macNodes.map((node) => node.displayName ?? node.nodeId).filter(Boolean);
217
- return {
218
- platforms: ["darwin"],
219
- hasBin: (bin) => bins.has(bin),
220
- hasAnyBin: (required) => required.some((bin) => bins.has(bin)),
221
- note: labels.length > 0 ? `Remote macOS node available (${labels.join(", ")}). Run macOS-only skills via nodes.run on that node.` : "Remote macOS node available. Run macOS-only skills via nodes.run on that node."
222
- };
223
- }
224
-
225
- //#endregion
226
- //#region src/auto-reply/skill-commands.ts
227
- function listReservedChatSlashCommandNames(extraNames = []) {
228
- const reserved = /* @__PURE__ */ new Set();
229
- for (const command of listChatCommands()) {
230
- if (command.nativeName) reserved.add(command.nativeName.toLowerCase());
231
- for (const alias of command.textAliases) {
232
- const trimmed = alias.trim();
233
- if (!trimmed.startsWith("/")) continue;
234
- reserved.add(trimmed.slice(1).toLowerCase());
235
- }
236
- }
237
- for (const name of extraNames) {
238
- const trimmed = name.trim().toLowerCase();
239
- if (trimmed) reserved.add(trimmed);
240
- }
241
- return reserved;
242
- }
243
- function listSkillCommandsForWorkspace(params) {
244
- return buildWorkspaceSkillCommandSpecs(params.workspaceDir, {
245
- config: params.cfg,
246
- skillFilter: params.skillFilter,
247
- eligibility: { remote: getRemoteSkillEligibility() },
248
- reservedNames: listReservedChatSlashCommandNames()
249
- });
250
- }
251
- function dedupeBySkillName(commands) {
252
- const seen = /* @__PURE__ */ new Set();
253
- const out = [];
254
- for (const cmd of commands) {
255
- const key = cmd.skillName.trim().toLowerCase();
256
- if (key && seen.has(key)) continue;
257
- if (key) seen.add(key);
258
- out.push(cmd);
259
- }
260
- return out;
261
- }
262
- function listSkillCommandsForAgents(params) {
263
- const mergeSkillFilters = (existing, incoming) => {
264
- if (existing === void 0 || incoming === void 0) return;
265
- if (existing.length === 0) return Array.from(new Set(incoming));
266
- if (incoming.length === 0) return Array.from(new Set(existing));
267
- return Array.from(new Set([...existing, ...incoming]));
268
- };
269
- const agentIds = params.agentIds ?? listAgentIds(params.cfg);
270
- const used = listReservedChatSlashCommandNames();
271
- const entries = [];
272
- const workspaceFilters = /* @__PURE__ */ new Map();
273
- for (const agentId of agentIds) {
274
- const workspaceDir = resolveAgentWorkspaceDir(params.cfg, agentId);
275
- if (!fs.existsSync(workspaceDir)) {
276
- logVerbose(`Skipping agent "${agentId}": workspace does not exist: ${workspaceDir}`);
277
- continue;
278
- }
279
- let canonicalDir;
280
- try {
281
- canonicalDir = fs.realpathSync(workspaceDir);
282
- } catch {
283
- logVerbose(`Skipping agent "${agentId}": cannot resolve workspace: ${workspaceDir}`);
284
- continue;
285
- }
286
- const skillFilter = resolveAgentSkillsFilter(params.cfg, agentId);
287
- const existing = workspaceFilters.get(canonicalDir);
288
- if (existing) {
289
- existing.skillFilter = mergeSkillFilters(existing.skillFilter, skillFilter);
290
- continue;
291
- }
292
- workspaceFilters.set(canonicalDir, {
293
- workspaceDir,
294
- skillFilter
295
- });
296
- }
297
- for (const { workspaceDir, skillFilter } of workspaceFilters.values()) {
298
- const commands = buildWorkspaceSkillCommandSpecs(workspaceDir, {
299
- config: params.cfg,
300
- skillFilter,
301
- eligibility: { remote: getRemoteSkillEligibility() },
302
- reservedNames: used
303
- });
304
- for (const command of commands) {
305
- used.add(command.name.toLowerCase());
306
- entries.push(command);
307
- }
308
- }
309
- return dedupeBySkillName(entries);
310
- }
311
- function normalizeSkillCommandLookup(value) {
312
- return value.trim().toLowerCase().replace(/[\s_]+/g, "-");
313
- }
314
- function findSkillCommand(skillCommands, rawName) {
315
- const trimmed = rawName.trim();
316
- if (!trimmed) return;
317
- const lowered = trimmed.toLowerCase();
318
- const normalized = normalizeSkillCommandLookup(trimmed);
319
- return skillCommands.find((entry) => {
320
- if (entry.name.toLowerCase() === lowered) return true;
321
- if (entry.skillName.toLowerCase() === lowered) return true;
322
- return normalizeSkillCommandLookup(entry.name) === normalized || normalizeSkillCommandLookup(entry.skillName) === normalized;
323
- });
324
- }
325
- function resolveSkillCommandInvocation(params) {
326
- const trimmed = params.commandBodyNormalized.trim();
327
- if (!trimmed.startsWith("/")) return null;
328
- const match = trimmed.match(/^\/([^\s]+)(?:\s+([\s\S]+))?$/);
329
- if (!match) return null;
330
- const commandName = match[1]?.trim().toLowerCase();
331
- if (!commandName) return null;
332
- if (commandName === "skill") {
333
- const remainder = match[2]?.trim();
334
- if (!remainder) return null;
335
- const skillMatch = remainder.match(/^([^\s]+)(?:\s+([\s\S]+))?$/);
336
- if (!skillMatch) return null;
337
- const skillCommand = findSkillCommand(params.skillCommands, skillMatch[1] ?? "");
338
- if (!skillCommand) return null;
339
- return {
340
- command: skillCommand,
341
- args: skillMatch[2]?.trim() || void 0
342
- };
343
- }
344
- const command = params.skillCommands.find((entry) => entry.name.toLowerCase() === commandName);
345
- if (!command) return null;
346
- return {
347
- command,
348
- args: match[2]?.trim() || void 0
349
- };
350
- }
351
-
352
- //#endregion
353
- export { getRemoteSkillEligibility as a, generatePairingToken as c, resolvePairingPaths as d, resolveSkillCommandInvocation as i, rejectPendingPairingRequest as l, listSkillCommandsForAgents as n, ensureSkillsWatcher as o, listSkillCommandsForWorkspace as r, getSkillsSnapshotVersion as s, listReservedChatSlashCommandNames as t, pruneExpiredPending as u };