adam-agent-server 1.16.0 → 1.18.0

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/App-SIQUVFJY.js +14 -0
  2. package/dist/approval-handler-BWA7UIKN.js +1 -0
  3. package/dist/{artifacts-S2KD6W76.js → artifacts-MAYKOTA2.js} +1 -1
  4. package/dist/audit-diagnostics-K3LUWXTI.js +1 -0
  5. package/dist/audit-manager-6WL2V6JG.js +1 -0
  6. package/dist/bree-engine-KYD4GKQK.js +1 -0
  7. package/dist/channels-2TWTBE6Y.js +1 -0
  8. package/dist/channels-PWDSTYNR.js +1 -0
  9. package/dist/chat-tool-calls-WJDFQ54U.js +1 -0
  10. package/dist/chunk-2A2TXYT3.js +15 -0
  11. package/dist/chunk-2CE2WUUZ.js +1 -0
  12. package/dist/chunk-2JIQT2CI.js +1 -0
  13. package/dist/chunk-3MROEPGR.js +1 -0
  14. package/dist/chunk-3UFEOB6P.js +143 -0
  15. package/dist/{chunk-VKKDSXMR.js → chunk-47HJPIUA.js} +1 -1
  16. package/dist/{chunk-AQAHVNNG.js → chunk-4JHACUZY.js} +5 -5
  17. package/dist/{chunk-NUJSTEV4.js → chunk-4N5G7ND2.js} +1 -1
  18. package/dist/{chunk-TLMG5W3L.js → chunk-5G64P4KE.js} +1 -1
  19. package/dist/{chunk-245WE5AF.js → chunk-5M6IGE5G.js} +1 -1
  20. package/dist/chunk-5PELJRUQ.js +1 -0
  21. package/dist/{chunk-VVQ532U2.js → chunk-6WQFYV3N.js} +1 -1
  22. package/dist/{chunk-N2OLEUAQ.js → chunk-AUSR5JYV.js} +1 -1
  23. package/dist/{chunk-LVHLUAZW.js → chunk-BE653A45.js} +8 -7
  24. package/dist/{chunk-OXGWWSKT.js → chunk-BMCNQGUH.js} +1 -1
  25. package/dist/{chunk-BLCNUT53.js → chunk-EZLBMUQD.js} +1 -1
  26. package/dist/{chunk-NLTYJUQG.js → chunk-HL373H4P.js} +1 -1
  27. package/dist/{chunk-6Y2DN2UH.js → chunk-HRPMRWHD.js} +1 -1
  28. package/dist/{chunk-HJICGOD4.js → chunk-IEBAOZED.js} +2 -2
  29. package/dist/{chunk-SCUPWMI5.js → chunk-JROGEBP5.js} +1 -1
  30. package/dist/{chunk-LQVBWVLE.js → chunk-JYZTIE2J.js} +1 -1
  31. package/dist/{chunk-I44JKROJ.js → chunk-JZBXLN7M.js} +1 -1
  32. package/dist/{chunk-H4MMEULK.js → chunk-KS24764D.js} +2 -2
  33. package/dist/chunk-LCD5DVS6.js +1 -0
  34. package/dist/chunk-LKGYQJMS.js +6 -0
  35. package/dist/chunk-MTRLUW7Z.js +1 -0
  36. package/dist/{chunk-3UR2PN5N.js → chunk-NSUXJ2VA.js} +1 -1
  37. package/dist/{chunk-OGY42NUN.js → chunk-NUOTFUNF.js} +1 -1
  38. package/dist/chunk-NXGR3PRY.js +1 -0
  39. package/dist/{chunk-YNS5LQX5.js → chunk-O6L4UVLV.js} +1 -1
  40. package/dist/{chunk-FYULPPFR.js → chunk-OBD4245G.js} +1 -1
  41. package/dist/chunk-QTGAK62Z.js +14 -0
  42. package/dist/chunk-QYI44EP6.js +10 -0
  43. package/dist/{chunk-R24YRJRG.js → chunk-SGLZAIVL.js} +1 -1
  44. package/dist/chunk-SKHMWKJT.js +80 -0
  45. package/dist/chunk-T2Z2JDPY.js +2 -0
  46. package/dist/chunk-TA5PFK5C.js +5 -0
  47. package/dist/chunk-TWOJVEO7.js +32 -0
  48. package/dist/chunk-UCUELFCS.js +61 -0
  49. package/dist/{chunk-TJTH7LHX.js → chunk-V2MMQ3SH.js} +1 -1
  50. package/dist/{chunk-WBAPIPST.js → chunk-VO24C673.js} +1 -1
  51. package/dist/{chunk-HC34HJFF.js → chunk-VPMHZJS2.js} +1 -1
  52. package/dist/chunk-VWX2B6OM.js +6 -0
  53. package/dist/{chunk-QL2ZOLMC.js → chunk-WY5BOCQP.js} +180 -33
  54. package/dist/{chunk-TCBGUVVU.js → chunk-XAPJJAJQ.js} +1 -1
  55. package/dist/{chunk-HXDS4NWI.js → chunk-Z2APBKIT.js} +1 -1
  56. package/dist/chunk-ZJ3TS4FL.js +182 -0
  57. package/dist/{chunk-52FETPCI.js → chunk-ZQN6JZIJ.js} +1 -1
  58. package/dist/cli.js +2 -2
  59. package/dist/config-U624HJKI.js +1 -0
  60. package/dist/config-X7A6NA73.js +1 -0
  61. package/dist/db-XODNIJSJ.js +1 -0
  62. package/dist/{delivery-log-3O3OHKY4.js → delivery-log-QMQQHES4.js} +1 -1
  63. package/dist/engine-OQXDHA2R.js +1 -0
  64. package/dist/evolution-audit-XF4KZZMP.js +1 -0
  65. package/dist/execution-tools-BR4T4MMW.js +1 -0
  66. package/dist/{external-api-YMEFVZGG.js → external-api-435WH6V3.js} +1 -1
  67. package/dist/index.js +67 -47
  68. package/dist/learner-4CJ7BSCN.js +1 -0
  69. package/dist/logger-TEZSHFTZ.js +1 -0
  70. package/dist/{memories-2DY5G6ZN.js → memories-NJFKSOL5.js} +1 -1
  71. package/dist/memory-extractor-UQI75BBK.js +1 -0
  72. package/dist/memory-gc-NTZVUGJX.js +1 -0
  73. package/dist/memory-service-3RLVOF2C.js +1 -0
  74. package/dist/outbound-gateway-NJNSN2ZX.js +1 -0
  75. package/dist/presets-SUJRFRJC.js +1 -0
  76. package/dist/reflection-job-F4BZA2E3.js +23 -0
  77. package/dist/role-presets-VEYTGYA4.js +1 -0
  78. package/dist/role-workspace-AIVHPX5P.js +1 -0
  79. package/dist/roles-WDMUBWQP.js +1 -0
  80. package/dist/runtime-OMLPOMCA.js +1 -0
  81. package/dist/server-bus-6QGH2AVL.js +1 -0
  82. package/dist/session-manager-XFUKWEC7.js +1 -0
  83. package/dist/skill-registry-LARMNUT5.js +1 -0
  84. package/dist/target-resolution-RLNUCT6M.js +1 -0
  85. package/dist/{task-templates-4YPKFFKG.js → task-templates-BIVCRNXA.js} +1 -1
  86. package/dist/template-dispatch-6FPJQN6A.js +1 -0
  87. package/dist/trace-context-NVCN6UPC.js +1 -0
  88. package/package.json +2 -1
  89. package/web/dist/assets/{ArtifactDetail-9DJdEqCz.js → ArtifactDetail-DDTEAl2E.js} +2 -2
  90. package/web/dist/assets/{Artifacts-CQ6SAemH.js → Artifacts-BrhnC1Ef.js} +1 -1
  91. package/web/dist/assets/{Button-xVc-P0vm.js → Button-CRNb8sD3.js} +1 -1
  92. package/web/dist/assets/{Card-WUD1cwG6.js → Card-Cwvv0An8.js} +1 -1
  93. package/web/dist/assets/{ChannelDetail-B21nBQwi.js → ChannelDetail-D0FBZoAX.js} +1 -1
  94. package/web/dist/assets/{Channels-CAeGE1r7.js → Channels-Cztxvsa2.js} +2 -2
  95. package/web/dist/assets/{Chat-KpFWchPp.js → Chat-Ce72TtUi.js} +2 -2
  96. package/web/dist/assets/Cost-K8-4xqBe.js +4 -0
  97. package/web/dist/assets/{Dashboard-DkRwHNmr.js → Dashboard-BXqFb_Vr.js} +1 -1
  98. package/web/dist/assets/{EmptyState-BLB33cKG.js → EmptyState-BvQA1o5K.js} +1 -1
  99. package/web/dist/assets/{EnvVarEditor-BchUNrmz.js → EnvVarEditor-FiiJazzp.js} +1 -1
  100. package/web/dist/assets/{EventDefDetail-DnBwWWfT.js → EventDefDetail-C3S1G0K8.js} +1 -1
  101. package/web/dist/assets/{Events-ByIzPIs2.js → Events-BKxqZ9j6.js} +1 -1
  102. package/web/dist/assets/{Evolution-Vh9RKdma.js → Evolution-DFcSm6Rw.js} +1 -1
  103. package/web/dist/assets/{ExtensionDetail-0CtJh5rF.js → ExtensionDetail-C8aPpyLv.js} +1 -1
  104. package/web/dist/assets/Extensions-MLZk05j0.js +1 -0
  105. package/web/dist/assets/{FeatureRequests-XhQbGg_q.js → FeatureRequests-D_4XaQ7F.js} +1 -1
  106. package/web/dist/assets/{GoalDetail-DIOxf7ES.js → GoalDetail-DVU7c0aR.js} +1 -1
  107. package/web/dist/assets/{Goals-CZnHu9qC.js → Goals-D3h4WMjU.js} +1 -1
  108. package/web/dist/assets/LineChart-Ck1vfYHs.js +33 -0
  109. package/web/dist/assets/Logs-D5MQv6Yw.js +1 -0
  110. package/web/dist/assets/{Memories-D-EAODUg.js → Memories-Dls71I2i.js} +1 -1
  111. package/web/dist/assets/{Mistakes-wW78K3cP.js → Mistakes-BZcTg0vP.js} +1 -1
  112. package/web/dist/assets/{NotFound-BsxIP-Xm.js → NotFound-t66RIvqO.js} +1 -1
  113. package/web/dist/assets/{PageHeader-D8pqg_wk.js → PageHeader-acLQTYct.js} +1 -1
  114. package/web/dist/assets/Plugins-CwCHGzI6.js +1 -0
  115. package/web/dist/assets/RoleDetail-B2M6ALSl.js +3 -0
  116. package/web/dist/assets/Roles-FEHqm_Jf.js +1 -0
  117. package/web/dist/assets/{SectionHeader-DZo4QVWr.js → SectionHeader-NZWZgoOs.js} +1 -1
  118. package/web/dist/assets/Settings-rdVQMfqX.js +1 -0
  119. package/web/dist/assets/{Strategies-Bg4qlLei.js → Strategies-CwJ9JQ-X.js} +1 -1
  120. package/web/dist/assets/{Switch-WWPXnSOG.js → Switch-1JjR4Imr.js} +1 -1
  121. package/web/dist/assets/{Table-XjSmrOyn.js → Table-CvSmzzkm.js} +1 -1
  122. package/web/dist/assets/{Tabs-CSbcG_5T.js → Tabs-DWk9HyNd.js} +1 -1
  123. package/web/dist/assets/TaskDetail-h12WxjfG.js +2 -0
  124. package/web/dist/assets/Work-CfzFRSZX.js +1 -0
  125. package/web/dist/assets/api-BP4ZP9kk.js +1 -0
  126. package/web/dist/assets/{es2015-BgPT8VkR.js → es2015-BkFSNOYE.js} +1 -1
  127. package/web/dist/assets/index-CXEJd-0s.js +12 -0
  128. package/web/dist/assets/index-CarTGiGO.css +2 -0
  129. package/web/dist/assets/{useIsMobileLayout-DF2fEEM9.js → useIsMobileLayout-BogOiFTv.js} +1 -1
  130. package/web/dist/assets/{usePluginsWithUsage-CjU8Lkdn.js → usePluginsWithUsage-4iLJAPjH.js} +1 -1
  131. package/web/dist/assets/{vendor-icons-H7p0EuQJ.js → vendor-icons-Bc_e_XXa.js} +1 -1
  132. package/web/dist/assets/{vendor-react-C1yKjxEP.js → vendor-react-bQ_cvNuA.js} +1 -1
  133. package/web/dist/assets/{vendor-state-D0TNAbOY.js → vendor-state-BMVR_B0I.js} +1 -1
  134. package/web/dist/index.html +8 -8
  135. package/dist/App-Z2GJAMX3.js +0 -14
  136. package/dist/approval-handler-6NPN24UN.js +0 -1
  137. package/dist/audit-diagnostics-2MDM3IQT.js +0 -1
  138. package/dist/audit-manager-QG7CMBV2.js +0 -1
  139. package/dist/bree-engine-3QSLZF3W.js +0 -1
  140. package/dist/channels-S4AAOOTN.js +0 -1
  141. package/dist/channels-TYXSSI7D.js +0 -1
  142. package/dist/chat-tool-calls-2C7O4B2X.js +0 -1
  143. package/dist/chunk-32LOJEHE.js +0 -32
  144. package/dist/chunk-3UZIEE2D.js +0 -6
  145. package/dist/chunk-4234WJJD.js +0 -178
  146. package/dist/chunk-AG5SADAI.js +0 -5
  147. package/dist/chunk-ASPPM7TQ.js +0 -1
  148. package/dist/chunk-C2XFPUFV.js +0 -1
  149. package/dist/chunk-DRO3DG7X.js +0 -1
  150. package/dist/chunk-EWYXVBOG.js +0 -61
  151. package/dist/chunk-FCV2DPZQ.js +0 -1
  152. package/dist/chunk-FHESRUJY.js +0 -9
  153. package/dist/chunk-K2TZW4DU.js +0 -132
  154. package/dist/chunk-K4IE6DPX.js +0 -6
  155. package/dist/chunk-MNSZE3NV.js +0 -1
  156. package/dist/chunk-MTQI6B7T.js +0 -15
  157. package/dist/chunk-P5Q2UINT.js +0 -1
  158. package/dist/chunk-WVHN54MA.js +0 -14
  159. package/dist/chunk-XYZVMTNN.js +0 -1
  160. package/dist/chunk-Z6LHGA27.js +0 -1
  161. package/dist/config-HDAAV5FV.js +0 -1
  162. package/dist/config-VHWLMFIN.js +0 -1
  163. package/dist/db-HFBXO2O5.js +0 -1
  164. package/dist/dist-HCSYRPJU.js +0 -1
  165. package/dist/engine-J43ECCH7.js +0 -1
  166. package/dist/evolution-audit-BSGPFGFK.js +0 -1
  167. package/dist/execution-tools-HHUPWLCF.js +0 -1
  168. package/dist/learner-TQQZKRSB.js +0 -1
  169. package/dist/logger-PAMNFWI3.js +0 -1
  170. package/dist/memory-extractor-TUOOFST2.js +0 -1
  171. package/dist/memory-gc-MRO53MEY.js +0 -1
  172. package/dist/memory-service-23WVAW7T.js +0 -1
  173. package/dist/onnxruntime_binding-2BPLI7ZQ.node +0 -0
  174. package/dist/onnxruntime_binding-5J67DTMJ.node +0 -0
  175. package/dist/onnxruntime_binding-7ZZLEQ2F.node +0 -0
  176. package/dist/onnxruntime_binding-KDCXAPN5.node +0 -0
  177. package/dist/onnxruntime_binding-R73P2IQW.node +0 -0
  178. package/dist/outbound-gateway-VXODXSQR.js +0 -1
  179. package/dist/presets-KJV6SNNB.js +0 -1
  180. package/dist/reflection-job-EFFW3WOR.js +0 -23
  181. package/dist/role-presets-PHHL3OEN.js +0 -1
  182. package/dist/role-workspace-USY47ZPQ.js +0 -1
  183. package/dist/roles-3JXNHL7K.js +0 -1
  184. package/dist/runtime-TWLGJSL6.js +0 -1
  185. package/dist/server-bus-GEGVMSCA.js +0 -1
  186. package/dist/session-manager-PI3JEINK.js +0 -1
  187. package/dist/skill-registry-ROGU2WED.js +0 -1
  188. package/dist/target-resolution-PSSBM4LX.js +0 -1
  189. package/dist/template-dispatch-46TN534D.js +0 -1
  190. package/dist/trace-context-UR7DI5ME.js +0 -1
  191. package/web/dist/assets/Extensions--O1ulwlC.js +0 -1
  192. package/web/dist/assets/Logs-DdeG3GiY.js +0 -1
  193. package/web/dist/assets/Plugins-DDUdX51_.js +0 -1
  194. package/web/dist/assets/RoleDetail-CU3G9j_q.js +0 -35
  195. package/web/dist/assets/Roles-BCoSzDBg.js +0 -1
  196. package/web/dist/assets/Settings-K3usfV-2.js +0 -1
  197. package/web/dist/assets/TaskDetail-C5roukcV.js +0 -2
  198. package/web/dist/assets/Work-DGTWSgtc.js +0 -1
  199. package/web/dist/assets/api-BkdixMz9.js +0 -1
  200. package/web/dist/assets/index-KNUbHDLy.css +0 -2
  201. package/web/dist/assets/index-iD-HOtIu.js +0 -12
@@ -1,3 +1,3 @@
1
- import{c as a}from"./chunk-VVQ532U2.js";import{b as m}from"./chunk-AG5SADAI.js";import{a as d,d as f}from"./chunk-FYULPPFR.js";import{a as s}from"./chunk-ASPPM7TQ.js";import{d as p}from"./chunk-Z6LHGA27.js";import{c,h as g}from"./chunk-BLCNUT53.js";function k(e,n,i){switch(n){case"wechat":return l(e);case"telegram":return e;case"slack":return w(e);case"email":return e;case"webhook":return JSON.stringify({result:e,taskId:i,timestamp:new Date().toISOString()});default:return l(e)}}function l(e){return e.replace(/^#{1,6}\s+/gm,"").replace(/\*\*(.+?)\*\*/g,"$1").replace(/\*(.+?)\*/g,"$1").replace(/__(.+?)__/g,"$1").replace(/_(.+?)_/g,"$1").replace(/`([^`]+)`/g,"$1").replace(/```[\s\S]*?```/g,n=>n.replace(/```\w*\n?/g,"").trim()).replace(/\[([^\]]+)\]\([^)]+\)/g,"$1").replace(/!\[([^\]]*)\]\([^)]+\)/g,"$1").replace(/\n{3,}/g,`
1
+ import{b as m}from"./chunk-TA5PFK5C.js";import{a as d,d as f}from"./chunk-OBD4245G.js";import{c as a}from"./chunk-6WQFYV3N.js";import{a as s}from"./chunk-NXGR3PRY.js";import{e as p}from"./chunk-3MROEPGR.js";import{c,h as g}from"./chunk-EZLBMUQD.js";function k(e,n,i){switch(n){case"wechat":return l(e);case"telegram":return e;case"slack":return w(e);case"email":return e;case"webhook":return JSON.stringify({result:e,taskId:i,timestamp:new Date().toISOString()});default:return l(e)}}function l(e){return e.replace(/^#{1,6}\s+/gm,"").replace(/\*\*(.+?)\*\*/g,"$1").replace(/\*(.+?)\*/g,"$1").replace(/__(.+?)__/g,"$1").replace(/_(.+?)_/g,"$1").replace(/`([^`]+)`/g,"$1").replace(/```[\s\S]*?```/g,n=>n.replace(/```\w*\n?/g,"").trim()).replace(/\[([^\]]+)\]\([^)]+\)/g,"$1").replace(/!\[([^\]]*)\]\([^)]+\)/g,"$1").replace(/\n{3,}/g,`
2
2
 
3
3
  `).trim()}function w(e){return e.replace(/\*\*(.+?)\*\*/g,"*$1*").replace(/\[([^\]]+)\]\(([^)]+)\)/g,"<$2|$1>")}f();g();var t=c("message-handler");function x(){try{let e=p().identity?.ownerViewerKey;if(typeof e=="string"&&e.trim().length>0)return e}catch{}return s.identity?.ownerViewerKey??"local-owner"}function u(e){if(e.type==="web"||e.type==="tui"||e.type==="api")return x();if(e.type!=="channel"||!e.channelId){t.warn({source:e},"Viewer identity unavailable for chat source"),r("chat source has no resolvable viewer identity",void 0);return}let i=a(e.channelId)?.viewerKey;if(typeof i=="string"&&i.trim().length>0)return i;t.warn({channelId:e.channelId},"Channel viewerKey missing; recent delivery context disabled"),r("channel viewerKey missing; recent delivery context disabled",e.channelId)}function E(e){if(e.type==="channel"){let o=a(e.channelId)?.viewerKey;if(typeof o=="string"&&o.trim().length>0)return o;t.warn({channelId:e.channelId},"Channel viewerKey missing; ledger recording skipped"),r("channel viewerKey missing; ledger recording skipped",e.channelId);return}let n=m(e.sessionId);if(!n){t.warn({sessionId:e.sessionId},"Session target missing; ledger recording skipped"),r("session target missing; ledger recording skipped",e.sessionId);return}return u(n.source)}function r(e,n){try{d({source:"viewer_identity",severity:"warning",sourceId:n,message:e})}catch{}}import v from"path";var h={".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".txt":"text/plain",".csv":"text/csv",".zip":"application/zip",".tar":"application/x-tar",".gz":"application/gzip",".mp3":"audio/mpeg",".ogg":"audio/ogg",".wav":"audio/wav",".amr":"audio/amr",".silk":"audio/x-silk",".md":"text/markdown",".html":"text/html",".json":"application/json",".xml":"text/xml",".mp4":"video/mp4",".mov":"video/quicktime",".webm":"video/webm",".mkv":"video/x-matroska",".avi":"video/x-msvideo",".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp",".bmp":"image/bmp"},y={"image/jpeg":".jpg","image/jpg":".jpg","image/png":".png","image/gif":".gif","image/webp":".webp","image/bmp":".bmp","video/mp4":".mp4","video/quicktime":".mov","video/webm":".webm","video/x-matroska":".mkv","video/x-msvideo":".avi","audio/mpeg":".mp3","audio/ogg":".ogg","audio/wav":".wav","audio/amr":".amr","audio/x-silk":".silk","application/pdf":".pdf","application/zip":".zip","application/x-tar":".tar","application/gzip":".gz","text/plain":".txt","text/csv":".csv","text/markdown":".md","audio/mp3":".mp3","text/html":".html","application/json":".json","application/xml":".xml","text/xml":".xml","application/vnd.openxmlformats-officedocument.wordprocessingml.document":".docx","application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":".xlsx","application/vnd.openxmlformats-officedocument.presentationml.presentation":".pptx","application/msword":".doc","application/vnd.ms-excel":".xls","application/vnd.ms-powerpoint":".ppt"};function $(e){let n=v.extname(e).toLowerCase();return h[n]??"application/octet-stream"}function F(e){let n=e.split(";")[0].trim().toLowerCase();return y[n]??".bin"}export{k as a,l as b,x as c,u as d,E as e,$ as f,F as g};
@@ -1,4 +1,4 @@
1
- import{n,p as o}from"./chunk-QL2ZOLMC.js";import{c as r,e as c}from"./chunk-245WE5AF.js";o();c();function a(e){return{id:e.id,sessionId:e.session_id,role:e.role,content:e.content,source:{type:e.source_type,...e.source_channel_id?{channelId:e.source_channel_id}:{},...e.source_chat_id?{chatId:e.source_chat_id}:{}},taskId:e.task_id??void 0,channelMessageId:e.channel_message_id??void 0,metadata:e.metadata?JSON.parse(e.metadata):void 0,createdAt:e.created_at,traceId:e.trace_id??void 0,kind:e.kind??void 0,parentMessageId:e.parent_message_id??void 0,threadRoot:e.thread_root??void 0,promptId:e.prompt_id??void 0,approvalShape:e.approval_shape??void 0,roleId:e.role_id??void 0,attachments:e.attachments?JSON.parse(e.attachments):void 0,mirroredToTargets:e.mirrored_to_targets?JSON.parse(e.mirrored_to_targets):void 0,platformMessageId:e.platform_message_id??void 0,seq:e.seq??void 0}}function p(e){let s=n(),t=e.kind??(e.role==="user"?"user_message":"assistant_text");s.prepare(`
1
+ import{n,p as o}from"./chunk-WY5BOCQP.js";import{c as r,e as c}from"./chunk-5M6IGE5G.js";o();c();function a(e){return{id:e.id,sessionId:e.session_id,role:e.role,content:e.content,source:{type:e.source_type,...e.source_channel_id?{channelId:e.source_channel_id}:{},...e.source_chat_id?{chatId:e.source_chat_id}:{}},taskId:e.task_id??void 0,channelMessageId:e.channel_message_id??void 0,metadata:e.metadata?JSON.parse(e.metadata):void 0,createdAt:e.created_at,traceId:e.trace_id??void 0,kind:e.kind??void 0,parentMessageId:e.parent_message_id??void 0,threadRoot:e.thread_root??void 0,promptId:e.prompt_id??void 0,approvalShape:e.approval_shape??void 0,roleId:e.role_id??void 0,attachments:e.attachments?JSON.parse(e.attachments):void 0,mirroredToTargets:e.mirrored_to_targets?JSON.parse(e.mirrored_to_targets):void 0,platformMessageId:e.platform_message_id??void 0,seq:e.seq??void 0}}function p(e){let s=n(),t=e.kind??(e.role==="user"?"user_message":"assistant_text");s.prepare(`
2
2
  INSERT INTO chat_messages (
3
3
  id, session_id, role, content, source_type, task_id,
4
4
  channel_message_id, metadata, created_at, trace_id,
@@ -12,4 +12,4 @@ import{n,p as o}from"./chunk-QL2ZOLMC.js";import{c as r,e as c}from"./chunk-245W
12
12
  JOIN chat_sessions s ON m.session_id = s.id
13
13
  WHERE s.source_type = 'channel' AND s.source_channel_id = ?
14
14
  ORDER BY m.created_at DESC LIMIT ? OFFSET ?
15
- `).all(e,s,t).map(a)}function M(e){let t=n().prepare("SELECT * FROM chat_messages WHERE platform_message_id = ? ORDER BY created_at DESC LIMIT 1").get(e);return t?a(t):void 0}function R(e){return n().prepare("SELECT * FROM chat_messages WHERE prompt_id = ? ORDER BY created_at ASC").all(e).map(a)}function I(e,s){n().prepare("UPDATE chat_messages SET prompt_id = ? WHERE id = ?").run(s,e)}export{p as a,_ as b,g as c,h as d,E as e,m as f,f as g,M as h,R as i,I as j};
15
+ `).all(e,s,t).map(a)}function M(e){let t=n().prepare("SELECT * FROM chat_messages WHERE platform_message_id = ? ORDER BY created_at DESC LIMIT 1").get(e);return t?a(t):void 0}function R(e){return n().prepare("SELECT * FROM chat_messages WHERE prompt_id = ? ORDER BY created_at ASC").all(e).map(a)}function I(e,s){n().prepare("UPDATE chat_messages SET prompt_id = ? WHERE id = ?").run(s,e)}function S(e,s){n().prepare("UPDATE chat_messages SET cost_usd = ?, token_usage = ?, model = ? WHERE id = ?").run(s.costUsd,s.tokenUsage,s.model,e)}export{p as a,_ as b,g as c,h as d,E as e,m as f,f as g,M as h,R as i,I as j,S as k};
@@ -1,4 +1,4 @@
1
- import{g as y}from"./chunk-32LOJEHE.js";import{c as m}from"./chunk-VVQ532U2.js";import{c as h,h as w}from"./chunk-BLCNUT53.js";w();var v="",I=Buffer.alloc(0);function O(o){v=o,I=Buffer.from(o)}function g(){return v}function C(){return I}var p=h("channels"),u=new Map,x=3e5,$=new Set(["telegram"]);function T(o){let e=o.trim().toLowerCase().match(/^(yes|y|是|允许|no|n|否|拒绝)\s+(\S+)$/);if(!e)return null;let[,c,l]=e,r=["yes","y","\u662F","\u5141\u8BB8"].includes(c);return{requestId:l,decision:r?"allow":"deny"}}function P(o){let n=m(o);return n?$.has(n.platform):!1}var b={low:"\u{1F7E2}",medium:"\u{1F7E1}",high:"\u{1F534}"},k={low:"\u4F4E",medium:"\u4E2D",high:"\u9AD8"};function _(o){let n=["\u{1F512} \u9700\u8981\u5BA1\u6279",""];for(let e of o.steps){if(e.description.startsWith("Execute task without OS sandbox"))n.push("\u26A0\uFE0F \u65E0\u6C99\u7BB1\u6267\u884C \u2014 \u6587\u4EF6\u7CFB\u7EDF\u9694\u79BB\u672A\u542F\u7528");else{let r=e.description.indexOf(": "),s=r>0?e.description.slice(0,r):"Operation";if(n.push(`\u64CD\u4F5C: ${s}`),s==="Bash"&&r>0)try{let t=JSON.parse(e.description.slice(r+2));if(t.command){let i=String(t.command).trim();n.push(`\u547D\u4EE4: ${i.length>120?i.slice(0,117)+"...":i}`)}}catch{let t=e.description.slice(r+2,r+122);n.push(`\u8BE6\u60C5: ${t}${e.description.length>r+122?"...":""}`)}else if(r>0){let t=e.description.slice(r+2,r+122);n.push(`\u8BE6\u60C5: ${t}${e.description.length>r+122?"...":""}`)}}let c=b[e.riskLevel]??"\u{1F7E1}",l=k[e.riskLevel]??e.riskLevel;n.push(`\u98CE\u9669: ${c} ${l}`),n.push("")}return n.join(`
1
+ import{g as y}from"./chunk-TWOJVEO7.js";import{c as m}from"./chunk-6WQFYV3N.js";import{c as h,h as w}from"./chunk-EZLBMUQD.js";w();var v="",I=Buffer.alloc(0);function O(o){v=o,I=Buffer.from(o)}function g(){return v}function C(){return I}var p=h("channels"),u=new Map,x=3e5,$=new Set(["telegram"]);function T(o){let e=o.trim().toLowerCase().match(/^(yes|y|是|允许|no|n|否|拒绝)\s+(\S+)$/);if(!e)return null;let[,c,l]=e,r=["yes","y","\u662F","\u5141\u8BB8"].includes(c);return{requestId:l,decision:r?"allow":"deny"}}function P(o){let n=m(o);return n?$.has(n.platform):!1}var b={low:"\u{1F7E2}",medium:"\u{1F7E1}",high:"\u{1F534}"},k={low:"\u4F4E",medium:"\u4E2D",high:"\u9AD8"};function _(o){let n=["\u{1F512} \u9700\u8981\u5BA1\u6279",""];for(let e of o.steps){if(e.description.startsWith("Execute task without OS sandbox"))n.push("\u26A0\uFE0F \u65E0\u6C99\u7BB1\u6267\u884C \u2014 \u6587\u4EF6\u7CFB\u7EDF\u9694\u79BB\u672A\u542F\u7528");else{let r=e.description.indexOf(": "),s=r>0?e.description.slice(0,r):"Operation";if(n.push(`\u64CD\u4F5C: ${s}`),s==="Bash"&&r>0)try{let t=JSON.parse(e.description.slice(r+2));if(t.command){let i=String(t.command).trim();n.push(`\u547D\u4EE4: ${i.length>120?i.slice(0,117)+"...":i}`)}}catch{let t=e.description.slice(r+2,r+122);n.push(`\u8BE6\u60C5: ${t}${e.description.length>r+122?"...":""}`)}else if(r>0){let t=e.description.slice(r+2,r+122);n.push(`\u8BE6\u60C5: ${t}${e.description.length>r+122?"...":""}`)}}let c=b[e.riskLevel]??"\u{1F7E1}",l=k[e.riskLevel]??e.riskLevel;n.push(`\u98CE\u9669: ${c} ${l}`),n.push("")}return n.join(`
2
2
  `).trimEnd()}async function q(o,n,e,c,l,r=x){let s=e,t=s.slice(0,8);u.set(t,{planId:e,taskId:c,channelId:o,chatId:n,requestId:s,timestamp:Date.now(),timeoutMs:r});let i=y(),d=P(o);if(d){let a=`${l}
3
3
 
4
4
  `;await i.send({channelId:o,chatId:n,content:a,messageType:"approval",replyMarkup:{inlineKeyboard:[[{text:"\u2705 Allow",callbackData:`yes ${t}`},{text:"\u274C Deny",callbackData:`no ${t}`}]]}})}else{let a=[l,"",`Reply 'yes ${t}' or 'no ${t}'`].join(`
@@ -1,4 +1,4 @@
1
- import{n as s,p as d}from"./chunk-QL2ZOLMC.js";import{c as l,e as u}from"./chunk-245WE5AF.js";d();u();function a(e){return{id:e.id,ruleId:e.rule_id??void 0,taskId:e.task_id??void 0,executionId:e.execution_id??void 0,status:e.status,target:JSON.parse(e.target),content:e.content,attempts:e.attempts,error:e.error??void 0,createdAt:e.created_at,deliveredAt:e.delivered_at??void 0,expiresAt:e.expires_at,source:e.source,messageType:e.message_type??void 0,traceId:e.trace_id??void 0}}var g=1440*60*1e3;function E(e){s().prepare(`
1
+ import{n as s,p as d}from"./chunk-WY5BOCQP.js";import{c as l,e as u}from"./chunk-5M6IGE5G.js";d();u();function a(e){return{id:e.id,ruleId:e.rule_id??void 0,taskId:e.task_id??void 0,executionId:e.execution_id??void 0,status:e.status,target:JSON.parse(e.target),content:e.content,attempts:e.attempts,error:e.error??void 0,createdAt:e.created_at,deliveredAt:e.delivered_at??void 0,expiresAt:e.expires_at,source:e.source,messageType:e.message_type??void 0,traceId:e.trace_id??void 0}}var g=1440*60*1e3;function E(e){s().prepare(`
2
2
  INSERT INTO delivery_log (id, rule_id, task_id, execution_id, status, target, content,
3
3
  attempts, error, created_at, delivered_at, expires_at, source, message_type, trace_id)
4
4
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
@@ -1,2 +1,2 @@
1
- import{n as e,p as s}from"./chunk-QL2ZOLMC.js";s();import{v4 as u}from"uuid";var r,a;function i(){return r||(r=e().prepare(`INSERT INTO chat_tool_calls (id, trace_id, session_id, tool_name, tool_input_json, tool_output_summary, called_at)
1
+ import{n as e,p as s}from"./chunk-WY5BOCQP.js";s();import{v4 as u}from"uuid";var r,a;function i(){return r||(r=e().prepare(`INSERT INTO chat_tool_calls (id, trace_id, session_id, tool_name, tool_input_json, tool_output_summary, called_at)
2
2
  VALUES (?, ?, ?, ?, ?, ?, ?)`)),r}function d(){return a||(a=e().prepare("SELECT * FROM chat_tool_calls WHERE trace_id = ? ORDER BY called_at ASC")),a}function I(t){let o=u(),n=t.calledAt??Date.now(),l=t.toolInput!==void 0?JSON.stringify(t.toolInput):null;return i().run(o,t.traceId,t.sessionId??null,t.toolName,l,t.toolOutputSummary??null,n),{id:o,traceId:t.traceId,sessionId:t.sessionId,toolName:t.toolName,toolInput:t.toolInput,toolOutputSummary:t.toolOutputSummary,calledAt:n}}function g(t){return d().all(t).map(n=>({id:n.id,traceId:n.trace_id,sessionId:n.session_id??void 0,toolName:n.tool_name,toolInput:n.tool_input_json?c(n.tool_input_json):void 0,toolOutputSummary:n.tool_output_summary??void 0,calledAt:n.called_at}))}function f(t,o){if(o.length===0)return!1;let l=`SELECT 1 FROM chat_tool_calls WHERE trace_id = ? AND tool_name IN (${o.map(()=>"?").join(",")}) LIMIT 1`;return e().prepare(l).get(t,...o)!==void 0}function c(t){try{return JSON.parse(t)}catch{return}}export{I as a,g as b,f as c};
@@ -1,8 +1,8 @@
1
- import{d as D}from"./chunk-SCUPWMI5.js";import{a as b}from"./chunk-NUJSTEV4.js";import{f as v}from"./chunk-HJICGOD4.js";import{g as O}from"./chunk-32LOJEHE.js";import{a as S,b as P,c,d as I,e as w,f as C,g as M}from"./chunk-LQVBWVLE.js";import{c as x}from"./chunk-VVQ532U2.js";import{b as y}from"./chunk-AG5SADAI.js";import{b as R}from"./chunk-AQAHVNNG.js";import{s as k}from"./chunk-K4IE6DPX.js";import{a as f}from"./chunk-L7JP7DUO.js";import{b as h,o as B}from"./chunk-MTQI6B7T.js";import{n as d,p as j}from"./chunk-QL2ZOLMC.js";import{c as E,h as N}from"./chunk-BLCNUT53.js";j();function L(i){return{id:i.id,eventType:i.event_type,matchCriteria:JSON.parse(i.match_criteria),target:JSON.parse(i.target),formatTemplate:i.format_template??void 0,maxPerMinute:i.max_per_minute,skipOriginChannel:i.skip_origin_channel===1,enabled:i.enabled===1,createdAt:i.created_at,createdBy:i.created_by??void 0}}function q(i){d().prepare(`
1
+ import{d as D}from"./chunk-JROGEBP5.js";import{a as b}from"./chunk-4N5G7ND2.js";import{f as v}from"./chunk-IEBAOZED.js";import{g as O}from"./chunk-TWOJVEO7.js";import{a as S,b as P,c,d as I,e as w,f as C,g as M}from"./chunk-JYZTIE2J.js";import{b as y}from"./chunk-TA5PFK5C.js";import{b as R}from"./chunk-4JHACUZY.js";import{s as k}from"./chunk-VWX2B6OM.js";import{a as f}from"./chunk-L7JP7DUO.js";import{b as h,p as B}from"./chunk-2A2TXYT3.js";import{c as x}from"./chunk-6WQFYV3N.js";import{n as d,p as j}from"./chunk-WY5BOCQP.js";import{c as E,h as N}from"./chunk-EZLBMUQD.js";j();function L(i){return{id:i.id,eventType:i.event_type,matchCriteria:JSON.parse(i.match_criteria),target:JSON.parse(i.target),formatTemplate:i.format_template??void 0,maxPerMinute:i.max_per_minute,skipOriginChannel:i.skip_origin_channel===1,enabled:i.enabled===1,createdAt:i.created_at,createdBy:i.created_by??void 0}}function q(i){d().prepare(`
2
2
  INSERT INTO delivery_rules (id, event_type, match_criteria, target, format_template,
3
3
  max_per_minute, skip_origin_channel, enabled, created_at, created_by)
4
4
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
5
- `).run(i.id,i.eventType,JSON.stringify(i.matchCriteria),JSON.stringify(i.target),i.formatTemplate??null,i.maxPerMinute,i.skipOriginChannel?1:0,i.enabled?1:0,i.createdAt,i.createdBy??null)}function H(i){let n=d().prepare("SELECT * FROM delivery_rules WHERE id = ?").get(i);return n?L(n):void 0}function W(i){let e=d(),n="SELECT * FROM delivery_rules",r=[];return i!==void 0&&(n+=" WHERE enabled = ?",r.push(i?1:0)),n+=" ORDER BY created_at DESC",e.prepare(n).all(...r).map(L)}function U(i,e){let n=d(),r=[],t=[];e.eventType!==void 0&&(r.push("event_type = ?"),t.push(e.eventType)),e.matchCriteria!==void 0&&(r.push("match_criteria = ?"),t.push(JSON.stringify(e.matchCriteria))),e.target!==void 0&&(r.push("target = ?"),t.push(JSON.stringify(e.target))),e.formatTemplate!==void 0&&(r.push("format_template = ?"),t.push(e.formatTemplate)),e.maxPerMinute!==void 0&&(r.push("max_per_minute = ?"),t.push(e.maxPerMinute)),e.skipOriginChannel!==void 0&&(r.push("skip_origin_channel = ?"),t.push(e.skipOriginChannel?1:0)),e.enabled!==void 0&&(r.push("enabled = ?"),t.push(e.enabled?1:0)),r.length!==0&&(t.push(i),n.prepare(`UPDATE delivery_rules SET ${r.join(", ")} WHERE id = ?`).run(...t))}function G(i){let e=d();e.prepare("DELETE FROM delivery_log WHERE rule_id = ?").run(i),e.prepare("DELETE FROM delivery_rules WHERE id = ?").run(i)}function A(i,e){return W(!0).filter(r=>{if(r.eventType!=="*"&&r.eventType!==i)return!1;let t=r.matchCriteria;if(t.templateId&&t.templateId!==e.templateId||t.roleId&&t.roleId!==e.roleId||t.taskStatus&&t.taskStatus!==e.taskStatus)return!1;if(t.promptPattern)try{if(!new RegExp(t.promptPattern,"i").test(e.prompt??""))return!1}catch{return!1}if(t.excludePromptPatterns&&t.excludePromptPatterns.length>0){let a=e.prompt??"";for(let s of t.excludePromptPatterns)if(!(typeof s!="string"||s.length>200))try{if(new RegExp(s,"i").test(a))return!1}catch{continue}}return!0})}B();N();import{v4 as J}from"uuid";function F(i){return!!(i.templateId&&i.stepId&&i.parentId)}var l=E("admin"),_=new Map,m=null,g=null,u=null,T=class{constructor(){f.on("task_status_change",e=>{(e.newStatus==="completed"||e.newStatus==="failed")&&this.handleTaskStatusChange(e.taskId,e.newStatus).catch(n=>{l.error({taskId:e.taskId,error:n},"Delivery processing failed")})}),f.on("plan_approval_request",e=>{this.handlePlanApprovalRequest(e.taskId,e.planId,e.plan).catch(n=>{l.error({taskId:e.taskId,error:n},"Delivery processing failed (plan_approval)")})}),f.on("template_execution_status_change",e=>{e.status==="failed"&&this.handleTemplateExecutionFailure(e.executionId,e.templateId).catch(n=>{l.error({executionId:e.executionId,error:n},"Template failure delivery processing failed")})}),l.info("DeliveryEngine initialized")}async handlePlanApprovalRequest(e,n,r){let t=h(e),a=this.getSourceChannelForTask(e);if(a){let o=D(r),{sendApprovalToChannel:p}=await import("./approval-handler-6NPN24UN.js");await p(a.channelId,a.chatId,n,e,o)}let s=D(r)+`
5
+ `).run(i.id,i.eventType,JSON.stringify(i.matchCriteria),JSON.stringify(i.target),i.formatTemplate??null,i.maxPerMinute,i.skipOriginChannel?1:0,i.enabled?1:0,i.createdAt,i.createdBy??null)}function H(i){let n=d().prepare("SELECT * FROM delivery_rules WHERE id = ?").get(i);return n?L(n):void 0}function W(i){let e=d(),n="SELECT * FROM delivery_rules",r=[];return i!==void 0&&(n+=" WHERE enabled = ?",r.push(i?1:0)),n+=" ORDER BY created_at DESC",e.prepare(n).all(...r).map(L)}function U(i,e){let n=d(),r=[],t=[];e.eventType!==void 0&&(r.push("event_type = ?"),t.push(e.eventType)),e.matchCriteria!==void 0&&(r.push("match_criteria = ?"),t.push(JSON.stringify(e.matchCriteria))),e.target!==void 0&&(r.push("target = ?"),t.push(JSON.stringify(e.target))),e.formatTemplate!==void 0&&(r.push("format_template = ?"),t.push(e.formatTemplate)),e.maxPerMinute!==void 0&&(r.push("max_per_minute = ?"),t.push(e.maxPerMinute)),e.skipOriginChannel!==void 0&&(r.push("skip_origin_channel = ?"),t.push(e.skipOriginChannel?1:0)),e.enabled!==void 0&&(r.push("enabled = ?"),t.push(e.enabled?1:0)),r.length!==0&&(t.push(i),n.prepare(`UPDATE delivery_rules SET ${r.join(", ")} WHERE id = ?`).run(...t))}function G(i){let e=d();e.prepare("DELETE FROM delivery_log WHERE rule_id = ?").run(i),e.prepare("DELETE FROM delivery_rules WHERE id = ?").run(i)}function A(i,e){return W(!0).filter(r=>{if(r.eventType!=="*"&&r.eventType!==i)return!1;let t=r.matchCriteria;if(t.templateId&&t.templateId!==e.templateId||t.roleId&&t.roleId!==e.roleId||t.taskStatus&&t.taskStatus!==e.taskStatus)return!1;if(t.promptPattern)try{if(!new RegExp(t.promptPattern,"i").test(e.prompt??""))return!1}catch{return!1}if(t.excludePromptPatterns&&t.excludePromptPatterns.length>0){let a=e.prompt??"";for(let s of t.excludePromptPatterns)if(!(typeof s!="string"||s.length>200))try{if(new RegExp(s,"i").test(a))return!1}catch{continue}}return!0})}B();N();import{v4 as J}from"uuid";function F(i){return!!(i.templateId&&i.stepId&&i.parentId)}var l=E("admin"),_=new Map,m=null,g=null,u=null,T=class{constructor(){f.on("task_status_change",e=>{(e.newStatus==="completed"||e.newStatus==="failed")&&this.handleTaskStatusChange(e.taskId,e.newStatus).catch(n=>{l.error({taskId:e.taskId,error:n},"Delivery processing failed")})}),f.on("plan_approval_request",e=>{this.handlePlanApprovalRequest(e.taskId,e.planId,e.plan).catch(n=>{l.error({taskId:e.taskId,error:n},"Delivery processing failed (plan_approval)")})}),f.on("template_execution_status_change",e=>{e.status==="failed"&&this.handleTemplateExecutionFailure(e.executionId,e.templateId).catch(n=>{l.error({executionId:e.executionId,error:n},"Template failure delivery processing failed")})}),l.info("DeliveryEngine initialized")}async handlePlanApprovalRequest(e,n,r){let t=h(e),a=this.getSourceChannelForTask(e);if(a){let o=D(r),{sendApprovalToChannel:p}=await import("./approval-handler-BWA7UIKN.js");await p(a.channelId,a.chatId,n,e,o)}let s=D(r)+`
6
6
 
7
7
  Task: ${e}`;await this.matchAndDeliver("plan_approval_request",{templateId:t?.templateId,roleId:t?.roleId,prompt:t?.prompt,taskStatus:"pending"},s,e)}async handleTemplateExecutionFailure(e,n){let r=R(e),t=n?k(n):null,a=r?Object.entries(r.stepStatuses).filter(([,o])=>o.status==="failed"):[],s=["\u26A0\uFE0F TemplateExecution failed",`Template: ${t?.name??n}`,`Execution: ${e}`,`Failed steps: ${a.map(([o])=>o).join(", ")||"(unknown \u2014 no failed step recorded)"}`,a[0]?.[1]?.error?`
8
8
  First error: ${a[0][1].error.slice(0,300)}`:""].filter(Boolean).join(`
@@ -0,0 +1 @@
1
+ import{e as A,i as J}from"./chunk-NSUXJ2VA.js";import{A as D,w as v}from"./chunk-2A2TXYT3.js";import{existsSync as m,readFileSync as P,readdirSync as w}from"fs";import{join as d}from"path";import E from"os";var b=()=>d(E.homedir(),".claude","plugins"),S=()=>d(b(),"installed_plugins.json"),_=()=>d(b(),"known_marketplaces.json"),x=()=>d(E.homedir(),".claude","settings.json");function y(s){try{if(!m(s))return null;let i=P(s,"utf-8");return JSON.parse(i)}catch{return null}}function R(){return y(x())?.enabledPlugins??{}}function T(s){let i=s;function l(t,p){let a={};try{if(!m(t))return a;let u=P(t,"utf-8").replace(/^```yaml\r?\n/,"").replace(/^```\r?\n/,"");for(let f of p){let r=new RegExp(`^${f}:\\s*(.+)$`,"m"),e=u.match(r);e&&(a[f]=e[1].trim())}}catch{}return a}function o(t){try{if(!m(t))return{};let p=P(t,"utf-8"),a=p.match(/^```yaml\r?\n([\s\S]*?)\r?\n```\r?\n/);if(!a){let r={};for(let e of p.split(/\r?\n/)){let n=e.match(/^(\w+):\s*(.+)$/);n&&(r[n[1]]=n[2])}return{name:r.name,description:r.description}}let c=a[1],u={};for(let r of c.split(/\r?\n/)){let e=r.match(/^(\w+):\s*(.*)$/);if(e){let[,n,g]=e;g.trim()&&(u[n]=g.trim())}}let f=c.match(/error_patterns:\r?\n([\s\S]*?)(?=\n\w|\n$)/);if(f){let r=f[1],e=[],n={};for(let g of r.split(/\r?\n/)){let h=g.match(/^\s*-\s*pattern:\s*(.+)$/);if(h){n.pattern&&e.push(n),n={pattern:h[1].replace(/^["']|["']$/g,"")};continue}let k=g.match(/^\s*category:\s*(.+)$/);if(k){n.category=k[1].trim();continue}let j=g.match(/^\s*user_action:\s*(.+)$/);if(j){n.user_action=j[1].replace(/^["']|["']$/g,""),n.pattern&&n.category&&n.user_action&&(e.push(n),n={});continue}}n.pattern&&e.push(n),e.length>0&&(u.error_patterns=e)}return{name:u.name,description:u.description,error_patterns:u.error_patterns}}catch{}return{}}try{let t={name:"",skills:[],agents:[],mcpServers:[],hooks:[],lspServers:[]},p=d(i,".claude-plugin","plugin.json");if(m(p))try{let r=JSON.parse(P(p,"utf-8"));t.name=r.name??"",t.version=r.version,t.description=r.description,Array.isArray(r.lspServers)&&(t.lspServers=r.lspServers),Array.isArray(r.mcpServers)&&(t.mcpServers=r.mcpServers),Array.isArray(r.hooks)&&(t.hooks=r.hooks)}catch{}let a=d(i,"skills");if(m(a)){let r=w(a,{withFileTypes:!0});for(let e of r){if(!e.isDirectory()&&!e.isSymbolicLink())continue;let n=d(a,e.name,"SKILL.md"),g=o(n);g.name&&t.skills.push({name:g.name,description:g.description??"",error_patterns:g.error_patterns})}}let c=d(i,"agents");if(m(c)){let r=w(c,{withFileTypes:!0});for(let e of r){if(!e.isFile()||!e.name.endsWith(".md"))continue;let n=l(d(c,e.name),["name","description"]);n.name&&t.agents.push({name:n.name,description:n.description??""})}}let u=d(i,".mcp.json");if(m(u))try{let r=JSON.parse(P(u,"utf-8"));r.mcpServers&&typeof r.mcpServers=="object"&&(t.mcpServers=Object.keys(r.mcpServers))}catch{}let f=d(i,"hooks","hooks.json");if(m(f))try{let r=JSON.parse(P(f,"utf-8"));Array.isArray(r)&&(t.hooks=r.map(e=>typeof e=="object"&&e!==null&&"event"in e?String(e.event):String(e)))}catch{}return t}catch{return null}}function $(s){let i=y(S());if(!i?.plugins)return[];let l=R(),o=[];for(let[t,p]of Object.entries(i.plugins))if(!(!Array.isArray(p)||p.length===0))for(let a of p){let c=a.scope??"user";s?.scope&&c!==s.scope||s?.projectPath&&a.projectPath!==s.projectPath||o.push({id:t,name:t.split("@")[0],version:a.version??"",scope:c,projectPath:a.projectPath,installPath:a.installPath??d(b(),t),enabled:l[t]??a.enabled??!0,installedAt:a.installedAt??"",lastUpdated:a.lastUpdated??""})}return o}function G(s){let i=y(S());if(!i?.plugins?.[s])return null;let l=i.plugins[s];if(!Array.isArray(l)||l.length===0)return null;let o=l[0],t=R();return{id:s,name:s.split("@")[0],version:o.version??"",scope:o.scope??"user",projectPath:o.projectPath,installPath:o.installPath??d(b(),s),enabled:t[s]??o.enabled??!0,installedAt:o.installedAt??"",lastUpdated:o.lastUpdated??""}}function M(s){let i=y(S()),l=new Map;for(let o of s){let t=i?.plugins?.[o];Array.isArray(t)&&t.length>0&&l.set(o,t[0].installPath??d(b(),o))}return l}function U(){return y(_())?.marketplaces??[]}function I(s){let i=d(s,".claude","settings.json"),l=y(i);return{enabledPlugins:l?.enabledPlugins??{},mcpServers:l?.mcpServers??{},allowedTools:l?.allowedTools??[],disallowedTools:l?.disallowedTools??[]}}J();D();var C={Read:{category:"File",label:"read"},Write:{category:"File",label:"write"},Edit:{category:"File",label:"edit"},Glob:{category:"Search",label:"find files"},Grep:{category:"Search",label:"search content"},Bash:{category:"Execution",label:"shell commands"},WebSearch:{category:"Web",label:"web search"},WebFetch:{category:"Web",label:"fetch pages"},NotebookEdit:{category:"Execution",label:"Jupyter notebooks"}};function q(s,i){let l=s.allowedTools??[],o=s.osCapabilities??[];if(l.length===0&&o.length===0&&Object.keys(s.mcpServers??{}).length===0&&(s.additionalDirectories?.length??0)===0&&(!i||i.plugins.length===0))return"No tool permissions";let t=new Map,p=[];for(let e of l){let n=C[e];if(n){let g=t.get(n.category)??[];g.push(n.label),t.set(n.category,g)}else p.push(e)}let a=[];for(let[e,n]of t)a.push(`${e} (${n.join(", ")})`);p.length>0&&a.push(p.join(", "));let c=a.join(" \xB7 "),u=e=>{c=c?`${c} \xB7 ${e}`:e},f=Object.keys(s.mcpServers??{});f.length>0&&u(`MCP: ${f.join(", ")}`);let r=s.additionalDirectories??[];if(r.length>0&&u(`Dirs: ${r.map(e=>e.path).join(", ")}`),o.length>0){let e=o.map(n=>{let g=v(n.id);return n.id==="automation"&&n.targets?.length?`${g.label} (${n.targets.join(", ")})`:g.label});u(`OS: ${e.join(", ")}`)}if(i&&i.plugins.length>0){let e=i.plugins.map(n=>{let g=[];return n.skills.length>0&&g.push(`skills: ${n.skills.map(h=>h.name).join(", ")}`),n.agents.length>0&&g.push(`agents: ${n.agents.map(h=>h.name).join(", ")}`),g.length>0?`${n.name} (${g.join("; ")})`:n.name});u(`Plugins: ${e.join(", ")}`)}return c}function O(s){let i=[],l=s.additionalDirectories??[];for(let o of l){if(!o.inheritPlugins&&!o.inheritMcp)continue;let t=I(o.path),p=Object.entries(t.enabledPlugins).filter(([,c])=>c).map(([c])=>c),a=M(p);for(let[,c]of a)i.includes(c)||i.push(c)}try{let o=A(s.name),t=$({scope:"project",projectPath:o});for(let p of t)p.installPath&&!i.includes(p.installPath)&&i.push(p.installPath)}catch{}return i}function z(s){let i=O(s),l=[];for(let o of i){let t=T(o);t&&l.push({name:t.name||o.split("/").pop()||"unknown",description:t.description,skills:t.skills,agents:t.agents,mcpServers:t.mcpServers,hooks:t.hooks})}return{plugins:l}}export{R as a,T as b,$ as c,G as d,U as e,I as f,q as g,O as h,z as i};
@@ -0,0 +1,6 @@
1
+ import{a as A,b as E}from"./chunk-2JIQT2CI.js";import{c as p,d as j,i as v}from"./chunk-QYI44EP6.js";import{a as B,b as d}from"./chunk-T2Z2JDPY.js";import{d as h,l as M,n as b,o as S,p as C,r as x}from"./chunk-V2MMQ3SH.js";import{K as g,L as w}from"./chunk-2A2TXYT3.js";w();var f=5;async function R(t,o,s){let c=g(t),i=o?`${t}::${o}`:void 0,r;if(s){if(r=j(t,s,f*4).map(a=>a.node).filter(a=>a.status==="active"),r.length<f*4){let a=new Set(r.map(n=>n.id)),u=p(t,{onlyActive:!0}).slice(0,f*4);for(let n of u)if(!a.has(n.id)&&(r.push(n),r.length>=f*4))break}}else r=p(t,{onlyActive:!0}).slice(0,f*4);i&&(r=r.filter(e=>e.scopeKey===i||e.scopeKey==null));let m=r.map(e=>({belief:e,score:A(e,c)??.5}));m.sort((e,a)=>a.score-e.score);let l=m.slice(0,f).map(e=>e.belief);for(let e of l)E(e,c),v(e.id),e.injectCount=(e.injectCount??0)+1;return l}function O(t,o){if(t.length===0)return"";let s=o==="initial"?"[Memory Context \u2014 retrieved from prior interactions]":"[Memory Refresh \u2014 \u8FC7\u5F80\u89C2\u5BDF,\u53EF\u80FD\u8FC7\u65F6;Step \u6307\u4EE4\u4E3A\u6743\u5A01,\u51B2\u7A81\u5219\u5FFD\u7565]",c=t.map(i=>i.isAnti?`- [anti-pattern] \u274C ${i.content}`:`- [belief] ${i.content}`);return`${s}
2
+ ${c.join(`
3
+ `)}
4
+
5
+ [User Request]
6
+ `}async function F(t,o,s={}){let c=s.topK??10,i=s.hybridConfig??C,r;try{r=await d(o)}catch{}let m=r??new Float32Array(B),l=x(t,m,o,c*2,i,{excludeSuperseded:!0}),e=t?S(t):M,a=l.map(({node:n,combinedRelevance:y})=>{let T=Math.min(.3,(n.retrievedCount??0)*.05),_=b(n.createdAt,y,n.importance,e)+T;return{...n,score:_}});a.sort((n,y)=>y.score-n.score);let u=a.slice(0,c);for(let n of u)h(n.id);return u}async function P(t,o,s=5,c){if(!o)return"";try{let i;try{i=await d(t)}catch{}let r=await R(o,void 0,i);return O(r,"initial")}catch{return""}}async function k(t,o,s,c={}){return(await F(t,o,c)).filter(r=>s.includes(r.tier??"episodic"))}export{R as a,O as b,F as c,P as d,k as e};
@@ -0,0 +1 @@
1
+ import{h as c,i as m}from"./chunk-4JHACUZY.js";import{c as a,h as f}from"./chunk-EZLBMUQD.js";import{c as s,e as u}from"./chunk-5M6IGE5G.js";u();f();var r=a("adam");function T(e){let i=e.traceIdOverride??s();if(!i){r.debug({toolName:e.toolName,entityType:e.entityType,verb:e.verb},"Mutation receipt skipped: no active trace context");return}let n={traceId:i,toolName:e.toolName,taskId:e.taskId,roleId:e.roleId};try{m({traceId:i,taskId:e.taskId,sessionId:e.sessionId,effectCategory:"entity_mutation",verb:e.verb,entityType:e.entityType,entityId:e.entityId,entityIds:e.entityIds,fieldChanges:e.fieldChanges,scope:e.scope,actor:n,outcome:"success"})}catch(o){o instanceof c?r.warn({errors:o.errors,toolName:e.toolName,entityType:e.entityType},"Mutation receipt validation failed"):r.warn({error:o instanceof Error?o.message:String(o),toolName:e.toolName},"Mutation receipt write failed")}}import{z as t}from"zod";var p=t.object({kind:t.literal("lengthTarget"),min:t.number().int().nonnegative(),max:t.number().int().positive(),unit:t.enum(["characters","words","bytes"])}).refine(e=>e.min<=e.max,{message:"min must be <= max"}),g=t.object({kind:t.literal("format"),value:t.enum(["markdown","json","text"])}),k=t.object({kind:t.literal("requireHeading"),value:t.boolean()}),y=t.object({kind:t.literal("mime"),declared:t.string().regex(/^[a-z]+\/[a-z0-9.+-]+(\/)?$/i,{message:"declared must be a valid MIME type (e.g. audio/mpeg, application/json)"})}),b=t.object({kind:t.literal("fileSizeBytes"),min:t.number().int().nonnegative().optional(),max:t.number().int().positive().optional()}).refine(e=>e.min!==void 0||e.max!==void 0,{message:"at least one of min/max required"}).refine(e=>e.min===void 0||e.max===void 0||e.min<=e.max,{message:"min must be <= max"}),x=t.object({kind:t.literal("audioZeroCrossingRatePerS"),max:t.number().positive()}),I=t.object({kind:t.literal("audioDurationMs"),min:t.number().int().nonnegative().optional(),max:t.number().int().positive().optional()}).refine(e=>e.min!==void 0||e.max!==void 0,{message:"at least one of min/max required"}).refine(e=>e.min===void 0||e.max===void 0||e.min<=e.max,{message:"min must be <= max"}),R=t.discriminatedUnion("kind",[p,g,k,y,b,x,I]),A=t.array(R);function d(e){return e.kind==="lengthTarget"||e.kind==="format"||e.kind==="requireHeading"||e.kind==="mime"}function l(e){return e.outputContract?.contractRules??[]}function E(e){return l(e).some(i=>!d(i)||i.kind==="mime"&&i.declared.toLowerCase()!=="application/json")}function N(e,i){return typeof i!="string"?!1:l(e).some(n=>n.kind==="format"&&(n.value==="markdown"||n.value==="text"))}export{T as a,R as b,A as c,d,l as e,E as f,N as g};
@@ -1,4 +1,4 @@
1
- import{E as R,I as E}from"./chunk-MTQI6B7T.js";import{d as h,h as A}from"./chunk-WBAPIPST.js";import{c as y,h as V}from"./chunk-BLCNUT53.js";import{c as v}from"./chunk-FCV2DPZQ.js";import{readFileSync as P,writeFileSync as I,existsSync as b}from"fs";import{join as x}from"path";function k(n){let e=x(m(n),".env");if(!b(e))return null;let s=P(e,"utf-8"),r={};for(let c of s.split(`
1
+ import{F as R,L as E}from"./chunk-2A2TXYT3.js";import{d as h,h as A}from"./chunk-VO24C673.js";import{c as y,h as V}from"./chunk-EZLBMUQD.js";import{b as v}from"./chunk-5PELJRUQ.js";import{readFileSync as P,writeFileSync as I,existsSync as b}from"fs";import{join as x}from"path";function k(n){let e=x(m(n),".env");if(!b(e))return null;let s=P(e,"utf-8"),r={};for(let c of s.split(`
2
2
  `)){let t=c.trim();if(!t||t.startsWith("#"))continue;let i=t.startsWith("export ")?t.slice(7).trim():t,a=i.indexOf("=");if(a===-1)continue;let d=i.slice(0,a).trim(),o=i.slice(a+1).trim();(o.startsWith('"')&&o.endsWith('"')||o.startsWith("'")&&o.endsWith("'"))&&(o=o.slice(1,-1)),!(o.includes("$")&&(o=o.replace(/\$\{(\w+)\}|\$(\w+)/g,(f,l,u)=>{let g=l??u;return r[g]??process.env[g]??""}),!o))&&(r[d]=o)}return r}function W(n,e){let s=k(n);if(!s)return e;let r={...e},c=0;for(let[t,i]of Object.entries(s)){if(t.startsWith("ANTHROPIC_")){$.warn({roleName:n,key:t},"Role .env contains ANTHROPIC_* key; ignored (managed globally)");continue}t in r||(r[t]=i,c++)}return c>0&&$.info({roleName:n,seeded:c},"Seeded role envVars from .env file"),Object.keys(r).length>0?r:void 0}function U(n,e){let s=k(n);if(!s)return[];let r=e??{},c=[];for(let[t,i]of Object.entries(s)){if(t.startsWith("ANTHROPIC_"))continue;let a=r[t]??"";a!==i&&c.push({envKey:t,dbValue:a,envValue:i})}for(let[t,i]of Object.entries(r))t in s||c.push({envKey:t,dbValue:i,envValue:""});return c}function q(n,e){let s=x(m(n),".env"),r=e??{},c=[],t=new Set;if(b(s)){let a=P(s,"utf-8");for(let d of a.split(`
3
3
  `)){let o=d.trim();if(!o||o.startsWith("#")){c.push(d);continue}let f=o.startsWith("export ")?o.slice(7).trim():o,l=f.indexOf("=");if(l===-1){c.push(d);continue}let u=f.slice(0,l).trim(),g=o.startsWith("export ")?"export ":"";u in r&&(c.push(`${g}${u}=${r[u]}`),t.add(u))}}let i=0;for(let[a,d]of Object.entries(r)){if(t.has(a)){i++;continue}d&&d.length>0&&(c.push(`${a}=${d}`),i++)}return I(s,c.join(`
4
4
  `)+`
@@ -1,2 +1,2 @@
1
- import{n as r,p as s}from"./chunk-QL2ZOLMC.js";import{c as i}from"./chunk-FCV2DPZQ.js";function p(e){let n=r().prepare("SELECT value FROM config WHERE key = ?").get(e);if(n)try{return JSON.parse(n.value)}catch{return n.value}}function E(e,t){let n=r(),o=JSON.stringify(t),u=Date.now();n.prepare(`INSERT INTO config (key, value, updated_at) VALUES (?, ?, ?)
1
+ import{n as r,p as s}from"./chunk-WY5BOCQP.js";import{b as i}from"./chunk-5PELJRUQ.js";function p(e){let n=r().prepare("SELECT value FROM config WHERE key = ?").get(e);if(n)try{return JSON.parse(n.value)}catch{return n.value}}function E(e,t){let n=r(),o=JSON.stringify(t),u=Date.now();n.prepare(`INSERT INTO config (key, value, updated_at) VALUES (?, ?, ?)
2
2
  ON CONFLICT(key) DO UPDATE SET value = excluded.value, updated_at = excluded.updated_at`).run(e,o,u)}function k(){let t=r().prepare("SELECT key, value FROM config").all(),n={};for(let o of t)try{n[o.key]=JSON.parse(o.value)}catch{n[o.key]=o.value}return n}function b(e){let t=r(),n=t.prepare("INSERT OR IGNORE INTO config (key, value, updated_at) VALUES (?, ?, ?)"),o=Date.now(),u=0;return t.transaction(()=>{for(let[c,a]of Object.entries(e)){if(a==null||a==="")continue;n.run(c,JSON.stringify(a),o).changes>0&&u++}})(),u}function w(){return r().prepare("SELECT COUNT(*) as count FROM config").get().count===0}function O(e){return r().prepare("DELETE FROM config WHERE key = ?").run(e).changes>0}var d=i(()=>{s()});export{p as a,E as b,k as c,b as d,w as e,O as f,d as g};
@@ -0,0 +1 @@
1
+ import{b as e,d as t,h as a}from"./chunk-VO24C673.js";a();var i={defaults:{timeout:600,maxTurns:400,maxBudgetUsd:5,effort:"high",model:"",settingSources:["user","project"],allowedTools:[],disallowedTools:[],approvalRequired:["rm -rf *","git push*","git reset*","curl * -X POST*","curl * --request POST*"],approvalTimeout:600,env:{},plugins:[],workspacePath:t,workspaceRetention:"immediate",deniedReadPaths:[...e]},externalApis:[],server:{port:7100,host:"0.0.0.0",timezone:"system"},identity:{ownerViewerKey:"local-owner"},logging:{level:"info"},roles:{presets:[],evolution:{triggerEvery:5,reflectionThreshold:150,retirementThreshold:.4,probationTasks:5}},chat:{sessionTimeoutMinutes:30,maxSessionTurns:20,autoTitle:!0,archiveExtractMemory:!0,contextBudgetTokens:2e4,artifactThresholdChars:4e3,maxConcurrentLiveSessions:3,liveSessionIdleMinutes:30,commitmentDetection:{locales:["zh","en"],blockedText:{zh:"\u4EFB\u52A1\u5DF2\u63D0\u4EA4\uFF0C\u5B8C\u6210\u540E\u6211\u4F1A\u66F4\u65B0\u7ED3\u679C\u3002",en:"Task dispatched; I will update you when it completes."},unsupportedSuccessText:{zh:"\u56FE\u7247\u5DF2\u751F\u6210\uFF0C\u53D1\u9001\u72B6\u6001\u8FD8\u6CA1\u6709\u5B8C\u6210\u9A8C\u8BC1\u3002",en:"Result is ready; delivery status is not yet verified."},unsupportedFailureText:{zh:"\u56FE\u7247\u5DF2\u751F\u6210\uFF0C\u4F46\u8FD8\u6CA1\u6709\u6267\u884C\u53D1\u9001\u3002",en:"Result is ready, but delivery has not been attempted."},unsupportedMutationText:{zh:"\u6211\u6CA1\u6709\u5B8C\u6210\u8FD9\u6B21\u8BB0\u5F55\uFF0C\u4E0D\u80FD\u8BF4\u5DF2\u8BB0\u5F55\u3002\u9700\u8981\u5148\u66F4\u65B0\u5BF9\u5E94\u6A21\u677F\u6216\u914D\u7F6E\u540E\u518D\u786E\u8BA4\u3002",en:"I did not actually record this. The template or config has not been updated yet."}}},memory:{midTaskInjection:{enabled:!0,toolCallThreshold:10,cooldownMs:6e4,topK:3,maxTokens:1e3},retrievalWeights:{cosSim:.4,recency:.2,tokenCost:.05},globalBudgetTokens:1500,retrievalDecayDays:30,attributionThresholds:{high:.7,low:.4},antiFlipMinUses:5,antiFlipSuccessEmaThreshold:.25,reflection:{maxBudgetUsd:5},scope:{emaAlpha:.3,humanFeedbackWeight:3,reflectionPoolMax:100,decayBase:.995,archiveThreshold:.2},embeddingModel:"bge-small-zh-v1.5"},watchdog:{enabled:!0,intervalMinutes:5,rules:{managerHealthCheck:{enabled:!0,action:"restart",staleDurationMinutes:15},staleTasks:{enabled:!0,action:"notify",maxPendingMinutes:30},staleRunningTasks:{enabled:!0,action:"notify",maxRunningMinutes:15},staleTemplateExecutions:{enabled:!0,action:"notify",maxOrphanMinutes:60},dbMaintenance:{enabled:!0,action:"ignore",walCheckpointThresholdMB:100},artifactCleanup:{enabled:!0,action:"ignore",ttlDays:7,orphanGcMinAgeHours:1},sandboxViolation:{enabled:!0,action:"alert"},reflectionJob:{enabled:!0,intervalMinutes:30},memoryGc:{enabled:!0,intervalHours:24,observationTtlDays:14}}},execution:{maxConcurrent:5,pollIntervalMs:3e4},anthropic:{apiKey:"",baseUrl:"",model:"",defaultOpusModel:"",defaultSonnetModel:"",defaultHaikuModel:"",smallFastModel:""},emailGateway:{enabled:!1,address:"",displayName:"Adam",imap:{host:"",port:993,secure:!0,auth:{user:"",pass:""},mailbox:"INBOX"},smtp:{host:"",port:465,secure:!0,auth:{user:"",pass:""},from:""},subjectPrefix:"Adam"},audit:{intentEval:{maxBudgetUsd:1,timeoutMs:3e4}},evaluation:{},delivery:{cronDefaultReportTo:null},storage:{localProfile:"default"},pricing:{models:{"claude-opus-4-7":{input:5,output:25,cacheRead:.5,cacheCreation:6.25,estimated:!0},"claude-sonnet-4-6":{input:3,output:15,cacheRead:.3,cacheCreation:3.75,estimated:!0},"claude-haiku-4-5":{input:1,output:5,cacheRead:.1,cacheCreation:1.25,estimated:!0},"deepseek-v4-flash":{input:.14,output:.28,cacheRead:.0028,cacheCreation:.14,estimated:!0},"deepseek-v4-pro":{input:1.74,output:3.48,cacheRead:.0145,cacheCreation:1.74,estimated:!0},"doubao-seed-2.0-pro":{input:.47,output:2.37,cacheRead:.094,cacheCreation:.47,estimated:!0},"minimax-m2":{input:.26,output:1,cacheRead:.26,cacheCreation:.26,estimated:!0},"gpt-4.1":{input:2,output:8,cacheRead:.5,cacheCreation:2,estimated:!0},"gpt-4o":{input:2.5,output:10,cacheRead:1.25,cacheCreation:2.5,estimated:!0},"gemini-2.5-pro":{input:1.25,output:10,cacheRead:.3125,cacheCreation:1.25,estimated:!0},"gemini-2.5-flash":{input:.3,output:2.5,cacheRead:.075,cacheCreation:.3,estimated:!0}}},cost:{dailyThresholdUsd:0}};export{i as a};
@@ -1,4 +1,4 @@
1
- import{f as g}from"./chunk-WVHN54MA.js";import{f as T,i as K}from"./chunk-3UR2PN5N.js";import{r as _,t as E,u as f}from"./chunk-K4IE6DPX.js";import{B as R,C as A,D as c,E as x,F as C,I as z}from"./chunk-MTQI6B7T.js";import{c as U,e as Y,f as H}from"./chunk-FCV2DPZQ.js";var L={};Y(L,{seedAdamAutomatorSkills:()=>J});async function J(t){let{ensureRoleWorkspace:r}=await import("./role-workspace-USY47ZPQ.js"),{getRole:e}=await import("./roles-3JXNHL7K.js"),{mkdir:a,readFile:n,writeFile:o,access:s}=await import("fs/promises"),{join:l}=await import("path"),d=e(t);if(!d)throw new Error(`Role '${t}' not found`);let u=r(d),m=l(u,".claude","skills");await a(m,{recursive:!0});let i=[{name:"aggregate_feature",description:"Aggregate a feature value over a window",inputs:[{name:"feature_name",desc:"Name of the feature to aggregate"},{name:"aggregation",desc:"Aggregation type: sum | avg | count | latest"},{name:"window_days",desc:"Number of days to look back"},{name:"field",desc:"Event payload field to aggregate"}],body:"Query events via sqlite3, compute aggregation, print numeric result."},{name:"check_threshold",description:"Compare a value vs threshold, emit breach if exceeded",inputs:[{name:"feature",desc:"Feature value (number)"},{name:"operator",desc:"Comparison operator: gt | gte | lt | lte | eq"},{name:"threshold",desc:"Threshold value"},{name:"on_breach_type",desc:"Event type to emit on breach"},{name:"on_breach_payload",desc:"JSON payload for breach event"}],body:"Read feature value, compare against threshold using the operator. On breach, emit new event via emit_event Skill."},{name:"query_events",description:"Range-query events table",inputs:[{name:"type_pattern",desc:"Event type pattern (e.g. 'scheduler.tick')"},{name:"window",desc:"Lookback window in hours"},{name:"limit",desc:"Maximum number of events to return"}],body:"sqlite3 parameterized query against the events table, returning matching rows as JSON."},{name:"query_state",description:"Read latest state_snapshot (not yet available)",inputs:[{name:"select",desc:"Dot-notation path to select (e.g. 'goals.active')"}],body:`Returns { state: null, available: false } \u2014 state_snapshot table not yet built (deferred to Phase 2).
1
+ import{g}from"./chunk-QTGAK62Z.js";import{f as T,i as K}from"./chunk-NSUXJ2VA.js";import{r as _,t as E,u as f}from"./chunk-VWX2B6OM.js";import{C as R,D as A,E as c,F as x,G as C,L as z}from"./chunk-2A2TXYT3.js";import{b as U,c as Y,d as H}from"./chunk-5PELJRUQ.js";var L={};Y(L,{seedAdamAutomatorSkills:()=>J});async function J(t){let{ensureRoleWorkspace:r}=await import("./role-workspace-AIVHPX5P.js"),{getRole:e}=await import("./roles-WDMUBWQP.js"),{mkdir:a,readFile:n,writeFile:o,access:s}=await import("fs/promises"),{join:l}=await import("path"),d=e(t);if(!d)throw new Error(`Role '${t}' not found`);let u=r(d),m=l(u,".claude","skills");await a(m,{recursive:!0});let i=[{name:"aggregate_feature",description:"Aggregate a feature value over a window",inputs:[{name:"feature_name",desc:"Name of the feature to aggregate"},{name:"aggregation",desc:"Aggregation type: sum | avg | count | latest"},{name:"window_days",desc:"Number of days to look back"},{name:"field",desc:"Event payload field to aggregate"}],body:"Query events via sqlite3, compute aggregation, print numeric result."},{name:"check_threshold",description:"Compare a value vs threshold, emit breach if exceeded",inputs:[{name:"feature",desc:"Feature value (number)"},{name:"operator",desc:"Comparison operator: gt | gte | lt | lte | eq"},{name:"threshold",desc:"Threshold value"},{name:"on_breach_type",desc:"Event type to emit on breach"},{name:"on_breach_payload",desc:"JSON payload for breach event"}],body:"Read feature value, compare against threshold using the operator. On breach, emit new event via emit_event Skill."},{name:"query_events",description:"Range-query events table",inputs:[{name:"type_pattern",desc:"Event type pattern (e.g. 'scheduler.tick')"},{name:"window",desc:"Lookback window in hours"},{name:"limit",desc:"Maximum number of events to return"}],body:"sqlite3 parameterized query against the events table, returning matching rows as JSON."},{name:"query_state",description:"Read latest state_snapshot (not yet available)",inputs:[{name:"select",desc:"Dot-notation path to select (e.g. 'goals.active')"}],body:`Returns { state: null, available: false } \u2014 state_snapshot table not yet built (deferred to Phase 2).
2
2
 
3
3
  When the state_snapshot table is available, this Skill will query it for the latest snapshot matching the select path and return the value.`},{name:"query_goals",description:"Read active goals (goal_graph_nodes not built)",inputs:[{name:"types",desc:"Goal type filter (e.g. 'daily|weekly')"},{name:"status",desc:"Goal status filter: active | completed | paused"}],body:`Returns { goals: [], available: false } \u2014 goal_graph_nodes table not yet built (deferred to Phase 2).
4
4
 
@@ -1,4 +1,4 @@
1
- import{n as r,p as n}from"./chunk-QL2ZOLMC.js";import{c,e as u}from"./chunk-245WE5AF.js";import{c as d,e as o}from"./chunk-FCV2DPZQ.js";var D={};o(D,{listAuditDiagnostics:()=>A,recordAuditDiagnostic:()=>g});import{v4 as a}from"uuid";function g(e){let t={id:a(),source:e.source,severity:e.severity,traceId:e.traceId??c()??void 0,sourceId:e.sourceId,message:e.message,createdAt:e.createdAt??Date.now()};return r().prepare(`
1
+ import{n as r,p as n}from"./chunk-WY5BOCQP.js";import{c,e as u}from"./chunk-5M6IGE5G.js";import{b as d,c as o}from"./chunk-5PELJRUQ.js";var D={};o(D,{listAuditDiagnostics:()=>A,recordAuditDiagnostic:()=>g});import{v4 as a}from"uuid";function g(e){let t={id:a(),source:e.source,severity:e.severity,traceId:e.traceId??c()??void 0,sourceId:e.sourceId,message:e.message,createdAt:e.createdAt??Date.now()};return r().prepare(`
2
2
  INSERT INTO audit_diagnostics (id, source, severity, trace_id, source_id, message, created_at)
3
3
  VALUES (?, ?, ?, ?, ?, ?, ?)
4
4
  `).run(t.id,t.source,t.severity,t.traceId??null,t.sourceId??null,t.message,t.createdAt),t}function A(e={}){let t=[],i=[];e.source&&(t.push("source = ?"),i.push(e.source)),e.traceId&&(t.push("trace_id = ?"),i.push(e.traceId));let s="SELECT * FROM audit_diagnostics";return t.length>0&&(s+=` WHERE ${t.join(" AND ")}`),s+=" ORDER BY created_at DESC",e.limit!==void 0&&(s+=" LIMIT ?",i.push(e.limit)),r().prepare(s).all(...i).map(m)}function m(e){return{id:e.id,source:e.source,severity:e.severity,traceId:e.trace_id??void 0,sourceId:e.source_id??void 0,message:e.message,createdAt:e.created_at}}var I=d(()=>{n();u()});export{g as a,A as b,D as c,I as d};
@@ -0,0 +1,14 @@
1
+ import{a as D,g as Be}from"./chunk-MTRLUW7Z.js";import{a as Te}from"./chunk-Z2APBKIT.js";import{b as ie}from"./chunk-4JHACUZY.js";import{e as Re,i as nt}from"./chunk-NSUXJ2VA.js";import{b as pe,k as me,m as re,s as oe}from"./chunk-VWX2B6OM.js";import{a as Oe}from"./chunk-L7JP7DUO.js";import{c as $e}from"./chunk-LKGYQJMS.js";import{b as Me}from"./chunk-T2Z2JDPY.js";import{a as Ne,b as fe,c as De,k as Pe}from"./chunk-V2MMQ3SH.js";import{D as ue,L as it,b as j,c as Ce,p as ot}from"./chunk-2A2TXYT3.js";import{a as J,b as ee,d as _e,j as ae,l as be,n as ge,o as ke,r as tt}from"./chunk-BE653A45.js";import{a as xe,b as te,c as we,d as ce,e as ve,f as de,j as Ee,l as Ae,n as K,p as le}from"./chunk-WY5BOCQP.js";import{c as Z,h as Ie}from"./chunk-EZLBMUQD.js";import{c as Se,e as rt}from"./chunk-5M6IGE5G.js";it();nt();ot();import{createSdkMcpServer as Ft,tool as M}from"@anthropic-ai/claude-agent-sdk";import{z as d}from"zod";import{v4 as he}from"uuid";tt();Ie();le();var st=Z("audit");function I(t){try{K().prepare(`
2
+ INSERT INTO artifact_access_log (
3
+ timestamp, task_id, role_id, execution_id, step_id, tool, artifact_key, artifact_id,
4
+ size_bytes, outcome, error_reason
5
+ )
6
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
7
+ `).run(t.timestamp,t.taskId??null,t.roleId??null,t.executionId,t.stepId??null,t.tool,t.artifactKey??null,t.artifactId??null,t.sizeBytes??null,t.outcome,t.errorReason??null)}catch(e){st.error({err:e,entry:t},"Failed to write artifact access log")}}Ae();import{tool as q}from"@anthropic-ai/claude-agent-sdk";import{z as k}from"zod";import{v4 as at}from"uuid";function B(t){return{content:[{type:"text",text:JSON.stringify(t)}]}}var ct={query:k.string().describe("Search query for memory retrieval"),roleId:pe.optional().describe("Role ID to scope search (omit for cross-role)"),topK:k.number().optional().describe("Max results to return (default 5)")},dt={query:k.string().describe("Search query for memory retrieval"),topK:k.number().optional().describe("Max results to return (default 5)")},lt={id:k.string().optional().describe("Memory ID to update. Omit to create new."),roleId:pe.describe("Role ID to save memory under"),content:k.string().describe("Memory content text"),type:k.enum(["event","thought","reflection"]).optional().describe("Memory type (default: thought)"),keywords:k.array(k.string()).optional().describe("Keywords for BM25 search"),importance:k.number().min(1).max(5).optional().describe("Importance 1-5 (default: 3)"),tier:k.enum(["working","episodic","semantic"]).optional().describe("Memory tier (default: episodic)")},ut={id:k.string().optional().describe("Memory ID to update. Omit to create new."),content:k.string().describe("Memory content text"),type:k.enum(["event","thought","reflection"]).optional().describe("Memory type (default: thought)"),keywords:k.array(k.string()).optional().describe("Keywords for BM25 search"),importance:k.number().min(1).max(5).optional().describe("Importance 1-5 (default: 3)"),tier:k.enum(["working","episodic","semantic"]).optional().describe("Memory tier (default: episodic)")},ze={id:k.string().describe("Memory ID to delete")};async function Fe(t,e){let r=t??e.roleId,n=e.topK??5,a=await $e(r,e.query,{topK:n});return B({results:a.map(c=>({id:c.id,type:c.type,content:c.content,keywords:c.keywords,importance:c.importance,score:c.score}))})}async function Ke(t,e){let r=t??e.roleId;if(!r)return B({error:"roleId is required"});let n,a=!0;try{n=await Me(e.content)}catch{a=!1}if(e.id){let y=fe(e.id);if(!y)return B({error:`Memory ${e.id} not found`});let A=De(e.id,{content:e.content,embedding:n,keywords:e.keywords,importance:e.importance,type:e.type});return D({toolName:"save_memory",entityType:"memory",verb:"update",entityId:e.id,fieldChanges:[{path:"content",op:"set",before:y.content,after:e.content}],roleId:r}),B({id:e.id,action:"updated",success:A,embeddingUpdated:a})}let c=`mem-${at().slice(0,8)}`,m=Date.now();return Ne({id:c,roleId:r,type:e.type??"thought",content:e.content,embedding:n,keywords:e.keywords??[],importance:e.importance??3,sourceType:"manual",createdAt:m,lastAccessed:m,retrievedCount:0,tier:e.tier??"episodic"}),D({toolName:"save_memory",entityType:"memory",verb:"create",entityId:c,fieldChanges:[{path:"_entity",op:"set",before:null,after:{id:c,roleId:r,type:e.type??"thought",content:e.content.length>200?`${e.content.slice(0,200)}\u2026`:e.content,tier:e.tier??"episodic"}}],roleId:r}),B({id:c,action:"created",success:!0,embeddingUpdated:a})}async function Le(t,e){let r=fe(e.id);if(t){if(!r)return B({error:`Memory ${e.id} not found`});if(r.roleId!==t)return B({error:`Memory ${e.id} does not belong to this role`})}return Pe(e.id),D({toolName:"delete_memory",entityType:"memory",verb:"delete",entityId:e.id,fieldChanges:[{path:"_entity",op:"set",before:r?{id:r.id,roleId:r.roleId,content:r.content.length>200?`${r.content.slice(0,200)}\u2026`:r.content}:null,after:null}],roleId:t??r?.roleId}),B({id:e.id,deleted:!0})}function je(t){return t?[q("search_memories","Search agent memory using hybrid vector + keyword search. Returns scored memories ranked by relevance, recency, and importance.",dt,async e=>Fe(t,e)),q("save_memory","Create a new memory or update an existing one. Provide 'id' to update, omit to create. Embedding is auto-generated from content.",ut,async e=>Ke(t,e)),q("delete_memory","Delete a memory by ID.",ze,async e=>Le(t,e))]:[q("search_memories","Search agent memory using hybrid vector + keyword search. Returns scored memories ranked by relevance, recency, and importance.",ct,async e=>Fe(void 0,e)),q("save_memory","Create a new memory or update an existing one. Provide 'id' to update, omit to create. Embedding is auto-generated from content.",lt,async e=>Ke(void 0,e)),q("delete_memory","Delete a memory by ID.",ze,async e=>Le(void 0,e))]}Ae();import{basename as Y,join as Lt}from"path";import{writeFileSync as jt}from"fs";Ie();le();import{v4 as pt}from"uuid";function qe(t){let e=[];if(t.verb||e.push("verb is required"),t.entityType||e.push("entityType is required"),!t.expected)return e.push("expected is required"),{valid:!1,errors:e};let r=t.expected;if(r.kind==="outbound")r.target?.channelId||e.push("expected.target.channelId is required for outbound"),r.attachmentCount!==void 0&&(typeof r.attachmentCount!="number"||r.attachmentCount<0)&&e.push("expected.attachmentCount must be a non-negative number");else if(r.kind==="field_change")r.entityId||e.push("expected.entityId is required for field_change"),r.fieldPath||e.push("expected.fieldPath is required for field_change"),r.op!=="set"&&r.op!=="list_add"&&r.op!=="list_remove"&&e.push("expected.op must be 'set', 'list_add', or 'list_remove'"),r.op==="set"&&(r.after===void 0&&e.push("expected.after is required when op='set'"),(r.added!==void 0||r.removed!==void 0)&&e.push("expected.added/removed must be absent when op='set'")),r.op==="list_add"&&((!Array.isArray(r.added)||r.added.length===0)&&e.push("expected.added (non-empty array) is required when op='list_add'"),(r.after!==void 0||r.removed!==void 0)&&e.push("expected.after/removed must be absent when op='list_add'")),r.op==="list_remove"&&((!Array.isArray(r.removed)||r.removed.length===0)&&e.push("expected.removed (non-empty array) is required when op='list_remove'"),(r.after!==void 0||r.added!==void 0)&&e.push("expected.after/added must be absent when op='list_remove'"));else if(r.kind==="batch"){r.entityType||e.push("expected.entityType is required for batch");let n=Array.isArray(r.entityIds)&&r.entityIds.length>0,a=!!r.scope&&typeof r.scope.expectedCount=="number"&&r.scope.expectedCount>=0&&!!r.scope.filter;!n&&!a&&e.push("batch claims require entityIds (non-empty) or scope (with filter + non-negative expectedCount)")}else e.push(`expected.kind must be 'outbound', 'field_change', or 'batch'; got '${r.kind}'`);return{valid:e.length===0,errors:e}}var H=class extends Error{constructor(r){super(`Invalid claim spec: ${r.join("; ")}`);this.errors=r;this.name="InvalidClaimError"}errors};function He(t){if(!t.traceId)throw new H(["traceId is required"]);if(!Array.isArray(t.claims)||t.claims.length===0)throw new H(["claims must be a non-empty array"]);for(let[r,n]of t.claims.entries()){let a=qe(n);if(!a.valid)throw new H([`claims[${r}]: ${a.errors.join("; ")}`])}let e={id:t.id??pt(),traceId:t.traceId,sessionId:t.sessionId,taskId:t.taskId,sourceMessageId:t.sourceMessageId,claims:t.claims,declaredAt:t.declaredAt??Date.now()};return K().prepare(`
8
+ INSERT INTO assistant_claims (
9
+ id, trace_id, session_id, task_id, source_message_id, claims_json, declared_at
10
+ )
11
+ VALUES (?, ?, ?, ?, ?, ?, ?)
12
+ `).run(e.id,e.traceId,e.sessionId??null,e.taskId??null,e.sourceMessageId??null,JSON.stringify(e.claims),e.declaredAt),e}function dr(t){return K().prepare(`
13
+ SELECT * FROM assistant_claims WHERE trace_id = ? ORDER BY declared_at ASC
14
+ `).all(t).map(mt)}function mt(t){return{id:t.id,traceId:t.trace_id,sessionId:t.session_id??void 0,taskId:t.task_id??void 0,sourceMessageId:t.source_message_id??void 0,claims:JSON.parse(t.claims_json),declaredAt:t.declared_at}}rt();import{execFile as Ot}from"child_process";import{promisify as Nt}from"util";import{isAbsolute as Dt,basename as Pt}from"path";import Ye from"vm";import{isAbsolute as ft}from"path";var P=class extends Error{constructor(e,r){super(`DSL parse error in "${e}": ${r}`),this.name="DslParseError"}},ht=/^[a-z][a-z0-9_.]*$/i,yt=/\.\./;function V(t){if(!ht.test(t))throw new P(t,`invalid handler key format "${t}" \u2014 must match [a-z][a-z0-9_.]*`);if(yt.test(t))throw new P(t,'handler key must not contain ".."')}function Ue(t){let e=t.trim();try{let n=JSON.parse(e);if(typeof n=="number"||typeof n=="string"||typeof n=="boolean")return n}catch{}let r=parseFloat(e);return Number.isNaN(r)?e:r}var It=/^([a-z][a-z0-9_.]*)\s+matches\s+\/(.+)\/([gimsuy]*)$/i,_t=/^([a-z][a-z0-9_.]*)\s*(<=|>=|==|!=)\s*(.+)$/i,bt=/^([a-z][a-z0-9_.]*)\s*(<|>)\s*(.+)$/i,gt=/^([a-z][a-z0-9_.]*)\s+between\s+(-?\d+(?:\.\d+)?)\s+and\s+(-?\d+(?:\.\d+)?)$/i,kt=/^([a-z][a-z0-9_.]*)\s+in\s+\[([^\]]+)\]$/i;function We(t){if(typeof t=="object"&&t!==null&&"script"in t){let r=String(t.script);if(!ft(r))throw new P(`{script: "${r}"}`,"script path must be absolute");return{kind:"script",scriptPath:r}}if(typeof t!="string")throw new P(String(t),"assertion must be a string or {script: string} object");let e=t.trim();if(!e)throw new P(e,"empty assertion string");{let r=It.exec(e);if(r){let n=r[1];return V(n),{kind:"matches",key:n,regexSource:r[2],regexFlags:r[3]??""}}}{let r=gt.exec(e);if(r){let n=r[1];return V(n),{kind:"between",key:n,min:parseFloat(r[2]),max:parseFloat(r[3])}}}{let r=kt.exec(e);if(r){let n=r[1];V(n);let a=r[2],c=[];for(let m of a.split(",")){let y=m.trim();if(y)try{let A=JSON.parse(y);typeof A=="number"||typeof A=="string"||typeof A=="boolean"?c.push(A):c.push(y)}catch{c.push(y)}}return{kind:"in",key:n,values:c}}}{let r=_t.exec(e);if(r){let n=r[1];return V(n),{kind:"comparison",key:n,op:r[2],value:Ue(r[3])}}}{let r=bt.exec(e);if(r){let n=r[1];return V(n),{kind:"comparison",key:n,op:r[2],value:Ue(r[3])}}}throw new P(e,"unrecognized assertion syntax \u2014 expected key <op> value, between, in [...], matches /.../, or {script: ...}")}import{execFile as wt,spawn as vt}from"child_process";import{promisify as Et}from"util";import{readFile as X}from"fs/promises";import{existsSync as At}from"fs";import{createHash as St}from"crypto";function xt(t){return typeof t=="number"?Number.isInteger(t)?t.toString():t.toFixed(4):JSON.stringify(t)}var L=class extends Error{constructor(r){super(`NO_HANDLER: ${r}, install relevant capability or remove assertion`);this.handlerKey=r;this.name="NoHandlerError"}handlerKey},C=class extends Error{constructor(r,n,a){super(`ASSERTION_FAILED: ${r}=${xt(n)}, expected ${a}`);this.handlerKey=r;this.measured=n;this.expected=a;this.name="AssertionFailedError"}handlerKey;measured;expected},g=class extends Error{constructor(r,n){super(`HANDLER_RUNTIME_ERROR: ${r}: ${n}`);this.handlerKey=r;this.detail=n;this.name="HandlerRuntimeError"}handlerKey;detail};var Ct=Et(wt);function z(t,e){if(!At(e))throw new g(t,`file not found: ${e}`)}async function Tt(t){try{return await Ct("ffprobe",t,{maxBuffer:10*1024*1024})}catch(e){throw e.code==="ENOENT"?new g("audio.*","ffprobe not found on PATH \u2014 install ffmpeg/ffprobe"):new g("audio.*",`ffprobe failed: ${e.message}`)}}async function Je(t,e){return new Promise((r,n)=>{let a=[],c=vt("ffmpeg",["-v","error","-i",t,"-f","s16le","-ar",String(e),"-ac","1","-"]);c.stdout.on("data",y=>a.push(y));let m="";c.stderr.on("data",y=>{m+=y.toString()}),c.on("error",y=>{y.code==="ENOENT"?n(new g("audio.*","ffmpeg not found on PATH \u2014 install ffmpeg/ffprobe")):n(new g("audio.*",`ffmpeg failed: ${y.message}`))}),c.on("close",y=>{y!==0?n(new g("audio.*",`ffmpeg exit ${y}: ${m.trim()}`)):r(Buffer.concat(a))})})}var Ve=new Map;async function Rt(t){let e=JSON.stringify(t);if(/"\$ref"\s*:\s*"https?:\/\//.test(e))throw new g("json.schema_valid","remote $ref not supported in schema");let r=St("sha256").update(e).digest("hex"),n=Ve.get(r);if(n)return n;let a=(await import("ajv")).default,m=new a({strict:!1,allErrors:!1}).compile(t);return Ve.set(r,m),m}var Xe={"audio.duration_s":async t=>{z("audio.duration_s",t);let{stdout:e}=await Tt(["-v","error","-show_entries","format=duration","-of","default=noprint_wrappers=1:nokey=1",t]),r=parseFloat(e.trim());if(!Number.isFinite(r))throw new g("audio.duration_s",`ffprobe returned non-numeric duration: ${e.trim()}`);return r},"audio.zc_rate_per_s":async t=>{z("audio.zc_rate_per_s",t);let e=24e3,r=await Je(t,e),n=new Int16Array(r.buffer,r.byteOffset,r.byteLength/2),a=0;for(let m=1;m<n.length;m++)n[m-1]>=0!=n[m]>=0&&a++;let c=n.length/e;return c>0?a/c:0},"audio.rms":async t=>{z("audio.rms",t);let r=await Je(t,24e3),n=new Int16Array(r.buffer,r.byteOffset,r.byteLength/2),a=0;for(let c=0;c<n.length;c++){let m=n[c]/32768;a+=m*m}return n.length>0?Math.sqrt(a/n.length):0},"markdown.word_count":async t=>{z("markdown.word_count",t);let e=await X(t,"utf-8");return e.trim().length===0?0:e.trim().split(/\s+/).length},"image.width_px":async t=>{z("image.width_px",t);let{imageSize:e}=await import("image-size"),r=await X(t),n=e(r);if(typeof n.width!="number")throw new g("image.width_px","could not determine image width");return n.width},"image.height_px":async t=>{z("image.height_px",t);let{imageSize:e}=await import("image-size"),r=await X(t),n=e(r);if(typeof n.height!="number")throw new g("image.height_px","could not determine image height");return n.height},"pdf.page_count":async t=>{z("pdf.page_count",t);let{PDFDocument:e}=await import("pdf-lib"),r=await X(t);return(await e.load(r,{ignoreEncryption:!0})).getPageCount()},"json.schema_valid":async(t,e)=>{if(z("json.schema_valid",t),!e||typeof e!="object"||!("schema"in e))throw new g("json.schema_valid","missing schema arg");let r=await Rt(e.schema),n=await X(t,"utf-8"),a;try{a=JSON.parse(n)}catch(c){throw new g("json.schema_valid",`file is not valid JSON: ${c.message}`)}return r(a)===!0}};var Mt=Nt(Ot);async function Ge(t,e,r={}){let n=r.handlerRegistry??Xe;for(let a=0;a<e.length;a++){let c=e[a],m=We(c);if(m.kind==="script"){await Bt(m.scriptPath,t);continue}let y=n[m.key];if(!y)throw new L(m.key);let A=r.handlerArgsByIndex?.[a],i=await y(t,A);$t(m,i)}}function $t(t,e){switch(t.kind){case"comparison":{let{key:r,op:n,value:a}=t,c=!1;if(n==="<"?c=e<a:n===">"?c=e>a:n==="<="?c=e<=a:n===">="?c=e>=a:n==="=="?c=e==a:n==="!="&&(c=e!=a),!c)throw new C(r,e,`${n} ${a}`);break}case"between":{let{key:r,min:n,max:a}=t;if(e<n||e>a)throw new C(r,e,`between ${n} and ${a}`);break}case"in":{let{key:r,values:n}=t;if(!n.includes(e))throw new C(r,e,`in [${n.join(", ")}]`);break}case"matches":{let{key:r,regexSource:n,regexFlags:a}=t;if(!zt(String(e),n,a,100))throw new C(r,e,`matches /${n}/${a}`);break}}}async function Bt(t,e){if(!Dt(t))throw new g("script",`script path must be absolute: ${t}`);try{await Mt(t,[e],{timeout:6e4,maxBuffer:1024*1024})}catch(r){let n=r;if(n.code==="ENOENT")throw new g("script",`script not found: ${t}`);let a=n.exitCode;throw new C("script:"+Pt(t),a??"error",n.stderr?.trim()??n.message)}}function zt(t,e,r,n){let a={value:t,regex:new RegExp(e,r),result:!1};Ye.createContext(a);try{return Ye.runInContext("result = regex.test(value)",a,{timeout:n}),a.result}catch(c){throw new g("matches",`regex evaluation timeout or error: ${c.message}`)}}le();var Kt="execution-tools",Pr="mcp__execution-tools__",Mr=["mcp__execution-tools__write_artifact","mcp__execution-tools__publish_artifact_file","mcp__execution-tools__send_to_channel","mcp__execution-tools__report_blocked","mcp__execution-tools__commit_claim","mcp__execution-tools__save_memory","mcp__execution-tools__delete_memory"],$r=["mcp__execution-tools__list_channels","mcp__execution-tools__read_artifact","mcp__execution-tools__fetch_artifact_file","mcp__execution-tools__list_artifacts","mcp__execution-tools__search_memories"],Br=["mcp__execution-tools__write_artifact","mcp__execution-tools__publish_artifact_file","mcp__execution-tools__send_to_channel","mcp__execution-tools__report_blocked","mcp__execution-tools__commit_claim","mcp__execution-tools__save_memory","mcp__execution-tools__delete_memory","mcp__execution-tools__list_channels","mcp__execution-tools__read_artifact","mcp__execution-tools__fetch_artifact_file","mcp__execution-tools__list_artifacts","mcp__execution-tools__search_memories"],U=Z("execution"),qt=/^[\p{L}0-9._-]{1,256}$/u,Ht=/^[\p{L}0-9._-]{1,128}$/u,ne=256*1024,Qe=/^[a-z]+\/[a-z0-9.+-]+$/;async function Ut(t){let{listChannels:e}=await import("./channels-2TWTBE6Y.js"),r=e(),{listSessions:n}=await import("./session-manager-XFUKWEC7.js"),a=[...n("active"),...n("archived")],{getDefaultChatIdForChannel:c}=await import("./target-resolution-RLNUCT6M.js"),m=r.find(A=>A.name.toLowerCase().includes(t.toLowerCase()));if(!m)return null;let y=c(m,a)??"";return{channelId:m.id,chatId:y}}function l(t){return{content:[{type:"text",text:JSON.stringify(t)}]}}function se(t){return qt.test(t)?null:"Invalid artifact key. Use only letters, numbers, dot, underscore, or dash (1-256 chars)."}function ye(t){return Ht.test(t)?null:"Invalid stepId format. Use only letters, numbers, dot, underscore, or dash (1-128 chars)."}function Ze(t,e,r){return t!==e?t:Y(r)}function et(t,e){let r=ie(t);if(!r)return null;let n=oe(r.templateId);return n?n.steps.find(m=>m.id===e)?.outputAs??null:null}var Wt=t=>{if(!t)return!1;let e=j(t);return!!(e?.parentId&&e.templateId&&e.stepId)};function co(t,e,r){let n=t?ue(t):void 0,a=r??(()=>{}),c=async()=>{if(!e)return{error:"artifact tools require a task context"};let i=j(e);if(!i)return{error:`task not found: ${e}`};let o=i.roleId??t;if(!o)return{error:"this template execution task has no role context"};let p=ue(o);return p?{taskId:e,roleId:o,roleWorkspacePath:Re(p.name)}:{error:`role not found: ${o}`}},m=async()=>{let i=await c();if("error"in i)return i;let o=j(i.taskId);return o.parentId?o.stepId?{executionId:o.parentId,stepId:o.stepId,roleId:i.roleId,roleWorkspacePath:i.roleWorkspacePath,taskId:i.taskId}:{error:"this task is not a TemplateExecution step (no step_id)"}:{error:"this task is not a TemplateExecution step (no execution context)"}},y=[...je(t),M("list_channels","List all available channels. Use this to discover what channels can be used with send_to_channel.",{},async()=>{let{listChannels:i}=await import("./channels-2TWTBE6Y.js"),o=i();return l({channels:o.map(p=>({id:p.id,name:p.name,enabled:p.enabled,type:p.config?.type??"unknown"}))})}),M("send_to_channel","Send a message to a connected channel by name. This role can only send to channels in its allowedChannels list (if configured).",{channelName:d.string().describe("The channel name, e.g., 'WeChat on iPad' or 'Client Mail'"),message:d.string().describe("The message content to send")},async i=>{if(n?.allowedChannels!==void 0){if(n.allowedChannels.length===0)return l({error:"This role is not allowed to send to any channels"});if(!n.allowedChannels.some(u=>u.toLowerCase()===i.channelName.toLowerCase()))return l({error:`Channel "${i.channelName}" is not in the allowed channels list for this role`})}let o=await Ut(i.channelName);if(!o)return l({error:`Channel "${i.channelName}" not found or has no chatId available`});let{getOutboundGateway:p}=await import("./outbound-gateway-NJNSN2ZX.js"),s=await p().send({channelId:o.channelId,chatId:o.chatId,content:i.message,messageType:"reply"});return l({success:s.success,channelName:i.channelName})}),M("write_artifact","Persist a small structured value (JSON <= 256KB) for downstream TemplateExecution steps to read. USE THIS for: extracted fields, status flags, URL lists, summaries, structured key-value data. Do NOT use for: files (audio, video, reports). For files use publish_artifact_file instead.",{key:d.string().describe("Artifact key \u2014 a unique identifier for this value within the template execution."),value:d.unknown().describe("The JSON value to persist (must be <= 256KB serialized)."),priority:d.number().int().min(0).max(1e3).optional().describe("Lower = higher priority for delivery packing. Use 10 for primary deliverables (audio/video), 50 for text/markdown, 100 for images. Omit to use server-side heuristic.")},async i=>{let o=await m();if("error"in o)return l({error:o.error});if(i.priority!==void 0&&(i.priority<0||i.priority>1e3||!Number.isInteger(i.priority)))return l({error:`Invalid priority: ${i.priority}. Must be an integer between 0 and 1000.`});let p=se(i.key);if(p)return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:i.key,outcome:"denied",errorReason:p}),l({error:p});let x=et(o.executionId,o.stepId),s=ie(o.executionId),h=s?oe(s.templateId):null,u=h?h.steps.some(_=>_.id===o.stepId):!1,w=i.key,$,G=h!=null&&h.steps.some(_=>!!_.outputAs);if(x===null&&u&&G){let _=`Step "${o.stepId}" in template "${s.templateId}" has no outputAs declared. This template must be migrated before its steps can publish artifacts. Operator action required: run \`pnpm tsx scripts/migrate-all-templates-outputAs.ts --apply\` from the project root, or have the operator ask ChatManager in chat to upgrade the template.`;return U.warn({taskId:o.taskId,stepId:o.stepId,templateId:s.templateId},"write_artifact: step has no outputAs in migrated template"),I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:i.key,outcome:"denied",errorReason:_}),l({error:_})}x&&i.key!==x&&(w=x,$=`key '${i.key}' replaced with step.outputAs '${x}'`,U.warn({taskId:o.taskId,llmKey:i.key,outputAs:x},"write_artifact: server key override"));let Q=h?.steps?.find(_=>_.id===o.stepId),T=Q?Be(Q,i.value):!1;try{let _=he(),v,S;if(T){let R=i.value;if(v=Buffer.byteLength(R,"utf8"),v>ne){let O=`Artifact text exceeds ${ne} bytes`;return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:i.key,sizeBytes:v,outcome:"denied",errorReason:O}),l({error:O})}S=Lt(xe(o.executionId),`${_}.bin`),jt(S,R,"utf8")}else{let R=JSON.stringify(i.value);if(v=Buffer.byteLength(R,"utf8"),v>ne){let O=`Artifact JSON exceeds ${ne} bytes`;return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:i.key,sizeBytes:v,outcome:"denied",errorReason:O}),l({error:O})}}return J({id:_,sourceKind:"template_step",executionId:o.executionId,stepId:o.stepId,key:w,...T?{kind:"file",blobPath:S,mime:"text/markdown",originalFilename:`${w}.md`}:{kind:"json",value:i.value},sizeBytes:v,createdAt:Date.now(),roleId:o.roleId,priority:i.priority}),D({toolName:"write_artifact",entityType:"artifact",verb:"create",entityId:_,fieldChanges:[{path:"_entity",op:"set",before:null,after:{artifactId:_,key:w,kind:T?"file":"json",taskId:o.taskId}}],taskId:o.taskId,roleId:o.roleId}),I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:w,artifactId:_,sizeBytes:v,outcome:"success"}),l({success:!0,artifactId:_,sizeBytes:v,...$?{note:$}:{}})}catch(_){let v=_ instanceof Error?_.message:String(_);return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"write_artifact",artifactKey:i.key,outcome:"error",errorReason:v}),l({error:v})}}),M("read_artifact","Read a structured value previously written by an upstream step's write_artifact. Returns the JSON value. For files, use fetch_artifact_file instead.",{stepId:re.describe("TemplateExecution step ID of the artifact's source step."),key:d.string().describe("Artifact key \u2014 a unique identifier for this value within the template execution.")},async i=>{let o=await m();if("error"in o)return l({error:o.error});let p=ye(i.stepId),x=se(i.key),s=p??x;if(s)return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"read_artifact",artifactKey:i.key,outcome:"denied",errorReason:s}),l({error:s});let h=ee(o.executionId,i.stepId,i.key);if(!h){let u=`no artifact at ${i.stepId}/${i.key}`;return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"read_artifact",artifactKey:i.key,outcome:"error",errorReason:u}),l({error:u})}if(h.kind!=="json"){let u="artifact is a file; use fetch_artifact_file";return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"read_artifact",artifactKey:i.key,artifactId:h.id,sizeBytes:h.sizeBytes,outcome:"denied",errorReason:u}),l({error:u})}return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"read_artifact",artifactKey:i.key,artifactId:h.id,sizeBytes:h.sizeBytes,outcome:"success"}),l({value:h.value,sizeBytes:h.sizeBytes})}),M("publish_artifact_file",'REQUIRED final action for any TemplateExecution step that produces a file deliverable. If your step declares outputAs and you finish work (writing audio/video/report/image to disk via Write, Edit, or Bash) WITHOUT calling this tool, the step is marked FAILED \u2014 downstream steps and delivery rules will not see your file, regardless of whether your work succeeded. "I wrote a file to my workspace" is NOT the same as "I published an artifact": the file must be registered through this call to count. Call this AFTER the file is fully written to disk, BEFORE ending your turn. The file is COPIED to template execution shared storage. USE for: generated audio, video, reports, images, large outputs. Do NOT use for small structured JSON values (<=256KB) \u2014 use write_artifact instead. sourcePath must be inside your role workspace (~/.adam/roles/<your-role>/...); if your file was written to an additionalDirectories location (InfoHub/PKOS/Code/etc.), Bash-copy it into the workspace first then publish from there. cleanup=true deletes the source after publish \u2014 only set when you no longer need the source file (the step becomes non-retryable through publish).',{key:d.string().describe("Artifact key \u2014 a unique identifier for this value within the template execution."),sourcePath:me.describe("Source file path in the Role workspace to publish as a TemplateExecution artifact."),mime:d.string().optional().describe("MIME type of the file (e.g., 'image/png', 'audio/mp3'). Auto-detected if omitted."),cleanup:d.boolean().optional().describe("If true, delete the source file after publishing. Only use when the source file is no longer needed."),priority:d.number().int().min(0).max(1e3).optional().describe("Lower = higher priority for delivery packing. Use 10 for primary deliverables (audio/video), 50 for text/markdown, 100 for images. Omit to use server-side heuristic."),role:d.string().optional().describe("Logical artifact role. REQUIRED when the step's outputContract declares expectedArtifacts \u2014 use one of the declared roles (e.g. 'podcast', 'song'). Publishing more than the declared count for a role, or an undeclared role, is rejected.")},async i=>{let o=await c();if("error"in o)return l({error:o.error});if(i.priority!==void 0&&(i.priority<0||i.priority>1e3||!Number.isInteger(i.priority)))return l({error:`Invalid priority: ${i.priority}. Must be an integer between 0 and 1000.`});let p=j(o.taskId);if(!!!(p.parentId&&p.templateId&&p.stepId)){if(i.mime&&!Qe.test(i.mime))return l({error:`Invalid MIME type: ${i.mime}`});try{te(i.sourcePath,o.roleWorkspacePath,!0)}catch(b){return l({error:b instanceof Error?b.message:String(b)})}let f=he(),E=null,N=!1;try{let b=Ee({kind:"task",artifactId:f,sourcePath:i.sourcePath});E=b.blobPath;let W={id:f,sourceKind:"task_published",taskId:o.taskId,roleId:o.roleId,kind:"file",blobPath:E,mime:i.mime,originalFilename:Y(i.sourcePath),sizeBytes:b.sizeBytes,createdAt:Date.now(),priority:i.priority};return J(W),N=!0,i.cleanup===!0&&ce(i.sourcePath),D({toolName:"publish_artifact_file",entityType:"artifact",verb:"create",entityId:f,fieldChanges:[{path:"_entity",op:"set",before:null,after:{artifactId:f,kind:"file",filename:Y(i.sourcePath),taskId:o.taskId,sourceKind:"task_published"}}],taskId:o.taskId,roleId:o.roleId}),U.info({taskId:o.taskId,roleId:o.roleId,artifactId:f,sizeBytes:b.sizeBytes},"publish_artifact_file task_published: success"),l({success:!0,artifactId:f,sizeBytes:b.sizeBytes})}catch(b){if(N)try{ae(f)}catch{}if(E)try{de(E)}catch{}let W=b instanceof Error?b.message:String(b);return U.warn({taskId:o.taskId,roleId:o.roleId,artifactId:f,err:b},"publish_artifact_file task_published: failed"),l({error:W})}}let s={executionId:p.parentId,stepId:p.stepId,roleId:o.roleId,roleWorkspacePath:o.roleWorkspacePath,taskId:o.taskId},h=se(i.key);if(h)return I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:i.key,outcome:"denied",errorReason:h}),l({error:h});if(i.mime&&!Qe.test(i.mime)){let f=`Invalid MIME type: ${i.mime}`;return I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:i.key,outcome:"denied",errorReason:f}),l({error:f})}let u=et(s.executionId,s.stepId),w=ie(s.executionId),$=w?oe(w.templateId):null,G=$?$.steps.find(f=>f.id===s.stepId)??null:null,Q=G!=null,T=i.key,_,v=$!=null&&$.steps.some(f=>!!f.outputAs);if(u===null&&Q&&v){let f=`Step "${s.stepId}" in template "${w.templateId}" has no outputAs declared. This template must be migrated before its steps can publish artifacts. Operator action required: run \`pnpm tsx scripts/migrate-all-templates-outputAs.ts --apply\` from the project root, or have the operator ask ChatManager in chat to upgrade the template.`;return U.warn({taskId:s.taskId,stepId:s.stepId,templateId:w.templateId},"publish_artifact_file: step has no outputAs in migrated template"),I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:i.key,outcome:"denied",errorReason:f}),l({error:f})}u&&i.key!==u&&(T=u,_=`key '${i.key}' replaced with step.outputAs '${u}'`,U.warn({taskId:s.taskId,llmKey:i.key,outputAs:u},"publish_artifact_file: server key override"));try{te(i.sourcePath,s.roleWorkspacePath,!0)}catch(f){let E=f instanceof Error?f.message:String(f);return I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:T,outcome:"denied",errorReason:E}),l({error:E})}let S=he(),R=null,O=!1,F=null;try{let f=we({executionId:s.executionId,artifactId:S,sourcePath:i.sourcePath});R=f.blobPath;let E=G?.assertions??[];E.length>0&&await Ge(R,E);let N={id:S,sourceKind:"template_step",executionId:s.executionId,stepId:s.stepId,key:T,kind:"file",blobPath:R,mime:i.mime,originalFilename:Y(i.sourcePath),sizeBytes:f.sizeBytes,createdAt:Date.now(),roleId:s.roleId,priority:i.priority,...i.role!==void 0?{artifactRole:i.role}:{}};if(u&&v){let b=ee(s.executionId,s.stepId,u);if(!b)J(N),O=!0,F=N;else if(b.kind==="file")F=ke(s.executionId,s.stepId,u,b,{...N,key:Ze(i.key,u,i.sourcePath)}).childArtifact;else if(b.kind==="json"&&be(b.value))F=ge(s.executionId,s.stepId,u,{...N,key:Ze(i.key,u,i.sourcePath)}).childArtifact;else throw new Error(`Artifact key "${u}" already contains a non-collection JSON artifact`)}else J(N),O=!0,F=N;return i.cleanup===!0&&ce(i.sourcePath),D({toolName:"publish_artifact_file",entityType:"artifact",verb:"create",entityId:S,fieldChanges:[{path:"_entity",op:"set",before:null,after:{artifactId:S,key:F?.key??T,kind:"file",filename:Y(i.sourcePath),taskId:s.taskId}}],taskId:s.taskId,roleId:s.roleId}),I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:F?.key??T,artifactId:S,sizeBytes:f.sizeBytes,outcome:"success"}),l({success:!0,artifactId:S,sizeBytes:f.sizeBytes,..._?{note:_}:{}})}catch(f){if(O)try{ae(S)}catch{}if(R&&(!F||O))try{de(R)}catch{}let E=f instanceof Error?f.message:String(f);if(I({timestamp:Date.now(),taskId:s.taskId,roleId:s.roleId,executionId:s.executionId,stepId:s.stepId,tool:"publish_artifact_file",artifactKey:T,artifactId:S,outcome:"error",errorReason:E}),f instanceof C||f instanceof L)try{let b=(K().prepare("SELECT COUNT(*) as n FROM step_logs WHERE task_id = ?").get(s.taskId)?.n??0)+1;Te({id:`step-${Date.now()}-${Math.random().toString(36).slice(2,8)}`,taskId:s.taskId,index:b,type:"validator_error",content:f.message,toolName:"publish_artifact_file",timestamp:Date.now()})}catch{}return l({error:E})}}),M("fetch_artifact_file","Copy an upstream step's published file into your current Role workspace. Use this when an earlier step published audio, video, reports, or other files you need to process.",{stepId:re.describe("TemplateExecution step ID of the artifact's source step."),key:d.string().describe("Artifact key \u2014 a unique identifier for this value within the template execution."),destPath:me.describe("Destination path in the Role workspace where the file will be copied.")},async i=>{let o=await m();if("error"in o)return l({error:o.error});let p=ye(i.stepId),x=se(i.key),s=p??x;if(s)return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,outcome:"denied",errorReason:s}),l({error:s});try{te(i.destPath,o.roleWorkspacePath,!1)}catch(u){let w=u instanceof Error?u.message:String(u);return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,outcome:"denied",errorReason:w}),l({error:w})}let h=ee(o.executionId,i.stepId,i.key);if(!h){let u=`no artifact at ${i.stepId}/${i.key}`;return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,outcome:"error",errorReason:u}),l({error:u})}if(h.kind!=="file"||!h.blobPath){let u="artifact is not a file";return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,artifactId:h.id,outcome:"denied",errorReason:u}),l({error:u})}try{let u=ve({blobPath:h.blobPath,destPath:i.destPath});return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,artifactId:h.id,sizeBytes:u.sizeBytes,outcome:"success"}),l({success:!0,sizeBytes:u.sizeBytes,mime:h.mime,destPath:i.destPath})}catch(u){let w=u instanceof Error?u.message:String(u);return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"fetch_artifact_file",artifactKey:i.key,artifactId:h.id,outcome:"error",errorReason:w}),l({error:w})}}),M("list_artifacts","Discover artifacts published by upstream steps in this template execution. Returns step_id, key, kind ('json' or 'file'), size, mime. Use this to learn what is available before calling read_artifact or fetch_artifact_file.",{stepId:re.optional().describe("Filter to a specific TemplateExecution step (omit to list all artifacts in the execution).")},async i=>{let o=await m();if("error"in o)return l({error:o.error});let p=i.stepId?ye(i.stepId):null;if(p)return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"list_artifacts",outcome:"denied",errorReason:p}),l({error:p});let x=_e(o.executionId,i.stepId);return I({timestamp:Date.now(),taskId:o.taskId,roleId:o.roleId,executionId:o.executionId,stepId:o.stepId,tool:"list_artifacts",sizeBytes:x.length,outcome:"success"}),l({artifacts:x.map(s=>({id:s.id,stepId:s.stepId,key:s.key,kind:s.kind,sizeBytes:s.sizeBytes,mime:s.mime,createdAt:s.createdAt}))})}),M("report_blocked","Report that the task cannot proceed due to a missing prerequisite (e.g., missing credential, missing input, missing target). This sets the task status to 'blocked', stores the reason for the UI to display, and aborts the execution loop.",{reason:d.string().describe("Short reason, e.g. 'missing_credential', 'missing_target', 'missing_input'"),missingPrereqs:d.array(d.string()).optional().describe("Specific keys/IDs that are missing, e.g. ['MINIMAX_API_KEY']"),resumeHint:d.string().optional().describe("How the user can unblock, e.g. 'set MINIMAX_API_KEY in role env'")},async i=>{if(!e)return l({error:"report_blocked requires a task context (taskId not available)"});let o=j(e);if(!o)return l({error:`task not found: ${e}`});let p={reason:i.reason,missingPrereqs:i.missingPrereqs,resumeHint:i.resumeHint};return Ce(e,{status:"blocked",blockReason:p,completedAt:Date.now()}),Oe.emit({type:"task_status_change",taskId:e,oldStatus:o.status,newStatus:"blocked"}),D({toolName:"report_blocked",entityType:"task",verb:"update",entityId:e,fieldChanges:[{path:"status",op:"set",before:o.status,after:"blocked"},{path:"blockReason",op:"set",before:void 0,after:i.reason},{path:"completedAt",op:"set",before:void 0,after:Date.now()}],taskId:e,roleId:o.roleId}),a(),l({success:!0,blocked:!0,reason:i.reason})}),M("commit_claim","Declare structured claims about what this worker task just did so the audit engine can verify against effect receipts. Call this in the SAME task turn before reporting completion text. Mirror of the ChatManager tool \u2014 workers may also need to declare claims for actions taken inside template execution steps.",{claims:d.array(d.object({verb:d.string().min(1).describe("What was done: 'send', 'update', 'create', 'delete', 'cancel', 'enable', 'disable', 'bind', 'unbind', etc."),entityType:d.string().min(1).describe("What kind of thing was affected: 'channel_message', 'task_template', 'task', 'goal', 'role', 'delivery_rule', 'plugin', 'mcp_binding', 'config_field', etc."),expected:d.discriminatedUnion("kind",[d.object({kind:d.literal("outbound").describe("Used when verb='send' \u2014 declares a channel message was sent."),target:d.object({channelId:d.string().min(1).describe("Channel that received the message."),chatId:d.string().min(1).optional().describe("Specific chat within the channel; omit for any chat.")}).describe("Where the message went."),attachmentCount:d.number().int().min(0).optional().describe("How many attachments were sent. Verifier requires receipt.attachmentCount >= this."),textPresent:d.boolean().optional().describe("Whether the message body had non-empty text. Verifier requires receipt.textChars > 0 when true.")}),d.object({kind:d.literal("field_change").describe("Used for single-entity updates \u2014 declares a specific field on a specific entity changed."),entityId:d.string().min(1).describe("Identifier of the entity that was changed."),fieldPath:d.string().min(1).describe("Dotted path to the field that changed, e.g. 'deliverTo', 'cron', 'config.timeout'."),op:d.enum(["set","list_add","list_remove"]).describe("How the field changed: scalar set, list append, or list removal."),added:d.array(d.unknown()).min(1).optional().describe("Items appended when op='list_add'. Verifier accepts a superset (receipt may have appended more items)."),removed:d.array(d.unknown()).min(1).optional().describe("Items removed when op='list_remove'. Verifier accepts a superset."),after:d.unknown().optional().describe("New value when op='set'. Verifier requires deep-equal match.")}),d.object({kind:d.literal("batch").describe("Used for batch operations like cancel-many or delete-many."),entityType:d.string().min(1).describe("Restrict matching to this entity type."),entityIds:d.array(d.string()).min(1).optional().describe("Specific entity IDs affected. Verifier checks receipt.entityIds is a superset."),scope:d.object({filter:d.string().min(1).describe("Free-text description of the filter applied (e.g., 'status=running AND role_id=role-x'). Verifier ignores this; human-readable only."),expectedCount:d.number().int().min(0).describe("Minimum number of entities expected to have been affected. Verifier requires receipt.scope.matchedCount >= this.")}).optional().describe("Filter+count for scope-based batches when individual IDs aren't enumerated.")})]).describe("Structured expectation matched against effect_receipts. Pick the kind that fits the action."),note:d.string().optional().describe("Free-text human note kept in the audit log only. Verifier ignores this.")})).min(1).max(20).describe("One or more claims declaring exactly what just happened. Each claim is verified independently against receipts.")},async i=>{let o=Se();if(!o)return l({error:"commit_claim requires an active trace context"});try{let p=He({traceId:o,taskId:e,claims:i.claims});return l({claimRowId:p.id,claimsCount:p.claims.length,declaredAt:p.declaredAt})}catch(p){let x=p instanceof Error?p.message:String(p);return l({error:x})}})],A=Wt(e)?y.filter(i=>i.name!=="list_channels"&&i.name!=="send_to_channel"):y;return Ft({name:Kt,version:"1.0.0",tools:A})}export{je as a,He as b,dr as c,Xe as d,Kt as e,Pr as f,Mr as g,$r as h,Br as i,qt as j,co as k};
@@ -0,0 +1,10 @@
1
+ import{h as c}from"./chunk-V2MMQ3SH.js";import{K as u,L as p}from"./chunk-2A2TXYT3.js";import{n as s,p as f}from"./chunk-WY5BOCQP.js";f();p();function r(e){return{id:e.id,roleId:e.role_id,content:e.content,isAnti:e.is_anti===1,evidenceObsIds:e.evidence_obs_ids?JSON.parse(e.evidence_obs_ids):[],embedding:e.embedding?new Float32Array(e.embedding.buffer,e.embedding.byteOffset,e.embedding.byteLength/4):void 0,supersededBy:e.superseded_by??void 0,createdAt:e.created_at,lastUsedAt:e.last_used_at,lastValidatedAt:e.last_validated_at,scopeKey:e.scope_key??void 0,status:e.status,successEma:e.success_ema??void 0,injectCount:e.inject_count??0}}function _(e){return Buffer.from(e.buffer,e.byteOffset,e.byteLength)}function g(e){let t=s(),n=e.lastUsedAt??u(e.roleId);t.prepare(`
2
+ INSERT INTO beliefs (id, role_id, content,
3
+ is_anti, evidence_obs_ids, embedding, superseded_by,
4
+ created_at, last_used_at, last_validated_at,
5
+ scope_key, status, success_ema, inject_count)
6
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
7
+ `).run(e.id,e.roleId,e.content,e.isAnti?1:0,JSON.stringify(e.evidenceObsIds),e.embedding?_(e.embedding):null,e.supersededBy??null,e.createdAt,n,e.lastValidatedAt,e.scopeKey??null,e.status??"active",e.successEma??null,e.injectCount??0)}function y(e){let n=s().prepare("SELECT * FROM beliefs WHERE id = ?").get(e);return n?r(n):void 0}function A(e,t){let n=s(),d=["role_id = ?"],l=[e];return t?.includeSuperseded||d.push("superseded_by IS NULL"),t?.includeAnti===!1&&d.push("is_anti = 0"),t?.onlyActive&&d.push("status = 'active'"),n.prepare(`SELECT * FROM beliefs WHERE ${d.join(" AND ")} ORDER BY last_used_at DESC`).all(...l).map(r)}function B(e,t,n){let a=s().prepare(`SELECT * FROM beliefs
8
+ WHERE role_id = ? AND embedding IS NOT NULL AND superseded_by IS NULL AND status = 'active'
9
+ ORDER BY last_used_at DESC
10
+ LIMIT ?`).all(e,Math.min(n*10,1e3)).map(i=>({node:r(i),cosine:i.embedding?c(t,new Float32Array(i.embedding.buffer,i.embedding.byteOffset,i.embedding.byteLength/4)):0})).filter(i=>i.cosine>=0);return a.sort((i,o)=>o.cosine-i.cosine),a.slice(0,n)}function S(e,t){s().prepare("UPDATE beliefs SET superseded_by = ? WHERE id = ?").run(t,e)}function R(e,t){s().prepare("UPDATE beliefs SET content = ?, is_anti = 1, last_validated_at = ? WHERE id = ?").run(t,Date.now(),e)}function v(e,t,n){let d=s();n?.scopeKey!==void 0?d.prepare("UPDATE beliefs SET status = ?, scope_key = COALESCE(?, scope_key) WHERE id = ?").run(t,n?.scopeKey??null,e):d.prepare("UPDATE beliefs SET status = ? WHERE id = ?").run(t,e)}function T(e,t,n){s().prepare("UPDATE beliefs SET success_ema = ?, last_used_at = ?, last_validated_at = ? WHERE id = ?").run(t,n,Date.now(),e)}function D(e){s().prepare("UPDATE beliefs SET inject_count = inject_count + 1 WHERE id = ?").run(e)}export{g as a,y as b,A as c,B as d,S as e,R as f,v as g,T as h,D as i};
@@ -1,4 +1,4 @@
1
- import{n as o,p as a}from"./chunk-QL2ZOLMC.js";import{c as u,e as c}from"./chunk-245WE5AF.js";a();c();import{v4 as p}from"uuid";function R(t){o().prepare(`
1
+ import{n as o,p as a}from"./chunk-WY5BOCQP.js";import{c as u,e as c}from"./chunk-5M6IGE5G.js";a();c();import{v4 as p}from"uuid";function R(t){o().prepare(`
2
2
  INSERT INTO evolution_audit (id, timestamp, old_rules, new_rules, diff, trigger_task_id, role_id, source, trace_id)
3
3
  VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)
4
4
  `).run(p(),t.timestamp,t.oldRules,t.newRules,t.diff,t.triggerTaskId??null,t.roleId??null,t.source??"reflection",t.traceId??u()??null)}function _(t=100,e=0){return o().prepare(`
@@ -0,0 +1,80 @@
1
+ import{k as D}from"./chunk-IEBAOZED.js";import{c as L,p as K}from"./chunk-2A2TXYT3.js";import{a as M,e as E}from"./chunk-3MROEPGR.js";import{n as y,p as W}from"./chunk-WY5BOCQP.js";import{c as b,h as w}from"./chunk-EZLBMUQD.js";W();function N(m){if(m.length===0)return;let s=y(),e=s.prepare(`
2
+ INSERT OR IGNORE INTO llm_costs
3
+ (id, call_id, source, model, role_id, task_id, session_id, message_id,
4
+ input_tokens, output_tokens, cache_read_tokens, cache_creation_tokens,
5
+ cost_usd, priced, estimated, sdk_total_cost_usd, num_turns, created_at)
6
+ VALUES
7
+ (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
8
+ `);s.transaction(i=>{for(let o of i)e.run(o.id,o.callId,o.source,o.model,o.roleId??null,o.taskId??null,o.sessionId??null,o.messageId??null,o.inputTokens,o.outputTokens,o.cacheReadTokens,o.cacheCreationTokens,o.costUsd,o.priced,o.estimated,o.sdkTotalCostUsd??null,o.numTurns??null,o.createdAt)})(m)}var R=new Set(["model","role","source","date"]),O=new Set(["day","week","month"]),B=new Set(["source","model"]);async function X(m){let{from:s,to:e,groupBy:c,granularity:i,trendStackBy:o}=m;if(!R.has(c))throw new Error(`Invalid groupBy: ${c}. Must be one of ${[...R].join(", ")}`);if(!O.has(i))throw new Error(`Invalid granularity: ${i}. Must be one of ${[...O].join(", ")}`);if(o!==void 0&&!B.has(o))throw new Error(`Invalid trendStackBy: ${o}. Must be one of ${[...B].join(", ")}`);let a=y(),p=`datetime(created_at / 1000 + (${Math.trunc(m.tzOffsetMinutes??0)*60}), 'unixepoch')`,d;c==="model"?d="model":c==="role"?d="COALESCE(role_id, 'system')":c==="source"?d="source":d=`strftime('%Y-%m-%d', ${p})`;let U=a.prepare(`
9
+ SELECT
10
+ ${d} AS key,
11
+ SUM(cost_usd) AS costUsd,
12
+ SUM(input_tokens) AS inputTokens,
13
+ SUM(output_tokens) AS outputTokens,
14
+ SUM(cache_read_tokens) AS cacheReadTokens,
15
+ SUM(cache_creation_tokens) AS cacheCreationTokens,
16
+ COUNT(DISTINCT call_id) AS callCount
17
+ FROM llm_costs
18
+ WHERE created_at >= ? AND created_at <= ?
19
+ GROUP BY key
20
+ ORDER BY costUsd DESC
21
+ `).all(s,e).map(n=>({key:n.key,costUsd:n.costUsd??0,inputTokens:n.inputTokens??0,outputTokens:n.outputTokens??0,cacheReadTokens:n.cacheReadTokens??0,cacheCreationTokens:n.cacheCreationTokens??0,callCount:n.callCount??0})),k=a.prepare(`
22
+ SELECT
23
+ SUM(cost_usd) AS totalCostUsd,
24
+ SUM(input_tokens) AS inputTokens,
25
+ SUM(output_tokens) AS outputTokens,
26
+ SUM(cache_read_tokens) AS cacheReadTokens,
27
+ SUM(cache_creation_tokens) AS cacheCreationTokens,
28
+ COUNT(DISTINCT call_id) AS callCount
29
+ FROM llm_costs
30
+ WHERE created_at >= ? AND created_at <= ?
31
+ `).get(s,e),r=a.prepare(`
32
+ SELECT
33
+ COUNT(DISTINCT call_id) AS unpricedCallCount,
34
+ SUM(input_tokens + output_tokens) AS unpricedTokens
35
+ FROM llm_costs
36
+ WHERE created_at >= ? AND created_at <= ? AND priced = 0
37
+ `).get(s,e),f=a.prepare(`
38
+ SELECT model
39
+ FROM llm_costs
40
+ WHERE created_at >= ? AND created_at <= ?
41
+ GROUP BY model
42
+ ORDER BY SUM(cost_usd) DESC
43
+ LIMIT 1
44
+ `).get(s,e),T;i==="day"?T="%Y-%m-%d":i==="week"?T="%Y-W%W":T="%Y-%m";let C=a.prepare(`
45
+ SELECT
46
+ strftime('${T}', ${p}) AS bucket,
47
+ SUM(cost_usd) AS costUsd,
48
+ COUNT(DISTINCT call_id) AS callCount
49
+ FROM llm_costs
50
+ WHERE created_at >= ? AND created_at <= ?
51
+ GROUP BY bucket
52
+ ORDER BY bucket ASC
53
+ `).all(s,e),g,l;if(o!==void 0){let n=o==="source"?"source":"model",F=a.prepare(`
54
+ SELECT
55
+ strftime('${T}', ${p}) AS bucket,
56
+ ${n} AS stackKey,
57
+ SUM(cost_usd) AS costUsd
58
+ FROM llm_costs
59
+ WHERE created_at >= ? AND created_at <= ?
60
+ GROUP BY bucket, stackKey
61
+ ORDER BY bucket ASC
62
+ `).all(s,e),h=new Set,I=new Map;for(let S of F){let A=S.stackKey??"unknown";h.add(A);let _=I.get(S.bucket);_||(_={bucket:S.bucket},I.set(S.bucket,_)),_[A]=(_[A]??0)+(S.costUsd??0)}l=[...h],g=[...I.values()]}return{totalCostUsd:k?.totalCostUsd??0,callCount:k?.callCount??0,topModel:f?.model,tokens:{input:k?.inputTokens??0,output:k?.outputTokens??0,cacheRead:k?.cacheReadTokens??0,cacheCreation:k?.cacheCreationTokens??0},unpricedCallCount:r?.unpricedCallCount??0,unpricedTokens:r?.unpricedTokens??0,groups:U,trend:C.map(n=>({bucket:n.bucket,costUsd:n.costUsd??0,callCount:n.callCount??0})),...g?{trendStacked:g,trendStackKeys:l}:{}}}async function q(m){let{groupBy:s,groupKey:e,from:c,to:i}=m;if(!R.has(s))throw new Error(`Invalid groupBy: ${s}. Must be one of ${[...R].join(", ")}`);let o=y(),a,u;s==="model"?(a="model = ?",u=e):s==="role"?(a=e==="system"?"role_id IS NULL":"role_id = ?",u=e):s==="source"?(a="source = ?",u=e):(a=`strftime('%Y-%m-%d', datetime(created_at / 1000 + (${Math.trunc(m.tzOffsetMinutes??0)*60}), 'unixepoch')) = ?`,u=e);let p=s==="role"&&e==="system";return o.prepare(`
63
+ SELECT
64
+ call_id AS callId,
65
+ source,
66
+ model,
67
+ SUM(cost_usd) AS costUsd,
68
+ SUM(input_tokens) AS inputTokens,
69
+ SUM(output_tokens) AS outputTokens,
70
+ MIN(priced) AS priced,
71
+ MIN(created_at) AS createdAt,
72
+ MAX(task_id) AS taskId,
73
+ MAX(session_id) AS sessionId,
74
+ MAX(message_id) AS messageId
75
+ FROM llm_costs
76
+ WHERE created_at >= ? AND created_at <= ?
77
+ AND ${a}
78
+ GROUP BY call_id
79
+ ORDER BY createdAt DESC
80
+ `).all(p?[c,i]:[c,i,u]).map(t=>({callId:t.callId,source:t.source,model:t.model,costUsd:t.costUsd??0,inputTokens:t.inputTokens??0,outputTokens:t.outputTokens??0,priced:t.priced??0,createdAt:t.createdAt,...t.taskId?{taskId:t.taskId}:{},...t.sessionId?{sessionId:t.sessionId}:{},...t.messageId?{messageId:t.messageId}:{}}))}import{randomUUID as j}from"crypto";K();w();var x=b("store");async function $(m){let{source:s,recompute:e,callId:c,roleId:i,taskId:o,sessionId:a,messageId:u,numTurns:p,mirror:d=!0}=m,t=c??j(),U=Date.now();if(d)try{if(s==="task"&&o){let r=e.perModel.reduce((l,n)=>l+n.inputTokens,0),f=e.perModel.reduce((l,n)=>l+n.outputTokens,0),T=e.perModel.reduce((l,n)=>l+n.cacheReadTokens,0),C=e.perModel.reduce((l,n)=>l+n.cacheCreationTokens,0),g={input:r,output:f,cacheRead:T,cacheCreation:C};L(o,{costUsd:e.costUsd,tokenUsage:g,...p!==void 0?{numTurns:p}:{},costBreakdown:e})}else if(s==="chat"&&u){let r=e.perModel.reduce((g,l)=>g+l.inputTokens,0),f=e.perModel.reduce((g,l)=>g+l.outputTokens,0),T=JSON.stringify({input:r,output:f}),C=e.perModel[0]?.model??"unknown";D(u,{costUsd:e.costUsd,tokenUsage:T,model:C})}}catch(r){x.warn({err:r,source:s,taskId:o,messageId:u},"recordLlmCost mirror write failed")}if(e.perModel.length===0)return{callId:t,rowsInserted:0};let k=e.perModel.map((r,f)=>({id:`${t}-${f}`,callId:t,source:s,model:r.model,roleId:i,taskId:o,sessionId:a,messageId:u,inputTokens:r.inputTokens,outputTokens:r.outputTokens,cacheReadTokens:r.cacheReadTokens,cacheCreationTokens:r.cacheCreationTokens,costUsd:r.costUsd,priced:r.priced?1:0,estimated:r.estimated?1:0,sdkTotalCostUsd:e.sdkTotalCostUsd,numTurns:p,createdAt:U}));try{N(k)}catch(r){return x.warn({err:r,callId:t,source:s},"recordLlmCost insertLlmCostRows failed"),{callId:t,rowsInserted:0}}return{callId:t,rowsInserted:k.length}}w();import{query as z}from"@anthropic-ai/claude-agent-sdk";import*as P from"fs/promises";import*as Y from"path";import*as G from"os";var H=b("manager"),v=Y.join(G.homedir(),".adam","llm-eval");async function de(m,s){await P.mkdir(v,{recursive:!0});let e=typeof s=="string"?{systemPrompt:s}:s??{},c={cwd:v,maxTurns:e.maxTurns??3,maxBudgetUsd:e.maxBudgetUsd??.05,persistSession:!1};e.systemPrompt&&(c.systemPrompt=e.systemPrompt),e.model&&(c.model=e.model);let i=z({prompt:m,options:c}),o="",a,u,p;for await(let d of i){let t=d;t.type==="result"&&typeof t.result=="string"&&(o=t.result,typeof t.total_cost_usd=="number"&&(a=t.total_cost_usd),t.modelUsage&&typeof t.modelUsage=="object"&&(u=t.modelUsage),typeof t.num_turns=="number"&&(p=t.num_turns))}if(u)try{let d=E().pricing?.models??{},t=M(u,d,a);$({source:"eval",recompute:t,numTurns:p,mirror:!1})}catch(d){H.warn({err:d},"llm-eval: cost capture failed (non-fatal)")}return o}export{X as a,q as b,$ as c,de as d};
@@ -0,0 +1,2 @@
1
+ import{e as O}from"./chunk-3MROEPGR.js";import{c as A,h as B}from"./chunk-EZLBMUQD.js";B();import*as c from"fs";import*as a from"path";import{homedir as R}from"os";import{createRequire as _}from"module";var k=A("embedding"),L=512,N=a.join(R(),".adam","models"),T={"bge-small-zh-v1.5":{repo:"Xenova/bge-small-zh-v1.5",onnxFile:"onnx/model.onnx",tokenizerFile:"tokenizer.json",dim:512},"paraphrase-multilingual-MiniLM-L12-v2":{repo:"Xenova/paraphrase-multilingual-MiniLM-L12-v2",onnxFile:"onnx/model.onnx",tokenizerFile:"tokenizer.json",dim:384}},S="bge-small-zh-v1.5",C="https://huggingface.co",y=null,j=null,I=null,M=!1,x=null;function E(){try{return O().memory?.embeddingModel??S}catch{return S}}function D(){let o=E();return T[o]??T[S]}function z(){let o=D(),e=a.join(N,o.repo.replace("/","_"));return c.existsSync(e)||c.mkdirSync(e,{recursive:!0}),e}async function v(o,e){if(c.existsSync(e))return;k.info({file:a.basename(e)},"Downloading model file");let t=await fetch(o);if(!t.ok)throw new Error(`Failed to download ${o}: ${t.status}`);let n=Buffer.from(await t.arrayBuffer());c.mkdirSync(a.dirname(e),{recursive:!0}),c.writeFileSync(e,n),k.info({file:a.basename(e),sizeMb:(n.length/1024/1024).toFixed(1)},"Downloaded")}async function $(){let o=D(),e=z(),t=a.join(e,"model.onnx"),n=a.join(e,"tokenizer.json"),i=`${C}/${o.repo}/resolve/main`;return await v(`${i}/${o.onnxFile}`,t),await v(`${i}/${o.tokenizerFile}`,n),{modelPath:t,tokenizerPath:n}}function P(){let o=_(import.meta.url),e=o.resolve("onnxruntime-web"),t=a.dirname(e),n=o(a.join(t,"ort.all.min.js"));return n.env.wasm.wasmPaths=t+"/",n}async function q(){if(M)throw x??new Error("Embedding session unavailable.");if(y&&j){let t=P(),n=z();return{session:y,ort:t,tokenizerPath:a.join(n,"tokenizer.json")}}if(I||(I=(async()=>{try{let{modelPath:t,tokenizerPath:n}=await $(),i=P();k.info({model:E()},"Loading ONNX inference session");let s=c.readFileSync(t),l=s.buffer.slice(s.byteOffset,s.byteOffset+s.byteLength);y=await i.InferenceSession.create(l,{executionProviders:["wasm"]}),j=JSON.parse(c.readFileSync(n,"utf-8")),k.info({model:E()},"Embedding session ready")}catch(t){throw M=!0,x=t instanceof Error?t:new Error(String(t)),k.warn({err:t},"Embedding session failed to load"),x}})()),await I,!y)throw x??new Error("Embedding session unavailable.");let o=P(),e=z();return{session:y,ort:o,tokenizerPath:a.join(e,"tokenizer.json")}}function X(o){let e=[];for(let t of o){let n=t.codePointAt(0)??0;if(n===0||n===65533)continue;if(new RegExp("^\\p{Cc}|\\p{Cf}","u").test(t)){(t===" "||t===`
2
+ `||t==="\r")&&e.push(" ");continue}n>=19968&&n<=40959||n>=13312&&n<=19903||n>=131072&&n<=173791||n>=173824&&n<=177983||n>=177984&&n<=178207||n>=178208&&n<=183983||n>=63744&&n<=64255||n>=194560&&n<=195103?e.push(" ",t," "):e.push(t)}return e.join("")}function G(o){let e=o.codePointAt(0)??0;return e>=33&&e<=47||e>=58&&e<=64||e>=91&&e<=96||e>=123&&e<=126?!0:new RegExp("^\\p{P}","u").test(o)}function U(o){let e=[];for(let t of o.split(/\s+/)){if(!t)continue;let n=[];for(let i of t)G(i)?(n.length>0&&(e.push(n.join("")),n=[]),e.push(i)):n.push(i);n.length>0&&e.push(n.join(""))}return e}function H(o,e,t){let n=Array.from(o);if(n.length>100)return[t];let i=[],s=0;for(;s<n.length;){let l=n.length,u=!1;for(;l>s;){let h=n.slice(s,l).join(""),d=s===0?h:"##"+h;if(d in e){i.push(e[d]),s=l,u=!0;break}l--}if(!u)return[t]}return i}function J(o,e,t=512){let n=e["[CLS]"]??101,i=e["[SEP]"]??102,s=e["[UNK]"]??100,l=e["[PAD]"]??0,u=X(o),h=U(u),d=[];for(let r of h){let b=H(r,e,s);d.push(...b)}let F=d.slice(0,t-2),w=[n,...F,i],m=w.length,f=new BigInt64Array(t),p=new BigInt64Array(t),g=new BigInt64Array(t);for(let r=0;r<t;r++)r<m?(f[r]=BigInt(w[r]),p[r]=1n):(f[r]=BigInt(l),p[r]=0n),g[r]=0n;return{inputIds:f,attentionMask:p,tokenTypeIds:g}}async function V(o){let{session:e,ort:t}=await q(),n=j.model.vocab,{inputIds:i,attentionMask:s,tokenTypeIds:l}=J(o,n),u=i.length,h={input_ids:new t.Tensor("int64",i,[1,u]),attention_mask:new t.Tensor("int64",s,[1,u]),token_type_ids:new t.Tensor("int64",l,[1,u])},d=await e.run(h),w=(d.last_hidden_state??d[Object.keys(d)[0]]).data,m=L,f=new Float32Array(m),p=0;for(let r=0;r<u;r++)if(s[r]===1n){p++;for(let b=0;b<m;b++)f[b]+=w[r*m+b]}if(p>0)for(let r=0;r<m;r++)f[r]/=p;let g=0;for(let r=0;r<m;r++)g+=f[r]*f[r];if(g=Math.sqrt(g),g>0)for(let r=0;r<m;r++)f[r]/=g;return f}function Z(){if(M)return!1;if(y)return!0;try{let o=z();return c.existsSync(a.join(o,"model.onnx"))&&c.existsSync(a.join(o,"tokenizer.json"))}catch{return!1}}export{L as a,V as b,Z as c};
@@ -0,0 +1,5 @@
1
+ import{n as a,p as o}from"./chunk-WY5BOCQP.js";o();function u(t){return{id:t.id,status:t.status,source:{type:t.source_type,channelId:t.source_channel_id??void 0,chatId:t.source_chat_id??void 0},title:t.title??void 0,createdAt:t.created_at,lastActiveAt:t.last_active_at,archivedAt:t.archived_at??void 0,messageCount:t.message_count,sdkSessionId:t.sdk_session_id??void 0}}function d(t){a().prepare(`
2
+ INSERT INTO chat_sessions (id, status, source_type, source_channel_id, source_chat_id,
3
+ title, created_at, last_active_at, archived_at, message_count)
4
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
5
+ `).run(t.id,t.status,t.source.type,t.source.channelId??null,t.source.chatId??null,t.title??null,t.createdAt,t.lastActiveAt,t.archivedAt??null,t.messageCount)}function l(t){let s=a().prepare("SELECT * FROM chat_sessions WHERE id = ?").get(t);return s?u(s):void 0}function h(t,e){let s=a(),n=[],i=[];e.status!==void 0&&(n.push("status = ?"),i.push(e.status)),e.title!==void 0&&(n.push("title = ?"),i.push(e.title)),e.lastActiveAt!==void 0&&(n.push("last_active_at = ?"),i.push(e.lastActiveAt)),"archivedAt"in e&&(n.push("archived_at = ?"),i.push(e.archivedAt??null)),e.messageCount!==void 0&&(n.push("message_count = ?"),i.push(e.messageCount)),n.length!==0&&(i.push(t),s.prepare(`UPDATE chat_sessions SET ${n.join(", ")} WHERE id = ?`).run(...i))}function _(t,e=100,s=0){let n=a();return t?n.prepare("SELECT * FROM chat_sessions WHERE status = ? ORDER BY last_active_at DESC LIMIT ? OFFSET ?").all(t,e,s).map(u):n.prepare("SELECT * FROM chat_sessions ORDER BY last_active_at DESC LIMIT ? OFFSET ?").all(e,s).map(u)}function S(t){let s=a().prepare("SELECT * FROM chat_sessions WHERE status = 'active' AND source_type = ? AND source_channel_id IS ? AND source_chat_id IS ? LIMIT 1").get(t.type,t.channelId??null,t.chatId??null);return s?u(s):void 0}function p(t,e){a().prepare("UPDATE chat_sessions SET sdk_session_id = ? WHERE id = ?").run(e,t)}function E(t){a().prepare("DELETE FROM chat_sessions WHERE id = ?").run(t)}export{d as a,l as b,h as c,_ as d,S as e,p as f,E as g};
@@ -0,0 +1,32 @@
1
+ import{b as K,c as k,d as L}from"./chunk-JYZTIE2J.js";import{a as te,e as re,g as ne}from"./chunk-HRPMRWHD.js";import{a as N,d as be}from"./chunk-OBD4245G.js";import{b as X,h as Q,i as Z}from"./chunk-4JHACUZY.js";import{s as G}from"./chunk-VWX2B6OM.js";import{a as w}from"./chunk-L7JP7DUO.js";import{c as R,h as ee}from"./chunk-6WQFYV3N.js";import{d as Y,r as ve}from"./chunk-BE653A45.js";import{n as S,p as _e}from"./chunk-WY5BOCQP.js";import{c as q,h as Ie}from"./chunk-EZLBMUQD.js";import{c as O,e as J}from"./chunk-5M6IGE5G.js";import{existsSync as Re}from"fs";import{createHash as Ce}from"crypto";import{isAbsolute as Ue}from"path";be();_e();J();import{v4 as Te}from"uuid";function oe(e){return{id:e.id,eventKey:e.event_key,sourceType:e.source_type,sourceId:e.source_id,taskId:e.task_id??void 0,templateId:e.template_id??void 0,templateName:e.template_name??void 0,messageType:e.message_type,viewerKey:e.viewer_key,title:e.title??void 0,contentPreview:e.content_preview,attachments:C(e.attachments_json),targets:C(e.targets_json),firstDeliveredAt:e.first_delivered_at,lastDeliveredAt:e.last_delivered_at,createdAt:e.created_at,traceId:e.trace_id??void 0}}function C(e){try{let t=JSON.parse(e);return Array.isArray(t)?t:[]}catch{return[]}}function de(e){if(!e.viewerKey||e.viewerKey.trim().length===0)throw new Error("recordUserVisibleDeliveryEvent requires viewerKey");if(!e.eventKey||e.eventKey.trim().length===0)throw new Error("recordUserVisibleDeliveryEvent requires eventKey");if(!e.sourceId||e.sourceId.trim().length===0)throw new Error("recordUserVisibleDeliveryEvent requires sourceId");let t=S(),r=Date.now(),n=e.deliveredAt??r,a=t.prepare("SELECT * FROM user_visible_events WHERE event_key = ?").get(e.eventKey);if(!a){let d=Te();return t.prepare(`
2
+ INSERT INTO user_visible_events (
3
+ id, event_key, source_type, source_id, task_id, template_id, template_name,
4
+ message_type, viewer_key, title, content_preview, attachments_json,
5
+ targets_json, first_delivered_at, last_delivered_at, created_at, trace_id
6
+ )
7
+ VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)
8
+ `).run(d,e.eventKey,e.sourceType,e.sourceId,e.taskId??null,e.templateId??null,e.templateName??null,e.messageType,e.viewerKey,e.title??null,e.contentPreview,JSON.stringify(e.attachments??[]),JSON.stringify(e.targets??[]),n,n,r,e.traceId??O()??null),se(e.eventKey)}let s=we(C(a.targets_json),e.targets??[]),o=ke(C(a.attachments_json),e.attachments??[]);return t.prepare(`
9
+ UPDATE user_visible_events
10
+ SET task_id = COALESCE(task_id, ?),
11
+ template_id = COALESCE(template_id, ?),
12
+ template_name = COALESCE(template_name, ?),
13
+ title = COALESCE(title, ?),
14
+ content_preview = CASE WHEN content_preview = '' THEN ? ELSE content_preview END,
15
+ attachments_json = ?,
16
+ targets_json = ?,
17
+ last_delivered_at = MAX(last_delivered_at, ?),
18
+ trace_id = COALESCE(trace_id, ?)
19
+ WHERE event_key = ?
20
+ `).run(e.taskId??null,e.templateId??null,e.templateName??null,e.title??null,e.contentPreview,JSON.stringify(o),JSON.stringify(s),n,e.traceId??O()??null,e.eventKey),se(e.eventKey)}function se(e){let t=S().prepare("SELECT * FROM user_visible_events WHERE event_key = ?").get(e);return t?oe(t):void 0}function qe(e){let t=S(),r=e.excludeSourceIds??[],n=[e.viewerKey,e.since,e.until],a=`
21
+ SELECT * FROM user_visible_events
22
+ WHERE viewer_key = ?
23
+ AND last_delivered_at >= ?
24
+ AND last_delivered_at <= ?
25
+ `;return r.length>0&&(a+=` AND source_id NOT IN (${r.map(()=>"?").join(",")})`,n.push(...r)),a+=" ORDER BY last_delivered_at ASC",e.limit!==void 0&&(a+=" LIMIT ?",n.push(e.limit)),t.prepare(a).all(...n).map(oe)}function we(e,t){let r=[...e];for(let n of t){let a=ie(n);r.some(s=>ie(s)===a)||r.push(n)}return r}function ie(e){return[e.type,e.channelId??"",e.webhookUrl??"",e.chatId??"",e.sessionId??""].join("|")}function ke(e,t){let r=[...e];for(let n of t){let a=ae(n),s=r.findIndex(o=>ae(o)===a);s>=0?r[s]={...r[s],...n}:r.push(n)}return r}function ae(e){return e.artifactId?`artifact:${e.artifactId}`:["file",e.filename??"",e.sizeBytes??"",e.mimeType??""].join("|")}Ie();import{v4 as F}from"uuid";J();ve();import{basename as U,extname as ce}from"path";function le(e){return Y(e).filter(t=>t.kind==="file"&&!!t.blobPath)}function Ae(e){let t=e.mime??"";return t.startsWith("image/")?"image":t.startsWith("audio/")?"audio":t.startsWith("video/")?"video":"file"}function Ee(e){let t=U(e.key??"").replace(/[\\/]/g,"-");if(e.originalFilename){let r=U(e.originalFilename).replace(/[\\/]/g,"-");if(ce(r))return r}if(ce(t))return t;if(e.mime){let r=ne(e.mime);if(r&&r!==".bin"&&t)return`${t}${r}`}return e.originalFilename?U(e.originalFilename).replace(/[\\/]/g,"-"):t||(e.blobPath?U(e.blobPath):e.id)}function ue(e){return e.map(t=>({path:t.blobPath,mediaType:Ae(t),filename:Ee(t),contentType:t.mime,mimeType:t.mime,artifactId:t.id,locator:t.locator,sizeBytes:t.sizeBytes,purpose:t.purpose,contentHash:t.contentHash}))}function $(e){if(e.priority!==void 0&&e.priority!==null)return e.priority;let t=e.mime??"";return t.startsWith("audio/")||t.startsWith("video/")?10:t==="text/markdown"||t==="text/plain"?50:t.startsWith("image/")?100:200}var x=1.33;function me(e,t){if(e.length===0)return{included:[],dropped:[]};let r=[...e].sort((d,i)=>{let g=$(d),y=$(i);return g!==y?g-y:i.sizeBytes-d.sizeBytes}),n=r[0];if(n.sizeBytes*x>t){if(r.length===1)return{firstItemOverflow:n};let d=r.slice(1),i=[],g=[],y=0;for(let _ of d){let l=_.sizeBytes*x;y+l<=t?(i.push(_),y+=l):g.push(_)}return i.length===0?{firstItemOverflow:n}:{included:i,dropped:[n,...g],firstOverflowWarning:!0}}let a=[],s=[],o=0;for(let d of r){let i=d.sizeBytes*x;o+i<=t?(a.push(d),o+=i):s.push(d)}return{included:a,dropped:s}}function pe(e,t,r,n){if(t.length===0)return e;let a=(r/(1024*1024)).toFixed(1),s=t.map(d=>`- ${d.filename} (${Oe(d.sizeBytes)})`),o=e.endsWith(`---
26
+ `)||e.endsWith("---")?"":`
27
+
28
+ ---`;return`${e}${o}
29
+ \u26A0\uFE0F \u56E0 ${n} \u90AE\u7BB1 ${a}MB \u4E0A\u9650\uFF0C\u4EE5\u4E0B\u4EA7\u7269\u672A\u9644\uFF1A
30
+ ${s.join(`
31
+ `)}
32
+ `}function Oe(e){return e<1024?`${e} bytes`:e<1024*1024?`${(e/1024).toFixed(1)} KB`:`${(e/(1024*1024)).toFixed(2)} MB`}var B=class extends Error{constructor(r,n,a,s,o){super(`OutboundFirstAttachmentExceedsCap: artifactKey=${r} sizeBytes=${n} effectiveSizeBytes=${a} capBytes=${s} recipientDomain=${o}`);this.artifactKey=r;this.sizeBytes=n;this.effectiveSizeBytes=a;this.capBytes=s;this.recipientDomain=o;this.name="OutboundFirstAttachmentExceedsCap"}artifactKey;sizeBytes;effectiveSizeBytes;capBytes;recipientDomain};function xe(e){if(!e)return"";let t=e.lastIndexOf("@");return t<0||t===e.length-1?"":e.slice(t+1).toLowerCase().trim()}function De(e,t){return t.find(r=>r.id===e)?.key??e}function Se(e,t){return t.find(r=>r.artifactId===e)?.filename??e}function fe(e,t,r,n,a){let s=xe(t),o=ee(e,s),d=r.map(l=>({id:l.id,sizeBytes:l.sizeBytes??0,priority:l.priority??void 0,mime:l.mime??void 0})),i=me(d,o);if("firstItemOverflow"in i){let l=i.firstItemOverflow,h=De(l.id,r);return{ok:!1,error:new B(h,l.sizeBytes,Math.floor(l.sizeBytes*x),o,s).message}}let g=new Set(i.included.map(l=>l.id)),y=n.filter(l=>l.artifactId&&g.has(l.artifactId)),_=a;if(i.dropped.length>0){let l=i.dropped.map(h=>({filename:Se(h.id,n),sizeBytes:h.sizeBytes}));_=pe(a,l,o,s)}return{ok:!0,result:{perTargetAttachments:y,perTargetContent:_}}}var E=q("adam"),W=class{_dedupCache=new Map;_rateLimitWindows=new Map;_recentlySentIds=new Set;_laneTails=new Map;async _acquireLane(t,r){let n=`${t}:${r}`,a=this._laneTails.get(n)??Promise.resolve(),s,o=new Promise(d=>{s=d});return this._laneTails.set(n,o),o.then(()=>{this._laneTails.get(n)===o&&this._laneTails.delete(n)}),await a,s}isRecentlySent(t){return this._recentlySentIds.has(t)}async send(t){let{taskId:r,channelId:n,chatId:a,content:s,messageType:o,platform:d,webhookUrl:i,replyMarkup:g,replyToMessageId:y,quoteExcerpt:_,quoteTitle:l,mediaUrl:h,mediaType:A,attachments:D,dedupDiscriminator:z}=t,I=ge(o),ye=I!=="reply"&&!!r,u;if(ye){u=`${r}:${n??"none"}:${a??"none"}:${I}${z?`:${z}`:""}`;let f=this._dedupCache.get(u);if(f&&Date.now()-f.timestamp<300*1e3)return E.debug({dedupKey:u},"Dedup hit, returning cached log entry"),{success:!0,logEntryId:f.logEntryId}}if(n){let f=Date.now(),v=6e4,p=this._rateLimitWindows.get(n);p||(p=[],this._rateLimitWindows.set(n,p));let P=f-v;for(;p.length>0&&p[0]<P;)p.shift();if(p.length>=60){let M=F();E.warn({channelId:n,count:p.length},"Rate limited, not sending");let b={type:"channel",channelId:n,chatId:a??""};return this._writeOutboundReceipt(t,b,s,"failure"),{success:!1,logEntryId:M,error:"rate_limited"}}p.push(f)}let he=d??(n?R(n)?.platform:void 0)??"unknown",H=i?s:te(s,he,r),c=F(),m={id:c,ruleId:void 0,taskId:r??void 0,status:"pending",target:n&&a?{type:"channel",channelId:n,chatId:a}:i?{type:"webhook",webhookUrl:i}:{type:"channel",channelId:n??"",chatId:a??""},content:H,attempts:0,createdAt:Date.now(),expiresAt:Date.now()+1440*60*1e3,source:"direct",messageType:I};K(m),u&&this._dedupCache.set(u,{logEntryId:c,timestamp:Date.now()});try{let f=Be(h);if(f)return k(c,"failed",f),u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"failed",error:f,messageType:I}),this._writeOutboundReceipt(t,m.target,s,"failure"),{success:!1,logEntryId:c,error:f};if(i){let v=await fetch(i,{method:"POST",body:JSON.stringify({result:s,taskId:r,timestamp:new Date().toISOString()}),signal:AbortSignal.timeout(1e4)});if(v.ok)return L(c),this._recordDeliveryLedgerAfterSuccess(t,m.target,I,s),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"delivered",messageType:I}),{success:!0,logEntryId:c};{let p=`Webhook returned ${v.status}`;return k(c,"failed",p),u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"failed",error:p,messageType:I}),{success:!1,logEntryId:c,error:p}}}else if(n&&a){let{getChannelManager:v}=await $e(),p=v();if(!p){let T="ChannelManager not available";return k(c,"failed",T),u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"failed",error:T,messageType:I}),this._writeOutboundReceipt(t,m.target,s,"failure"),{success:!1,logEntryId:c,error:T}}let P={content:H,messageType:I,...g?{replyMarkup:g}:{},...y?{replyToMessageId:y}:{},..._?{quoteExcerpt:_}:{},...l?{quoteTitle:l}:{},...h?{mediaUrl:h}:{},...A?{mediaType:A}:{},...D?{attachments:D}:{}},M=await this._acquireLane(n,a),b;try{b=await p.sendMessage(n,a,P)}finally{M()}if(b===null){let T="Channel adapter send failed (returned null)";return k(c,"failed",T),u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"failed",error:T,messageType:I}),this._writeOutboundReceipt(t,m.target,s,"failure"),{success:!1,logEntryId:c,error:T}}if(b&&(this._recentlySentIds.add(b),setTimeout(()=>this._recentlySentIds.delete(b),300*1e3)),b?.startsWith("queued-")){let T="queued_not_delivered";return u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"pending",error:T,messageType:I}),{success:!1,messageId:b,logEntryId:c,error:T}}return L(c),this._recordDeliveryLedgerAfterSuccess(t,m.target,I,s),this._writeOutboundReceipt(t,m.target,s,"success"),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"delivered",messageType:I}),{success:!0,messageId:b??void 0,logEntryId:c}}else{let v="No channelId/chatId or webhookUrl provided";return k(c,"failed",v),u&&this._dedupCache.delete(u),{success:!1,logEntryId:c,error:v}}}catch(f){let v=f instanceof Error?f.message:String(f);return k(c,"failed",v),u&&this._dedupCache.delete(u),w.emit({type:"delivery_status_change",logEntryId:c,taskId:r,target:m.target,status:"failed",error:v,messageType:I}),this._writeOutboundReceipt(t,m.target,s,"failure"),{success:!1,logEntryId:c,error:v}}}_writeOutboundReceipt(t,r,n,a){if(r.type!=="channel"||!r.channelId)return;let s=O();if(!s){E.debug({taskId:t.taskId,channelId:r.channelId,outcome:a},"Outbound receipt skipped: no active trace context");return}let o=(t.attachments??[]).map(i=>i.artifactId).filter(i=>typeof i=="string"&&i.length>0),d=t.actorToolName??"OutboundGateway.send";try{Z({traceId:s,taskId:t.taskId,sessionId:t.sessionId,effectCategory:"outbound_message",verb:"send",entityType:"channel_message",target:{channelId:r.channelId,chatId:r.chatId,platform:t.platform},payload:{textChars:n.length,attachmentCount:t.attachments?.length??0,attachmentRefs:o.length>0?o:void 0},actor:{traceId:s,toolName:d,taskId:t.taskId},outcome:a})}catch(i){i instanceof Q?E.warn({errors:i.errors,taskId:t.taskId,channelId:r.channelId},"Outbound receipt validation failed"):E.warn({error:i instanceof Error?i.message:String(i),taskId:t.taskId},"Outbound receipt write failed")}}async redeliverExecutionTo(t){let r=t.includeArtifacts??!0,n=t.messageType??"result_delivery",a=t.dedupDiscriminator??`redelivery:${Date.now()}`,s=r?t.fileArtifacts??le(t.executionId):[],o=s.length>0?ue(s):void 0,d=[];for(let i of t.targets){let g=R(i.channelId);if(!g){d.push({target:{channelId:i.channelId,chatId:i.chatId},deliveryLogId:"",status:"failed",attachmentCount:0,error:`Channel not found: ${i.channelId}`});continue}let y=o,_=t.content;if(g.platform==="email"&&o&&o.length>0){let h=fe(i.channelId,i.chatId,s,o,t.content);if(!h.ok){let A=F(),D={type:"channel",channelId:i.channelId,chatId:i.chatId??""};K({id:A,ruleId:void 0,taskId:t.executionId,status:"pending",target:D,content:t.content,attempts:0,createdAt:Date.now(),expiresAt:Date.now()+1440*60*1e3,source:"direct",messageType:ge(n)}),k(A,"failed",h.error),d.push({target:{channelId:i.channelId,chatId:i.chatId},deliveryLogId:A,status:"failed",attachmentCount:0,error:h.error});continue}y=h.result.perTargetAttachments,_=h.result.perTargetContent}let l=await this.send({taskId:t.executionId,sessionId:t.sessionId,channelId:i.channelId,chatId:i.chatId,content:_,messageType:n,platform:g.platform,attachments:y,dedupDiscriminator:a,actorToolName:t.actorToolName});d.push({target:{channelId:i.channelId,chatId:i.chatId},deliveryLogId:l.logEntryId,status:l.success?"delivered":"failed",attachmentCount:y?.length??0,...l.error?{error:l.error}:{}})}return{deliveries:d}}_recordDeliveryLedgerAfterSuccess(t,r,n,a){if(Ve(n,t.taskId))try{let s=Pe(t,r);if(!s){N({source:"delivery_ledger",severity:"warning",sourceId:t.taskId,message:`Skipped user-visible delivery ledger write for ${n}: viewer identity unresolved`});return}let o=Me(t.taskId),d=Ne(a);de({eventKey:`${s}|${o.sourceId}|${n}|${d}`,sourceType:o.sourceType,sourceId:o.sourceId,taskId:t.taskId,templateId:o.templateId,templateName:o.templateName,messageType:n,viewerKey:s,title:o.templateName,contentPreview:a,attachments:(t.attachments??[]).map(Ke),targets:[Le(r)]})}catch(s){let o=s instanceof Error?s.message:String(s);E.warn({error:o,taskId:t.taskId,messageType:n},"User-visible delivery ledger write failed");try{N({source:"delivery_ledger",severity:"error",sourceId:t.taskId,message:o})}catch{}}}};function Ve(e,t){return t?!["reply","assistant_text","user_message","approval","approval_prompt"].includes(e):!1}function Pe(e,t){if(e.viewerKey)return e.viewerKey;if(t.type==="channel"&&t.channelId)return re({type:"channel",channelId:t.channelId,chatId:t.chatId})}function Me(e){let t=X(e);if(!t)return{sourceType:"task",sourceId:e};let r=G(t.templateId);return{sourceType:"template_execution",sourceId:t.id,templateId:t.templateId,templateName:r?.name}}function Ke(e){return{artifactId:e.artifactId,locator:e.locator,filename:e.filename,mimeType:e.mimeType??e.contentType,sizeBytes:e.sizeBytes,purpose:e.purpose,contentHash:e.contentHash}}function Le(e){if(e.type==="webhook")return{type:"webhook",webhookUrl:e.webhookUrl};let t=e.channelId?R(e.channelId):void 0;return{type:"channel",channelId:e.channelId,chatId:e.chatId,label:t?.name}}function Ne(e){return Ce("sha256").update(e).digest("hex")}var V=null;function $e(){return V||(V=import("./channels-PWDSTYNR.js")),V}function At(){V=null}function Be(e){if(!e)return;if(e.includes("://")&&!e.startsWith("file://"))return"mediaUrl must be a local file path";let t=e.startsWith("file://")?new URL(e).pathname:e;if(!Ue(t))return"mediaUrl must be absolute";if(!Re(t))return"mediaUrl file does not exist"}function ge(e){return e==="report"?"status_report":e==="deliver"?"result_delivery":e}var j=null;function Fe(){return j||(j=new W),j}function Et(e){return Fe().isRecentlySent(e)}export{qe as a,le as b,Ae as c,Ee as d,W as e,At as f,Fe as g,Et as h};