agentic-qe 3.9.2 → 3.9.4

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 (296) hide show
  1. package/CHANGELOG.md +53 -0
  2. package/dist/cli/bundle.js +5 -5
  3. package/dist/cli/chunks/adapter-5ODIX6ZG.js +2 -0
  4. package/dist/cli/chunks/{agent-booster-wasm-AKAOHSCX.js → agent-booster-wasm-MGGEPROV.js} +2 -2
  5. package/dist/cli/chunks/{agent-handler-MTGPOUVP.js → agent-handler-AFHYFQXV.js} +2 -2
  6. package/dist/cli/chunks/{agent-memory-branch-UFPKWUFK.js → agent-memory-branch-SQ3KDIG6.js} +2 -2
  7. package/dist/cli/chunks/aqe-learning-engine-PWGRS6KK.js +2 -0
  8. package/dist/cli/chunks/{audit-VBEZHNHO.js → audit-SM5CK2K5.js} +2 -2
  9. package/dist/cli/chunks/base-TJGIYR7L.js +2 -0
  10. package/dist/cli/chunks/{better-sqlite3-IRPHIXRU.js → better-sqlite3-UGOYRNXI.js} +2 -2
  11. package/dist/cli/chunks/{brain-handler-7EO3FFRZ.js → brain-handler-SKXTB63O.js} +3 -3
  12. package/dist/cli/chunks/{branch-enumerator-MZRGP35N.js → branch-enumerator-77NSOLNK.js} +2 -2
  13. package/dist/cli/chunks/{browser-VSIWQE7J.js → browser-MCE5DWPV.js} +2 -2
  14. package/dist/cli/chunks/browser-workflow-GUR7RLFP.js +2 -0
  15. package/dist/cli/chunks/{chunk-5RL66XSH.js → chunk-27FNBMUC.js} +2 -2
  16. package/dist/cli/chunks/{chunk-FRJLP7IB.js → chunk-27P4VTCY.js} +2 -2
  17. package/dist/cli/chunks/{chunk-2VVV73PW.js → chunk-2JLKOGNU.js} +1 -1
  18. package/dist/cli/chunks/{chunk-PJFLO37I.js → chunk-2MQMXI7C.js} +2 -2
  19. package/dist/cli/chunks/{chunk-BKCTNRC5.js → chunk-3MN7E6HY.js} +2 -2
  20. package/dist/cli/chunks/{chunk-BY47GV4T.js → chunk-3MRFR534.js} +2 -2
  21. package/dist/cli/chunks/{chunk-563PJBDM.js → chunk-3RHIPCBG.js} +2 -2
  22. package/dist/cli/chunks/{chunk-WXWY2GAF.js → chunk-3SPYUOSS.js} +2 -2
  23. package/dist/cli/chunks/{chunk-5AUKULWO.js → chunk-4BQTEPAD.js} +2 -2
  24. package/dist/cli/chunks/{chunk-N3F3CX4V.js → chunk-4GJAYXB7.js} +2 -2
  25. package/dist/cli/chunks/{chunk-7NOIIC7G.js → chunk-4TZTGYBQ.js} +1 -1
  26. package/dist/cli/chunks/{chunk-VL7YOOC2.js → chunk-53M65YFH.js} +2 -2
  27. package/dist/cli/chunks/{chunk-QNBQBSAI.js → chunk-54OLXGXJ.js} +2 -2
  28. package/dist/cli/chunks/{chunk-HW4ISY5B.js → chunk-5UKAEBKC.js} +3 -3
  29. package/dist/cli/chunks/{chunk-CQP7ZFME.js → chunk-72EC26AS.js} +2 -2
  30. package/dist/cli/chunks/{chunk-J4BS6IWE.js → chunk-7EL65Y27.js} +1 -1
  31. package/dist/cli/chunks/{chunk-PFNFC43Q.js → chunk-7FJIIB4H.js} +1 -1
  32. package/dist/cli/chunks/{chunk-AKSJQ6B3.js → chunk-7ST2YENJ.js} +2 -2
  33. package/dist/cli/chunks/{chunk-SNVM4YJS.js → chunk-7ZXNJT4Q.js} +2 -2
  34. package/dist/cli/chunks/{chunk-BOH22AKC.js → chunk-A6ZBQCYB.js} +2 -2
  35. package/dist/cli/chunks/{chunk-VHVWAXCF.js → chunk-B252DDC5.js} +1 -1
  36. package/dist/cli/chunks/{chunk-2EC5Z2J4.js → chunk-B6HLXE3D.js} +9 -9
  37. package/dist/cli/chunks/{chunk-L5WZUPZF.js → chunk-BH5XPYA3.js} +2 -2
  38. package/dist/cli/chunks/{chunk-LMMEUVE5.js → chunk-BZ22GI4E.js} +1 -1
  39. package/dist/cli/chunks/{chunk-YXCU4CJX.js → chunk-C2HGOUEB.js} +1 -1
  40. package/dist/cli/chunks/{chunk-JV7LX6OT.js → chunk-C3BXT3ZC.js} +4 -4
  41. package/dist/cli/chunks/{chunk-3GZKAORV.js → chunk-C567IO5M.js} +2 -2
  42. package/dist/cli/chunks/{chunk-SCF7NRVE.js → chunk-COIRFVFO.js} +1 -1
  43. package/dist/cli/chunks/{chunk-RITN3XR4.js → chunk-DHJJJ24V.js} +2 -2
  44. package/dist/cli/chunks/{chunk-RC5CPXON.js → chunk-DLMEBVLF.js} +2 -2
  45. package/dist/cli/chunks/{chunk-XFMKJ3UD.js → chunk-DZHGYZJP.js} +1 -1
  46. package/dist/cli/chunks/{chunk-V6XBAZNH.js → chunk-EEARIB4C.js} +1 -1
  47. package/dist/cli/chunks/{chunk-NM6TIEJ3.js → chunk-EFD2J6GG.js} +3 -3
  48. package/dist/cli/chunks/{chunk-Z5HXGVXZ.js → chunk-EHGTXIT7.js} +1 -1
  49. package/dist/cli/chunks/{chunk-QODE4LM6.js → chunk-ENKPW6MA.js} +2 -2
  50. package/dist/cli/chunks/{chunk-4PKXIBX2.js → chunk-EZTUUOVI.js} +1 -1
  51. package/dist/cli/chunks/{chunk-SDTVHR63.js → chunk-F6AU2MAZ.js} +2 -2
  52. package/dist/cli/chunks/{chunk-GK72GUHA.js → chunk-G6RTCJFY.js} +2 -2
  53. package/dist/cli/chunks/{chunk-E25S5E2D.js → chunk-G72E5DL3.js} +1 -1
  54. package/dist/cli/chunks/{chunk-FUIHWBVF.js → chunk-GAG2P4I2.js} +1 -1
  55. package/dist/cli/chunks/{chunk-KDDZYXP4.js → chunk-GQ7DCSKS.js} +2 -2
  56. package/dist/cli/chunks/{chunk-WG4GHAML.js → chunk-GSKZL36U.js} +2 -2
  57. package/dist/cli/chunks/{chunk-Z2IKNC5M.js → chunk-GT35EJKR.js} +1 -1
  58. package/dist/cli/chunks/{chunk-56IWS2KY.js → chunk-GVFHRHXC.js} +2 -2
  59. package/dist/cli/chunks/{chunk-CCYMJKWX.js → chunk-GX7MEHQ2.js} +1 -1
  60. package/dist/cli/chunks/{chunk-4UH25U4O.js → chunk-HKTNFHWI.js} +1 -1
  61. package/dist/cli/chunks/{chunk-X6LCMOGC.js → chunk-IGJ472XJ.js} +2 -2
  62. package/dist/cli/chunks/{chunk-XH53ARZD.js → chunk-IQE6GOH6.js} +2 -2
  63. package/dist/cli/chunks/{chunk-RJROC5M3.js → chunk-J222JLZ6.js} +2 -2
  64. package/dist/cli/chunks/{chunk-DSE57A5N.js → chunk-J6KBI5NW.js} +1 -1
  65. package/dist/cli/chunks/{chunk-CQBSGYRA.js → chunk-J72Q6ERO.js} +2 -2
  66. package/dist/cli/chunks/{chunk-ICDXWIFZ.js → chunk-JMBUIVVE.js} +1 -1
  67. package/dist/cli/chunks/{chunk-6SOJVEU7.js → chunk-JVUNZBKX.js} +2 -2
  68. package/dist/cli/chunks/{chunk-MN742FIH.js → chunk-KELYPHMV.js} +2 -2
  69. package/dist/cli/chunks/{chunk-DHE66JRR.js → chunk-KSMQH2CV.js} +1 -1
  70. package/dist/cli/chunks/{chunk-GPLERTZU.js → chunk-LH3ZL2OK.js} +2 -2
  71. package/dist/cli/chunks/{chunk-GITD7SRQ.js → chunk-LW3DV23G.js} +2 -2
  72. package/dist/cli/chunks/chunk-MDFXPCBO.js +2 -0
  73. package/dist/cli/chunks/{chunk-KZUJBZ7B.js → chunk-MGRE767N.js} +2 -2
  74. package/dist/cli/chunks/{chunk-DBE34QES.js → chunk-MN2MYLVW.js} +2 -2
  75. package/dist/cli/chunks/{chunk-25LFUL2K.js → chunk-MR5I6UR2.js} +2 -2
  76. package/dist/cli/chunks/{chunk-S3RDH5CI.js → chunk-MS6LTE4L.js} +2 -2
  77. package/dist/cli/chunks/{chunk-QEQTC4WQ.js → chunk-MUX762XZ.js} +2 -2
  78. package/dist/cli/chunks/{chunk-4Z27TRQF.js → chunk-NEYZXYFH.js} +2 -2
  79. package/dist/cli/chunks/{chunk-7SLN2JGP.js → chunk-NRH2QE4X.js} +3 -3
  80. package/dist/cli/chunks/{chunk-CL3K5EJK.js → chunk-NS4CCCTZ.js} +2 -2
  81. package/dist/cli/chunks/{chunk-NJY7ZA77.js → chunk-NZ5LY2BT.js} +1 -1
  82. package/dist/cli/chunks/{chunk-UKDOMLBI.js → chunk-O6QAOPUA.js} +3 -3
  83. package/dist/cli/chunks/{chunk-QPRVX4H2.js → chunk-OHZ6RJLS.js} +2 -2
  84. package/dist/cli/chunks/{chunk-DNLMZTE2.js → chunk-ONOYANDX.js} +1 -1
  85. package/dist/cli/chunks/chunk-OZC42UMD.js +2 -0
  86. package/dist/cli/chunks/{chunk-34U7JDCN.js → chunk-P3EOWBME.js} +2 -2
  87. package/dist/cli/chunks/{chunk-4DAOZQ3V.js → chunk-Q2ZYUIS2.js} +2 -2
  88. package/dist/cli/chunks/{chunk-RQGYJK7H.js → chunk-Q6FSXNQP.js} +2 -2
  89. package/dist/cli/chunks/{chunk-X35GP7TR.js → chunk-QEYPK7KS.js} +1 -1
  90. package/dist/cli/chunks/{chunk-T5GV6UIO.js → chunk-QOU4R6AF.js} +2 -2
  91. package/dist/cli/chunks/{chunk-KZTO5EVM.js → chunk-QPC4STR6.js} +2 -2
  92. package/dist/cli/chunks/{chunk-4FT3PND7.js → chunk-QVZSIFSJ.js} +3 -3
  93. package/dist/cli/chunks/{chunk-GCMVJS5X.js → chunk-RAZ2PGZD.js} +2 -2
  94. package/dist/cli/chunks/{chunk-727BDQ3K.js → chunk-RE6XD6RI.js} +2 -2
  95. package/dist/cli/chunks/{chunk-STE42EMB.js → chunk-RGRYL4MG.js} +2 -2
  96. package/dist/cli/chunks/{chunk-XYJL6DKI.js → chunk-RN3SN4ZC.js} +2 -2
  97. package/dist/cli/chunks/{chunk-JOVINE23.js → chunk-RPYUKEAH.js} +2 -2
  98. package/dist/cli/chunks/{chunk-5L6AU3QK.js → chunk-RRQEIGLS.js} +2 -2
  99. package/dist/cli/chunks/{chunk-VUAO4VFC.js → chunk-RS7ZGWHV.js} +2 -2
  100. package/dist/cli/chunks/{chunk-KTYUCZEM.js → chunk-RTC3ZCPK.js} +5 -5
  101. package/dist/cli/chunks/{chunk-4LA7IW3V.js → chunk-RUJU5XEQ.js} +1 -1
  102. package/dist/cli/chunks/{chunk-SRRFWTNF.js → chunk-SHJZ3YNX.js} +2 -2
  103. package/dist/cli/chunks/{chunk-FAXVVLPL.js → chunk-SKWI5QBM.js} +2 -2
  104. package/dist/cli/chunks/{chunk-NRCKGXJJ.js → chunk-TNWTQWLL.js} +1 -1
  105. package/dist/cli/chunks/{chunk-KBA7FBK3.js → chunk-TT2TB6UF.js} +3 -3
  106. package/dist/cli/chunks/{chunk-Z54EO6E6.js → chunk-U7YC7VCM.js} +2 -2
  107. package/dist/cli/chunks/{chunk-TKF447CW.js → chunk-UJLSCJJS.js} +1 -1
  108. package/dist/cli/chunks/{chunk-MY4LMIG7.js → chunk-UPJZRDZK.js} +2 -2
  109. package/dist/cli/chunks/{chunk-KQTJ2YLI.js → chunk-UUL3D5HR.js} +4 -4
  110. package/dist/cli/chunks/{chunk-TTOE336G.js → chunk-V57PXZIK.js} +3 -3
  111. package/dist/cli/chunks/{chunk-SGAW2WLI.js → chunk-VBXJBXMG.js} +4 -4
  112. package/dist/cli/chunks/{chunk-BIVIPF4O.js → chunk-VBYREHZI.js} +1 -1
  113. package/dist/cli/chunks/{chunk-PNL5G6TE.js → chunk-VFXTZWNF.js} +2 -2
  114. package/dist/cli/chunks/{chunk-2WBCYSUN.js → chunk-VSNPI2NO.js} +8 -8
  115. package/dist/cli/chunks/{chunk-Y6O7CDLI.js → chunk-WHT46PJM.js} +2 -2
  116. package/dist/cli/chunks/{chunk-L5YEPSDU.js → chunk-XB5HXTL4.js} +2 -2
  117. package/dist/cli/chunks/{chunk-4FMHBBG5.js → chunk-XYVMKCSI.js} +1 -1
  118. package/dist/cli/chunks/{chunk-AA33R5U4.js → chunk-YDJKQKQH.js} +2 -2
  119. package/dist/cli/chunks/{chunk-4D2ZG2QO.js → chunk-YS6C2Q4F.js} +1 -1
  120. package/dist/cli/chunks/{chunk-65M7C6SH.js → chunk-Z75DMTMI.js} +1 -1
  121. package/dist/cli/chunks/{chunk-Q4A72ZTV.js → chunk-ZKWNZ3ZK.js} +2 -2
  122. package/dist/cli/chunks/{chunk-2Z2TFEOL.js → chunk-ZODUKKPC.js} +2 -2
  123. package/dist/cli/chunks/{chunk-KNVAAVHH.js → chunk-ZQSEPDIJ.js} +2 -2
  124. package/dist/cli/chunks/{chunk-QIH3E775.js → chunk-ZW5DRPZY.js} +2 -2
  125. package/dist/cli/chunks/{ci-2BCOBWFG.js → ci-THZEECIQ.js} +2 -2
  126. package/dist/cli/chunks/{ci-output-FB4OJHAC.js → ci-output-G6QLGL4S.js} +2 -2
  127. package/dist/cli/chunks/{claude-flow-setup-NEEFZTMB.js → claude-flow-setup-5MTYQM34.js} +2 -2
  128. package/dist/cli/chunks/client-IFMC3AYQ.js +2 -0
  129. package/dist/cli/chunks/{cline-installer-ODO2PS4K.js → cline-installer-E2LF2DQS.js} +2 -2
  130. package/dist/cli/chunks/{code-NSOF62VE.js → code-QRF7ZGXG.js} +2 -2
  131. package/dist/cli/chunks/{code-index-extractor-YQL5XN52.js → code-index-extractor-II6IRWU6.js} +2 -2
  132. package/dist/cli/chunks/{codex-installer-SPEY6VYT.js → codex-installer-LGOQ23ZS.js} +2 -2
  133. package/dist/cli/chunks/{completions-OWKBUMBE.js → completions-LB2RR2OQ.js} +2 -2
  134. package/dist/cli/chunks/{complexity-analyzer-PGTXKP73.js → complexity-analyzer-PUIPIRX3.js} +2 -2
  135. package/dist/cli/chunks/{continuedev-installer-KGOXAC7L.js → continuedev-installer-HQAEAQZU.js} +2 -2
  136. package/dist/cli/chunks/{copilot-installer-BF3UA3TG.js → copilot-installer-3PKCX5K5.js} +2 -2
  137. package/dist/cli/chunks/{cost-tracker-2HDJ66E2.js → cost-tracker-JG3SZ2Q3.js} +2 -2
  138. package/dist/cli/chunks/{coverage-KPA2PHIN.js → coverage-D3PZTOKT.js} +3 -3
  139. package/dist/cli/chunks/cross-domain-router-2LPBUUWY.js +2 -0
  140. package/dist/cli/chunks/{cursor-installer-7CDZFHTV.js → cursor-installer-UY6GWKTO.js} +2 -2
  141. package/dist/cli/chunks/{daemon-4BPGCKDJ.js → daemon-UNO3LRRN.js} +3 -3
  142. package/dist/cli/chunks/{dag-attention-scheduler-2MAVGSBB.js → dag-attention-scheduler-S2MXANYL.js} +2 -2
  143. package/dist/cli/chunks/{detect-WRPWTGP5.js → detect-DU2FTRKR.js} +2 -2
  144. package/dist/cli/chunks/{domain-handler-JZVSJ7AG.js → domain-handler-KPNO36LF.js} +2 -2
  145. package/dist/cli/chunks/{domain-transfer-XGIZOR2X.js → domain-transfer-6X3ZZF6A.js} +2 -2
  146. package/dist/cli/chunks/dream-NGRDMOTE.js +2 -0
  147. package/dist/cli/chunks/esm-node-3COTOSO3.js +2 -0
  148. package/dist/cli/chunks/{eval-T7YPAS4G.js → eval-6RXEDTBZ.js} +2 -2
  149. package/dist/cli/chunks/{fast-paths-QECJTKCQ.js → fast-paths-FYODFGZB.js} +2 -2
  150. package/dist/cli/chunks/{feature-flags-LIFURSFZ.js → feature-flags-YOULURDA.js} +2 -2
  151. package/dist/cli/chunks/{feature-flags-R4QZYTIW.js → feature-flags-ZJ42B4IL.js} +2 -2
  152. package/dist/cli/chunks/{file-discovery-4W3K3W4C.js → file-discovery-KOL7FSBQ.js} +2 -2
  153. package/dist/cli/chunks/{fleet-NLLQWCI5.js → fleet-22I74LGD.js} +3 -3
  154. package/dist/cli/chunks/{gnn-wrapper-XEII72LN.js → gnn-wrapper-DFHTHLIZ.js} +2 -2
  155. package/dist/cli/chunks/{heartbeat-handler-DJ65RE5D.js → heartbeat-handler-SQ6VYEAA.js} +4 -4
  156. package/dist/cli/chunks/{heartbeat-scheduler-H664265Q.js → heartbeat-scheduler-W6PQJ5SG.js} +2 -2
  157. package/dist/cli/chunks/hnsw-adapter-BASJNTEV.js +2 -0
  158. package/dist/cli/chunks/hnsw-index-NFN2AUIX.js +2 -0
  159. package/dist/cli/chunks/{hnsw-legacy-bridge-SQIDTWAA.js → hnsw-legacy-bridge-AYTRT54U.js} +2 -2
  160. package/dist/cli/chunks/{hnswlib-node-WICYCU5U.js → hnswlib-node-4IA56UH4.js} +2 -2
  161. package/dist/cli/chunks/{hooks-GZUHUD63.js → hooks-T6UMR72X.js} +6 -6
  162. package/dist/cli/chunks/{hypergraph-engine-MLCDZ6BL.js → hypergraph-engine-WVPYKMFY.js} +2 -2
  163. package/dist/cli/chunks/{hypergraph-handler-NNDDI4R3.js → hypergraph-handler-NB6GL4CR.js} +3 -3
  164. package/dist/cli/chunks/impact-analyzer-ZMQXHQDV.js +2 -0
  165. package/dist/cli/chunks/init-handler-UOFNBXEP.js +68 -0
  166. package/dist/cli/chunks/init-wizard-QHAA4GWF.js +2 -0
  167. package/dist/cli/chunks/kernel-SNJFYN3T.js +2 -0
  168. package/dist/cli/chunks/{kilocode-installer-EPZFFPFE.js → kilocode-installer-VWMNI4QX.js} +2 -2
  169. package/dist/cli/chunks/{kiro-installer-5VACG3HU.js → kiro-installer-RNM47FV5.js} +15 -15
  170. package/dist/cli/chunks/knowledge-graph-EP5UTODP.js +2 -0
  171. package/dist/cli/chunks/{learning-6FITK6XY.js → learning-L4RB5XYP.js} +3 -3
  172. package/dist/cli/chunks/{llm-router-4DDC6AKJ.js → llm-router-BZYZL3YI.js} +2 -2
  173. package/dist/cli/chunks/{load-KGDNVUBX.js → load-4UGEGRMO.js} +2 -2
  174. package/dist/cli/chunks/load-test-KMMRHABK.js +2 -0
  175. package/dist/cli/chunks/mcp-FWWZIWCI.js +2 -0
  176. package/dist/cli/chunks/{memory-II4I4QMO.js → memory-5OXPMXU6.js} +5 -5
  177. package/dist/cli/chunks/memory-backend-Q5MWPMDE.js +2 -0
  178. package/dist/cli/chunks/{memory-handlers-TQXTOJGQ.js → memory-handlers-JS7BTWJK.js} +2 -2
  179. package/dist/cli/chunks/{opencode-installer-EU6JCWBW.js → opencode-installer-BS5TQKHB.js} +2 -2
  180. package/dist/cli/chunks/orchestrator-G6BUZ6QE.js +370 -0
  181. package/dist/cli/chunks/{pipeline-MPZJWYKK.js → pipeline-3MZ5COPR.js} +2 -2
  182. package/dist/cli/chunks/{platform-YH35ZZFZ.js → platform-TKD4JCUG.js} +2 -2
  183. package/dist/cli/chunks/{plugin-B7JYZFNQ.js → plugin-XXJ7R6SY.js} +2 -2
  184. package/dist/cli/chunks/{prime-radiant-advanced-wasm-KTUK6UE2.js → prime-radiant-advanced-wasm-JLJ6NKIP.js} +2 -2
  185. package/dist/cli/chunks/protocol-executor-ORFR4WJ3.js +2 -0
  186. package/dist/cli/chunks/{protocol-handler-3NXMVU34.js → protocol-handler-ZLYGQPHG.js} +2 -2
  187. package/dist/cli/chunks/{prove-H5LMGSUC.js → prove-E2WZ335X.js} +2 -2
  188. package/dist/cli/chunks/qe-reasoning-bank-PLTOH4SG.js +2 -0
  189. package/dist/cli/chunks/{quality-RCWHY6GO.js → quality-6MHHBINU.js} +2 -2
  190. package/dist/cli/chunks/queen-coordinator-L3TRAX7H.js +2 -0
  191. package/dist/cli/chunks/{real-embeddings-NKH4VURF.js → real-embeddings-QN5BY3WS.js} +2 -2
  192. package/dist/cli/chunks/{roocode-installer-SB7QJYM3.js → roocode-installer-GTVII272.js} +2 -2
  193. package/dist/cli/chunks/router-3PBJJLRQ.js +2 -0
  194. package/dist/cli/chunks/routing-feedback-Q775MZ3Z.js +2 -0
  195. package/dist/cli/chunks/{routing-handler-SY7GKG2W.js → routing-handler-HYKZ3ISS.js} +2 -2
  196. package/dist/cli/chunks/{ruvector-commands-HATTO3UQ.js → ruvector-commands-LBWHPUTZ.js} +2 -2
  197. package/dist/cli/chunks/{rvf-dual-writer-D57EXQUD.js → rvf-dual-writer-TVCJ2Y6N.js} +2 -2
  198. package/dist/cli/chunks/{rvf-migration-adapter-OWDYN6KD.js → rvf-migration-adapter-34ITXLU3.js} +2 -2
  199. package/dist/cli/chunks/{rvf-migration-coordinator-SIQVJB5S.js → rvf-migration-coordinator-SX2C7777.js} +2 -2
  200. package/dist/cli/chunks/rvf-native-adapter-HLY2652E.js +2 -0
  201. package/dist/cli/chunks/safe-db-CCKCBZ5I.js +2 -0
  202. package/dist/cli/chunks/schedule-WZ5VV55N.js +2 -0
  203. package/dist/cli/chunks/scheduler-6PIKLCH7.js +2 -0
  204. package/dist/cli/chunks/{security-DS3XLZWN.js → security-7A4EW77M.js} +3 -3
  205. package/dist/cli/chunks/shared-rvf-adapter-VCJNSACZ.js +2 -0
  206. package/dist/cli/chunks/{shared-rvf-dual-writer-YB7AH6XJ.js → shared-rvf-dual-writer-27L4R5WK.js} +2 -2
  207. package/dist/cli/chunks/sqlite-persistence-HMXYD56G.js +2 -0
  208. package/dist/cli/chunks/{status-handler-TUYHE4FT.js → status-handler-JN6PRYLD.js} +2 -2
  209. package/dist/cli/chunks/{structural-health-XNGBNRRD.js → structural-health-JSY3DY7H.js} +2 -2
  210. package/dist/cli/chunks/{sync-K6CIRKBB.js → sync-ET3LYW2V.js} +10 -10
  211. package/dist/cli/chunks/{task-handler-7PJY67DR.js → task-handler-R24MR74L.js} +2 -2
  212. package/dist/cli/chunks/{task-handlers-WB5CDWUR.js → task-handlers-YNPEEPPZ.js} +2 -2
  213. package/dist/cli/chunks/{test-WV5ALEBB.js → test-7BZXFZCT.js} +4 -4
  214. package/dist/cli/chunks/{test-scheduling-N55ZGGA2.js → test-scheduling-EVIFD5EY.js} +3 -3
  215. package/dist/cli/chunks/{token-bootstrap-SINWHAKR.js → token-bootstrap-QYYQRXM5.js} +2 -2
  216. package/dist/cli/chunks/{token-usage-R7TGEVGL.js → token-usage-H4OZA77I.js} +2 -2
  217. package/dist/cli/chunks/{transformers-6DBLXPV7.js → transformers-ILQFO5HZ.js} +2 -2
  218. package/dist/cli/chunks/{tree-sitter-wasm-parser-7C7FKMQW.js → tree-sitter-wasm-parser-KTST5NWH.js} +2 -2
  219. package/dist/cli/chunks/{types-VNPMOKQT.js → types-4Z7XELU6.js} +2 -2
  220. package/dist/cli/chunks/unified-memory-RBHCTAWW.js +2 -0
  221. package/dist/cli/chunks/unified-memory-hnsw-UBF5PT6D.js +2 -0
  222. package/dist/cli/chunks/unified-persistence-ZIJDP6GW.js +2 -0
  223. package/dist/cli/chunks/{validate-53MNIRAF.js → validate-GSQCH6VN.js} +2 -2
  224. package/dist/cli/chunks/{validate-swarm-ZY4RGUFO.js → validate-swarm-SP2RPOYD.js} +2 -2
  225. package/dist/cli/chunks/{vibium-PBADBIV6.js → vibium-2SGOFYTF.js} +2 -2
  226. package/dist/cli/chunks/visual-security-WKIWOUTH.js +2 -0
  227. package/dist/cli/chunks/{web-tree-sitter-O7VI6RLB.js → web-tree-sitter-QSQ27UTH.js} +2 -2
  228. package/dist/cli/chunks/{windsurf-installer-HV3C3TAD.js → windsurf-installer-NIEH46E2.js} +2 -2
  229. package/dist/cli/chunks/witness-chain-4BRX3GGH.js +2 -0
  230. package/dist/cli/chunks/{witness-chain-4WIMYP4X.js → witness-chain-62GJTCT5.js} +2 -2
  231. package/dist/cli/chunks/{workflow-5RVAQ4TM.js → workflow-WZMV2MGW.js} +4 -4
  232. package/dist/cli/chunks/workflow-orchestrator-G6VU7QZ4.js +2 -0
  233. package/dist/cli/chunks/{wrappers-RRHCCA3E.js → wrappers-LNTV533I.js} +2 -2
  234. package/dist/cli/commands/init.js +2 -0
  235. package/dist/cli/commands/mcp.js +27 -17
  236. package/dist/cli/commands/sync.js +25 -8
  237. package/dist/cli/handlers/init-handler.d.ts +1 -0
  238. package/dist/cli/handlers/init-handler.js +2 -0
  239. package/dist/init/governance-installer.js +46 -14
  240. package/dist/init/kiro-installer.js +15 -2
  241. package/dist/init/orchestrator.js +1 -0
  242. package/dist/init/phases/06-code-intelligence.d.ts +46 -1
  243. package/dist/init/phases/06-code-intelligence.js +164 -10
  244. package/dist/init/phases/10-workers.d.ts +0 -14
  245. package/dist/init/phases/10-workers.js +19 -164
  246. package/dist/init/phases/phase-interface.d.ts +9 -0
  247. package/dist/kernel/hnsw-adapter.d.ts +14 -0
  248. package/dist/kernel/hnsw-adapter.js +25 -1
  249. package/dist/kernel/hnsw-index-provider.d.ts +16 -0
  250. package/dist/kernel/native-hnsw-backend.d.ts +11 -0
  251. package/dist/kernel/native-hnsw-backend.js +20 -0
  252. package/dist/kernel/progressive-hnsw-backend.d.ts +9 -0
  253. package/dist/kernel/progressive-hnsw-backend.js +41 -12
  254. package/dist/kernel/unified-memory.js +10 -0
  255. package/dist/mcp/bundle.js +216 -216
  256. package/dist/optimization/token-optimizer-service.d.ts +31 -2
  257. package/dist/optimization/token-optimizer-service.js +85 -23
  258. package/package.json +1 -1
  259. package/dist/cli/chunks/adapter-53WBPKXU.js +0 -2
  260. package/dist/cli/chunks/aqe-learning-engine-MV7NGY24.js +0 -2
  261. package/dist/cli/chunks/base-DZVGMQN2.js +0 -2
  262. package/dist/cli/chunks/browser-workflow-3J5YNMEI.js +0 -2
  263. package/dist/cli/chunks/chunk-LCAA6H4J.js +0 -2
  264. package/dist/cli/chunks/chunk-XIBVVZGB.js +0 -2
  265. package/dist/cli/chunks/client-EF555KYW.js +0 -2
  266. package/dist/cli/chunks/cross-domain-router-GXFNK5TS.js +0 -2
  267. package/dist/cli/chunks/dream-3IKF5XH4.js +0 -2
  268. package/dist/cli/chunks/esm-node-DHAE52OW.js +0 -2
  269. package/dist/cli/chunks/hnsw-adapter-DML5KXQR.js +0 -2
  270. package/dist/cli/chunks/hnsw-index-BUPPGVR6.js +0 -2
  271. package/dist/cli/chunks/impact-analyzer-DPTMJRYS.js +0 -2
  272. package/dist/cli/chunks/init-handler-IJ6BHE6A.js +0 -68
  273. package/dist/cli/chunks/init-wizard-35PUDJPW.js +0 -2
  274. package/dist/cli/chunks/kernel-2HZ44ZJ4.js +0 -2
  275. package/dist/cli/chunks/knowledge-graph-JL62G72U.js +0 -2
  276. package/dist/cli/chunks/load-test-LN245SSD.js +0 -2
  277. package/dist/cli/chunks/mcp-4LETGVIV.js +0 -2
  278. package/dist/cli/chunks/memory-backend-SVM7YRIE.js +0 -2
  279. package/dist/cli/chunks/orchestrator-YLMGJVSP.js +0 -371
  280. package/dist/cli/chunks/protocol-executor-IEN2XB4L.js +0 -2
  281. package/dist/cli/chunks/qe-reasoning-bank-Q3ZV3JRG.js +0 -2
  282. package/dist/cli/chunks/queen-coordinator-E6ON3JUR.js +0 -2
  283. package/dist/cli/chunks/router-WMC3LZ3C.js +0 -2
  284. package/dist/cli/chunks/routing-feedback-VKCZRCE3.js +0 -2
  285. package/dist/cli/chunks/rvf-native-adapter-C7NBH5UN.js +0 -2
  286. package/dist/cli/chunks/safe-db-5KLXCNXN.js +0 -2
  287. package/dist/cli/chunks/schedule-HAWWOXWB.js +0 -2
  288. package/dist/cli/chunks/scheduler-HTRDY5BC.js +0 -2
  289. package/dist/cli/chunks/shared-rvf-adapter-6I2Z5UGL.js +0 -2
  290. package/dist/cli/chunks/sqlite-persistence-WNNRGTGG.js +0 -2
  291. package/dist/cli/chunks/unified-memory-72SKVZ7Y.js +0 -2
  292. package/dist/cli/chunks/unified-memory-hnsw-TMN2L77W.js +0 -2
  293. package/dist/cli/chunks/unified-persistence-MDN3SRCR.js +0 -2
  294. package/dist/cli/chunks/visual-security-TRBCXPIB.js +0 -2
  295. package/dist/cli/chunks/witness-chain-JOI2YYGK.js +0 -2
  296. package/dist/cli/chunks/workflow-orchestrator-2NQ72S3C.js +0 -2
@@ -1,5 +1,5 @@
1
- import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.9.2");process.exit(0)}
2
- import{b as t4,c as r4}from"./chunk-DNLMZTE2.js";import{a as i4}from"./chunk-TTOE336G.js";import{a as o4}from"./chunk-4LA7IW3V.js";import{d as p4}from"./chunk-STE42EMB.js";import{a as L,b as U0,c as Pu,d as dt,e as mt,f as Dt,g as Ee,h as Yi,i as Yu}from"./chunk-VL7YOOC2.js";import{a as s4,c as l4}from"./chunk-Z5HXGVXZ.js";import{a as Xi,b as ht,c as un,d as Q0,e as en,f as an,g as Y0,h as tn,i as pt}from"./chunk-Q4A72ZTV.js";import{a as Yl}from"./chunk-7NOIIC7G.js";import{a as E4,b as d4,e as m4}from"./chunk-NM6TIEJ3.js";import{o as D4,s as h4}from"./chunk-JV7LX6OT.js";import{a as e4}from"./chunk-3GZKAORV.js";import{e as At,l as yt,q as o3}from"./chunk-BY47GV4T.js";import{a as n4,j as Ku}from"./chunk-GITD7SRQ.js";import{c as X0}from"./chunk-FAXVVLPL.js";import{g as c4}from"./chunk-QEQTC4WQ.js";import{a as ea}from"./chunk-GCMVJS5X.js";import{a as M,b as Z0,c as Re,d as Pe,e as ua,f as ju,g as ze}from"./chunk-UKDOMLBI.js";import{c as Ct}from"./chunk-QPRVX4H2.js";import{b as nn}from"./chunk-6SOJVEU7.js";import{f as n3}from"./chunk-RQGYJK7H.js";import{c as Et,d as a4}from"./chunk-QNBQBSAI.js";import{f as u4,o as c0}from"./chunk-GK72GUHA.js";import{a as N}from"./chunk-XIBVVZGB.js";import{c as B}from"./chunk-JOVINE23.js";import{b as rn,d as gt}from"./chunk-RJROC5M3.js";import{b as T,d as J}from"./chunk-N3F3CX4V.js";import{a as Fu,b as p,c as m}from"./chunk-BIVIPF4O.js";import{a as k,b as g,c as S}from"./chunk-SDTVHR63.js";import{f as A}from"./chunk-E25S5E2D.js";import{a as Qi}from"./chunk-VUAO4VFC.js";import{a as K,b as Du,d as cu}from"./chunk-34U7JDCN.js";import{a as Xl,c as J0,d as Ui,e as Zi}from"./chunk-MN742FIH.js";import{a as ce,b as we,c as lt,d as ct}from"./chunk-4DAOZQ3V.js";import{S as Qu,b as Te,n as Me}from"./chunk-DBE34QES.js";import{a as Ji,c as Zu,e as s0,g as l0}from"./chunk-YXCU4CJX.js";var f4={};s0(f4,{ALL_SUPPORTED_LANGUAGES:()=>h3,ALL_TEST_FRAMEWORKS:()=>Bt,DEFAULT_FRAMEWORKS:()=>cn,FRAMEWORK_ALIASES:()=>y4,FRAMEWORK_TO_LANGUAGE:()=>D3,LANGUAGE_FILE_EXTENSIONS:()=>x4,getLanguageFromExtension:()=>de,resolveFrameworkAlias:()=>kt});function kt(s){let e=s.toLowerCase().trim();return Bt.includes(e)?e:y4[e]}function de(s){return x4[s.startsWith(".")?s:`.${s}`]}var cn,y4,D3,x4,Bt,h3,d0=Zu(()=>{"use strict";cn={typescript:"vitest",javascript:"jest",python:"pytest",java:"junit5",csharp:"xunit",go:"go-test",rust:"rust-test",swift:"swift-testing",kotlin:"kotlin-junit",dart:"flutter-test"},y4={junit:"junit5","junit-5":"junit5","junit-4":"junit5",nunit:"nunit","x-unit":"xunit",xunit:"xunit",gotest:"go-test",go_test:"go-test",rusttest:"rust-test",rust_test:"rust-test",swift_testing:"swift-testing",swifttesting:"swift-testing",kotlin_junit:"kotlin-junit",kotlinjunit:"kotlin-junit",flutter_test:"flutter-test",fluttertest:"flutter-test",jest_rn:"jest-rn","jest-react-native":"jest-rn","react-native":"jest-rn"},D3={jest:"javascript",vitest:"typescript",mocha:"javascript",pytest:"python","node-test":"javascript",junit5:"java",testng:"java",xunit:"csharp",nunit:"csharp","go-test":"go","rust-test":"rust","swift-testing":"swift",xctest:"swift","kotlin-junit":"kotlin","flutter-test":"dart","jest-rn":"javascript",playwright:"typescript",cypress:"javascript"},x4={".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".java":"java",".cs":"csharp",".go":"go",".rs":"rust",".swift":"swift",".kt":"kotlin",".kts":"kotlin",".dart":"dart"},Bt=["jest","vitest","mocha","pytest","node-test","junit5","testng","xunit","nunit","go-test","rust-test","swift-testing","xctest","kotlin-junit","flutter-test","jest-rn","playwright","cypress"],h3=["typescript","javascript","python","java","csharp","go","rust","swift","kotlin","dart"]});function Oo(s,e={}){let{additionalContext:u,sourceCode:a,includeEvidence:t=!0,includeRemediation:r=!0,maxLength:i=8e3}=e,n=[];n.push(`# Security Finding Verification Request
1
+ import{createRequire as __cr}from"module";const require=__cr(import.meta.url);if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.9.4");process.exit(0)}
2
+ import{b as t4,c as r4}from"./chunk-ONOYANDX.js";import{a as i4}from"./chunk-V57PXZIK.js";import{a as o4}from"./chunk-RUJU5XEQ.js";import{d as p4}from"./chunk-RGRYL4MG.js";import{a as L,b as U0,c as Pu,d as dt,e as mt,f as Dt,g as Ee,h as Yi,i as Yu}from"./chunk-53M65YFH.js";import{a as s4,c as l4}from"./chunk-EHGTXIT7.js";import{a as Xi,b as ht,c as un,d as Q0,e as en,f as an,g as Y0,h as tn,i as pt}from"./chunk-ZKWNZ3ZK.js";import{a as Yl}from"./chunk-4TZTGYBQ.js";import{a as E4,b as d4,e as m4}from"./chunk-EFD2J6GG.js";import{o as D4,s as h4}from"./chunk-C3BXT3ZC.js";import{a as e4}from"./chunk-C567IO5M.js";import{e as At,l as yt,q as o3}from"./chunk-3MRFR534.js";import{a as n4,j as Ku}from"./chunk-LW3DV23G.js";import{c as X0}from"./chunk-SKWI5QBM.js";import{g as c4}from"./chunk-MUX762XZ.js";import{a as ea}from"./chunk-RAZ2PGZD.js";import{a as M,b as Z0,c as Re,d as Pe,e as ua,f as ju,g as ze}from"./chunk-O6QAOPUA.js";import{c as Ct}from"./chunk-OHZ6RJLS.js";import{b as nn}from"./chunk-JVUNZBKX.js";import{f as n3}from"./chunk-Q6FSXNQP.js";import{c as Et,d as a4}from"./chunk-54OLXGXJ.js";import{f as u4,o as c0}from"./chunk-G6RTCJFY.js";import{a as N}from"./chunk-MDFXPCBO.js";import{c as B}from"./chunk-RPYUKEAH.js";import{b as rn,d as gt}from"./chunk-J222JLZ6.js";import{b as T,d as J}from"./chunk-4GJAYXB7.js";import{a as Fu,b as p,c as m}from"./chunk-VBYREHZI.js";import{a as k,b as g,c as S}from"./chunk-F6AU2MAZ.js";import{f as A}from"./chunk-G72E5DL3.js";import{a as Qi}from"./chunk-RS7ZGWHV.js";import{a as K,b as Du,d as cu}from"./chunk-P3EOWBME.js";import{a as Xl,c as J0,d as Ui,e as Zi}from"./chunk-KELYPHMV.js";import{a as ce,b as we,c as lt,d as ct}from"./chunk-Q2ZYUIS2.js";import{S as Qu,b as Te,n as Me}from"./chunk-MN2MYLVW.js";import{a as Ji,c as Zu,e as s0,g as l0}from"./chunk-C2HGOUEB.js";var f4={};s0(f4,{ALL_SUPPORTED_LANGUAGES:()=>h3,ALL_TEST_FRAMEWORKS:()=>Bt,DEFAULT_FRAMEWORKS:()=>cn,FRAMEWORK_ALIASES:()=>y4,FRAMEWORK_TO_LANGUAGE:()=>D3,LANGUAGE_FILE_EXTENSIONS:()=>x4,getLanguageFromExtension:()=>de,resolveFrameworkAlias:()=>kt});function kt(s){let e=s.toLowerCase().trim();return Bt.includes(e)?e:y4[e]}function de(s){return x4[s.startsWith(".")?s:`.${s}`]}var cn,y4,D3,x4,Bt,h3,d0=Zu(()=>{"use strict";cn={typescript:"vitest",javascript:"jest",python:"pytest",java:"junit5",csharp:"xunit",go:"go-test",rust:"rust-test",swift:"swift-testing",kotlin:"kotlin-junit",dart:"flutter-test"},y4={junit:"junit5","junit-5":"junit5","junit-4":"junit5",nunit:"nunit","x-unit":"xunit",xunit:"xunit",gotest:"go-test",go_test:"go-test",rusttest:"rust-test",rust_test:"rust-test",swift_testing:"swift-testing",swifttesting:"swift-testing",kotlin_junit:"kotlin-junit",kotlinjunit:"kotlin-junit",flutter_test:"flutter-test",fluttertest:"flutter-test",jest_rn:"jest-rn","jest-react-native":"jest-rn","react-native":"jest-rn"},D3={jest:"javascript",vitest:"typescript",mocha:"javascript",pytest:"python","node-test":"javascript",junit5:"java",testng:"java",xunit:"csharp",nunit:"csharp","go-test":"go","rust-test":"rust","swift-testing":"swift",xctest:"swift","kotlin-junit":"kotlin","flutter-test":"dart","jest-rn":"javascript",playwright:"typescript",cypress:"javascript"},x4={".ts":"typescript",".tsx":"typescript",".js":"javascript",".jsx":"javascript",".mjs":"javascript",".cjs":"javascript",".py":"python",".java":"java",".cs":"csharp",".go":"go",".rs":"rust",".swift":"swift",".kt":"kotlin",".kts":"kotlin",".dart":"dart"},Bt=["jest","vitest","mocha","pytest","node-test","junit5","testng","xunit","nunit","go-test","rust-test","swift-testing","xctest","kotlin-junit","flutter-test","jest-rn","playwright","cypress"],h3=["typescript","javascript","python","java","csharp","go","rust","swift","kotlin","dart"]});function Oo(s,e={}){let{additionalContext:u,sourceCode:a,includeEvidence:t=!0,includeRemediation:r=!0,maxLength:i=8e3}=e,n=[];n.push(`# Security Finding Verification Request
3
3
 
4
4
  You are a security expert tasked with verifying whether the following security finding is valid or a false positive.
5
5
 
@@ -114,7 +114,7 @@ Always explain your reasoning clearly.
114
114
  Format your response with: verdict (confirmed/rejected/uncertain), confidence (0-100), and reasoning.`}}});import{randomUUID as W2u}from"crypto";Zi();var on={LOOP_WARNING:"loop.warning",LOOP_DETECTED:"loop.detected"},xt=class{subscriptions=new Map;subscriptionsByEventType=new Map;subscriptionsByChannel=new Map;wildcardSubscriptions=new Set;eventHistory;maxHistorySize=Ui.MAX_HISTORY_SIZE;subscriptionCounter=0;middlewares=[];constructor(e=Ui.MAX_HISTORY_SIZE){this.maxHistorySize=e,this.eventHistory=new Yl(e)}registerMiddleware(e){this.middlewares.push(e),this.middlewares.sort((u,a)=>u.priority-a.priority)}removeMiddleware(e){let u=this.middlewares.findIndex(a=>a.name===e);return u>=0?(this.middlewares.splice(u,1),!0):!1}getMiddlewares(){return this.middlewares}async publish(e){let u=e;for(let o of this.middlewares)if(o.onEmit&&u&&(u=await o.onEmit(u),!u))return;this.eventHistory.push(u);let a=new Set,t=this.subscriptionsByEventType.get(u.type);if(t)for(let o of t)a.add(o);let r=this.subscriptionsByChannel.get(u.source);if(r)for(let o of r)a.add(o);for(let o of this.wildcardSubscriptions)a.add(o);let i=[];for(let o of a){let l=this.subscriptions.get(o);!l||!l.active||l.channel&&l.channel!==u.source||l.eventType!=="*"&&l.eventType!==u.type||i.push(l)}let n=u;for(let o of this.middlewares)if(o.onReceive&&n&&(n=await o.onReceive(n),!n))return;await Promise.allSettled(i.map(o=>o.handler(n)))}subscribe(e,u){let a=`sub_${++this.subscriptionCounter}`,t={id:a,eventType:e,handler:u,active:!0};return this.subscriptions.set(a,t),e==="*"?this.wildcardSubscriptions.add(a):(this.subscriptionsByEventType.has(e)||this.subscriptionsByEventType.set(e,new Set),this.subscriptionsByEventType.get(e).add(a)),{unsubscribe:()=>{t.active=!1,this.subscriptions.delete(a),e==="*"?this.wildcardSubscriptions.delete(a):this.subscriptionsByEventType.get(e)?.delete(a)},get active(){return t.active}}}subscribeToChannel(e,u){let a=`sub_${++this.subscriptionCounter}`,t={id:a,eventType:"*",channel:e,handler:u,active:!0};return this.subscriptions.set(a,t),this.subscriptionsByChannel.has(e)||this.subscriptionsByChannel.set(e,new Set),this.subscriptionsByChannel.get(e).add(a),{unsubscribe:()=>{t.active=!1,this.subscriptions.delete(a),this.subscriptionsByChannel.get(e)?.delete(a)},get active(){return t.active}}}async getHistory(e){let u=this.eventHistory.toArray();return e&&(e.eventTypes?.length&&(u=u.filter(a=>e.eventTypes.includes(a.type))),e.sources?.length&&(u=u.filter(a=>e.sources.includes(a.source))),e.fromTimestamp&&(u=u.filter(a=>a.timestamp>=e.fromTimestamp)),e.toTimestamp&&(u=u.filter(a=>a.timestamp<=e.toTimestamp)),e.correlationId&&(u=u.filter(a=>a.correlationId===e.correlationId)),e.limit&&(u=u.slice(-e.limit))),u}async dispose(){this.subscriptions.clear(),this.subscriptionsByEventType.clear(),this.subscriptionsByChannel.clear(),this.wildcardSubscriptions.clear(),this.eventHistory.clear(),this.middlewares=[]}};Zi();var ft=class{agents=new Map;maxAgents;memoryBranch=null;constructor(e=J0.MAX_CONCURRENT_AGENTS){this.maxAgents=e}setMemoryBranch(e){this.memoryBranch=e}async spawn(e){if(!this.canSpawn())return m(new Error(`Cannot spawn agent: maximum concurrent agents (${this.maxAgents}) reached. Active: ${this.getActiveCount()}`));let u=e.config??{};if(e.progressiveContext?.strategy==="predictive"||process.env.AQE_PROGRESSIVE_CONTEXT_ENABLED==="true")try{let i=u.taskDescription||e.name||"",n=u.availableFiles||[];if(i&&n.length>0){let l=new sn(e.progressiveContext).predictFilesForTask(i,n);u={...u,availableFiles:l,contextFiles:l,initialFiles:l,progressiveContextApplied:!0}}}catch{}let t=A(),r={id:t,name:e.name,domain:e.domain,type:e.type,status:"running",capabilities:e.capabilities,config:u,startedAt:new Date};if(this.agents.set(t,r),this.memoryBranch)try{let i=this.memoryBranch.createBranch(t);r.config={...r.config,_memoryBranchPath:i.childPath,_memoryBranchRecordIngest:n=>{this.memoryBranch?.recordIngest(t,n)}}}catch(i){console.warn(`[AgentCoordinator] Memory branch creation failed for ${t}:`,i)}return p(t)}getStatus(e){return this.agents.get(e)?.status}listAgents(e){let u=Array.from(this.agents.values());return e&&(e.domain&&(u=u.filter(a=>a.domain===e.domain)),e.status&&(u=u.filter(a=>a.status===e.status)),e.type&&(u=u.filter(a=>a.type===e.type))),u.map(a=>({id:a.id,name:a.name,domain:a.domain,type:a.type,status:a.status,startedAt:a.startedAt}))}async stop(e){let u=this.agents.get(e);return u?u.status!=="running"?m(new Error(`Agent ${e} is not running (status: ${u.status})`)):(u.status="completed",u.completedAt=new Date,p(void 0)):m(new Error(`Agent not found: ${e}`))}getActiveCount(){return Array.from(this.agents.values()).filter(e=>e.status==="running"||e.status==="queued").length}canSpawn(){return this.getActiveCount()<this.maxAgents}async dispose(){let e=Array.from(this.agents.values()).filter(u=>u.status==="running");await Promise.all(e.map(u=>this.stop(u.id))),this.agents.clear()}markCompleted(e){let u=this.agents.get(e);u&&u.status==="running"&&(u.status="completed",u.completedAt=new Date,this.handleBranchOnComplete(e,"merge"))}markFailed(e){let u=this.agents.get(e);u&&u.status==="running"&&(u.status="failed",u.completedAt=new Date,this.handleBranchOnComplete(e,"discard"))}handleBranchOnComplete(e,u){if(!this.memoryBranch)return;let a=this.memoryBranch.getBranch(e);if(a)try{u==="merge"?this.memoryBranch.mergeBranch(a).catch(t=>{console.warn(`[AgentCoordinator] Branch merge failed for ${e}:`,t)}):this.memoryBranch.discardBranch(a)}catch(t){console.warn(`[AgentCoordinator] Branch ${u} failed for ${e}:`,t)}}cleanup(e=J0.DEFAULT_AGENT_TTL_MS){let u=Date.now(),a=0;for(let[t,r]of this.agents.entries())(r.status==="completed"||r.status==="failed")&&r.completedAt&&u-r.completedAt.getTime()>e&&(this.agents.delete(t),a++);return a}},s3={strategy:"full",maxInitialFiles:10,predictionThreshold:.7,trackFileRequests:!0},sn=class{config;fileRequests=[];preloadedFiles=new Set;constructor(e){this.config={...s3,...e}}isEnabled(){return process.env.AQE_PROGRESSIVE_CONTEXT_ENABLED==="true"}predictFilesForTask(e,u){if(!this.isEnabled()||this.config.strategy==="full")return[...u];if(!e||e.trim().length===0)return u.slice(0,this.config.maxInitialFiles);if(u.length===0)return[];let a=this.extractKeywords(e);if(a.length===0)return u.slice(0,this.config.maxInitialFiles);let t=u.map(i=>({filePath:i,score:this.scoreFile(i,a)}));t.sort((i,n)=>n.score-i.score);let r=t.slice(0,this.config.maxInitialFiles).map(i=>i.filePath);return this.preloadedFiles=new Set(r),r}recordFileRequest(e){this.config.trackFileRequests&&this.fileRequests.push(e)}getPredictionAccuracy(){let e=this.preloadedFiles.size,u=this.fileRequests.filter(i=>i.wasPreloaded).length,a=new Set(this.fileRequests.map(i=>i.filePath)),t=[...a].filter(i=>this.preloadedFiles.has(i)).length,r=a.size>0?t/a.size:0;return{predicted:e,actuallyUsed:u,hitRate:r}}getFileRequestHistory(e){return e?this.fileRequests.filter(u=>u.agentId===e):[...this.fileRequests]}extractKeywords(e){let u=new Set(["the","a","an","is","are","was","were","be","been","being","have","has","had","do","does","did","will","would","could","should","may","might","shall","can","to","of","in","for","on","with","at","by","from","as","into","through","during","before","after","and","but","or","nor","not","so","yet","both","either","neither","each","every","all","any","few","more","most","other","some","such","no","only","same","than","too","very","just","because","if","when","while","that","this","these","those","it","its","they","them","their","we","our","you","your","he","she","his","her","i","me","my"]),a=e.toLowerCase().split(/[\s\-_./\\,;:!?()[\]{}'"]+/).filter(t=>t.length>1&&!u.has(t));return[...new Set(a)]}scoreFile(e,u){let a=e.toLowerCase(),t=a.split(/[\\/.]/).filter(i=>i.length>0),r=0;for(let i of u)if(t.includes(i))r+=2;else if(a.includes(i))r+=1;else for(let n of t)if(n.startsWith(i)||i.startsWith(n)){r+=.5;break}return u.length>0?r/(u.length*2):0}};N();var l3=B.create("plugin-loader"),aa=class{constructor(e,u,a=!0){this.eventBus=e;this.memory=u}plugins=new Map;factories=new Map;loading=new Map;registerFactory(e,u){this.factories.set(e,u)}async load(e){let u=this.plugins.get(e);if(u)return u;let a=this.loading.get(e);if(a)return a;let t=this.factories.get(e);if(!t){let i=Array.from(this.factories.keys());throw new Error(`No factory registered for domain: ${e}
115
115
  This usually means the domain is not enabled in your config.
116
116
  Registered domains: ${i.join(", ")}
117
- Fix: Add '${e}' to domains.enabled in .agentic-qe/config.yaml, or run 'aqe init --auto-migrate' to enable all domains.`)}let r=this.loadPlugin(e,t);this.loading.set(e,r);try{let i=await r;return this.plugins.set(e,i),i}finally{this.loading.delete(e)}}async loadPlugin(e,u){let a=await u(this.eventBus,this.memory);for(let t of a.dependencies)this.isLoaded(t)||await this.load(t);return await a.initialize(),a}async unload(e){let u=this.plugins.get(e);if(u){for(let[a,t]of this.plugins.entries())if(t.dependencies.includes(e))throw new Error(`Cannot unload ${e}: domain ${a} depends on it`);await u.dispose(),this.plugins.delete(e)}}isLoaded(e){return this.plugins.has(e)}getLoaded(){return Array.from(this.plugins.keys())}async loadAll(){let e=Array.from(this.factories.keys()),u=this.topologicalSort(e);for(let a of u)await this.load(a)}topologicalSort(e){let u=[],a=new Set,t=new Set,r=i=>{if(a.has(i))return;if(t.has(i))throw new Error(`Circular dependency detected involving: ${i}`);t.add(i);let o=this.plugins.get(i)?.dependencies??[];for(let l of o)e.includes(l)&&r(l);t.delete(i),a.add(i),u.push(i)};for(let i of e)r(i);return u}getPlugin(e){return this.plugins.get(e)}async disposeAll(){let e=[...this.getLoaded()].reverse();for(let u of e)try{await this.unload(u)}catch(a){l3.debug("Plugin unload failed, force removing",{domain:u,error:a instanceof Error?a.message:String(a)}),this.plugins.delete(u)}}};ct();N();var ln=B.create("anti-drift-middleware"),c3={maxIdenticalCalls:3,windowMs:3e4,steeringMessage:"Loop detected: the same tool call has been repeated multiple times. Consider an alternative approach or different parameters.",enableFleetLearning:!1};function g4(s){let e=2166136261;for(let u=0;u<s.length;u++)e^=s.charCodeAt(u),e=Math.imul(e,16777619);return(e>>>0).toString(16).padStart(8,"0")}var vt=class{config;callHistory=new Map;totalCallsTracked=0;loopsDetected=0;constructor(e){this.config={...c3,...e}}trackCall(e,u,a){if(process.env.AQE_LOOP_DETECTION_ENABLED==="false")return{isLoop:!1,callCount:1,signature:this.createSignature(u,a),action:"allow"};let t=this.createSignature(u,a);this.totalCallsTracked++,this.callHistory.has(e)||this.callHistory.set(e,[]);let r=this.callHistory.get(e);r.push(t);let i=Date.now()-this.config.windowMs,n=r.findIndex(l=>l.timestamp>=i);n>0?r.splice(0,n):n===-1&&(r.length=0,r.push(t));let o=r.filter(l=>l.hash===t.hash).length;return o>=this.config.maxIdenticalCalls?(this.loopsDetected++,{isLoop:!0,callCount:o,signature:t,action:"steer",steeringMessage:this.config.steeringMessage}):o===this.config.maxIdenticalCalls-1?{isLoop:!1,callCount:o,signature:t,action:"warn"}:{isLoop:!1,callCount:o,signature:t,action:"allow"}}getMetrics(){return{totalCallsTracked:this.totalCallsTracked,loopsDetected:this.loopsDetected}}clear(){this.callHistory.clear(),this.totalCallsTracked=0,this.loopsDetected=0}createSignature(e,u){let a=JSON.stringify(u??""),t=g4(a),r=`${e}:${a}`;return{hash:g4(r),toolName:e,argsFingerprint:t,timestamp:Date.now()}}},A4={"quality-gate":.05,coverage:.1,"test-generation":.15,learning:.2,default:.12},E3={thresholds:A4,agentId:"unknown",maxHistorySize:200,fallbackDimension:64};function d3(s,e){let u=new Float64Array(e),a=2166136261,t=16777619;for(let n=0;n<s.length;n++){let o=s.charCodeAt(n);a^=o,a=Math.imul(a,16777619),t^=o,t=Math.imul(t,2166136261);let l=(a>>>0)%e;u[l]+=(t>>>0)/4294967295*2-1}let r=0;for(let n=0;n<e;n++)r+=u[n]*u[n];r=Math.sqrt(r);let i=new Array(e);for(let n=0;n<e;n++)i[n]=r===0?0:u[n]/r;return i}var C4=!1,E0=!1,Ft=null;async function m3(){if(C4)return E0;C4=!0;try{let s=await import("./real-embeddings-NKH4VURF.js");if(typeof s.isTransformerAvailable=="function"&&s.isTransformerAvailable())Ft=s.computeRealEmbedding,E0=!0;else try{await s.computeRealEmbedding("probe"),Ft=s.computeRealEmbedding,E0=!0}catch(e){ln.debug("Transformer probe embedding failed",{error:e instanceof Error?e.message:String(e)}),E0=!1}}catch(s){ln.debug("Transformer module import failed",{error:s instanceof Error?s.message:String(s)}),E0=!1}return E0}var bt=class{name="semantic-anti-drift";priority=10;config;history=[];totalChecked=0;driftCount=0;similaritySum=0;constructor(e){this.config={...E3,...e,thresholds:{...A4,...e?.thresholds}}}async onEmit(e){let u=JSON.stringify(e.payload),a=await this.embed(u),t=this.resolveCategory(e.type),r=this.config.thresholds[t]??this.config.thresholds.default,i={embedding:a,driftThreshold:r,sourceAgentId:this.config.agentId,hopCount:0,emittedAt:Date.now()};return{...e,semanticFingerprint:i}}async onReceive(e){let u=e.semanticFingerprint;if(!u)return e;let a=JSON.stringify(e.payload),t=await this.embed(a),r=ce(t,u.embedding),n=1-r>u.driftThreshold;this.totalChecked++,this.similaritySum+=r;let o={drifted:n,cosineSimilarity:r,threshold:u.driftThreshold,eventType:e.type,hopCount:u.hopCount+1,checkedAt:Date.now()};if(this.history.push(o),this.history.length>this.config.maxHistorySize&&this.history.shift(),n)return this.driftCount++,await this.emitDriftEvent(e,o),null;let l={...u,hopCount:u.hopCount+1};return{...e,semanticFingerprint:l}}getDriftHistory(){return this.history}getStats(){return{totalChecked:this.totalChecked,driftCount:this.driftCount,averageSimilarity:this.totalChecked>0?this.similaritySum/this.totalChecked:0}}validateConfig(){for(let[e,u]of Object.entries(this.config.thresholds))if(typeof u!="number"||u<0||u>1)return m(new Error(`Invalid threshold for "${e}": must be between 0 and 1, got ${u}`));return this.config.maxHistorySize<=0?m(new Error("maxHistorySize must be positive")):this.config.fallbackDimension<=0?m(new Error("fallbackDimension must be positive")):p(void 0)}async embed(e){return await m3()&&Ft?Ft(e):d3(e,this.config.fallbackDimension)}resolveCategory(e){let u=e.toLowerCase();for(let a of Object.keys(this.config.thresholds))if(a!=="default"&&u.includes(a))return a;return"default"}async emitDriftEvent(e,u){if(!this.config.onDriftDetected)return;let a={id:`drift-${e.id}-${Date.now()}`,type:"SemanticDriftDetected",timestamp:new Date,source:e.source,correlationId:e.correlationId,payload:{originalEventId:e.id,originalEventType:e.type,cosineSimilarity:u.cosineSimilarity,threshold:u.threshold,hopCount:u.hopCount,agentId:this.config.agentId}};try{await this.config.onDriftDetected(a)}catch(t){ln.debug("onDriftDetected callback failed",{error:t instanceof Error?t.message:String(t)})}}};Zi();c0();import*as o0 from"path";import*as qi from"fs";S();var U=class{constructor(e,u){this.eventBus=e;this.memory=u}_initialized=!1;_health={status:"idle",agents:{total:0,active:0,idle:0,failed:0},errors:[]};_minCutBridge;_consensusConfig;isReady(){return this._initialized}getHealth(){return{...this._health}}async initialize(){this._initialized||(await this.onInitialize(),this.subscribeToEvents(),this._initialized=!0)}async dispose(){await this.onDispose(),this._initialized=!1}async handleEvent(e){await this.onEvent(e)}async onInitialize(){}async onDispose(){}async onEvent(e){}subscribeToEvents(){}async publishEvent(e,u){let a={id:crypto.randomUUID(),type:e,timestamp:new Date,source:this.name,payload:u};await this.eventBus.publish(a)}updateHealth(e){this._health={...this._health,...e}}setMinCutBridge(e){this._minCutBridge=e,this.onMinCutBridgeSet(e)}getMinCutBridge(){return this._minCutBridge}setConsensusConfig(e){this._consensusConfig=e,this.onConsensusConfigSet(e)}getConsensusConfig(){return this._consensusConfig}setIntegrationConfig(e){e.minCutBridge&&this.setMinCutBridge(e.minCutBridge),e.consensusConfig&&this.setConsensusConfig(e.consensusConfig)}hasMinCutIntegration(){return this._minCutBridge!==void 0}hasConsensusEnabled(){return this._consensusConfig?.enabled===!0}onMinCutBridgeSet(e){}onConsensusConfigSet(e){}getTaskHandlers(){return new Map}canHandleTask(e){return this.getTaskHandlers().has(e)}async executeTask(e,u){let t=this.getTaskHandlers().get(e.taskType);return t?(this.runTaskAsync(e,t,u),p(void 0)):m(new Error(`Domain ${this.name} has no handler for task type: ${e.taskType}`))}async runTaskAsync(e,u,a){let t=Date.now();try{let r=await u(e.payload),i=Date.now()-t,n={taskId:e.taskId,success:r.success,data:r.success?r.value:void 0,error:r.success?void 0:r.error?.message,duration:i};if(await a(n),r.success)this.updateHealth({lastActivity:new Date,agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),idle:this._health.agents.idle+1}});else{let o=r.error?.message??"Unknown error";this.updateHealth({lastActivity:new Date,errors:[...this._health.errors.slice(-9),o],agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),failed:this._health.agents.failed+1}})}}catch(r){let i=Date.now()-t,n=k(r);await a({taskId:e.taskId,success:!1,error:n,duration:i}),this.updateHealth({lastActivity:new Date,errors:[...this._health.errors.slice(-9),n],agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),failed:this._health.agents.failed+1}})}}};N();S();N();import*as oc from"fs";import*as ga from"path";d0();import{randomBytes as p3,randomInt as me,randomUUID as g3}from"node:crypto";function v4(s){return p3(s).toString("hex")}var z={uuid:()=>g3(),email:()=>`user_${v4(3)}@example.com`,fullName:()=>{let s=["Alice","Bob","Carol","Dave","Eve","Frank"],e=["Smith","Jones","Lee","Garcia","Chen","Novak"];return`${s[me(s.length)]} ${e[me(e.length)]}`},url:()=>`https://example.com/${v4(4)}`,recentDate:()=>new Date(Date.now()-me(7*864e5)).toISOString(),phone:()=>`+1${String(me(2e9,9999999999))}`,streetAddress:()=>`${me(1,9999)} Main St`,word:()=>{let s=["alpha","bravo","charlie","delta","echo","foxtrot","golf","hotel"];return s[me(s.length)]},int:(s=1,e=100)=>{if(s>e){let u=s;s=e,e=u}return me(s,e+1)},float:(s=0,e=100,u=2)=>{if(s>e){let t=s;s=e,e=t}if(s===e)return s;let a=s+me(0,1000001)/1e6*(e-s);return Number(a.toFixed(u))}};var uu=class s{static NAME_VALUE_TABLE=[["id",()=>`'${z.uuid()}'`],["email",()=>`'${z.email()}'`],["name",()=>`'${z.fullName()}'`],["url",()=>`'${z.url()}'`],["date",()=>`new Date('${z.recentDate()}')`],["phone",()=>`'${z.phone()}'`],["address",()=>`'${z.streetAddress()}'`]];static TYPE_VALUE_TABLE=[["string",()=>`'${z.word()}'`],["number",()=>String(z.int(1,100))],["boolean",()=>"true"],["[]",()=>"[]"],["array",()=>"[]"],["object",()=>"{}"],["{",()=>"{}"],["function",()=>"() => {}"],["promise",()=>"Promise.resolve()"],["date",()=>"new Date()"]];generateTestValue(e){if(e.defaultValue)return e.defaultValue;let u=e.type?.toLowerCase()||"unknown",a=e.name.toLowerCase();for(let[t,r]of s.NAME_VALUE_TABLE)if(a.includes(t))return r();for(let[t,r]of s.TYPE_VALUE_TABLE)if(u.includes(t))return r();return`{} /* TODO: provide ${e.name}: ${e.type||"unknown"} */`}generateTestCasesForFunction(e){let u=[],a=e.parameters.map(l=>this.generateTestValue(l)).join(", "),t=e.isAsync?`await ${e.name}(${a})`:`${e.name}(${a})`,r=e.returnType==="void"||e.returnType==="Promise<void>",i="expect(result).toBeDefined();";if(!r){if(/^(is|has|can)[A-Z]/.test(e.name))i="expect(typeof result).toBe('boolean');";else if(/^(get|fetch|find)[A-Z]/.test(e.name))i="expect(result).not.toBeUndefined();";else if(/^(create|build|make)[A-Z]/.test(e.name))i="expect(result).toBeTruthy();";else if(e.returnType){let l=e.returnType.toLowerCase().replace(/promise<(.+)>/,"$1");l.includes("{")?i="expect(typeof result).toBe('object');":l==="boolean"?i="expect(typeof result).toBe('boolean');":l==="number"?i="expect(typeof result).toBe('number');":l==="string"?i="expect(typeof result).toBe('string');":l.includes("[]")||l.includes("array")?i="expect(Array.isArray(result)).toBe(true);":l.includes("boolean")?i="expect(typeof result).toBe('boolean');":l.includes("number")?i="expect(typeof result).toBe('number');":l.includes("string")&&(i="expect(typeof result).toBe('string');")}}u.push({description:"should handle valid input correctly",type:"happy-path",action:r?`${t};`:`const result = ${t};`,assertion:r?"// void function \u2014 no return value to assert":i});let n=e.body||"",o=/\bthrow\b/.test(n)||/\bvalidat/i.test(n);for(let l of e.parameters){if(!l.optional){let c=e.parameters.map(E=>E.name===l.name?"undefined":this.generateTestValue(E)).join(", ");if(o)u.push({description:`should handle undefined ${l.name}`,type:"error-handling",action:e.isAsync?`const action = async () => await ${e.name}(${c});`:`const action = () => ${e.name}(${c});`,assertion:"expect(action).toThrow();"});else{let E=e.isAsync?`await ${e.name}(${c})`:`${e.name}(${c})`;u.push({description:`should handle undefined ${l.name}`,type:"edge-case",action:e.isAsync?`let threw = false;
117
+ Fix: Add '${e}' to domains.enabled in .agentic-qe/config.yaml, or run 'aqe init --auto-migrate' to enable all domains.`)}let r=this.loadPlugin(e,t);this.loading.set(e,r);try{let i=await r;return this.plugins.set(e,i),i}finally{this.loading.delete(e)}}async loadPlugin(e,u){let a=await u(this.eventBus,this.memory);for(let t of a.dependencies)this.isLoaded(t)||await this.load(t);return await a.initialize(),a}async unload(e){let u=this.plugins.get(e);if(u){for(let[a,t]of this.plugins.entries())if(t.dependencies.includes(e))throw new Error(`Cannot unload ${e}: domain ${a} depends on it`);await u.dispose(),this.plugins.delete(e)}}isLoaded(e){return this.plugins.has(e)}getLoaded(){return Array.from(this.plugins.keys())}async loadAll(){let e=Array.from(this.factories.keys()),u=this.topologicalSort(e);for(let a of u)await this.load(a)}topologicalSort(e){let u=[],a=new Set,t=new Set,r=i=>{if(a.has(i))return;if(t.has(i))throw new Error(`Circular dependency detected involving: ${i}`);t.add(i);let o=this.plugins.get(i)?.dependencies??[];for(let l of o)e.includes(l)&&r(l);t.delete(i),a.add(i),u.push(i)};for(let i of e)r(i);return u}getPlugin(e){return this.plugins.get(e)}async disposeAll(){let e=[...this.getLoaded()].reverse();for(let u of e)try{await this.unload(u)}catch(a){l3.debug("Plugin unload failed, force removing",{domain:u,error:a instanceof Error?a.message:String(a)}),this.plugins.delete(u)}}};ct();N();var ln=B.create("anti-drift-middleware"),c3={maxIdenticalCalls:3,windowMs:3e4,steeringMessage:"Loop detected: the same tool call has been repeated multiple times. Consider an alternative approach or different parameters.",enableFleetLearning:!1};function g4(s){let e=2166136261;for(let u=0;u<s.length;u++)e^=s.charCodeAt(u),e=Math.imul(e,16777619);return(e>>>0).toString(16).padStart(8,"0")}var vt=class{config;callHistory=new Map;totalCallsTracked=0;loopsDetected=0;constructor(e){this.config={...c3,...e}}trackCall(e,u,a){if(process.env.AQE_LOOP_DETECTION_ENABLED==="false")return{isLoop:!1,callCount:1,signature:this.createSignature(u,a),action:"allow"};let t=this.createSignature(u,a);this.totalCallsTracked++,this.callHistory.has(e)||this.callHistory.set(e,[]);let r=this.callHistory.get(e);r.push(t);let i=Date.now()-this.config.windowMs,n=r.findIndex(l=>l.timestamp>=i);n>0?r.splice(0,n):n===-1&&(r.length=0,r.push(t));let o=r.filter(l=>l.hash===t.hash).length;return o>=this.config.maxIdenticalCalls?(this.loopsDetected++,{isLoop:!0,callCount:o,signature:t,action:"steer",steeringMessage:this.config.steeringMessage}):o===this.config.maxIdenticalCalls-1?{isLoop:!1,callCount:o,signature:t,action:"warn"}:{isLoop:!1,callCount:o,signature:t,action:"allow"}}getMetrics(){return{totalCallsTracked:this.totalCallsTracked,loopsDetected:this.loopsDetected}}clear(){this.callHistory.clear(),this.totalCallsTracked=0,this.loopsDetected=0}createSignature(e,u){let a=JSON.stringify(u??""),t=g4(a),r=`${e}:${a}`;return{hash:g4(r),toolName:e,argsFingerprint:t,timestamp:Date.now()}}},A4={"quality-gate":.05,coverage:.1,"test-generation":.15,learning:.2,default:.12},E3={thresholds:A4,agentId:"unknown",maxHistorySize:200,fallbackDimension:64};function d3(s,e){let u=new Float64Array(e),a=2166136261,t=16777619;for(let n=0;n<s.length;n++){let o=s.charCodeAt(n);a^=o,a=Math.imul(a,16777619),t^=o,t=Math.imul(t,2166136261);let l=(a>>>0)%e;u[l]+=(t>>>0)/4294967295*2-1}let r=0;for(let n=0;n<e;n++)r+=u[n]*u[n];r=Math.sqrt(r);let i=new Array(e);for(let n=0;n<e;n++)i[n]=r===0?0:u[n]/r;return i}var C4=!1,E0=!1,Ft=null;async function m3(){if(C4)return E0;C4=!0;try{let s=await import("./real-embeddings-QN5BY3WS.js");if(typeof s.isTransformerAvailable=="function"&&s.isTransformerAvailable())Ft=s.computeRealEmbedding,E0=!0;else try{await s.computeRealEmbedding("probe"),Ft=s.computeRealEmbedding,E0=!0}catch(e){ln.debug("Transformer probe embedding failed",{error:e instanceof Error?e.message:String(e)}),E0=!1}}catch(s){ln.debug("Transformer module import failed",{error:s instanceof Error?s.message:String(s)}),E0=!1}return E0}var bt=class{name="semantic-anti-drift";priority=10;config;history=[];totalChecked=0;driftCount=0;similaritySum=0;constructor(e){this.config={...E3,...e,thresholds:{...A4,...e?.thresholds}}}async onEmit(e){let u=JSON.stringify(e.payload),a=await this.embed(u),t=this.resolveCategory(e.type),r=this.config.thresholds[t]??this.config.thresholds.default,i={embedding:a,driftThreshold:r,sourceAgentId:this.config.agentId,hopCount:0,emittedAt:Date.now()};return{...e,semanticFingerprint:i}}async onReceive(e){let u=e.semanticFingerprint;if(!u)return e;let a=JSON.stringify(e.payload),t=await this.embed(a),r=ce(t,u.embedding),n=1-r>u.driftThreshold;this.totalChecked++,this.similaritySum+=r;let o={drifted:n,cosineSimilarity:r,threshold:u.driftThreshold,eventType:e.type,hopCount:u.hopCount+1,checkedAt:Date.now()};if(this.history.push(o),this.history.length>this.config.maxHistorySize&&this.history.shift(),n)return this.driftCount++,await this.emitDriftEvent(e,o),null;let l={...u,hopCount:u.hopCount+1};return{...e,semanticFingerprint:l}}getDriftHistory(){return this.history}getStats(){return{totalChecked:this.totalChecked,driftCount:this.driftCount,averageSimilarity:this.totalChecked>0?this.similaritySum/this.totalChecked:0}}validateConfig(){for(let[e,u]of Object.entries(this.config.thresholds))if(typeof u!="number"||u<0||u>1)return m(new Error(`Invalid threshold for "${e}": must be between 0 and 1, got ${u}`));return this.config.maxHistorySize<=0?m(new Error("maxHistorySize must be positive")):this.config.fallbackDimension<=0?m(new Error("fallbackDimension must be positive")):p(void 0)}async embed(e){return await m3()&&Ft?Ft(e):d3(e,this.config.fallbackDimension)}resolveCategory(e){let u=e.toLowerCase();for(let a of Object.keys(this.config.thresholds))if(a!=="default"&&u.includes(a))return a;return"default"}async emitDriftEvent(e,u){if(!this.config.onDriftDetected)return;let a={id:`drift-${e.id}-${Date.now()}`,type:"SemanticDriftDetected",timestamp:new Date,source:e.source,correlationId:e.correlationId,payload:{originalEventId:e.id,originalEventType:e.type,cosineSimilarity:u.cosineSimilarity,threshold:u.threshold,hopCount:u.hopCount,agentId:this.config.agentId}};try{await this.config.onDriftDetected(a)}catch(t){ln.debug("onDriftDetected callback failed",{error:t instanceof Error?t.message:String(t)})}}};Zi();c0();import*as o0 from"path";import*as qi from"fs";S();var U=class{constructor(e,u){this.eventBus=e;this.memory=u}_initialized=!1;_health={status:"idle",agents:{total:0,active:0,idle:0,failed:0},errors:[]};_minCutBridge;_consensusConfig;isReady(){return this._initialized}getHealth(){return{...this._health}}async initialize(){this._initialized||(await this.onInitialize(),this.subscribeToEvents(),this._initialized=!0)}async dispose(){await this.onDispose(),this._initialized=!1}async handleEvent(e){await this.onEvent(e)}async onInitialize(){}async onDispose(){}async onEvent(e){}subscribeToEvents(){}async publishEvent(e,u){let a={id:crypto.randomUUID(),type:e,timestamp:new Date,source:this.name,payload:u};await this.eventBus.publish(a)}updateHealth(e){this._health={...this._health,...e}}setMinCutBridge(e){this._minCutBridge=e,this.onMinCutBridgeSet(e)}getMinCutBridge(){return this._minCutBridge}setConsensusConfig(e){this._consensusConfig=e,this.onConsensusConfigSet(e)}getConsensusConfig(){return this._consensusConfig}setIntegrationConfig(e){e.minCutBridge&&this.setMinCutBridge(e.minCutBridge),e.consensusConfig&&this.setConsensusConfig(e.consensusConfig)}hasMinCutIntegration(){return this._minCutBridge!==void 0}hasConsensusEnabled(){return this._consensusConfig?.enabled===!0}onMinCutBridgeSet(e){}onConsensusConfigSet(e){}getTaskHandlers(){return new Map}canHandleTask(e){return this.getTaskHandlers().has(e)}async executeTask(e,u){let t=this.getTaskHandlers().get(e.taskType);return t?(this.runTaskAsync(e,t,u),p(void 0)):m(new Error(`Domain ${this.name} has no handler for task type: ${e.taskType}`))}async runTaskAsync(e,u,a){let t=Date.now();try{let r=await u(e.payload),i=Date.now()-t,n={taskId:e.taskId,success:r.success,data:r.success?r.value:void 0,error:r.success?void 0:r.error?.message,duration:i};if(await a(n),r.success)this.updateHealth({lastActivity:new Date,agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),idle:this._health.agents.idle+1}});else{let o=r.error?.message??"Unknown error";this.updateHealth({lastActivity:new Date,errors:[...this._health.errors.slice(-9),o],agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),failed:this._health.agents.failed+1}})}}catch(r){let i=Date.now()-t,n=k(r);await a({taskId:e.taskId,success:!1,error:n,duration:i}),this.updateHealth({lastActivity:new Date,errors:[...this._health.errors.slice(-9),n],agents:{...this._health.agents,active:Math.max(0,this._health.agents.active-1),failed:this._health.agents.failed+1}})}}};N();S();N();import*as oc from"fs";import*as ga from"path";d0();import{randomBytes as p3,randomInt as me,randomUUID as g3}from"node:crypto";function v4(s){return p3(s).toString("hex")}var z={uuid:()=>g3(),email:()=>`user_${v4(3)}@example.com`,fullName:()=>{let s=["Alice","Bob","Carol","Dave","Eve","Frank"],e=["Smith","Jones","Lee","Garcia","Chen","Novak"];return`${s[me(s.length)]} ${e[me(e.length)]}`},url:()=>`https://example.com/${v4(4)}`,recentDate:()=>new Date(Date.now()-me(7*864e5)).toISOString(),phone:()=>`+1${String(me(2e9,9999999999))}`,streetAddress:()=>`${me(1,9999)} Main St`,word:()=>{let s=["alpha","bravo","charlie","delta","echo","foxtrot","golf","hotel"];return s[me(s.length)]},int:(s=1,e=100)=>{if(s>e){let u=s;s=e,e=u}return me(s,e+1)},float:(s=0,e=100,u=2)=>{if(s>e){let t=s;s=e,e=t}if(s===e)return s;let a=s+me(0,1000001)/1e6*(e-s);return Number(a.toFixed(u))}};var uu=class s{static NAME_VALUE_TABLE=[["id",()=>`'${z.uuid()}'`],["email",()=>`'${z.email()}'`],["name",()=>`'${z.fullName()}'`],["url",()=>`'${z.url()}'`],["date",()=>`new Date('${z.recentDate()}')`],["phone",()=>`'${z.phone()}'`],["address",()=>`'${z.streetAddress()}'`]];static TYPE_VALUE_TABLE=[["string",()=>`'${z.word()}'`],["number",()=>String(z.int(1,100))],["boolean",()=>"true"],["[]",()=>"[]"],["array",()=>"[]"],["object",()=>"{}"],["{",()=>"{}"],["function",()=>"() => {}"],["promise",()=>"Promise.resolve()"],["date",()=>"new Date()"]];generateTestValue(e){if(e.defaultValue)return e.defaultValue;let u=e.type?.toLowerCase()||"unknown",a=e.name.toLowerCase();for(let[t,r]of s.NAME_VALUE_TABLE)if(a.includes(t))return r();for(let[t,r]of s.TYPE_VALUE_TABLE)if(u.includes(t))return r();return`{} /* TODO: provide ${e.name}: ${e.type||"unknown"} */`}generateTestCasesForFunction(e){let u=[],a=e.parameters.map(l=>this.generateTestValue(l)).join(", "),t=e.isAsync?`await ${e.name}(${a})`:`${e.name}(${a})`,r=e.returnType==="void"||e.returnType==="Promise<void>",i="expect(result).toBeDefined();";if(!r){if(/^(is|has|can)[A-Z]/.test(e.name))i="expect(typeof result).toBe('boolean');";else if(/^(get|fetch|find)[A-Z]/.test(e.name))i="expect(result).not.toBeUndefined();";else if(/^(create|build|make)[A-Z]/.test(e.name))i="expect(result).toBeTruthy();";else if(e.returnType){let l=e.returnType.toLowerCase().replace(/promise<(.+)>/,"$1");l.includes("{")?i="expect(typeof result).toBe('object');":l==="boolean"?i="expect(typeof result).toBe('boolean');":l==="number"?i="expect(typeof result).toBe('number');":l==="string"?i="expect(typeof result).toBe('string');":l.includes("[]")||l.includes("array")?i="expect(Array.isArray(result)).toBe(true);":l.includes("boolean")?i="expect(typeof result).toBe('boolean');":l.includes("number")?i="expect(typeof result).toBe('number');":l.includes("string")&&(i="expect(typeof result).toBe('string');")}}u.push({description:"should handle valid input correctly",type:"happy-path",action:r?`${t};`:`const result = ${t};`,assertion:r?"// void function \u2014 no return value to assert":i});let n=e.body||"",o=/\bthrow\b/.test(n)||/\bvalidat/i.test(n);for(let l of e.parameters){if(!l.optional){let c=e.parameters.map(E=>E.name===l.name?"undefined":this.generateTestValue(E)).join(", ");if(o)u.push({description:`should handle undefined ${l.name}`,type:"error-handling",action:e.isAsync?`const action = async () => await ${e.name}(${c});`:`const action = () => ${e.name}(${c});`,assertion:"expect(action).toThrow();"});else{let E=e.isAsync?`await ${e.name}(${c})`:`${e.name}(${c})`;u.push({description:`should handle undefined ${l.name}`,type:"edge-case",action:e.isAsync?`let threw = false;
118
118
  try {
119
119
  await ${e.name}(${c});
120
120
  } catch (e) {
@@ -2059,7 +2059,7 @@ ${e}
2059
2059
  Return a JSON array of test suggestions, each with: { "name": "test name", "description": "what to test", "type": "unit|integration|edge" }`},{role:"user",content:`Analyze this ${a} code and suggest test cases:
2060
2060
  \`\`\`${this.getCodeFenceLanguage(a)}
2061
2061
  ${e}
2062
- \`\`\``}],model:t,maxTokens:1024,temperature:.5});if(r.content)try{let i=r.content.match(/\[[\s\S]*\]/);if(i)return T(i[0]).map(o=>o.name)}catch{}return[]}catch{return jo.warn("LLM suggestion generation failed:"),[]}}async generateTests(e){try{let u=ac({sourceFiles:e.sourceFiles,language:e.language,framework:e.framework,projectRoot:e.projectRoot}),a=e.framework||u?.framework||"vitest",t=e.language||u?.language,{sourceFiles:r,testType:i,coverageTarget:n=this.config.coverageTargetDefault,patterns:o=[]}=e;if(r.length===0)return m(new Error("No source files provided"));let l=[],c=[];for(let d of r){let D=await this.generateTestsForFile(d,i,a,o,t,e);D.success&&(l.push(...D.value.tests),c.push(...D.value.patternsUsed))}if(process.env.AQE_HOLDOUT_TESTING_ENABLED==="true")for(let d of l)D6u(d.id)&&(d.holdout=!0);let E=this.estimateCoverage(l,n);return await this.storeGenerationMetadata(l,c),p({tests:l,coverageEstimate:E,patternsUsed:Array.from(new Set(c))})}catch(u){return m(g(u))}}async generateForCoverageGap(e,u,a){try{if(u.length===0)return p([]);let t=[],r=this.groupConsecutiveLines(u),i=this.generatorFactory.supports(a)?a:this.config.defaultFramework;for(let n of r){let o=await this.generateTestForLines(e,n,i);o&&t.push(o)}return p(t)}catch(t){return m(g(t))}}async generateTDDTests(e){try{let u=await this.tddGenerator.generateTDDTests(e);return p(u)}catch(u){return m(g(u))}}async generatePropertyTests(e){try{let u=await this.propertyTestGenerator.generatePropertyTests(e);return p(u)}catch(u){return m(g(u))}}async generateTestData(e){try{let u=await this.testDataGenerator.generateTestData(e);return p(u)}catch(u){return m(g(u))}}async generateTestsForFile(e,u,a,t,r,i){let n=this.getTestFilePath(e,a),o=[],l=await this.findApplicablePatterns(e,t);o.push(...l.map(w=>w.name));let c=null,E="";try{E=oc.readFileSync(e,"utf-8"),c=await this.analyzeSourceCode(E,e)}catch{}let d,D;this.memory&&E&&await this.hasKGVectors()&&(d=await this.queryKGDependencies(e,E),D=await this.queryKGSimilarCode(E));let h=this.generatorFactory.create(a),C=this.extractModuleName(e),y=this.getImportPath(e),x={moduleName:C,importPath:y,testType:u,patterns:l,analysis:c??void 0,dependencies:d,similarCode:D},b=h.generateTests(x);this.isLLMEnhancementAvailable()&&E&&(b=await this.enhanceTestWithLLM(b,E,c,x));let R={id:A(),name:`${C} tests`,sourceFile:e,testFile:n,testCode:b,type:u,assertions:this.countAssertions(b),language:r,framework:a,llmEnhanced:this.isLLMEnhancementAvailable()};if(i?.compileValidation&&r)try{let w=await rc.validate(b,r,i.projectRoot);R.compilationValidated=w.compiles,w.compiles||(R.compilationErrors=w.errors.map(P=>P.message))}catch{}return this.qualityGate&&(R.qualityGateResult=this.qualityGate.validate(b,e,E||void 0)),p({tests:[R],patternsUsed:o})}async generateTestForLines(e,u,a){if(u.length===0)return null;let t=A(),r=this.getTestFilePath(e,a),i=this.extractModuleName(e),n=this.getImportPath(e),l=this.generatorFactory.create(a).generateCoverageTests(i,n,u);return{id:t,name:`Coverage test for lines ${u[0]}-${u[u.length-1]}`,sourceFile:e,testFile:r,testCode:l,type:"unit",assertions:this.countAssertions(l)}}async analyzeSourceCode(e,u){let a=ga.extname(u),t=de(a);if(t&&t!=="typescript"&&t!=="javascript"){let l=await Z0.parseFile(e,u,t);if(l)return De.convertParsedFile(l)}let r=M.createSourceFile(ga.basename(u),e,M.ScriptTarget.Latest,!0,M.ScriptKind.TS),i=[],n=[],o=l=>{if(M.isFunctionDeclaration(l)&&l.name)i.push(this.extractFunctionInfo(l,r));else if(M.isVariableStatement(l)){for(let c of l.declarationList.declarations)if(M.isVariableDeclaration(c)&&c.initializer&&(M.isArrowFunction(c.initializer)||M.isFunctionExpression(c.initializer))){let E=c.name.getText(r);i.push(this.extractArrowFunctionInfo(E,c.initializer,r,l))}}else M.isClassDeclaration(l)&&l.name&&n.push(this.extractClassInfo(l,r));M.forEachChild(l,o)};return M.forEachChild(r,o),{functions:i,classes:n}}extractFunctionInfo(e,u){let a=e.name?.getText(u)||"anonymous",t=this.extractParameters(e.parameters,u),r=e.type?.getText(u),i=e.modifiers?.some(c=>c.kind===M.SyntaxKind.AsyncKeyword)??!1,n=e.modifiers?.some(c=>c.kind===M.SyntaxKind.ExportKeyword)??!1,{line:o}=u.getLineAndCharacterOfPosition(e.getStart(u)),{line:l}=u.getLineAndCharacterOfPosition(e.getEnd());return{name:a,parameters:t,returnType:r,isAsync:i,isExported:n,complexity:this.calculateComplexity(e),startLine:o+1,endLine:l+1,body:e.body?.getText(u)}}extractArrowFunctionInfo(e,u,a,t){let r=this.extractParameters(u.parameters,a),i=u.type?.getText(a),n=u.modifiers?.some(E=>E.kind===M.SyntaxKind.AsyncKeyword)??!1,o=M.isVariableStatement(t)&&(t.modifiers?.some(E=>E.kind===M.SyntaxKind.ExportKeyword)??!1),{line:l}=a.getLineAndCharacterOfPosition(u.getStart(a)),{line:c}=a.getLineAndCharacterOfPosition(u.getEnd());return{name:e,parameters:r,returnType:i,isAsync:n,isExported:o,complexity:this.calculateComplexity(u),startLine:l+1,endLine:c+1,body:u.body?.getText(a)}}extractClassInfo(e,u){let a=e.name?.getText(u)||"AnonymousClass",t=[],r=[],i=!1,n,o=e.modifiers?.some(l=>l.kind===M.SyntaxKind.ExportKeyword)??!1;for(let l of e.members)if(M.isMethodDeclaration(l)){let c=l.name.getText(u),E=this.extractParameters(l.parameters,u),d=l.type?.getText(u),D=l.modifiers?.some(y=>y.kind===M.SyntaxKind.AsyncKeyword)??!1,{line:h}=u.getLineAndCharacterOfPosition(l.getStart(u)),{line:C}=u.getLineAndCharacterOfPosition(l.getEnd());t.push({name:c,parameters:E,returnType:d,isAsync:D,isExported:!1,complexity:this.calculateComplexity(l),startLine:h+1,endLine:C+1,body:l.body?.getText(u)})}else if(M.isConstructorDeclaration(l))i=!0,n=this.extractParameters(l.parameters,u);else if(M.isPropertyDeclaration(l)){let c=l.name.getText(u),E=l.type?.getText(u),d=l.modifiers?.some(h=>h.kind===M.SyntaxKind.PrivateKeyword)??!1,D=l.modifiers?.some(h=>h.kind===M.SyntaxKind.ReadonlyKeyword)??!1;r.push({name:c,type:E,isPrivate:d,isReadonly:D})}return{name:a,methods:t,properties:r,isExported:o,hasConstructor:i,constructorParams:n}}extractParameters(e,u){let a=0,t=0;return e.map(r=>{let i=r.name.getText(u),n=r.type?.getText(u);return M.isObjectBindingPattern(r.name)?(a++,i=a>1?`options${a}`:"options",n||(n=`{ ${r.name.elements.map(l=>`${l.name.getText(u)}: unknown`).join(", ")} }`)):M.isArrayBindingPattern(r.name)&&(t++,i=t>1?`items${t}`:"items",n||(n="unknown[]")),{name:i,type:n,optional:r.questionToken!==void 0,defaultValue:r.initializer?.getText(u)}})}calculateComplexity(e){let u=1,a=t=>{switch(t.kind){case M.SyntaxKind.IfStatement:case M.SyntaxKind.ForStatement:case M.SyntaxKind.ForInStatement:case M.SyntaxKind.ForOfStatement:case M.SyntaxKind.WhileStatement:case M.SyntaxKind.DoStatement:case M.SyntaxKind.CaseClause:case M.SyntaxKind.CatchClause:case M.SyntaxKind.ConditionalExpression:u++;break;case M.SyntaxKind.BinaryExpression:{let r=t;(r.operatorToken.kind===M.SyntaxKind.AmpersandAmpersandToken||r.operatorToken.kind===M.SyntaxKind.BarBarToken)&&u++;break}}M.forEachChild(t,a)};return M.forEachChild(e,a),u}async hasKGVectors(){try{let e=new Array(384).fill(0);return e[0]=1,(await this.memory.vectorSearch(e,1)).length>0}catch{return!1}}async queryKGDependencies(e,u){try{let a=[],t=[],r=[],i=[],n=u.matchAll(/(?:import|from)\s+['"]([^'"]+)['"]/g);for(let d of n)a.push(d[1]);if(e.endsWith(".py")){let d=u.matchAll(/(?:^|\n)\s*(?:from\s+(\S+)\s+import|import\s+(\S+))/g);for(let D of d){let h=D[1]||D[2];h&&/^[a-zA-Z_][\w.]*$/.test(h)&&a.push(h)}}let c=e.replace(/\\/g,"/").split("/").pop()?.replace(/\.(ts|js|tsx|jsx|py)$/,"")||"",E=await this.memory.search(`code-intelligence:kg:node:*${c}*`,50);for(let d of E){if(!d.includes(c))continue;let D=d.split(":"),h=D[D.length-2],C=D[D.length-1];h==="function"&&r.push(C)}return a.length===0&&t.length===0&&r.length===0&&i.length===0?void 0:{imports:a,importedBy:t,callees:r,callers:i}}catch{return}}async queryKGSimilarCode(e){try{let u=this.generatePseudoEmbedding(e),a=await this.memory.vectorSearch(u,5);if(a.length===0)return;let t=[];for(let r of a){if(r.score<.1)continue;let i=r.metadata,n=i?.file||r.key,o=i?.name||i?.type||r.key.split(":").pop()||"";t.push({file:n,snippet:o,score:r.score})}return t.length>0?{snippets:t}:void 0}catch{return}}generatePseudoEmbedding(e){let a=new Array(384).fill(0),t=e.split(/[^a-zA-Z0-9_$]+/).filter(i=>i.length>1);for(let i=0;i<t.length;i++){let n=t[i];for(let o=0;o<n.length&&o<a.length;o++)a[(i+o)%384]+=n.charCodeAt(o)/1e3}let r=Math.sqrt(a.reduce((i,n)=>i+n*n,0));if(r>0)for(let i=0;i<384;i++)a[i]/=r;return a}getCodeFenceLanguage(e){try{let{FRAMEWORK_TO_LANGUAGE:u}=(d0(),l0(f4)),a=u?.[e];if(a){let t=nc(a);if(t)return t.codeFenceLanguage}}catch{}return"typescript"}convertParsedToCodeAnalysis(e){return De.convertParsedFile(e)}async findApplicablePatterns(e,u){let a=[];try{let{getUnifiedMemory:t}=await import("./unified-memory-72SKVZ7Y.js"),r=t().getDatabase();for(let o of u){let l=r.prepare(`SELECT id, name, description, pattern_type, usage_count, quality_score
2062
+ \`\`\``}],model:t,maxTokens:1024,temperature:.5});if(r.content)try{let i=r.content.match(/\[[\s\S]*\]/);if(i)return T(i[0]).map(o=>o.name)}catch{}return[]}catch{return jo.warn("LLM suggestion generation failed:"),[]}}async generateTests(e){try{let u=ac({sourceFiles:e.sourceFiles,language:e.language,framework:e.framework,projectRoot:e.projectRoot}),a=e.framework||u?.framework||"vitest",t=e.language||u?.language,{sourceFiles:r,testType:i,coverageTarget:n=this.config.coverageTargetDefault,patterns:o=[]}=e;if(r.length===0)return m(new Error("No source files provided"));let l=[],c=[];for(let d of r){let D=await this.generateTestsForFile(d,i,a,o,t,e);D.success&&(l.push(...D.value.tests),c.push(...D.value.patternsUsed))}if(process.env.AQE_HOLDOUT_TESTING_ENABLED==="true")for(let d of l)D6u(d.id)&&(d.holdout=!0);let E=this.estimateCoverage(l,n);return await this.storeGenerationMetadata(l,c),p({tests:l,coverageEstimate:E,patternsUsed:Array.from(new Set(c))})}catch(u){return m(g(u))}}async generateForCoverageGap(e,u,a){try{if(u.length===0)return p([]);let t=[],r=this.groupConsecutiveLines(u),i=this.generatorFactory.supports(a)?a:this.config.defaultFramework;for(let n of r){let o=await this.generateTestForLines(e,n,i);o&&t.push(o)}return p(t)}catch(t){return m(g(t))}}async generateTDDTests(e){try{let u=await this.tddGenerator.generateTDDTests(e);return p(u)}catch(u){return m(g(u))}}async generatePropertyTests(e){try{let u=await this.propertyTestGenerator.generatePropertyTests(e);return p(u)}catch(u){return m(g(u))}}async generateTestData(e){try{let u=await this.testDataGenerator.generateTestData(e);return p(u)}catch(u){return m(g(u))}}async generateTestsForFile(e,u,a,t,r,i){let n=this.getTestFilePath(e,a),o=[],l=await this.findApplicablePatterns(e,t);o.push(...l.map(w=>w.name));let c=null,E="";try{E=oc.readFileSync(e,"utf-8"),c=await this.analyzeSourceCode(E,e)}catch{}let d,D;this.memory&&E&&await this.hasKGVectors()&&(d=await this.queryKGDependencies(e,E),D=await this.queryKGSimilarCode(E));let h=this.generatorFactory.create(a),C=this.extractModuleName(e),y=this.getImportPath(e),x={moduleName:C,importPath:y,testType:u,patterns:l,analysis:c??void 0,dependencies:d,similarCode:D},b=h.generateTests(x);this.isLLMEnhancementAvailable()&&E&&(b=await this.enhanceTestWithLLM(b,E,c,x));let R={id:A(),name:`${C} tests`,sourceFile:e,testFile:n,testCode:b,type:u,assertions:this.countAssertions(b),language:r,framework:a,llmEnhanced:this.isLLMEnhancementAvailable()};if(i?.compileValidation&&r)try{let w=await rc.validate(b,r,i.projectRoot);R.compilationValidated=w.compiles,w.compiles||(R.compilationErrors=w.errors.map(P=>P.message))}catch{}return this.qualityGate&&(R.qualityGateResult=this.qualityGate.validate(b,e,E||void 0)),p({tests:[R],patternsUsed:o})}async generateTestForLines(e,u,a){if(u.length===0)return null;let t=A(),r=this.getTestFilePath(e,a),i=this.extractModuleName(e),n=this.getImportPath(e),l=this.generatorFactory.create(a).generateCoverageTests(i,n,u);return{id:t,name:`Coverage test for lines ${u[0]}-${u[u.length-1]}`,sourceFile:e,testFile:r,testCode:l,type:"unit",assertions:this.countAssertions(l)}}async analyzeSourceCode(e,u){let a=ga.extname(u),t=de(a);if(t&&t!=="typescript"&&t!=="javascript"){let l=await Z0.parseFile(e,u,t);if(l)return De.convertParsedFile(l)}let r=M.createSourceFile(ga.basename(u),e,M.ScriptTarget.Latest,!0,M.ScriptKind.TS),i=[],n=[],o=l=>{if(M.isFunctionDeclaration(l)&&l.name)i.push(this.extractFunctionInfo(l,r));else if(M.isVariableStatement(l)){for(let c of l.declarationList.declarations)if(M.isVariableDeclaration(c)&&c.initializer&&(M.isArrowFunction(c.initializer)||M.isFunctionExpression(c.initializer))){let E=c.name.getText(r);i.push(this.extractArrowFunctionInfo(E,c.initializer,r,l))}}else M.isClassDeclaration(l)&&l.name&&n.push(this.extractClassInfo(l,r));M.forEachChild(l,o)};return M.forEachChild(r,o),{functions:i,classes:n}}extractFunctionInfo(e,u){let a=e.name?.getText(u)||"anonymous",t=this.extractParameters(e.parameters,u),r=e.type?.getText(u),i=e.modifiers?.some(c=>c.kind===M.SyntaxKind.AsyncKeyword)??!1,n=e.modifiers?.some(c=>c.kind===M.SyntaxKind.ExportKeyword)??!1,{line:o}=u.getLineAndCharacterOfPosition(e.getStart(u)),{line:l}=u.getLineAndCharacterOfPosition(e.getEnd());return{name:a,parameters:t,returnType:r,isAsync:i,isExported:n,complexity:this.calculateComplexity(e),startLine:o+1,endLine:l+1,body:e.body?.getText(u)}}extractArrowFunctionInfo(e,u,a,t){let r=this.extractParameters(u.parameters,a),i=u.type?.getText(a),n=u.modifiers?.some(E=>E.kind===M.SyntaxKind.AsyncKeyword)??!1,o=M.isVariableStatement(t)&&(t.modifiers?.some(E=>E.kind===M.SyntaxKind.ExportKeyword)??!1),{line:l}=a.getLineAndCharacterOfPosition(u.getStart(a)),{line:c}=a.getLineAndCharacterOfPosition(u.getEnd());return{name:e,parameters:r,returnType:i,isAsync:n,isExported:o,complexity:this.calculateComplexity(u),startLine:l+1,endLine:c+1,body:u.body?.getText(a)}}extractClassInfo(e,u){let a=e.name?.getText(u)||"AnonymousClass",t=[],r=[],i=!1,n,o=e.modifiers?.some(l=>l.kind===M.SyntaxKind.ExportKeyword)??!1;for(let l of e.members)if(M.isMethodDeclaration(l)){let c=l.name.getText(u),E=this.extractParameters(l.parameters,u),d=l.type?.getText(u),D=l.modifiers?.some(y=>y.kind===M.SyntaxKind.AsyncKeyword)??!1,{line:h}=u.getLineAndCharacterOfPosition(l.getStart(u)),{line:C}=u.getLineAndCharacterOfPosition(l.getEnd());t.push({name:c,parameters:E,returnType:d,isAsync:D,isExported:!1,complexity:this.calculateComplexity(l),startLine:h+1,endLine:C+1,body:l.body?.getText(u)})}else if(M.isConstructorDeclaration(l))i=!0,n=this.extractParameters(l.parameters,u);else if(M.isPropertyDeclaration(l)){let c=l.name.getText(u),E=l.type?.getText(u),d=l.modifiers?.some(h=>h.kind===M.SyntaxKind.PrivateKeyword)??!1,D=l.modifiers?.some(h=>h.kind===M.SyntaxKind.ReadonlyKeyword)??!1;r.push({name:c,type:E,isPrivate:d,isReadonly:D})}return{name:a,methods:t,properties:r,isExported:o,hasConstructor:i,constructorParams:n}}extractParameters(e,u){let a=0,t=0;return e.map(r=>{let i=r.name.getText(u),n=r.type?.getText(u);return M.isObjectBindingPattern(r.name)?(a++,i=a>1?`options${a}`:"options",n||(n=`{ ${r.name.elements.map(l=>`${l.name.getText(u)}: unknown`).join(", ")} }`)):M.isArrayBindingPattern(r.name)&&(t++,i=t>1?`items${t}`:"items",n||(n="unknown[]")),{name:i,type:n,optional:r.questionToken!==void 0,defaultValue:r.initializer?.getText(u)}})}calculateComplexity(e){let u=1,a=t=>{switch(t.kind){case M.SyntaxKind.IfStatement:case M.SyntaxKind.ForStatement:case M.SyntaxKind.ForInStatement:case M.SyntaxKind.ForOfStatement:case M.SyntaxKind.WhileStatement:case M.SyntaxKind.DoStatement:case M.SyntaxKind.CaseClause:case M.SyntaxKind.CatchClause:case M.SyntaxKind.ConditionalExpression:u++;break;case M.SyntaxKind.BinaryExpression:{let r=t;(r.operatorToken.kind===M.SyntaxKind.AmpersandAmpersandToken||r.operatorToken.kind===M.SyntaxKind.BarBarToken)&&u++;break}}M.forEachChild(t,a)};return M.forEachChild(e,a),u}async hasKGVectors(){try{let e=new Array(384).fill(0);return e[0]=1,(await this.memory.vectorSearch(e,1)).length>0}catch{return!1}}async queryKGDependencies(e,u){try{let a=[],t=[],r=[],i=[],n=u.matchAll(/(?:import|from)\s+['"]([^'"]+)['"]/g);for(let d of n)a.push(d[1]);if(e.endsWith(".py")){let d=u.matchAll(/(?:^|\n)\s*(?:from\s+(\S+)\s+import|import\s+(\S+))/g);for(let D of d){let h=D[1]||D[2];h&&/^[a-zA-Z_][\w.]*$/.test(h)&&a.push(h)}}let c=e.replace(/\\/g,"/").split("/").pop()?.replace(/\.(ts|js|tsx|jsx|py)$/,"")||"",E=await this.memory.search(`code-intelligence:kg:node:*${c}*`,50);for(let d of E){if(!d.includes(c))continue;let D=d.split(":"),h=D[D.length-2],C=D[D.length-1];h==="function"&&r.push(C)}return a.length===0&&t.length===0&&r.length===0&&i.length===0?void 0:{imports:a,importedBy:t,callees:r,callers:i}}catch{return}}async queryKGSimilarCode(e){try{let u=this.generatePseudoEmbedding(e),a=await this.memory.vectorSearch(u,5);if(a.length===0)return;let t=[];for(let r of a){if(r.score<.1)continue;let i=r.metadata,n=i?.file||r.key,o=i?.name||i?.type||r.key.split(":").pop()||"";t.push({file:n,snippet:o,score:r.score})}return t.length>0?{snippets:t}:void 0}catch{return}}generatePseudoEmbedding(e){let a=new Array(384).fill(0),t=e.split(/[^a-zA-Z0-9_$]+/).filter(i=>i.length>1);for(let i=0;i<t.length;i++){let n=t[i];for(let o=0;o<n.length&&o<a.length;o++)a[(i+o)%384]+=n.charCodeAt(o)/1e3}let r=Math.sqrt(a.reduce((i,n)=>i+n*n,0));if(r>0)for(let i=0;i<384;i++)a[i]/=r;return a}getCodeFenceLanguage(e){try{let{FRAMEWORK_TO_LANGUAGE:u}=(d0(),l0(f4)),a=u?.[e];if(a){let t=nc(a);if(t)return t.codeFenceLanguage}}catch{}return"typescript"}convertParsedToCodeAnalysis(e){return De.convertParsedFile(e)}async findApplicablePatterns(e,u){let a=[];try{let{getUnifiedMemory:t}=await import("./unified-memory-RBHCTAWW.js"),r=t().getDatabase();for(let o of u){let l=r.prepare(`SELECT id, name, description, pattern_type, usage_count, quality_score
2063
2063
  FROM qe_patterns WHERE id = ? OR name = ? LIMIT 1`).get(o,o);l&&a.push({id:l.id,name:l.name,structure:l.pattern_type,examples:l.usage_count,applicability:l.quality_score})}let i=e.split(".").pop()||"",n=r.prepare(`SELECT id, name, description, pattern_type, usage_count, quality_score
2064
2064
  FROM qe_patterns
2065
2065
  WHERE qe_domain = 'test-generation'
@@ -2149,7 +2149,7 @@ Individual assessments:`),e.forEach(i=>{let n=this.countsAsAgreement(i)?"\u2713
2149
2149
  created_at TEXT DEFAULT (datetime('now')),
2150
2150
  updated_at TEXT DEFAULT (datetime('now'))
2151
2151
  );
2152
- `,hs={loadOnInit:!0,autoSaveInterval:0,maxPatternsToLoad:1e4,enableCrossProcessSharing:!0},Zt=class{baseEngine;config;persistence=null;db=null;prepared=new Map;initialized=!1;initPromise=null;pendingSaves=new Map;saveTimer=null;serverClient=null;constructor(e){this.config={...hs,...e},this.baseEngine=new n4(e),this.serverClient=e.serverClient??null}async initialize(){if(!this.initialized)return this.initPromise||(this.initPromise=this._doInitialize()),this.initPromise}async _doInitialize(){if(!this.initialized)try{this.persistence=Et(),this.persistence.isInitialized()||await this.persistence.initialize(),this.db=this.persistence.getDatabase(),this.ensureSchema(),this.prepareStatements(),this.config.loadOnInit&&await this.loadPatterns();let{isSONAThreeLoopEnabled:e}=await import("./feature-flags-R4QZYTIW.js");if(e()){this.baseEngine.initThreeLoopEngine(),this.baseEngine.setFisherPersistence((a,t,r,i,n)=>{this.saveFisherMatrix(a,t,r,i,n)},this.config.domain);let u=this._loadFisherMatrixUnsafe(this.config.domain);if(u){let a=this.baseEngine.getThreeLoopEngine();a&&(a.restoreFisher({fisherDiagonal:u.fisherDiagonal,optimalParams:u.optimalParams,baseWeights:u.baseWeights,requestCount:u.requestCount}),Ut.info("Three-loop engine restored Fisher state from SQLite",{domain:this.config.domain,requestCount:u.requestCount,taskBoundaries:u.taskBoundaries}))}Ut.info("Three-loop engine initialized with Fisher persistence",{domain:this.config.domain})}this.initialized=!0,console.log(`[PersistentSONAEngine] Initialized: domain=${this.config.domain}`)}catch(e){throw this.initPromise=null,new Error(`Failed to initialize PersistentSONAEngine: ${k(e)}`)}}ensureSchema(){if(!this.db)throw new Error("Database not initialized");this.db.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='sona_patterns'").get()||(console.log("[PersistentSONAEngine] Creating sona_patterns table"),this.db.exec(vc)),this.db.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='sona_fisher_matrices'").get()||(console.log("[PersistentSONAEngine] Creating sona_fisher_matrices table"),this.db.exec(Fc))}prepareStatements(){if(!this.db)throw new Error("Database not initialized");this.prepared.set("getById",this.db.prepare("SELECT * FROM sona_patterns WHERE id = ?")),this.prepared.set("getByDomain",this.db.prepare(`
2152
+ `,hs={loadOnInit:!0,autoSaveInterval:0,maxPatternsToLoad:1e4,enableCrossProcessSharing:!0},Zt=class{baseEngine;config;persistence=null;db=null;prepared=new Map;initialized=!1;initPromise=null;pendingSaves=new Map;saveTimer=null;serverClient=null;constructor(e){this.config={...hs,...e},this.baseEngine=new n4(e),this.serverClient=e.serverClient??null}async initialize(){if(!this.initialized)return this.initPromise||(this.initPromise=this._doInitialize()),this.initPromise}async _doInitialize(){if(!this.initialized)try{this.persistence=Et(),this.persistence.isInitialized()||await this.persistence.initialize(),this.db=this.persistence.getDatabase(),this.ensureSchema(),this.prepareStatements(),this.config.loadOnInit&&await this.loadPatterns();let{isSONAThreeLoopEnabled:e}=await import("./feature-flags-ZJ42B4IL.js");if(e()){this.baseEngine.initThreeLoopEngine(),this.baseEngine.setFisherPersistence((a,t,r,i,n)=>{this.saveFisherMatrix(a,t,r,i,n)},this.config.domain);let u=this._loadFisherMatrixUnsafe(this.config.domain);if(u){let a=this.baseEngine.getThreeLoopEngine();a&&(a.restoreFisher({fisherDiagonal:u.fisherDiagonal,optimalParams:u.optimalParams,baseWeights:u.baseWeights,requestCount:u.requestCount}),Ut.info("Three-loop engine restored Fisher state from SQLite",{domain:this.config.domain,requestCount:u.requestCount,taskBoundaries:u.taskBoundaries}))}Ut.info("Three-loop engine initialized with Fisher persistence",{domain:this.config.domain})}this.initialized=!0,console.log(`[PersistentSONAEngine] Initialized: domain=${this.config.domain}`)}catch(e){throw this.initPromise=null,new Error(`Failed to initialize PersistentSONAEngine: ${k(e)}`)}}ensureSchema(){if(!this.db)throw new Error("Database not initialized");this.db.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='sona_patterns'").get()||(console.log("[PersistentSONAEngine] Creating sona_patterns table"),this.db.exec(vc)),this.db.prepare("SELECT name FROM sqlite_master WHERE type='table' AND name='sona_fisher_matrices'").get()||(console.log("[PersistentSONAEngine] Creating sona_fisher_matrices table"),this.db.exec(Fc))}prepareStatements(){if(!this.db)throw new Error("Database not initialized");this.prepared.set("getById",this.db.prepare("SELECT * FROM sona_patterns WHERE id = ?")),this.prepared.set("getByDomain",this.db.prepare(`
2153
2153
  SELECT * FROM sona_patterns
2154
2154
  WHERE domain = ?
2155
2155
  ORDER BY confidence DESC, updated_at DESC
@@ -2765,7 +2765,7 @@ ${e.slice(0,4e3)}
2765
2765
  // File: ${c}
2766
2766
  ${d.value.slice(0,2e3)}
2767
2767
  `)}}let o=this.calculateModelConfidence(r),l=null;if(this.isLLMPredictionAvailable()&&n.length>0){let c=await this.getHistoricalDefectPatterns(u);if(l=await this.analyzeDefectRiskWithLLM(n,r,c),l){for(let E of r)E.recommendations=this.mergeRecommendationsWithLLM(E.recommendations,l);l.confidenceLevel>.7&&(o=Math.min(1,o*1.1))}}return await this.storePrediction(r),this.modelMetrics.totalPredictions+=r.length,this.modelMetrics.lastUpdated=new Date,p({predictions:r,modelConfidence:o,factors:Array.from(i),llmAnalysis:l??void 0})}catch(u){return m(g(u))}}async getHistoricalDefectPatterns(e){let u=[];for(let t of e.slice(0,5)){let r=await this.memory.get(`${this.config.modelNamespace}:defect-patterns:${t}`);r?.patterns&&u.push(...r.patterns)}let a=await this.memory.get(`${this.config.modelNamespace}:common-defect-patterns`);return a&&u.push(...a),[...new Set(u)].slice(0,10)}async analyzeRegressionRisk(e){try{let{changeset:u,baseline:a,depth:t="shallow"}=e;if(u.length===0)return m(new Error("No files in changeset"));let r=[],i=0;for(let E of u){let d=await this.analyzeFileImpact(E,t);r.push(...d.areas),i+=d.risk}if(a&&this.config.enableHistoricalAnalysis){let E=await this.getBaselineRisk(a);i=(i+E)/2}let n=Math.min(1,i/u.length),o=this.riskToSeverity(n),l=this.generateTestRecommendations(r);return p({overallRisk:n,riskLevel:o,impactedAreas:r,recommendedTests:l,confidence:t==="deep"?.85:.7})}catch(u){return m(g(u))}}async updateModel(e){try{let u=`${this.config.modelNamespace}:feedback:${e.predictionId}`;return await this.memory.set(u,e,{namespace:"defect-intelligence",persist:!0}),await this.recalculateMetrics(e),p(void 0)}catch(u){return m(g(u))}}async getModelMetrics(){let e=await this.memory.get(`${this.config.modelNamespace}:metrics`);return e&&(this.modelMetrics={...e,lastUpdated:new Date(e.lastUpdated)}),{...this.modelMetrics}}async predictForFile(e,u,a){let t=await this.extractFileMetrics(e),r=[],i=0;for(let l of u){let E=(t[l.name]??0)*l.weight;i+=E,r.push({name:l.name,contribution:Math.round(E*100)/100})}i=Math.max(0,Math.min(1,i));let n=this.probabilityToRisk(i,a),o=this.generateRecommendations(r,i);return{file:e,probability:i,riskLevel:n,factors:r.filter(l=>l.contribution>.05),recommendations:o}}async extractFileMetrics(e){let u=await this.memory.get(`${this.config.modelNamespace}:file-metrics:${e}`);if(u)return u;let a={codeComplexity:await this.calculateComplexity(e),changeFrequency:await this.getChangeFrequency(e),developerExperience:await this.getDeveloperExperience(e),testCoverage:await this.getTestCoverage(e),codeAge:await this.getCodeAge(e),bugHistory:await this.getBugHistory(e)};return await this.memory.set(`${this.config.modelNamespace}:file-metrics:${e}`,a,{namespace:"defect-intelligence",ttl:3600}),a}async calculateComplexity(e){let u=e.split(".").pop()?.toLowerCase();if(u&&["ts","tsx","js","jsx"].includes(u)){let a=await this.fileReader.readFile(e);if(a.success)try{let t=e.split("/").pop()||e,r=this.tsParser.parseFile(t,a.value),i=this.tsParser.extractFunctions(r),n=this.tsParser.extractClasses(r),o=a.value.split(`
2768
- `).length,l=i.length,c=n.length,E=n.reduce((eu,q)=>eu+q.methods.length,0),d=i.filter(eu=>eu.isAsync).length,D=a.value,h=(D.match(/\bif\s*\(/g)||[]).length,C=(D.match(/\b(for|while|do)\s*[\(\{]/g)||[]).length,y=(D.match(/\bswitch\s*\(/g)||[]).length,x=(D.match(/\bcatch\s*\(/g)||[]).length,b=(D.match(/\?[^?:]+:/g)||[]).length,R=h+C*2+y*2+x+b,w=Math.min(1,o/500),P=Math.min(1,(l+E)/30),V=Math.min(1,R/50),X=d>0?.1:0,Bu=w*.2+P*.25+V*.4+X+(c>3?.05:0);return Math.max(0,Math.min(1,Bu))}catch(t){al.debug(`AST parse failed: ${t instanceof Error?t.message:t}`)}}return this.estimateComplexityFromPath(e)}estimateComplexityFromPath(e){let u=e.split("/"),a=u[u.length-1],t=.3;return(e.includes("controller")||e.includes("service"))&&(t+=.2),(e.includes("coordinator")||e.includes("orchestrator"))&&(t+=.15),(e.includes("utils")||e.includes("helper"))&&(t-=.1),(e.includes("types")||e.includes("interfaces"))&&(t-=.15),a.length>30&&(t+=.1),Math.max(0,Math.min(1,t))}async getChangeFrequency(e){let u=await this.gitAnalyzer.getChangeFrequency(e);if(u!==.4)return await this.memory.set(`${this.config.modelNamespace}:history:${e}`,{changes:Math.round(u*30)},{ttl:3600}),u;let a=`${this.config.modelNamespace}:history:${e}`,t=await this.memory.get(a);return t?Math.min(1,t.changes/50):.4}async getDeveloperExperience(e){let u=await this.gitAnalyzer.getDeveloperExperience(e);if(u!==.5)return await this.memory.set(`${this.config.modelNamespace}:developer-exp:${e}`,{score:u},{ttl:3600}),u;let a=`${this.config.modelNamespace}:developer-exp:${e}`,t=await this.memory.get(a);return t?t.score:.5}async getTestCoverage(e){try{let u=await this.memory.get(`coverage:file:${e}`);if(u&&typeof u.line=="number")return 1-u.line/100;let a=await this.memory.get("coverage:latest");if(a&&typeof a.line=="number")return 1-a.line/100}catch{}return .4}async getCodeAge(e){let u=await this.gitAnalyzer.getCodeAge(e);if(u!==.4)return u;let a=`${this.config.modelNamespace}:age:${e}`,t=await this.memory.get(a);return t?t.days<7?.7:t.days>365?.3:.4:.4}async getBugHistory(e){let u=await this.gitAnalyzer.getBugHistory(e);if(u!==.2)return await this.memory.set(`${this.config.modelNamespace}:bugs:${e}`,{count:Math.round(u*10)},{ttl:3600}),u;let a=`${this.config.modelNamespace}:bugs:${e}`,t=await this.memory.get(a);return t?Math.min(1,t.count/10):.2}probabilityToRisk(e,u){return e>=u+.3?"critical":e>=u+.15?"high":e>=u?"medium":e>=u-.2?"low":"info"}riskToSeverity(e){return e>=.8?"critical":e>=.6?"high":e>=.4?"medium":e>=.2?"low":"info"}generateRecommendations(e,u){let a=[],t=[...e].sort((r,i)=>i.contribution-r.contribution);for(let r of t.slice(0,3))switch(r.name){case"codeComplexity":r.contribution>.1&&(a.push("Consider refactoring to reduce cyclomatic complexity"),a.push("Break down large functions into smaller, testable units"));break;case"changeFrequency":r.contribution>.1&&(a.push("High churn area - add comprehensive regression tests"),a.push("Consider stabilizing the interface before further changes"));break;case"testCoverage":r.contribution>.1&&(a.push("Increase test coverage to reduce defect risk"),a.push("Add unit tests for critical paths"));break;case"bugHistory":r.contribution>.1&&(a.push("Review past bug fixes for patterns"),a.push("Add regression tests for previously fixed issues"));break;case"codeAge":r.contribution>.1&&a.push("New code requires thorough review and testing");break;case"developerExperience":r.contribution>.1&&a.push("Request code review from senior developer");break}return u>.7&&a.push("CRITICAL: Schedule immediate code review"),a}async analyzeFileImpact(e,u){let a=[],t=0,r=this.categorizeFile(e),i=(await this.extractFileMetrics(e)).codeComplexity;if(a.push({area:r,files:[e],risk:i,reason:`Modified file in ${r} area`}),t+=i,u==="deep"){let n=await this.analyzeDependencies(e);for(let o of n){let l=(await this.extractFileMetrics(o)).codeComplexity*.5;a.push({area:this.categorizeFile(o),files:[o],risk:l,reason:`Dependency of ${e}`}),t+=l}}return{areas:a,risk:t}}categorizeFile(e){return e.includes("controller")?"API Layer":e.includes("service")?"Business Logic":e.includes("repository")||e.includes("dao")?"Data Access":e.includes("model")||e.includes("entity")?"Domain Model":e.includes("util")||e.includes("helper")?"Utilities":e.includes("test")?"Tests":e.includes("config")?"Configuration":"General"}async analyzeDependencies(e){let u=`code-intelligence:dependencies:${e}`,a=await this.memory.get(u);if(a&&a.length>0)return a;let t=[];try{let r=await this.fileReader.readFile(e);if(!r.success)return[];let i=e.split("/").pop()||e,n=this.tsParser.parseFile(i,r.value),o=this.tsParser.extractImports(n);for(let l of o)if(l.module.startsWith(".")){let c=this.resolveRelativeImport(e,l.module);t.push(c)}else l.module.startsWith("node:")||t.push(l.module);t.length>0&&await this.memory.set(u,t,{namespace:"code-intelligence",ttl:3600})}catch(r){al.error(`Failed to analyze dependencies for ${e}`,r instanceof Error?r:void 0)}return t}resolveRelativeImport(e,u){let t=e.substring(0,e.lastIndexOf("/")).split("/"),r=u.split("/");for(let n of r)n!=="."&&(n===".."?t.pop():t.push(n));let i=t.join("/");return!i.endsWith(".ts")&&!i.endsWith(".tsx")&&!i.endsWith(".js")&&(i=i+".ts"),i}async getBaselineRisk(e){let u=`${this.config.modelNamespace}:baseline:${e}`;return(await this.memory.get(u))?.risk??.3}generateTestRecommendations(e){let u=[],a=new Set(e.map(r=>r.area));for(let r of a)switch(r){case"API Layer":u.push("Run API integration tests"),u.push("Verify endpoint response contracts");break;case"Business Logic":u.push("Run unit tests for business rules"),u.push("Execute scenario-based tests");break;case"Data Access":u.push("Run database integration tests"),u.push("Verify data integrity constraints");break;case"Domain Model":u.push("Run entity validation tests"),u.push("Check serialization/deserialization");break}return e.filter(r=>r.risk>.6).length>0&&(u.push("Run full regression test suite"),u.push("Consider exploratory testing for edge cases")),[...new Set(u)]}calculateModelConfidence(e){let u=this.modelMetrics.accuracy,a=e.map(r=>r.probability);return this.calculateVariance(a)>.2&&(u*=.9),e.length>10&&(u*=1.05),Math.min(1,Math.max(0,u))}calculateVariance(e){if(e.length===0)return 0;let u=e.reduce((t,r)=>t+r,0)/e.length;return e.map(t=>Math.pow(t-u,2)).reduce((t,r)=>t+r,0)/e.length}async storePrediction(e){let u=A();await this.memory.set(`${this.config.modelNamespace}:prediction:${u}`,{id:u,predictions:e,timestamp:new Date().toISOString()},{namespace:"defect-intelligence",ttl:86400*7})}async recalculateMetrics(e){let u=e.predictedProbability>=this.config.defaultThreshold,a=u===e.actualDefect,t=.01;this.modelMetrics.accuracy=this.modelMetrics.accuracy*(1-t)+(a?1:0)*t,u&&e.actualDefect?(this.modelMetrics.precision=this.modelMetrics.precision*(1-t)+1*t,this.modelMetrics.recall=this.modelMetrics.recall*(1-t)+1*t):u&&!e.actualDefect?this.modelMetrics.precision=this.modelMetrics.precision*(1-t)+0*t:!u&&e.actualDefect&&(this.modelMetrics.recall=this.modelMetrics.recall*(1-t)+0*t),this.modelMetrics.f1Score=2*this.modelMetrics.precision*this.modelMetrics.recall/(this.modelMetrics.precision+this.modelMetrics.recall||1),this.modelMetrics.lastUpdated=new Date,await this.memory.set(`${this.config.modelNamespace}:metrics`,this.modelMetrics,{namespace:"defect-intelligence",persist:!0})}};N();S();var bpu={minPatternFrequency:2,maxPatterns:50,clusterThreshold:.7,embeddingDimension:Re.DIMENSIONS,patternNamespace:"defect-intelligence:patterns",enableSemanticClustering:!0,enableFlashAttention:!0},qr={"null-pointer":{indicators:["null","undefined","NullPointerException","TypeError: Cannot read"],prevention:"Use null-safe operators and defensive programming"},"race-condition":{indicators:["concurrent","async","race","timing","intermittent"],prevention:"Implement proper synchronization and use atomic operations"},"memory-leak":{indicators:["memory","leak","OutOfMemory","heap","gc"],prevention:"Ensure proper resource cleanup and avoid circular references"},"off-by-one":{indicators:["index","boundary","array","loop","range"],prevention:"Validate array bounds and use inclusive/exclusive ranges consistently"},"input-validation":{indicators:["validation","sanitize","input","injection","XSS"],prevention:"Implement strict input validation and sanitization"},"resource-exhaustion":{indicators:["timeout","resource","exhausted","limit","quota"],prevention:"Implement rate limiting and resource pooling"},"state-corruption":{indicators:["state","inconsistent","corrupt","invalid state"],prevention:"Use immutable state patterns and proper state machines"},"encoding-issue":{indicators:["encoding","charset","UTF","unicode","character"],prevention:"Use consistent encoding throughout the application"}},Bpu=B.create("defect-intelligence/pattern-learner"),B0=class{constructor(e,u={}){this.memory=e;this.config={...bpu,...u},this.embedder=u.embedder??new Pe({enableFallback:!0}),this.config.enableFlashAttention&&this.initializeFlashAttention()}config;patternCache=new Map;embedder;flashAttention=null;flashAttentionAvailable=!1;MAX_CACHED_PATTERNS=5e3;async initializeFlashAttention(){let{createQEFlashAttention:e}=await import("./wrappers-RRHCCA3E.js");this.flashAttention=await e("defect-matching",this.config.flashAttentionConfig),this.flashAttentionAvailable=!0,Bpu.info("Flash Attention initialized for defect matching")}async ensureFlashAttentionInitialized(){this.config.enableFlashAttention&&!this.flashAttention&&await this.initializeFlashAttention()}async learnPatterns(e){try{let{defects:u,includeResolutions:a=!1}=e;if(u.length===0)return m(new Error("No defects provided for learning"));let t=[],r=!1,i=await this.extractPatterns(u),n=this.mergeWithKnownPatterns(i);for(let l of n)l.frequency>=this.config.minPatternFrequency&&(t.push(l),await this.storePattern(l),r=!0);let o=this.calculateImprovementEstimate(u.length,t);return a&&await this.learnResolutions(u,t),p({patterns:t.slice(0,this.config.maxPatterns),modelUpdated:r,improvementEstimate:o})}catch(u){return m(g(u))}}async clusterDefects(e){try{let{defects:u,method:a,minClusterSize:t=2}=e;if(u.length===0)return m(new Error("No defects provided for clustering"));let r;switch(a){case"semantic":r=await this.clusterBySemantic(u,t);break;case"behavioral":r=await this.clusterByBehavior(u,t);break;case"temporal":r=await this.clusterByTemporal(u,t);break;default:return m(new Error(`Unknown clustering method: ${a}`))}let i=new Set(r.flatMap(l=>l.defects)),n=u.filter(l=>!i.has(l.id)).map(l=>l.id),o=this.calculateClusteringMetrics(r,u.length);return p({clusters:r,outliers:n,clusteringMetrics:o})}catch(u){return m(g(u))}}async findSimilarDefects(e,u=5){try{let a=await this.generateDefectEmbedding(e),t=await this.memory.vectorSearch(a,u+1),r=[];for(let i of t)if(i.score>=this.config.clusterThreshold){let n=await this.memory.get(i.key);n&&n.id!==e.id&&r.push(n)}return p(r.slice(0,u))}catch(a){return m(g(a))}}async getPatternById(e){if(this.patternCache.has(e))return this.patternCache.get(e);let u=`${this.config.patternNamespace}:${e}`,a=await this.memory.get(u);if(a)return this.cachePattern(a),a}async listPatterns(e=this.config.maxPatterns){let u=[],a=await this.memory.search(`${this.config.patternNamespace}:*`,e*2);for(let t of a){let r=await this.memory.get(t);if(r&&(u.push(r),u.length>=e))break}return u.sort((t,r)=>r.frequency-t.frequency)}getFlashAttentionStatus(){let e=0,u=null,a=null;return this.flashAttention&&(e=this.flashAttention.getMetrics().length,u=this.flashAttention.getAverageSpeedup(),a=this.flashAttention.getWorkload()),{enabled:this.config.enableFlashAttention??!1,available:this.flashAttentionAvailable,workload:a,metricsCount:e,averageSpeedup:u}}async extractPatterns(e){let u=new Map;for(let t of e){let r=`${t.title} ${t.description}`.toLowerCase();for(let[i,n]of Object.entries(qr)){let o=n.indicators.filter(l=>r.includes(l.toLowerCase()));if(o.length>0){let l=u.get(i);l?(l.defects.push(t.id),l.indicators.push(...o.filter(c=>!l.indicators.includes(c)))):u.set(i,{indicators:o,defects:[t.id]})}}if(t.tags)for(let i of t.tags){let n=`tag-${i}`,o=u.get(n);o?o.defects.push(t.id):u.set(n,{indicators:[i],defects:[t.id]})}}let a=[];for(let[t,r]of u){let i=qr[t];a.push({id:A(),name:this.formatPatternName(t),indicators:[...new Set(r.indicators)],frequency:r.defects.length,prevention:i?.prevention||`Address ${t} issues proactively`})}return a}mergeWithKnownPatterns(e){let u=[...e];for(let[a,t]of Object.entries(qr))u.some(i=>i.name.toLowerCase().includes(a.replace("-"," ")))||u.push({id:A(),name:this.formatPatternName(a),indicators:t.indicators,frequency:0,prevention:t.prevention});return u}formatPatternName(e){return e.split("-").map(u=>u.charAt(0).toUpperCase()+u.slice(1)).join(" ")}async storePattern(e){let u=`${this.config.patternNamespace}:${e.id}`;if(await this.memory.set(u,e,{namespace:"defect-intelligence",persist:!0}),this.config.enableSemanticClustering){let a=await this.generatePatternEmbedding(e);await this.memory.storeVector(u,a,{patternId:e.id,name:e.name})}this.cachePattern(e)}async learnResolutions(e,u){for(let a of u){let t=e.filter(r=>{let i=`${r.title} ${r.description}`.toLowerCase();return a.indicators.some(n=>i.includes(n.toLowerCase()))});t.length>0&&await this.memory.set(`${this.config.patternNamespace}:resolutions:${a.id}`,{patternId:a.id,defectIds:t.map(r=>r.id),learnedAt:new Date().toISOString()},{namespace:"defect-intelligence",persist:!0})}}calculateImprovementEstimate(e,u){if(e===0)return 0;let a=u.reduce((i,n)=>i+n.frequency,0),t=Math.min(1,a/e),r=u.length>0?u.reduce((i,n)=>i+(n.prevention?.1:0),0)/u.length:0;return t*.7+r*.3}async clusterBySemantic(e,u){let a=new Map;await this.ensureFlashAttentionInitialized();let t=[];for(let i of e){let n=await this.generateDefectEmbedding(i);t.push({defect:i,embedding:n}),await this.memory.storeVector(`${this.config.patternNamespace}:defect:${i.id}`,n,{defectId:i.id})}let r=new Set;for(let{defect:i,embedding:n}of t){if(r.has(i.id))continue;let o=[i.id];r.add(i.id);for(let l of t){if(l.defect.id===i.id||r.has(l.defect.id))continue;await this.computeSimilarity(n,l.embedding)>=this.config.clusterThreshold&&(o.push(l.defect.id),r.add(l.defect.id))}if(o.length>=u){let l=A(),c=this.findCommonFactors(e.filter(E=>o.includes(E.id)));a.set(l,{id:l,label:this.generateClusterLabel(e.filter(E=>o.includes(E.id))),defects:o,commonFactors:c,suggestedFix:this.suggestFix(c)})}}return Array.from(a.values())}async computeSimilarity(e,u){if(!this.flashAttention)throw new Error("[PatternLearnerService] Flash Attention not initialized. Call ensureFlashAttentionInitialized() first.");return this.computeFlashAttentionSimilarity(e,u)}async computeFlashAttentionSimilarity(e,u){let a=e.length,t=new Float32Array(a),r=new Float32Array(a),i=new Float32Array(a);for(let l=0;l<a;l++)t[l]=e[l],r[l]=u[l],i[l]=u[l];let n=await this.flashAttention.computeFlashAttention(t,r,i,1,a),o=0;for(let l=0;l<a;l++)o+=n[l]*e[l];return Math.max(0,Math.min(1,(o+1)/2))}async batchComputeSimilarities(e,u){if(await this.ensureFlashAttentionInitialized(),!this.flashAttention)throw new Error("[PatternLearnerService] Flash Attention not initialized. Ensure @ruvector/attention is installed as a dependency.");let a=new Float32Array(e),t=u.map(n=>new Float32Array(n)),r=await this.flashAttention.matchDefectPattern(a,t),i=new Array(u.length).fill(0);for(let n of r)n.pattern<i.length&&(i[n.pattern]=Math.max(0,Math.min(1,(n.score+1)/2)));return i}async clusterByBehavior(e,u){let a=new Map,t=new Map;for(let r of e){let i=r.tags?.sort().join("|")||r.file||"unknown",n=t.get(i)||[];n.push(r),t.set(i,n)}for(let[r,i]of t)if(i.length>=u){let n=A(),o=this.findCommonFactors(i);a.set(n,{id:n,label:`Behavioral: ${r.replace(/\|/g,", ")}`,defects:i.map(l=>l.id),commonFactors:o,suggestedFix:this.suggestFix(o)})}return Array.from(a.values())}async clusterByTemporal(e,u){let a=new Map,t=new Map;for(let r of e){let i=r.title.toLowerCase().split(/\s+/).slice(0,2).join(" "),n=t.get(i)||[];n.push(r),t.set(i,n)}for(let[r,i]of t)if(i.length>=2){let n=A(),o=this.findCommonFactors(i);a.set(n,{id:n,label:`Temporal: ${r}`,defects:i.map(l=>l.id),commonFactors:o,suggestedFix:this.suggestFix(o)})}return Array.from(a.values())}findCommonFactors(e){let u=[];if(e.every(r=>r.tags)){let r=e.map(n=>new Set(n.tags)),i=[...r[0]].filter(n=>r.every(o=>o.has(n)));u.push(...i)}if(e.every(r=>r.file)){let r=e.map(n=>n.file.split("/")),i=Math.min(...r.map(n=>n.length));for(let n=0;n<i;n++)r.every(o=>o[n]===r[0][n])&&u.push(`Path: ${r[0][n]}`)}let a=e.map(r=>new Set(r.title.toLowerCase().split(/\s+/))),t=[...a[0]].filter(r=>r.length>3&&a.every(i=>i.has(r)));return u.push(...t.map(r=>`Keyword: ${r}`)),[...new Set(u)]}generateClusterLabel(e){let a=e.map(i=>i.title.toLowerCase()).flatMap(i=>i.split(/\s+/)),t=new Map;for(let i of a)i.length>3&&t.set(i,(t.get(i)||0)+1);return[...t.entries()].sort((i,n)=>n[1]-i[1]).slice(0,2).map(([i])=>i).join(" ")||"Unnamed Cluster"}suggestFix(e){for(let u of e)for(let[a,t]of Object.entries(qr))if(u.toLowerCase().includes(a)||t.indicators.some(r=>u.toLowerCase().includes(r.toLowerCase())))return t.prevention;return"Review common factors and implement targeted fixes"}calculateClusteringMetrics(e,u){if(e.length===0||u===0)return{silhouette:0,cohesion:0};let a=e.reduce((l,c)=>l+c.defects.length,0),t=a/e.length,r=a/u,i=e.map(l=>l.defects.length),n=i.reduce((l,c)=>l+Math.pow(c-t,2),0)/i.length,o=Math.max(0,1-n/(t*t||1));return{silhouette:Math.round(o*100)/100,cohesion:Math.round(r*100)/100}}async generateDefectEmbedding(e){let u=this.formatDefectForEmbedding(e);return this.embedder.embed(u)}async generatePatternEmbedding(e){let u=this.formatPatternForEmbedding(e);return this.embedder.embed(u)}formatDefectForEmbedding(e){return[`Title: ${e.title}`,e.description?`Description: ${e.description}`:"",e.tags?.length?`Tags: ${e.tags.join(", ")}`:"",e.file?`File: ${e.file}`:""].filter(Boolean).join(`
2768
+ `).length,l=i.length,c=n.length,E=n.reduce((eu,q)=>eu+q.methods.length,0),d=i.filter(eu=>eu.isAsync).length,D=a.value,h=(D.match(/\bif\s*\(/g)||[]).length,C=(D.match(/\b(for|while|do)\s*[\(\{]/g)||[]).length,y=(D.match(/\bswitch\s*\(/g)||[]).length,x=(D.match(/\bcatch\s*\(/g)||[]).length,b=(D.match(/\?[^?:]+:/g)||[]).length,R=h+C*2+y*2+x+b,w=Math.min(1,o/500),P=Math.min(1,(l+E)/30),V=Math.min(1,R/50),X=d>0?.1:0,Bu=w*.2+P*.25+V*.4+X+(c>3?.05:0);return Math.max(0,Math.min(1,Bu))}catch(t){al.debug(`AST parse failed: ${t instanceof Error?t.message:t}`)}}return this.estimateComplexityFromPath(e)}estimateComplexityFromPath(e){let u=e.split("/"),a=u[u.length-1],t=.3;return(e.includes("controller")||e.includes("service"))&&(t+=.2),(e.includes("coordinator")||e.includes("orchestrator"))&&(t+=.15),(e.includes("utils")||e.includes("helper"))&&(t-=.1),(e.includes("types")||e.includes("interfaces"))&&(t-=.15),a.length>30&&(t+=.1),Math.max(0,Math.min(1,t))}async getChangeFrequency(e){let u=await this.gitAnalyzer.getChangeFrequency(e);if(u!==.4)return await this.memory.set(`${this.config.modelNamespace}:history:${e}`,{changes:Math.round(u*30)},{ttl:3600}),u;let a=`${this.config.modelNamespace}:history:${e}`,t=await this.memory.get(a);return t?Math.min(1,t.changes/50):.4}async getDeveloperExperience(e){let u=await this.gitAnalyzer.getDeveloperExperience(e);if(u!==.5)return await this.memory.set(`${this.config.modelNamespace}:developer-exp:${e}`,{score:u},{ttl:3600}),u;let a=`${this.config.modelNamespace}:developer-exp:${e}`,t=await this.memory.get(a);return t?t.score:.5}async getTestCoverage(e){try{let u=await this.memory.get(`coverage:file:${e}`);if(u&&typeof u.line=="number")return 1-u.line/100;let a=await this.memory.get("coverage:latest");if(a&&typeof a.line=="number")return 1-a.line/100}catch{}return .4}async getCodeAge(e){let u=await this.gitAnalyzer.getCodeAge(e);if(u!==.4)return u;let a=`${this.config.modelNamespace}:age:${e}`,t=await this.memory.get(a);return t?t.days<7?.7:t.days>365?.3:.4:.4}async getBugHistory(e){let u=await this.gitAnalyzer.getBugHistory(e);if(u!==.2)return await this.memory.set(`${this.config.modelNamespace}:bugs:${e}`,{count:Math.round(u*10)},{ttl:3600}),u;let a=`${this.config.modelNamespace}:bugs:${e}`,t=await this.memory.get(a);return t?Math.min(1,t.count/10):.2}probabilityToRisk(e,u){return e>=u+.3?"critical":e>=u+.15?"high":e>=u?"medium":e>=u-.2?"low":"info"}riskToSeverity(e){return e>=.8?"critical":e>=.6?"high":e>=.4?"medium":e>=.2?"low":"info"}generateRecommendations(e,u){let a=[],t=[...e].sort((r,i)=>i.contribution-r.contribution);for(let r of t.slice(0,3))switch(r.name){case"codeComplexity":r.contribution>.1&&(a.push("Consider refactoring to reduce cyclomatic complexity"),a.push("Break down large functions into smaller, testable units"));break;case"changeFrequency":r.contribution>.1&&(a.push("High churn area - add comprehensive regression tests"),a.push("Consider stabilizing the interface before further changes"));break;case"testCoverage":r.contribution>.1&&(a.push("Increase test coverage to reduce defect risk"),a.push("Add unit tests for critical paths"));break;case"bugHistory":r.contribution>.1&&(a.push("Review past bug fixes for patterns"),a.push("Add regression tests for previously fixed issues"));break;case"codeAge":r.contribution>.1&&a.push("New code requires thorough review and testing");break;case"developerExperience":r.contribution>.1&&a.push("Request code review from senior developer");break}return u>.7&&a.push("CRITICAL: Schedule immediate code review"),a}async analyzeFileImpact(e,u){let a=[],t=0,r=this.categorizeFile(e),i=(await this.extractFileMetrics(e)).codeComplexity;if(a.push({area:r,files:[e],risk:i,reason:`Modified file in ${r} area`}),t+=i,u==="deep"){let n=await this.analyzeDependencies(e);for(let o of n){let l=(await this.extractFileMetrics(o)).codeComplexity*.5;a.push({area:this.categorizeFile(o),files:[o],risk:l,reason:`Dependency of ${e}`}),t+=l}}return{areas:a,risk:t}}categorizeFile(e){return e.includes("controller")?"API Layer":e.includes("service")?"Business Logic":e.includes("repository")||e.includes("dao")?"Data Access":e.includes("model")||e.includes("entity")?"Domain Model":e.includes("util")||e.includes("helper")?"Utilities":e.includes("test")?"Tests":e.includes("config")?"Configuration":"General"}async analyzeDependencies(e){let u=`code-intelligence:dependencies:${e}`,a=await this.memory.get(u);if(a&&a.length>0)return a;let t=[];try{let r=await this.fileReader.readFile(e);if(!r.success)return[];let i=e.split("/").pop()||e,n=this.tsParser.parseFile(i,r.value),o=this.tsParser.extractImports(n);for(let l of o)if(l.module.startsWith(".")){let c=this.resolveRelativeImport(e,l.module);t.push(c)}else l.module.startsWith("node:")||t.push(l.module);t.length>0&&await this.memory.set(u,t,{namespace:"code-intelligence",ttl:3600})}catch(r){al.error(`Failed to analyze dependencies for ${e}`,r instanceof Error?r:void 0)}return t}resolveRelativeImport(e,u){let t=e.substring(0,e.lastIndexOf("/")).split("/"),r=u.split("/");for(let n of r)n!=="."&&(n===".."?t.pop():t.push(n));let i=t.join("/");return!i.endsWith(".ts")&&!i.endsWith(".tsx")&&!i.endsWith(".js")&&(i=i+".ts"),i}async getBaselineRisk(e){let u=`${this.config.modelNamespace}:baseline:${e}`;return(await this.memory.get(u))?.risk??.3}generateTestRecommendations(e){let u=[],a=new Set(e.map(r=>r.area));for(let r of a)switch(r){case"API Layer":u.push("Run API integration tests"),u.push("Verify endpoint response contracts");break;case"Business Logic":u.push("Run unit tests for business rules"),u.push("Execute scenario-based tests");break;case"Data Access":u.push("Run database integration tests"),u.push("Verify data integrity constraints");break;case"Domain Model":u.push("Run entity validation tests"),u.push("Check serialization/deserialization");break}return e.filter(r=>r.risk>.6).length>0&&(u.push("Run full regression test suite"),u.push("Consider exploratory testing for edge cases")),[...new Set(u)]}calculateModelConfidence(e){let u=this.modelMetrics.accuracy,a=e.map(r=>r.probability);return this.calculateVariance(a)>.2&&(u*=.9),e.length>10&&(u*=1.05),Math.min(1,Math.max(0,u))}calculateVariance(e){if(e.length===0)return 0;let u=e.reduce((t,r)=>t+r,0)/e.length;return e.map(t=>Math.pow(t-u,2)).reduce((t,r)=>t+r,0)/e.length}async storePrediction(e){let u=A();await this.memory.set(`${this.config.modelNamespace}:prediction:${u}`,{id:u,predictions:e,timestamp:new Date().toISOString()},{namespace:"defect-intelligence",ttl:86400*7})}async recalculateMetrics(e){let u=e.predictedProbability>=this.config.defaultThreshold,a=u===e.actualDefect,t=.01;this.modelMetrics.accuracy=this.modelMetrics.accuracy*(1-t)+(a?1:0)*t,u&&e.actualDefect?(this.modelMetrics.precision=this.modelMetrics.precision*(1-t)+1*t,this.modelMetrics.recall=this.modelMetrics.recall*(1-t)+1*t):u&&!e.actualDefect?this.modelMetrics.precision=this.modelMetrics.precision*(1-t)+0*t:!u&&e.actualDefect&&(this.modelMetrics.recall=this.modelMetrics.recall*(1-t)+0*t),this.modelMetrics.f1Score=2*this.modelMetrics.precision*this.modelMetrics.recall/(this.modelMetrics.precision+this.modelMetrics.recall||1),this.modelMetrics.lastUpdated=new Date,await this.memory.set(`${this.config.modelNamespace}:metrics`,this.modelMetrics,{namespace:"defect-intelligence",persist:!0})}};N();S();var bpu={minPatternFrequency:2,maxPatterns:50,clusterThreshold:.7,embeddingDimension:Re.DIMENSIONS,patternNamespace:"defect-intelligence:patterns",enableSemanticClustering:!0,enableFlashAttention:!0},qr={"null-pointer":{indicators:["null","undefined","NullPointerException","TypeError: Cannot read"],prevention:"Use null-safe operators and defensive programming"},"race-condition":{indicators:["concurrent","async","race","timing","intermittent"],prevention:"Implement proper synchronization and use atomic operations"},"memory-leak":{indicators:["memory","leak","OutOfMemory","heap","gc"],prevention:"Ensure proper resource cleanup and avoid circular references"},"off-by-one":{indicators:["index","boundary","array","loop","range"],prevention:"Validate array bounds and use inclusive/exclusive ranges consistently"},"input-validation":{indicators:["validation","sanitize","input","injection","XSS"],prevention:"Implement strict input validation and sanitization"},"resource-exhaustion":{indicators:["timeout","resource","exhausted","limit","quota"],prevention:"Implement rate limiting and resource pooling"},"state-corruption":{indicators:["state","inconsistent","corrupt","invalid state"],prevention:"Use immutable state patterns and proper state machines"},"encoding-issue":{indicators:["encoding","charset","UTF","unicode","character"],prevention:"Use consistent encoding throughout the application"}},Bpu=B.create("defect-intelligence/pattern-learner"),B0=class{constructor(e,u={}){this.memory=e;this.config={...bpu,...u},this.embedder=u.embedder??new Pe({enableFallback:!0}),this.config.enableFlashAttention&&this.initializeFlashAttention()}config;patternCache=new Map;embedder;flashAttention=null;flashAttentionAvailable=!1;MAX_CACHED_PATTERNS=5e3;async initializeFlashAttention(){let{createQEFlashAttention:e}=await import("./wrappers-LNTV533I.js");this.flashAttention=await e("defect-matching",this.config.flashAttentionConfig),this.flashAttentionAvailable=!0,Bpu.info("Flash Attention initialized for defect matching")}async ensureFlashAttentionInitialized(){this.config.enableFlashAttention&&!this.flashAttention&&await this.initializeFlashAttention()}async learnPatterns(e){try{let{defects:u,includeResolutions:a=!1}=e;if(u.length===0)return m(new Error("No defects provided for learning"));let t=[],r=!1,i=await this.extractPatterns(u),n=this.mergeWithKnownPatterns(i);for(let l of n)l.frequency>=this.config.minPatternFrequency&&(t.push(l),await this.storePattern(l),r=!0);let o=this.calculateImprovementEstimate(u.length,t);return a&&await this.learnResolutions(u,t),p({patterns:t.slice(0,this.config.maxPatterns),modelUpdated:r,improvementEstimate:o})}catch(u){return m(g(u))}}async clusterDefects(e){try{let{defects:u,method:a,minClusterSize:t=2}=e;if(u.length===0)return m(new Error("No defects provided for clustering"));let r;switch(a){case"semantic":r=await this.clusterBySemantic(u,t);break;case"behavioral":r=await this.clusterByBehavior(u,t);break;case"temporal":r=await this.clusterByTemporal(u,t);break;default:return m(new Error(`Unknown clustering method: ${a}`))}let i=new Set(r.flatMap(l=>l.defects)),n=u.filter(l=>!i.has(l.id)).map(l=>l.id),o=this.calculateClusteringMetrics(r,u.length);return p({clusters:r,outliers:n,clusteringMetrics:o})}catch(u){return m(g(u))}}async findSimilarDefects(e,u=5){try{let a=await this.generateDefectEmbedding(e),t=await this.memory.vectorSearch(a,u+1),r=[];for(let i of t)if(i.score>=this.config.clusterThreshold){let n=await this.memory.get(i.key);n&&n.id!==e.id&&r.push(n)}return p(r.slice(0,u))}catch(a){return m(g(a))}}async getPatternById(e){if(this.patternCache.has(e))return this.patternCache.get(e);let u=`${this.config.patternNamespace}:${e}`,a=await this.memory.get(u);if(a)return this.cachePattern(a),a}async listPatterns(e=this.config.maxPatterns){let u=[],a=await this.memory.search(`${this.config.patternNamespace}:*`,e*2);for(let t of a){let r=await this.memory.get(t);if(r&&(u.push(r),u.length>=e))break}return u.sort((t,r)=>r.frequency-t.frequency)}getFlashAttentionStatus(){let e=0,u=null,a=null;return this.flashAttention&&(e=this.flashAttention.getMetrics().length,u=this.flashAttention.getAverageSpeedup(),a=this.flashAttention.getWorkload()),{enabled:this.config.enableFlashAttention??!1,available:this.flashAttentionAvailable,workload:a,metricsCount:e,averageSpeedup:u}}async extractPatterns(e){let u=new Map;for(let t of e){let r=`${t.title} ${t.description}`.toLowerCase();for(let[i,n]of Object.entries(qr)){let o=n.indicators.filter(l=>r.includes(l.toLowerCase()));if(o.length>0){let l=u.get(i);l?(l.defects.push(t.id),l.indicators.push(...o.filter(c=>!l.indicators.includes(c)))):u.set(i,{indicators:o,defects:[t.id]})}}if(t.tags)for(let i of t.tags){let n=`tag-${i}`,o=u.get(n);o?o.defects.push(t.id):u.set(n,{indicators:[i],defects:[t.id]})}}let a=[];for(let[t,r]of u){let i=qr[t];a.push({id:A(),name:this.formatPatternName(t),indicators:[...new Set(r.indicators)],frequency:r.defects.length,prevention:i?.prevention||`Address ${t} issues proactively`})}return a}mergeWithKnownPatterns(e){let u=[...e];for(let[a,t]of Object.entries(qr))u.some(i=>i.name.toLowerCase().includes(a.replace("-"," ")))||u.push({id:A(),name:this.formatPatternName(a),indicators:t.indicators,frequency:0,prevention:t.prevention});return u}formatPatternName(e){return e.split("-").map(u=>u.charAt(0).toUpperCase()+u.slice(1)).join(" ")}async storePattern(e){let u=`${this.config.patternNamespace}:${e.id}`;if(await this.memory.set(u,e,{namespace:"defect-intelligence",persist:!0}),this.config.enableSemanticClustering){let a=await this.generatePatternEmbedding(e);await this.memory.storeVector(u,a,{patternId:e.id,name:e.name})}this.cachePattern(e)}async learnResolutions(e,u){for(let a of u){let t=e.filter(r=>{let i=`${r.title} ${r.description}`.toLowerCase();return a.indicators.some(n=>i.includes(n.toLowerCase()))});t.length>0&&await this.memory.set(`${this.config.patternNamespace}:resolutions:${a.id}`,{patternId:a.id,defectIds:t.map(r=>r.id),learnedAt:new Date().toISOString()},{namespace:"defect-intelligence",persist:!0})}}calculateImprovementEstimate(e,u){if(e===0)return 0;let a=u.reduce((i,n)=>i+n.frequency,0),t=Math.min(1,a/e),r=u.length>0?u.reduce((i,n)=>i+(n.prevention?.1:0),0)/u.length:0;return t*.7+r*.3}async clusterBySemantic(e,u){let a=new Map;await this.ensureFlashAttentionInitialized();let t=[];for(let i of e){let n=await this.generateDefectEmbedding(i);t.push({defect:i,embedding:n}),await this.memory.storeVector(`${this.config.patternNamespace}:defect:${i.id}`,n,{defectId:i.id})}let r=new Set;for(let{defect:i,embedding:n}of t){if(r.has(i.id))continue;let o=[i.id];r.add(i.id);for(let l of t){if(l.defect.id===i.id||r.has(l.defect.id))continue;await this.computeSimilarity(n,l.embedding)>=this.config.clusterThreshold&&(o.push(l.defect.id),r.add(l.defect.id))}if(o.length>=u){let l=A(),c=this.findCommonFactors(e.filter(E=>o.includes(E.id)));a.set(l,{id:l,label:this.generateClusterLabel(e.filter(E=>o.includes(E.id))),defects:o,commonFactors:c,suggestedFix:this.suggestFix(c)})}}return Array.from(a.values())}async computeSimilarity(e,u){if(!this.flashAttention)throw new Error("[PatternLearnerService] Flash Attention not initialized. Call ensureFlashAttentionInitialized() first.");return this.computeFlashAttentionSimilarity(e,u)}async computeFlashAttentionSimilarity(e,u){let a=e.length,t=new Float32Array(a),r=new Float32Array(a),i=new Float32Array(a);for(let l=0;l<a;l++)t[l]=e[l],r[l]=u[l],i[l]=u[l];let n=await this.flashAttention.computeFlashAttention(t,r,i,1,a),o=0;for(let l=0;l<a;l++)o+=n[l]*e[l];return Math.max(0,Math.min(1,(o+1)/2))}async batchComputeSimilarities(e,u){if(await this.ensureFlashAttentionInitialized(),!this.flashAttention)throw new Error("[PatternLearnerService] Flash Attention not initialized. Ensure @ruvector/attention is installed as a dependency.");let a=new Float32Array(e),t=u.map(n=>new Float32Array(n)),r=await this.flashAttention.matchDefectPattern(a,t),i=new Array(u.length).fill(0);for(let n of r)n.pattern<i.length&&(i[n.pattern]=Math.max(0,Math.min(1,(n.score+1)/2)));return i}async clusterByBehavior(e,u){let a=new Map,t=new Map;for(let r of e){let i=r.tags?.sort().join("|")||r.file||"unknown",n=t.get(i)||[];n.push(r),t.set(i,n)}for(let[r,i]of t)if(i.length>=u){let n=A(),o=this.findCommonFactors(i);a.set(n,{id:n,label:`Behavioral: ${r.replace(/\|/g,", ")}`,defects:i.map(l=>l.id),commonFactors:o,suggestedFix:this.suggestFix(o)})}return Array.from(a.values())}async clusterByTemporal(e,u){let a=new Map,t=new Map;for(let r of e){let i=r.title.toLowerCase().split(/\s+/).slice(0,2).join(" "),n=t.get(i)||[];n.push(r),t.set(i,n)}for(let[r,i]of t)if(i.length>=2){let n=A(),o=this.findCommonFactors(i);a.set(n,{id:n,label:`Temporal: ${r}`,defects:i.map(l=>l.id),commonFactors:o,suggestedFix:this.suggestFix(o)})}return Array.from(a.values())}findCommonFactors(e){let u=[];if(e.every(r=>r.tags)){let r=e.map(n=>new Set(n.tags)),i=[...r[0]].filter(n=>r.every(o=>o.has(n)));u.push(...i)}if(e.every(r=>r.file)){let r=e.map(n=>n.file.split("/")),i=Math.min(...r.map(n=>n.length));for(let n=0;n<i;n++)r.every(o=>o[n]===r[0][n])&&u.push(`Path: ${r[0][n]}`)}let a=e.map(r=>new Set(r.title.toLowerCase().split(/\s+/))),t=[...a[0]].filter(r=>r.length>3&&a.every(i=>i.has(r)));return u.push(...t.map(r=>`Keyword: ${r}`)),[...new Set(u)]}generateClusterLabel(e){let a=e.map(i=>i.title.toLowerCase()).flatMap(i=>i.split(/\s+/)),t=new Map;for(let i of a)i.length>3&&t.set(i,(t.get(i)||0)+1);return[...t.entries()].sort((i,n)=>n[1]-i[1]).slice(0,2).map(([i])=>i).join(" ")||"Unnamed Cluster"}suggestFix(e){for(let u of e)for(let[a,t]of Object.entries(qr))if(u.toLowerCase().includes(a)||t.indicators.some(r=>u.toLowerCase().includes(r.toLowerCase())))return t.prevention;return"Review common factors and implement targeted fixes"}calculateClusteringMetrics(e,u){if(e.length===0||u===0)return{silhouette:0,cohesion:0};let a=e.reduce((l,c)=>l+c.defects.length,0),t=a/e.length,r=a/u,i=e.map(l=>l.defects.length),n=i.reduce((l,c)=>l+Math.pow(c-t,2),0)/i.length,o=Math.max(0,1-n/(t*t||1));return{silhouette:Math.round(o*100)/100,cohesion:Math.round(r*100)/100}}async generateDefectEmbedding(e){let u=this.formatDefectForEmbedding(e);return this.embedder.embed(u)}async generatePatternEmbedding(e){let u=this.formatPatternForEmbedding(e);return this.embedder.embed(u)}formatDefectForEmbedding(e){return[`Title: ${e.title}`,e.description?`Description: ${e.description}`:"",e.tags?.length?`Tags: ${e.tags.join(", ")}`:"",e.file?`File: ${e.file}`:""].filter(Boolean).join(`
2769
2769
  `)}formatPatternForEmbedding(e){return[`Pattern: ${e.name}`,`Indicators: ${e.indicators.join(", ")}`,`Prevention: ${e.prevention}`,`Frequency: ${e.frequency}`].filter(Boolean).join(`
2770
2770
  `)}cachePattern(e){if(this.patternCache.size>=this.MAX_CACHED_PATTERNS){let u=this.patternCache.keys().next().value;u&&this.patternCache.delete(u)}this.patternCache.set(e.id,e)}destroy(){this.patternCache.clear(),this.flashAttention=null,this.flashAttentionAvailable=!1}};N();S();J();var kpu={maxTimelineEvents:20,maxRelatedFiles:10,minConfidenceThreshold:.3,analyzerNamespace:"defect-intelligence:root-cause",enableDeepAnalysis:!0,enableLLMAnalysis:!0,llmModelTier:2,llmMaxTokens:2048},Jr={"logic-error":{symptoms:["wrong result","incorrect output","unexpected behavior","calculation"],causes:["Incorrect algorithm implementation","Missing edge case handling","Wrong operator usage","Off-by-one error"],impact:"high",remediation:["Review algorithm logic step by step","Add comprehensive unit tests","Use property-based testing for edge cases"]},"null-reference":{symptoms:["null","undefined","cannot read property","NullPointerException"],causes:["Missing null check","Uninitialized variable","Race condition in initialization","API returning null unexpectedly"],impact:"high",remediation:["Add defensive null checks","Use Optional/Maybe pattern","Initialize variables at declaration"]},concurrency:{symptoms:["race","deadlock","intermittent","timing","thread"],causes:["Missing synchronization","Shared mutable state","Lock ordering issue","Async operation not awaited"],impact:"high",remediation:["Use immutable data structures","Implement proper locking strategy","Add synchronization primitives"]},"resource-management":{symptoms:["memory","leak","connection","file handle","exhausted"],causes:["Resource not properly released","Missing cleanup in error path","Connection pool misconfiguration","Circular reference preventing GC"],impact:"medium",remediation:["Use try-finally or using blocks","Implement IDisposable pattern","Configure resource pools properly"]},configuration:{symptoms:["config","environment","setting","property","parameter"],causes:["Wrong configuration value","Missing required setting","Environment mismatch","Hardcoded values"],impact:"medium",remediation:["Validate configuration at startup","Use configuration schema validation","Document all required settings"]},integration:{symptoms:["api","service","external","timeout","connection"],causes:["External service change","API contract violation","Network configuration issue","Missing retry logic"],impact:"high",remediation:["Implement circuit breaker pattern","Add contract tests","Use retry with exponential backoff"]},"data-integrity":{symptoms:["corrupt","invalid","constraint","duplicate","data"],causes:["Missing validation","Database constraint violated","Race condition in data update","Inconsistent state transitions"],impact:"high",remediation:["Add input validation at all layers","Use database transactions properly","Implement optimistic locking"]},security:{symptoms:["injection","auth","permission","access","security"],causes:["Missing input sanitization","Broken authentication","Insufficient authorization checks","Sensitive data exposure"],impact:"high",remediation:["Sanitize all user inputs","Implement proper authentication","Follow principle of least privilege"]}},Spu=B.create("defect-intelligence/root-cause-analyzer"),k0=class{config;memory;llmRouter;constructor(e,u={}){this.config={...kpu,...u},this.isMemoryBackend(e)?(this.memory=e,this.llmRouter=void 0):(this.memory=e.memory,this.llmRouter=e.llmRouter)}isMemoryBackend(e){return typeof e.get=="function"&&typeof e.set=="function"&&!("memory"in e)}isLLMAnalysisAvailable(){return this.config.enableLLMAnalysis===!0&&this.llmRouter!==void 0}getModelForTier(e){switch(e){case 1:return"claude-3-5-haiku-20241022";case 2:return"claude-sonnet-4-20250514";case 3:return"claude-sonnet-4-20250514";case 4:return"claude-opus-4-5-20251101";default:return"claude-sonnet-4-20250514"}}async analyzeRootCauseWithLLM(e,u,a){if(!this.llmRouter)return null;try{let t=this.buildLLMAnalysisPrompt(e,u,a),r=this.getModelForTier(this.config.llmModelTier??2),i=await this.llmRouter.chat({messages:[{role:"system",content:`You are an expert software engineer specialized in debugging and root cause analysis.
2771
2771
  Analyze the provided defect information and provide:
@@ -2896,7 +2896,7 @@ Please analyze these requirements for:
2896
2896
  `).map(t=>t.trim()).filter(t=>t.length>0&&Au(t));if(a.length>0){let t=0;for(let r of a)t+=V1(r);return ti(t,"jest",s)}return qa(s,e)}catch{return qa(s,e)}}function cgu(s,e){try{let a=Ja("cargo test --list",{cwd:s,encoding:"utf-8",timeout:e.timeout}).split(`
2897
2897
  `).filter(o=>o.endsWith(": test")),t=a.length,r=a.filter(o=>!o.includes("integration")&&!o.includes("e2e")).length,i=a.filter(o=>o.includes("integration")).length,n=a.filter(o=>o.includes("e2e")).length;return{total:t,unit:r,integration:i,e2e:n,source:"cargo"}}catch{return{total:0,unit:0,integration:0,e2e:0,source:"cargo"}}}function Egu(s,e){try{let a=Ja("pytest --collect-only -q",{cwd:s,encoding:"utf-8",timeout:e.timeout}).split(`
2898
2898
  `).filter(o=>o.includes("::test_")||o.includes("::Test")),t=a.length,r=a.filter(o=>o.includes("unit")||!o.includes("integration")&&!o.includes("e2e")).length,i=a.filter(o=>o.includes("integration")||o.includes("_integration")).length,n=a.filter(o=>o.includes("e2e")||o.includes("end_to_end")).length;return{total:t,unit:r-i-n,integration:i,e2e:n,source:"pytest"}}catch{return{total:0,unit:0,integration:0,e2e:0,source:"pytest"}}}function dgu(s,e){try{let a=Ja('go test -list ".*" ./...',{cwd:s,encoding:"utf-8",timeout:e.timeout}).split(`
2899
- `).filter(o=>o.startsWith("Test")||o.startsWith("Example")||o.startsWith("Benchmark")),t=a.filter(o=>o.startsWith("Test")).length,r=a.filter(o=>o.startsWith("Test")&&!o.includes("Integration")&&!o.includes("E2E")).length,i=a.filter(o=>o.includes("Integration")).length,n=a.filter(o=>o.includes("E2E")).length;return{total:t,unit:r,integration:i,e2e:n,source:"go"}}catch{return{total:0,unit:0,integration:0,e2e:0,source:"go"}}}function qa(s,e){let u=0,a=0,t=0,r=0;function i(n){if(!Au(n))return;let o=ngu(n,{withFileTypes:!0});for(let l of o){let c=vu(n,l.name);if(l.isDirectory()){if(e.excludeDirs.includes(l.name))continue;i(c)}else if(l.isFile()&&mgu(l.name)){let E=ogu(l.name).toLowerCase(),d=0;[".ts",".tsx",".js",".jsx",".mjs"].includes(E)?d=V1(c):E===".py"?d=Dgu(c):E===".rs"?d=hgu(c):E===".go"&&(d=pgu(c)),u+=d;let D=c.toLowerCase();D.includes("e2e")||D.includes("end-to-end")?r+=d:D.includes("integration")?t+=d:a+=d}}}return i(s),{total:u,unit:a,integration:t,e2e:r,source:"fallback"}}function mgu(s){let e=s.toLowerCase();return e.includes(".test.")||e.includes(".spec.")||e.includes("_test.")||e.startsWith("test_")||e.endsWith("_test.ts")||e.endsWith("_test.js")||e.endsWith("_test.py")||e.endsWith("_test.go")||e.endsWith("_test.rs")}function V1(s){try{let e=Ua(s,"utf-8"),u=e.match(/\bit\s*\(/g)||[],a=e.match(/\btest\s*\(/g)||[];return u.length+a.length}catch{return 0}}function Dgu(s){try{let e=Ua(s,"utf-8"),u=e.match(/\bdef\s+test_\w+\s*\(/g)||[],a=e.match(/\basync\s+def\s+test_\w+\s*\(/g)||[];return u.length+a.length}catch{return 0}}function hgu(s){try{let e=Ua(s,"utf-8"),u=e.match(/#\[test\]/g)||[],a=e.match(/#\[tokio::test\]/g)||[],t=e.match(/#\[async_std::test\]/g)||[];return u.length+a.length+t.length}catch{return 0}}function pgu(s){try{return(Ua(s,"utf-8").match(/\bfunc\s+Test\w+\s*\(/g)||[]).length}catch{return 0}}function ti(s,e,u){let a=s,t=0,r=0;return(Au(vu(u,"tests","integration"))||Au(vu(u,"test","integration"))||Au(vu(u,"__tests__","integration")))&&(t=Math.floor(s*.2),a-=t),(Au(vu(u,"tests","e2e"))||Au(vu(u,"test","e2e"))||Au(vu(u,"e2e"))||Au(vu(u,"cypress")))&&(r=Math.floor(s*.1),a-=r),{total:s,unit:Math.max(0,a),integration:t,e2e:r,source:e}}var ml=class{config;cache=new Map;cacheHits=0;cacheMisses=0;constructor(e={}){this.config={...Ze,...e}}async collectAll(e){let u=`all:${e}`;if(this.config.enableCache){let c=this.getFromCache(u);if(c)return c}let[a,t,r]=await Promise.all([this.countLOC(e),this.countTests(e),this.countPatterns(e,this.detectLanguage(e))]),i=[];a.source!=="fallback"&&i.push(a.source),t.source!=="fallback"&&i.push(t.source);let n=a.source==="fallback"?"approximate":"accurate",o=t.source==="fallback"?"approximate":"accurate",l={loc:a,tests:t,patterns:r,collectedAt:new Date,toolsUsed:i,accuracy:{loc:n,tests:o,overall:n==="accurate"&&o==="accurate"?"accurate":"approximate"}};return this.config.enableCache&&this.setInCache(u,l),l}async countLOC(e){let u=`loc:${e}`;if(this.config.enableCache){let t=this.getFromCache(u);if(t)return t}let a=await sl(e,this.config);return this.config.enableCache&&this.setInCache(u,a),a}async countTests(e){let u=`tests:${e}`;if(this.config.enableCache){let t=this.getFromCache(u);if(t)return t}let a=await El(e,this.config);return this.config.enableCache&&this.setInCache(u,a),a}async countPatterns(e,u){let a=`patterns:${e}:${u}`;if(this.config.enableCache){let r=this.getFromCache(a);if(r)return r}let t=this.countPatternsInternal(e,u);return this.config.enableCache&&this.setInCache(a,t),t}checkTools(){let e=ll(),u=dl(process.cwd());return[...e,...u]}clearCache(){this.cache.clear(),this.cacheHits=0,this.cacheMisses=0}getCacheStats(){return{hits:this.cacheHits,misses:this.cacheMisses,size:this.cache.size}}getFromCache(e){let u=this.cache.get(e);return u&&Date.now()-u.timestamp<this.config.cacheTTL?(this.cacheHits++,u.data):(this.cacheMisses++,null)}setInCache(e,u){this.cache.set(e,{data:u,timestamp:Date.now()})}detectLanguage(e){return Qe(Ye(e,"Cargo.toml"))?"rust":Qe(Ye(e,"go.mod"))?"go":Qe(Ye(e,"pyproject.toml"))||Qe(Ye(e,"requirements.txt"))?"python":Qe(Ye(e,"package.json"))?Qe(Ye(e,"tsconfig.json"))?"typescript":"javascript":"unknown"}countPatternsInternal(e,u){let a={},t=0,r=0,i=0,n=0,o=this.getPatternsForLanguage(u);function l(c){if(!Qe(c))return;let E=Cgu(c,{withFileTypes:!0});for(let d of E){let D=Ye(c,d.name);if(d.isDirectory()){if(["node_modules","dist","coverage","build",".git","vendor","target"].includes(d.name))continue;l(D)}else if(d.isFile()){let h=Agu(d.name).toLowerCase();if(ygu(h,u)){let C=xgu(D,o);(C.unwraps>0||C.unsafeBlocks>0||C.todoComments>0||C.consoleStatements>0)&&(a[D]=C,t+=C.unwraps,r+=C.unsafeBlocks,i+=C.todoComments,n+=C.consoleStatements)}}}}return l(e),{unwraps:t,unsafeBlocks:r,todoComments:i,consoleStatements:n,byFile:a}}getPatternsForLanguage(e){switch(e){case"rust":return{unwrap:/\.unwrap\s*\(/g,unsafe:/\bunsafe\s*\{/g,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(println!|print!|eprintln!|eprint!|dbg!)\s*\(/g};case"python":return{unwrap:null,unsafe:null,todo:/#\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(print)\s*\(/g};case"go":return{unwrap:null,unsafe:/\bunsafe\./g,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(fmt\.Print|fmt\.Printf|fmt\.Println|log\.Print|log\.Printf|log\.Println)\s*\(/g};default:return{unwrap:null,unsafe:null,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\bconsole\.(log|debug|info|warn|error)\s*\(/g}}}};function ygu(s,e){switch(e){case"rust":return s===".rs";case"python":return[".py",".pyw"].includes(s);case"go":return s===".go";case"typescript":return[".ts",".tsx"].includes(s);case"javascript":return[".js",".jsx",".mjs",".cjs"].includes(s);default:return[".ts",".tsx",".js",".jsx",".py",".rs",".go"].includes(s)}}function xgu(s,e){try{let u=ggu(s,"utf-8");return{unwraps:e.unwrap?(u.match(e.unwrap)||[]).length:0,unsafeBlocks:e.unsafe?(u.match(e.unsafe)||[]).length:0,todoComments:(u.match(e.todo)||[]).length,consoleStatements:(u.match(e.console)||[]).length}}catch{return{unwraps:0,unsafeBlocks:0,todoComments:0,consoleStatements:0}}}function O1(s={}){return new ml(s)}N();S();cu();c0();S();c0();S();c0();S();c0();S();cu();c0();S();var $Hu=300*1e3;Qu();Qu();N();Qu();var nGu=B.create("temporal-compression");S();N();var cGu=B.create("ruvector-server-client");n3();import{Buffer as zgu}from"buffer";var gGu=zgu.from("COGCNTNR","ascii");Qu();Qu();var Ngu={capacity:1e4,minCoherenceThreshold:.3,highTierThreshold:.8,mediumTierThreshold:.5,highTierWeight:3,mediumTierWeight:1.5,lowTierWeight:1},Dl=class{config;cusumDetector;buffer;totalSeen=0;totalAdmitted=0;totalRejected=0;totalEvicted=0;totalSampled=0;constructor(e){this.config={...Ngu,...e},this.cusumDetector=new nn({threshold:this.config.cusumConfig?.threshold??5,slack:this.config.cusumConfig?.slack??.5,resetOnAlarm:!1,warmupSamples:20}),this.buffer=[]}admit(e,u,a){this.totalSeen++;let t=this.getEffectiveThreshold();if(a<t)return this.totalRejected++,!1;let r=this.classifyTier(a),i={id:e,data:u,coherenceScore:a,tier:r,admittedAt:Date.now(),replayCount:0};if(this.buffer.length<this.config.capacity)return this.buffer.push(i),this.totalAdmitted++,!0;let n=Math.floor(Math.random()*this.totalAdmitted),o=this.getTierWeight(r),l=Math.floor(n/o);if(l<this.config.capacity){let c=this.selectEvictionTarget(l);return this.buffer[c]=i,this.totalEvicted++,this.totalAdmitted++,!0}return this.totalRejected++,!1}sample(e,u){if(this.buffer.length===0)return[];let a=u!==void 0?this.buffer.filter(n=>n.coherenceScore>=u):this.buffer;if(a.length===0)return[];if(e>=a.length){let n=[...a];for(let o of n)o.replayCount++;return this.totalSampled+=n.length,n}let t=a.map(n=>this.getTierWeight(n.tier)),r=[],i=new Set;for(;r.length<e&&i.size<a.length;){let n=0;for(let c=0;c<a.length;c++)i.has(c)||(n+=t[c]);if(n<=0)break;let o=Math.random()*n,l=-1;for(let c=0;c<a.length;c++)if(!i.has(c)&&(o-=t[c],o<=0)){l=c;break}if(l===-1){for(let c=0;c<a.length;c++)if(!i.has(c)){l=c;break}}l>=0&&(i.add(l),a[l].replayCount++,r.push(a[l]))}return this.totalSampled+=r.length,r}size(){return this.buffer.length}getStats(){let e={high:0,medium:0,low:0};for(let u of this.buffer)e[u.tier]++;return{size:this.buffer.length,capacity:this.config.capacity,totalAdmitted:this.totalAdmitted,totalRejected:this.totalRejected,totalEvicted:this.totalEvicted,tierCounts:e,totalSampled:this.totalSampled}}getByTier(e){return this.buffer.filter(u=>u.tier===e)}clear(){this.buffer.length=0,this.totalSeen=0,this.totalAdmitted=0,this.totalRejected=0,this.totalEvicted=0,this.totalSampled=0,this.cusumDetector.reset()}getCusumState(e){return this.cusumDetector.getState(e)}observeCoherence(e,u){return this.cusumDetector.update(e,u)}classifyTier(e){return e>=this.config.highTierThreshold?"high":e>=this.config.mediumTierThreshold?"medium":"low"}getTierWeight(e){switch(e){case"high":return this.config.highTierWeight;case"medium":return this.config.mediumTierWeight;case"low":return this.config.lowTierWeight}}getEffectiveThreshold(){let e=["retrieve","write","learn","act"],u=!1;for(let a of e)if(this.cusumDetector.getState(a).driftDetected){u=!0;break}return u?Math.min(this.config.minCoherenceThreshold*1.5,.9):this.config.minCoherenceThreshold}selectEvictionTarget(e){let u=Math.min(10,this.buffer.length),a=Math.max(0,e-Math.floor(u/2)),t=Math.min(this.buffer.length,a+u),r=e,i=this.buffer[e].coherenceScore;for(let n=a;n<t;n++)this.buffer[n].coherenceScore<i&&(i=this.buffer[n].coherenceScore,r=n);return r}};cu();var M0=B.create("code-intelligence/gnn");async function _1(s,e,u){try{for(let a of u)try{let t=await e.readFile(a);if(t.success&&t.value){let i={vector:await hl(a,t.value),dimension:384,namespace:"code",text:t.value.slice(0,1e3),timestamp:Date.now(),quantization:"none",metadata:{path:a}};s.addEmbedding(i)}}catch(t){M0.error(`Failed to index ${a}:`,t instanceof Error?t:void 0)}M0.info(`Indexed ${u.length} code embeddings`)}catch(a){M0.error("Failed to index code embeddings:",a instanceof Error?a:void 0)}}async function hl(s,e){let u=[],a=s.split(".").pop(),t=ii(a||"");u.push(t%1e3/1e3),u.push(Math.min(1,e.length/1e4));let r=e.match(/function\s+\w+/g)||[],i=e.match(/class\s+\w+/g)||[];u.push(Math.min(1,(r.length+i.length)/50));let n=e.match(/import\s+.*from|require\s*\(/g)||[];u.push(Math.min(1,n.length/20));let o=e.match(/for\s*\(|while\s*\(/g)||[],l=e.match(/if\s*\(/g)||[];u.push(Math.min(1,(o.length+l.length)/30));let c=e.match(/\/\/.*|\/\*[\s\S]*?\*\//g)||[];u.push(Math.min(1,c.length/50));let E=ii(e.slice(0,500));for(let d=u.length;d<384;d++)u.push(E*(d+1)%1e4/1e4);return u.slice(0,384)}async function W1(s,e){try{let a={vector:await hl("query",e),dimension:384,namespace:"code",text:e,timestamp:Date.now(),quantization:"none"};return s.search(a,{limit:10,namespace:"code"}).map(r=>({file:r.metadata?.path??`file-${r.id}`,similarity:1-r.distance}))}catch(u){return M0.error("Failed to search with GNN:",u instanceof Error?u:void 0),[]}}async function $1(s,e,u){try{for(let a of u.changedFiles){let t=await e.readFile(a);if(t.success&&t.value){let i={vector:await hl(a,t.value),dimension:384,namespace:"code",text:t.value.slice(0,1e3),timestamp:Date.now(),quantization:"none",metadata:{path:a}},n=s.search(i,{limit:5,namespace:"code"});M0.info(`Found ${n.length} semantically similar files to ${a}`)}}}catch(a){M0.error("Failed to enhance impact analysis:",a instanceof Error?a:void 0)}}function q1(s,e){let u=new Map,a=new Map;for(let t of s)u.set(t.file,t.score),a.set(t.file,t);for(let t of e){let r=u.get(t.file);r!==void 0?u.set(t.file,(r+t.similarity)/2):(u.set(t.file,t.similarity*.8),a.set(t.file,{file:t.file,snippet:"",score:t.similarity*.8,highlights:[]}))}return Array.from(a.values()).map(t=>({...t,score:u.get(t.file)??t.score})).sort((t,r)=>r.score-t.score).slice(0,20)}function ii(s){let e=0;for(let u=0;u<s.length;u++)e=(e<<5)-e+s.charCodeAt(u),e=e|0;return Math.abs(e)}N();S();var qu=B.create("code-intelligence/hypergraph");async function J1(s,e,u){try{let a=await s.findUntestedFunctions();if(qu.info(`[CodeIntelligence] Found ${a.length} untested functions via hypergraph`),u){let t=L("code-intelligence.UntestedFunctionsFound","code-intelligence",{count:a.length,functions:a.slice(0,10).map(r=>({name:r.name,file:r.filePath,complexity:r.complexity}))});await e.publish(t)}return{success:!0,value:a}}catch(a){let t=g(a);return qu.error("Failed to find untested functions:"),m(t)}}async function U1(s,e,u,a){if(e.length===0)return{success:!0,value:[]};try{let t=await s.findImpactedTests(e);if(qu.info(`[CodeIntelligence] Found ${t.length} impacted tests for ${e.length} changed files via hypergraph`),a){let r=L("code-intelligence.ImpactedTestsFound","code-intelligence",{changedFiles:e,testCount:t.length,tests:t.slice(0,10).map(i=>({name:i.name,file:i.filePath}))});await u.publish(r)}return{success:!0,value:t}}catch(t){let r=g(t);return qu.error("Failed to find impacted tests:"),m(r)}}async function Z1(s,e,u,a){try{let t=await s.findCoverageGaps(e);if(qu.info(`[CodeIntelligence] Found ${t.length} coverage gaps (functions with <=${e}% coverage) via hypergraph`),a){let r=L("code-intelligence.CoverageGapsFound","code-intelligence",{maxCoverage:e,gapCount:t.length,gaps:t.slice(0,10).map(i=>({name:i.name,file:i.filePath,coverage:i.coverage,complexity:i.complexity}))});await u.publish(r)}return{success:!0,value:t}}catch(t){let r=g(t);return qu.error("Failed to find coverage gaps:"),m(r)}}async function Q1(s,e,u,a,t){try{qu.info(`[CodeIntelligence] Building hypergraph from ${e.files.length} indexed files`);let r=await s.buildFromIndexResult(e);if(qu.info(`[CodeIntelligence] Hypergraph built: ${r.nodesCreated} nodes created, ${r.nodesUpdated} nodes updated, ${r.edgesCreated} edges created (${r.durationMs}ms)`),await u.set("hypergraph:build:latest",{timestamp:new Date().toISOString(),...r},{namespace:"code-intelligence",persist:!0}),t){let i=L("code-intelligence.HypergraphBuilt","code-intelligence",{nodesCreated:r.nodesCreated,nodesUpdated:r.nodesUpdated,edgesCreated:r.edgesCreated,durationMs:r.durationMs,errorCount:r.errors.length});await a.publish(i)}return{success:!0,value:r}}catch(r){let i=g(r);return qu.error("Failed to build hypergraph:"),m(i)}}async function Y1(s,e,u){try{let a=await s.findImpactedTests(e.changedFiles),t=new Set([...u.impactedTests,...a.map(n=>n.filePath||n.name)]),r=u.riskLevel;if(a.length>u.impactedTests.length){let n=u.directImpact.length+u.transitiveImpact.length;n>10&&t.size>20?r="critical":n>5&&t.size>10&&(r="high")}let i=[...u.recommendations];return a.length>0&&i.push(`Hypergraph analysis found ${a.length} additional test(s) to run`),{...u,impactedTests:Array.from(t),riskLevel:r,recommendations:i}}catch(a){return qu.error("Failed to enhance impact with hypergraph:",a instanceof Error?a:void 0),u}}N();var R0=B.create("code-intelligence/consensus");async function X1(s,e,u,a){let t=O({id:A(),type:"code-pattern-detection",confidence:e,description:`Verify code pattern: ${s.name} (${s.type}) at ${s.location}`,payload:s,detectedBy:"code-intelligence-coordinator",severity:e>.9?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info(`Code pattern '${s.name}' verified by consensus`),!0):(R0.warn(`Code pattern '${s.name}' NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function uE(s,e,u,a){let t=O({id:A(),type:"impact-analysis",confidence:e,description:`Verify impact analysis: ${s.changedFiles.length} files, risk=${s.riskLevel}, ${s.impactedTests.length} tests`,payload:s,detectedBy:"code-intelligence-coordinator",severity:s.riskLevel==="critical"||s.riskLevel==="high"?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info(`Impact analysis verified by consensus (risk=${s.riskLevel})`),!0):(R0.warn(`Impact analysis NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function eE(s,e,u,a){let t=O({id:A(),type:"dependency-mapping",confidence:e,description:`Verify dependency: ${s.source} -> ${s.targets.length} targets (${s.type})`,payload:s,detectedBy:"code-intelligence-coordinator",severity:e>.85?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info("Dependency mapping verified by consensus"),!0):(R0.warn(`Dependency mapping NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}var Xgu={maxConcurrentWorkflows:5,defaultTimeout:12e4,publishEvents:!0,enableIncrementalIndex:!0,enableGNN:!0,enableSONA:!0,enableMetricCollector:!0,enableHypergraph:!0,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},su=B.create("code-intelligence"),Qa=class extends Y{constructor(u,a,t,r={}){let i={...Xgu,...r};super(u,"code-intelligence",i,{verifyFindingTypes:["code-pattern-detection","impact-analysis","dependency-mapping"]});this.memory=a;this.agentCoordinator=t;this.knowledgeGraph=new ze(a),this.semanticAnalyzer=new Ue(a),this.impactAnalyzer=new ea(a,this.knowledgeGraph),this.fileReader=new ju,this.productFactorsBridge=new ei(u,a,{publishEvents:this.config.publishEvents})}knowledgeGraph;semanticAnalyzer;impactAnalyzer;fileReader;gnnIndex;sonaEngine;rlInitialized=!1;metricCollector;hypergraph;hypergraphDb;productFactorsBridge;async onInitialize(){this.subscribeToEvents(),await this.loadWorkflowState(),(this.config.enableGNN||this.config.enableSONA)&&await this.initializeRLIntegrations(),this.config.enableMetricCollector&&(this.metricCollector=O1({enableCache:!0,cacheTTL:3e5}),su.info("MetricCollector initialized for real code metrics")),this.config.enableHypergraph&&await this.initializeHypergraph(),await this.productFactorsBridge.initialize()}async initializeHypergraph(){try{let{openDatabase:u}=await import("./safe-db-5KLXCNXN.js"),a=await import("fs"),t=await import("path"),{findProjectRoot:r}=await import("./unified-memory-72SKVZ7Y.js"),i=r(),n=this.config.hypergraphDbPath||t.join(i,".agentic-qe","memory.db"),o=t.dirname(n);a.existsSync(o)||a.mkdirSync(o,{recursive:!0}),this.hypergraphDb=u(n),this.hypergraph=await Ct({db:this.hypergraphDb,maxTraversalDepth:10,maxQueryResults:1e3,enableVectorSearch:this.config.enableGNN}),su.info(`Hypergraph Engine initialized at ${n}`)}catch(u){let a=u instanceof Error?u.message:String(u);if(su.warn(`Hypergraph Engine initialization failed (feature degraded): ${a}`),this.hypergraph=void 0,this.hypergraphDb=void 0,this.config.publishEvents){let t=L("code-intelligence.HypergraphDegraded","code-intelligence",{reason:a});this.eventBus.publish(t).catch(()=>{})}}}async initializeRLIntegrations(){try{if(this.config.enableGNN&&(rn(),this.gnnIndex=gt.getInstance("code-intelligence",{M:16,efConstruction:200,efSearch:50,dimension:384,metric:"cosine"}),this.gnnIndex.initializeIndex("code"),this.gnnIndex.initializeIndex("test")),this.config.enableSONA)try{this.sonaEngine=await gu({domain:"code-intelligence",loadOnInit:!0,autoSaveInterval:6e4,maxPatterns:1e4,minConfidence:.6}),su.info("PersistentSONAEngine initialized for code pattern learning")}catch(u){su.error("Failed to initialize PersistentSONAEngine:",u instanceof Error?u:void 0),this.sonaEngine=void 0}this.rlInitialized=!0}catch(u){throw su.error("Failed to initialize RL integrations:",u instanceof Error?u:void 0),u}}async onDispose(){if(await this.saveWorkflowState(),this.gnnIndex&&gt.closeInstance("code-intelligence"),this.sonaEngine)try{await this.sonaEngine.close(),this.sonaEngine=void 0}catch(u){su.error("Error closing SONA engine:",u instanceof Error?u:void 0)}if(this.hypergraphDb){try{this.hypergraphDb.close()}catch(u){su.error("Error closing hypergraph database:",u instanceof Error?u:void 0)}this.hypergraphDb=void 0}this.hypergraph=void 0,await this.productFactorsBridge.dispose()}getActiveWorkflows(){return super.getActiveWorkflows()}async index(u){let a=A();try{if(this.startWorkflow(a,"index"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&su.warn("Topology degraded, using conservative strategy"),this.minCutMixin.shouldPauseOperations())return m(new Error("Indexing paused: topology is in critical state"));if(!this.agentCoordinator.canSpawn())return m(new Error("Agent limit reached, cannot spawn indexing agents"));let t=await this.spawnIndexerAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value),this.updateWorkflowProgress(a,10);let r=await this.knowledgeGraph.index(u);if(r.success){if(this.updateWorkflowProgress(a,40),this.config.enableGNN&&this.gnnIndex&&u.paths.length>0&&await this.indexCodeEmbeddings(u.paths),this.updateWorkflowProgress(a,60),this.config.enableMetricCollector&&this.metricCollector&&u.paths.length>0){let i=this.getProjectRootFromPaths(u.paths);i&&await this.collectProjectMetrics(i)}if(this.updateWorkflowProgress(a,70),u.paths.length>0&&await this.indexForSemanticSearch(u.paths),this.updateWorkflowProgress(a,85),this.config.enableHypergraph&&this.hypergraph&&u.paths.length>0)try{let i=await this.buildCodeIndexResultFromPaths(u.paths);i.files.length>0&&(await this.hypergraph.buildFromIndexResult(i),su.info(`Hypergraph rebuilt from ${i.files.length} indexed files`))}catch(i){su.warn(`Hypergraph rebuild skipped: ${i instanceof Error?i.message:i}`)}this.updateWorkflowProgress(a,100),this.completeWorkflow(a),this.config.publishEvents&&await this.publishKnowledgeGraphUpdated(r.value)}else this.failWorkflow(a,r.error.message);return await this.agentCoordinator.stop(t.value),r}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async search(u){let a=A();try{this.startWorkflow(a,"search");let t=await this.spawnSearchAgent(a,u);if(t.success&&this.addAgentToWorkflow(a,t.value),this.config.enableSONA&&this.sonaEngine){let n=await this.adaptSearchPattern(u);n.success&&n.pattern&&su.info(`Adapted search pattern with ${n.similarity.toFixed(3)} similarity`)}let r=[];this.config.enableGNN&&this.gnnIndex&&(r=await this.searchCodeWithGNN(u));let i=await this.semanticAnalyzer.search(u);return i.success?(r.length>0&&(i.value.results=this.mergeSearchResults(i.value.results,r)),this.completeWorkflow(a),this.config.publishEvents&&await this.publishSemanticSearchCompleted(u,i.value)):this.failWorkflow(a,i.error.message),t.success&&await this.agentCoordinator.stop(t.value),i}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async analyzeImpact(u){let a=A();try{if(this.startWorkflow(a,"impact"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&su.warn("Topology degraded, using conservative impact analysis"),this.minCutMixin.shouldPauseOperations())return m(new Error("Impact analysis paused: topology is in critical state"));let t=await this.spawnImpactAnalyzerAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value),this.updateWorkflowProgress(a,20),this.config.enableGNN&&this.gnnIndex&&await this.enhanceImpactAnalysisWithGNN(u);let r=await this.impactAnalyzer.analyzeImpact(u);if(r.success){this.updateWorkflowProgress(a,80);let i=r.value;return this.config.enableHypergraph&&this.hypergraph&&(i=await this.enhanceImpactWithHypergraph(u,r.value)),this.updateWorkflowProgress(a,100),this.completeWorkflow(a),this.config.enableSONA&&this.sonaEngine&&await this.storeImpactPattern(u,i),this.config.publishEvents&&await this.publishImpactAnalysisCompleted(u,i),{success:!0,value:i}}else this.failWorkflow(a,r.error.message);return await this.agentCoordinator.stop(t.value),r}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async mapDependencies(u){let a=A();try{this.startWorkflow(a,"dependency");let t=await this.knowledgeGraph.mapDependencies(u);return t.success?this.completeWorkflow(a):this.failWorkflow(a,t.error.message),t}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async queryKG(u){let a=A();try{this.startWorkflow(a,"query");let t=await this.knowledgeGraph.query(u);return t.success?this.completeWorkflow(a):this.failWorkflow(a,t.error.message),t}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async indexCodeEmbeddings(u){!this.gnnIndex||!this.rlInitialized||await _1(this.gnnIndex,this.fileReader,u)}async searchCodeWithGNN(u){return!this.gnnIndex||!this.rlInitialized?[]:W1(this.gnnIndex,u.query)}async enhanceImpactAnalysisWithGNN(u){!this.gnnIndex||!this.rlInitialized||await $1(this.gnnIndex,this.fileReader,u)}async adaptSearchPattern(u){if(!this.sonaEngine||!this.rlInitialized)return{success:!1,pattern:null,similarity:0};try{let a=Array.isArray(u.filters)?u.filters.find(i=>i.field==="language")?.value:void 0,t={id:`search-${u.type}`,features:[u.query.length,u.type==="semantic"?1:0,u.type==="exact"?1:0,a==="typescript"?1:0,a==="javascript"?1:0]},r=await this.sonaEngine.adaptPattern(t,"coverage-optimization","code-intelligence");return{success:r.success,pattern:r.pattern,similarity:r.similarity}}catch(a){return su.error("Failed to adapt search pattern:",a instanceof Error?a:void 0),{success:!1,pattern:null,similarity:0}}}async storeImpactPattern(u,a){if(!(!this.sonaEngine||!this.rlInitialized))try{let t={id:`impact-${u.changedFiles.join(",")}`,features:[u.changedFiles.length,u.depth||1,a.directImpact.length,a.transitiveImpact.length,a.impactedTests.length,a.riskLevel==="high"?1:a.riskLevel==="medium"?.5:0]},r={type:"analyze-impact",value:a.riskLevel},i={reward:a.riskLevel==="high"?.8:a.riskLevel==="medium"?.5:.3,success:a.impactedTests.length>0,quality:(a.directImpact.length+a.transitiveImpact.length)/100},n=this.sonaEngine.createPattern(t,r,i,"coverage-optimization","code-intelligence",{changedFiles:u.changedFiles,impactCount:a.directImpact.length+a.transitiveImpact.length,testImpactCount:a.impactedTests.length});su.info(`Stored impact pattern ${n.id}`)}catch(t){su.error("Failed to store impact pattern:",t instanceof Error?t:void 0)}}mergeSearchResults(u,a){return q1(u,a)}hashCode(u){return ii(u)}async spawnIndexerAgent(u,a){let t={name:`kg-indexer-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["indexing","ast-parsing","graph-building"],config:{workflowId:u,paths:a.paths,incremental:a.incremental}};return this.agentCoordinator.spawn(t)}async spawnSearchAgent(u,a){let t={name:`semantic-search-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["semantic-search","vector-similarity",a.type],config:{workflowId:u,query:a.query,type:a.type}};return this.agentCoordinator.spawn(t)}async spawnImpactAnalyzerAgent(u,a){let t={name:`impact-analyzer-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["impact-analysis","dependency-traversal","risk-assessment"],config:{workflowId:u,changedFiles:a.changedFiles,depth:a.depth}};return this.agentCoordinator.spawn(t)}async publishKnowledgeGraphUpdated(u){let a={nodes:u.nodesCreated,edges:u.edgesCreated,filesIndexed:u.filesIndexed,duration:u.duration},t=L(Ee.KnowledgeGraphUpdated,"code-intelligence",a);await this.eventBus.publish(t)}async publishImpactAnalysisCompleted(u,a){let t={analysisId:A(),changedFiles:u.changedFiles,impactedFiles:[...a.directImpact.map(i=>i.file),...a.transitiveImpact.map(i=>i.file)],impactedTests:a.impactedTests,riskLevel:a.riskLevel},r=L(Ee.ImpactAnalysisCompleted,"code-intelligence",t);await this.eventBus.publish(r)}async publishSemanticSearchCompleted(u,a){let t=L(Ee.SemanticSearchCompleted,"code-intelligence",{query:u.query,type:u.type,resultCount:a.total,searchTime:a.searchTime});await this.eventBus.publish(t)}subscribeToEvents(){this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("source-control.FilesChanged",this.handleFilesChanged.bind(this))}async handleTestRunCompleted(u){let a=u.payload;await this.memory.set(`code-intelligence:test-correlation:${a.runId}`,a,{namespace:"code-intelligence",ttl:86400})}async handleFilesChanged(u){if(!this.config.enableIncrementalIndex)return;let a=u.payload;a.files&&a.files.length>0&&await this.memory.set(`code-intelligence:pending-index:${Date.now()}`,{files:a.files,timestamp:new Date().toISOString()},{namespace:"code-intelligence",ttl:3600})}async indexForSemanticSearch(u){let a=u.slice(0,100);for(let t of a)try{let r=await this.fileReader.readFile(t);r.success&&r.value&&await this.semanticAnalyzer.indexCode(t,r.value)}catch{}}async loadWorkflowState(){let u=await this.memory.get("code-intelligence:coordinator:workflows");if(u)for(let a of u)a.status==="running"&&(a.status="failed",a.error="Coordinator restarted",a.completedAt=new Date),this.workflows.set(a.id,a)}async saveWorkflowState(){let u=Array.from(this.workflows.values());await this.memory.set("code-intelligence:coordinator:workflows",u,{namespace:"code-intelligence",persist:!0})}async generateC4Diagrams(u,a){let t=A();try{this.startWorkflow(t,"query");let r={projectPath:u,detectExternalSystems:a?.detectExternalSystems??!0,analyzeComponents:a?.analyzeComponents??!0,analyzeCoupling:a?.analyzeCoupling??!0,includeContext:a?.includeContext??!0,includeContainer:a?.includeContainer??!0,includeComponent:a?.includeComponent??!0,includeDependency:a?.includeDependency??!1,excludePatterns:a?.excludePatterns};this.updateWorkflowProgress(t,20);let i=await this.productFactorsBridge.requestC4Diagrams(r);return i.success?(this.updateWorkflowProgress(t,80),await this.storeC4DiagramsInMemory(u,i.value),this.updateWorkflowProgress(t,100),this.completeWorkflow(t),su.info(`[CodeIntelligenceCoordinator] C4 diagrams generated for ${u}: ${i.value.components.length} components, ${i.value.externalSystems.length} external systems`)):this.failWorkflow(t,i.error.message),i}catch(r){let i=g(r);return this.failWorkflow(t,i.message),m(i)}}getProductFactorsBridge(){return this.productFactorsBridge}async storeC4DiagramsInMemory(u,a){let t=`c4-diagrams:latest:${this.hashCode(u)}`;await this.memory.set(t,a,{namespace:"code-intelligence",persist:!0,ttl:36e5}),await this.memory.set(`c4-components:${this.hashCode(u)}`,a.components,{namespace:"code-intelligence",ttl:36e5}),await this.memory.set(`c4-external-systems:${this.hashCode(u)}`,a.externalSystems,{namespace:"code-intelligence",ttl:36e5})}async collectProjectMetrics(u){if(!this.config.enableMetricCollector||!this.metricCollector)return m(new Error("MetricCollector is not enabled"));try{su.info(`Collecting real metrics for ${u}`);let a=await this.metricCollector.collectAll(u),t=a.toolsUsed.length>0?a.toolsUsed.join(", "):a.loc.source==="node-native"?"node-native":"fallback";if(su.info(`[CodeIntelligence] Real metrics collected: ${a.loc.total} LOC, ${a.tests.total} tests, tools: ${t}`),a.loc.source==="node-native"&&su.info("[CodeIntelligence] Using Node.js-native line counter (no cloc/tokei needed)"),await this.storeProjectMetricsInMemory(u,a),this.config.publishEvents){let r=L("code-intelligence.MetricsCollected","code-intelligence",{projectPath:u,loc:a.loc.total,tests:a.tests.total,toolsUsed:a.toolsUsed});await this.eventBus.publish(r)}return{success:!0,value:a}}catch(a){let t=g(a);return su.error("Failed to collect metrics:"),m(t)}}async storeProjectMetricsInMemory(u,a){let t=`project-metrics:latest:${this.hashCode(u)}`;await this.memory.set(t,a,{namespace:"code-intelligence",persist:!0,ttl:3e5}),await this.memory.set(`loc-metrics:${this.hashCode(u)}`,a.loc,{namespace:"code-intelligence",ttl:3e5}),await this.memory.set(`test-metrics:${this.hashCode(u)}`,a.tests,{namespace:"code-intelligence",ttl:3e5})}getMetricCollector(){return this.metricCollector}getProjectRootFromPaths(u){if(u.length===0)return null;let a=u[0],t=a.split("/"),r="";for(let n of t){r=r?`${r}/${n}`:n;let o=["package.json","Cargo.toml","go.mod","pyproject.toml",".git"];for(let l of o)try{let c=`${r}/${l}`;if(Ji("fs").existsSync(c))return r}catch{}}let i=a.lastIndexOf("/");return i>0?a.substring(0,i):a}isHypergraphEnabled(){return this.config.enableHypergraph&&this.hypergraph!==void 0}async findUntestedFunctions(){return this.hypergraph?J1(this.hypergraph,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async findImpactedTestsFromHypergraph(u){return this.hypergraph?U1(this.hypergraph,u,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async findCoverageGapsFromHypergraph(u=50){return this.hypergraph?Z1(this.hypergraph,u,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async buildHypergraphFromIndex(u){return this.hypergraph?Q1(this.hypergraph,u,this.memory,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}getHypergraph(){return this.hypergraph}async enhanceImpactWithHypergraph(u,a){return this.hypergraph?Y1(this.hypergraph,u,a):a}async buildCodeIndexResultFromPaths(u){let{extractCodeIndex:a}=await import("./code-index-extractor-YQL5XN52.js");return a(u)}async verifyCodePatternDetection(u,a){return X1(u,a,this.consensusMixin,this.domainName)}async verifyImpactAnalysis(u,a){return uE(u,a,this.consensusMixin,this.domainName)}async verifyDependencyMapping(u,a){return eE(u,a,this.consensusMixin,this.domainName)}};S();var ni=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;knowledgeGraph=null;semanticAnalyzer=null;impactAnalyzer=null;pluginConfig;get name(){return"code-intelligence"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{index:this.index.bind(this),search:this.search.bind(this),analyzeImpact:this.analyzeImpact.bind(this),mapDependencies:this.mapDependencies.bind(this),getDependencies:this.mapDependencies.bind(this),queryKG:this.queryKG.bind(this),getMetrics:this.getMetrics.bind(this),getCoordinator:()=>this.coordinator,getKnowledgeGraph:()=>this.knowledgeGraph,getSemanticAnalyzer:()=>this.semanticAnalyzer,getImpactAnalyzer:()=>this.impactAnalyzer}}getTaskHandlers(){return new Map([["index",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.paths;if(!a||a.length===0)return m(new Error("Invalid index payload: missing paths"));let t=u.language?[u.language]:u.languages;return this.coordinator.index({paths:a,languages:t})}],["search",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.query;return a?this.coordinator.search({query:a,type:u.type??"semantic",limit:u.limit}):m(new Error("Invalid search payload: missing query"))}],["analyze-impact",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.changedFiles;return!a||a.length===0?m(new Error("Invalid analyze-impact payload: missing changedFiles")):this.coordinator.analyzeImpact({changedFiles:a})}],["query-dependencies",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.file,r=u.files??(a?[a]:void 0);return!r||r.length===0?m(new Error("Invalid query-dependencies payload: missing file or files")):this.coordinator.mapDependencies({files:r,direction:u.direction??"both",depth:u.depth})}]])}async onInitialize(){this.knowledgeGraph=new ze(this.memory,this.pluginConfig.knowledgeGraph),this.semanticAnalyzer=new Ue(this.memory,this.pluginConfig.semanticAnalyzer),this.impactAnalyzer=new ea(this.memory,this.knowledgeGraph,this.pluginConfig.impactAnalyzer),this.coordinator=new Qa(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null,this.knowledgeGraph=null,this.semanticAnalyzer=null,this.impactAnalyzer=null}subscribeToEvents(){this.eventBus.subscribe("test-generation.TestGenerated",this.handleTestGenerated.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("defect-intelligence.DefectPredicted",this.handleDefectPredicted.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"test-generation.TestGenerated":await this.handleTestGenerated(u);break;case"coverage-analysis.CoverageGapDetected":await this.handleCoverageGap(u);break;case"defect-intelligence.DefectPredicted":await this.handleDefectPredicted(u);break;default:break}}async index(u){this.ensureInitialized();try{let a=await this.coordinator.index(u);return a.success?this.trackSuccessfulOperation("index",a.value):this.trackFailedOperation("index",a.error),a}catch(a){return this.handleError(a)}}async search(u){this.ensureInitialized();try{let a=await this.coordinator.search(u);return a.success?this.trackSuccessfulOperation("search",a.value):this.trackFailedOperation("search",a.error),a}catch(a){return this.handleError(a)}}async analyzeImpact(u){this.ensureInitialized();try{let a=await this.coordinator.analyzeImpact(u);return a.success?this.trackSuccessfulOperation("impact",a.value):this.trackFailedOperation("impact",a.error),a}catch(a){return this.handleError(a)}}async mapDependencies(u){this.ensureInitialized();try{let a=await this.coordinator.mapDependencies(u);return a.success?this.trackSuccessfulOperation("dependency",a.value):this.trackFailedOperation("dependency",a.error),a}catch(a){return this.handleError(a)}}async queryKG(u){this.ensureInitialized();try{let a=await this.coordinator.queryKG(u);return a.success?this.trackSuccessfulOperation("query",a.value):this.trackFailedOperation("query",a.error),a}catch(a){return this.handleError(a)}}async getMetrics(){this.ensureInitialized();try{let u=this.getHealth();return{success:!0,value:{indexed:u.agents.total,queries:u.agents.idle,impacts:u.agents.active}}}catch(u){return this.handleError(u)}}async handleTestGenerated(u){let a=u.payload;await this.memory.set(`code-intelligence:test-mapping:${a.testId}`,{testFile:a.testFile,sourceFile:a.sourceFile,generatedAt:new Date().toISOString()},{namespace:"code-intelligence",ttl:86400*30})}async handleCoverageGap(u){let a=u.payload;await this.memory.set(`code-intelligence:coverage-gap:${a.gapId}`,a,{namespace:"code-intelligence",ttl:86400*7})}async handleDefectPredicted(u){let a=u.payload;await this.memory.set(`code-intelligence:defect-prediction:${a.predictionId}`,a,{namespace:"code-intelligence",ttl:86400*7})}ensureInitialized(){if(!this._initialized)throw new Error("CodeIntelligencePlugin is not initialized");if(!this.coordinator||!this.knowledgeGraph||!this.semanticAnalyzer||!this.impactAnalyzer)throw new Error("CodeIntelligencePlugin services are not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),{success:!1,error:a}}trackSuccessfulOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,total:t.agents.total+1,idle:t.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,failed:t.agents.failed+1},errors:[...t.errors.slice(-9),a.message]})}};function pl(s,e,u,a){return new ni(s,e,u,a)}N();S();var yu=class s{constructor(e){this._value=e;if(!e||e.trim()==="")throw new Error("FilePath cannot be empty")}get value(){return this._value}get extension(){let e=this._value.split(".");return e.length>1?e[e.length-1]:""}get directory(){let e=this._value.lastIndexOf("/");return e>0?this._value.substring(0,e):""}get filename(){let e=this._value.lastIndexOf("/");return e>=0?this._value.substring(e+1):this._value}equals(e){return this._value===e._value}static create(e){return new s(e)}};var P0=class s{constructor(e){this._value=e;if(e<0||e>1)throw new Error("RiskScore must be between 0 and 1")}get value(){return this._value}get percentage(){return this._value*100}get level(){return this._value>=.8?"critical":this._value>=.6?"high":this._value>=.3?"medium":"low"}isHigherThan(e){return this._value>e._value}equals(e){return this._value===e._value}static create(e){return new s(e)}static fromPercentage(e){return new s(e/100)}},Ju=class s{constructor(e,u){this._start=e;this._end=u;if(e>u)throw new Error("Start date cannot be after end date")}get start(){return this._start}get end(){return this._end}get durationMs(){return this._end.getTime()-this._start.getTime()}get durationSeconds(){return this.durationMs/1e3}contains(e){return e>=this._start&&e<=this._end}overlaps(e){return this._start<=e._end&&e._start<=this._end}equals(e){return this._start.getTime()===e._start.getTime()&&this._end.getTime()===e._end.getTime()}static create(e,u){return new s(e,u)}static lastNDays(e){let u=new Date,a=new Date(u.getTime()-e*24*60*60*1e3);return new s(a,u)}},Xe=class s{constructor(e,u,a,t){this._major=e;this._minor=u;this._patch=a;this._prerelease=t}get major(){return this._major}get minor(){return this._minor}get patch(){return this._patch}get prerelease(){return this._prerelease}toString(){let e=`${this._major}.${this._minor}.${this._patch}`;return this._prerelease?`${e}-${this._prerelease}`:e}isNewerThan(e){return this._major!==e._major?this._major>e._major:this._minor!==e._minor?this._minor>e._minor:this._patch>e._patch}equals(e){return this._major===e._major&&this._minor===e._minor&&this._patch===e._patch&&this._prerelease===e._prerelease}static create(e,u,a,t){return new s(e,u,a,t)}static parse(e){let u=e.match(/^(\d+)\.(\d+)\.(\d+)(?:-(.+))?$/);if(!u)throw new Error(`Invalid version format: ${e}`);return new s(parseInt(u[1]),parseInt(u[2]),parseInt(u[3]),u[4])}};var oi={defaultRuleSets:["owasp-top-10","cwe-sans-25"],maxConcurrentScans:4,timeout:3e5,enableFalsePositiveDetection:!0,dastMaxDepth:5,dastActiveScanning:!1,enableLLMAnalysis:!0,llmModelTier:4,enableSemgrep:!0};N();var gl=[{id:"sqli-string-concat",pattern:/query\s*\(\s*['"`].*\+.*['"`]\s*\)/g,category:"injection",severity:"critical",title:"SQL Injection via String Concatenation",description:"SQL query constructed using string concatenation with potentially untrusted input",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Use parameterized queries or prepared statements instead of string concatenation",fixExample:'db.query("SELECT * FROM users WHERE id = $1", [userId])'},{id:"sqli-template-literal",pattern:/execute\s*\(\s*`[^`]*\$\{[^}]+\}[^`]*`\s*\)/g,category:"injection",severity:"critical",title:"SQL Injection via Template Literal",description:"SQL query constructed using template literals with embedded expressions",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Use parameterized queries instead of template literals for SQL",fixExample:'db.execute("DELETE FROM users WHERE id = ?", [userId])'},{id:"sqli-raw-query",pattern:/\.raw\s*\(\s*['"`].*\+|\.raw\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"high",title:"SQL Injection via Raw Query",description:"Raw SQL query with potential user input interpolation",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Avoid raw queries with user input; use ORM methods or parameterized queries"},{id:"sqli-exec",pattern:/exec(?:ute)?(?:Sql|Query)?\s*\([^)]*\+[^)]*\)/gi,category:"injection",severity:"critical",title:"SQL Injection via Dynamic Execution",description:"Dynamic SQL execution with string concatenation detected",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Never concatenate user input into SQL queries"}],Cl=[{id:"xss-innerhtml",pattern:/\.innerHTML\s*=\s*[^'"`;\n]+/g,category:"xss",severity:"high",title:"XSS via innerHTML Assignment",description:"Direct innerHTML assignment with potentially unsanitized content",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Use textContent for text, or sanitize HTML with DOMPurify before innerHTML assignment",fixExample:"element.textContent = userInput; // or DOMPurify.sanitize(userInput)"},{id:"xss-document-write",pattern:/document\.write\s*\([^)]+\)/g,category:"xss",severity:"high",title:"XSS via document.write",description:"document.write() can execute scripts from untrusted data",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Avoid document.write(); use DOM manipulation methods instead",fixExample:"document.body.appendChild(document.createTextNode(text))"},{id:"xss-dangerously-set",pattern:/dangerouslySetInnerHTML\s*=\s*\{/g,category:"xss",severity:"medium",title:"React dangerouslySetInnerHTML Usage",description:"dangerouslySetInnerHTML bypasses React XSS protections",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Sanitize HTML content with DOMPurify before using dangerouslySetInnerHTML",fixExample:"dangerouslySetInnerHTML={{ __html: DOMPurify.sanitize(content) }}"},{id:"xss-eval",pattern:/eval\s*\([^)]+\)/g,category:"xss",severity:"critical",title:"Code Injection via eval()",description:"eval() executes arbitrary code and is a major security risk",owaspId:"A03:2021",cweId:"CWE-95",remediation:"Never use eval(); use JSON.parse() for JSON data or safer alternatives",fixExample:"JSON.parse(jsonString) // instead of eval(jsonString)"},{id:"xss-new-function",pattern:/new\s+Function\s*\([^)]+\)/g,category:"xss",severity:"critical",title:"Code Injection via Function Constructor",description:"Function constructor can execute arbitrary code like eval()",owaspId:"A03:2021",cweId:"CWE-95",remediation:"Avoid the Function constructor; use predefined functions instead"},{id:"xss-outerhtml",pattern:/\.outerHTML\s*=\s*[^'"`;\n]+/g,category:"xss",severity:"high",title:"XSS via outerHTML Assignment",description:"Direct outerHTML assignment with potentially unsanitized content",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Sanitize content before outerHTML assignment"}],Al=[{id:"secret-aws-access-key",pattern:/['"`]AKIA[0-9A-Z]{16}['"`]/g,category:"sensitive-data",severity:"critical",title:"AWS Access Key Detected",description:"Hardcoded AWS Access Key ID found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or AWS Secrets Manager for credentials",fixExample:"const accessKey = process.env.AWS_ACCESS_KEY_ID"},{id:"secret-aws-secret-key",pattern:/['"`][A-Za-z0-9/+=]{40}['"`]/g,category:"sensitive-data",severity:"critical",title:"Potential AWS Secret Key Detected",description:"Potential hardcoded AWS Secret Access Key found",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Store secrets in environment variables or secrets manager"},{id:"secret-openai-key",pattern:/['"`]sk-[a-zA-Z0-9]{48,}['"`]/g,category:"sensitive-data",severity:"critical",title:"OpenAI API Key Detected",description:"Hardcoded OpenAI API key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for API keys",fixExample:"const apiKey = process.env.OPENAI_API_KEY"},{id:"secret-generic-password",pattern:/password\s*[:=]\s*['"`][^'"`]{4,}['"`]/gi,category:"sensitive-data",severity:"high",title:"Hardcoded Password Detected",description:"Hardcoded password found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Never hardcode passwords; use environment variables or secrets manager",fixExample:"const password = process.env.DB_PASSWORD"},{id:"secret-api-key",pattern:/api[_-]?key\s*[:=]\s*['"`][a-zA-Z0-9_\-]{16,}['"`]/gi,category:"sensitive-data",severity:"high",title:"Hardcoded API Key Detected",description:"Hardcoded API key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for API keys",fixExample:"const apiKey = process.env.API_KEY"},{id:"secret-jwt",pattern:/['"`]eyJ[A-Za-z0-9_-]+\.eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+['"`]/g,category:"sensitive-data",severity:"high",title:"Hardcoded JWT Token Detected",description:"Hardcoded JWT token found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Generate JWT tokens dynamically; never hardcode them"},{id:"secret-private-key",pattern:/-----BEGIN\s+(RSA|EC|OPENSSH|DSA)?\s*PRIVATE\s+KEY-----/g,category:"sensitive-data",severity:"critical",title:"Private Key Detected",description:"Private key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Store private keys in secure key management systems, not in code"},{id:"secret-github-token",pattern:/['"`]ghp_[a-zA-Z0-9]{36}['"`]|['"`]github_pat_[a-zA-Z0-9]{22}_[a-zA-Z0-9]{59}['"`]/g,category:"sensitive-data",severity:"critical",title:"GitHub Token Detected",description:"Hardcoded GitHub personal access token found",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or GitHub Actions secrets"},{id:"secret-slack-token",pattern:/['"`]xox[baprs]-[0-9]{10,13}-[0-9]{10,13}[a-zA-Z0-9-]*['"`]/g,category:"sensitive-data",severity:"high",title:"Slack Token Detected",description:"Hardcoded Slack token found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for Slack tokens"},{id:"secret-generic-assignment",pattern:/\b\w*(?:SECRET|secret)(?:_KEY|_key|Key)?\s*[:=]\s*['"`][^'"`]{4,}['"`]/g,category:"sensitive-data",severity:"high",title:"Generic Secret Assignment Detected",description:"Hardcoded secret assignment (SECRET_KEY, JWT_SECRET, APP_SECRET, etc.) found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or a secrets manager instead of hardcoding secrets",fixExample:"const secretKey = process.env.SECRET_KEY"}],yl=[{id:"path-traversal-readfile",pattern:/(?:readFile|readFileSync)\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via File Read",description:"File read operation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate and sanitize file paths; use path.resolve() and check against base directory",fixExample:"const safePath = path.resolve(baseDir, path.basename(userInput))"},{id:"path-traversal-pattern",pattern:/\.\.\/.*\.\.\//g,category:"access-control",severity:"medium",title:"Path Traversal Pattern Detected",description:"Suspicious path traversal pattern (../) found in code",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate paths and ensure they resolve within expected directories"},{id:"path-traversal-writefile",pattern:/(?:writeFile|writeFileSync)\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via File Write",description:"File write operation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate file paths before writing; ensure path is within allowed directory"},{id:"path-traversal-createstream",pattern:/createReadStream\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via Stream",description:"Stream creation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate and sanitize file paths before creating streams"}],xl=[{id:"cmd-injection-exec",pattern:/exec\s*\([^)]*\+[^)]*\)|exec\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"critical",title:"Command Injection via exec()",description:"Shell command execution with unsanitized input",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Use execFile() with argument array instead of exec() with string concatenation",fixExample:'execFile("command", [arg1, arg2], callback)'},{id:"cmd-injection-spawn",pattern:/spawn\s*\(\s*[^,]+\+|spawn\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"critical",title:"Command Injection via spawn()",description:"Process spawn with potentially unsanitized command",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Use spawn with command and args array; validate inputs",fixExample:'spawn("command", [sanitizedArg1, sanitizedArg2])'},{id:"cmd-injection-shell-true",pattern:/spawn\s*\([^)]+,\s*\{[^}]*shell\s*:\s*true/g,category:"injection",severity:"high",title:"Dangerous Shell Option in spawn()",description:"spawn() with shell: true can enable command injection",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Avoid shell: true option; use direct command execution"}],fl=[{id:"misc-cors-wildcard",pattern:/cors\s*\(\s*\{[^}]*origin\s*:\s*['"]\*['"]/gi,category:"security-misconfiguration",severity:"medium",title:"Permissive CORS Configuration",description:"CORS allows all origins (*) which may expose sensitive data",owaspId:"A05:2021",cweId:"CWE-942",remediation:"Restrict CORS to specific trusted origins",fixExample:'cors({ origin: ["https://trusted-domain.com"] })'},{id:"misc-debug-enabled",pattern:/debug\s*[:=]\s*true|DEBUG\s*[:=]\s*['"]?true['"]?/gi,category:"security-misconfiguration",severity:"low",title:"Debug Mode Enabled",description:"Debug mode may expose sensitive information in production",owaspId:"A05:2021",cweId:"CWE-489",remediation:"Disable debug mode in production environments"},{id:"misc-ssl-disabled",pattern:/rejectUnauthorized\s*:\s*false|NODE_TLS_REJECT_UNAUTHORIZED\s*=\s*['"]?0['"]?/g,category:"security-misconfiguration",severity:"high",title:"TLS Certificate Validation Disabled",description:"Disabling TLS certificate validation exposes to MITM attacks",owaspId:"A05:2021",cweId:"CWE-295",remediation:"Always enable TLS certificate validation in production"},{id:"misc-helmet-missing",pattern:/app\.use\s*\(\s*express\s*\(\s*\)\s*\)/g,category:"security-misconfiguration",severity:"low",title:"Express App Without Security Headers",description:"Express app initialized without helmet or security headers",owaspId:"A05:2021",cweId:"CWE-693",remediation:"Use helmet middleware for security headers",fixExample:"app.use(helmet())"}],vl=[{id:"deser-yaml-load",pattern:/yaml\.load\s*\([^)]+\)/g,category:"insecure-deserialization",severity:"high",title:"Unsafe YAML Deserialization",description:"yaml.load() can execute arbitrary code from untrusted YAML",owaspId:"A08:2021",cweId:"CWE-502",remediation:"Use yaml.safeLoad() or schema-constrained loading",fixExample:"yaml.load(content, { schema: yaml.SAFE_SCHEMA })"},{id:"deser-serialize-js",pattern:/serialize\s*\([^)]+\)|unserialize\s*\([^)]+\)/g,category:"insecure-deserialization",severity:"high",title:"Unsafe Serialization Function",description:"Node serialize/unserialize functions can execute arbitrary code",owaspId:"A08:2021",cweId:"CWE-502",remediation:"Use JSON.parse/stringify for serialization"}],Fl=[{id:"auth-weak-jwt-secret",pattern:/jwt\.sign\s*\([^)]+,\s*['"][a-zA-Z0-9]{1,16}['"]/g,category:"broken-auth",severity:"high",title:"Weak JWT Secret",description:"JWT signed with a weak or short secret key",owaspId:"A07:2021",cweId:"CWE-327",remediation:"Use a strong, randomly generated secret of at least 256 bits"},{id:"auth-no-algorithm",pattern:/jwt\.verify\s*\([^)]+\)\s*(?!.*algorithm)/g,category:"broken-auth",severity:"medium",title:"JWT Without Algorithm Specification",description:"JWT verification without explicit algorithm can be exploited",owaspId:"A07:2021",cweId:"CWE-347",remediation:"Always specify the expected algorithm in JWT verification",fixExample:'jwt.verify(token, secret, { algorithms: ["HS256"] })'}],si=[...gl,...Cl,...Al,...yl,...xl,...fl,...vl,...Fl],Ya=[{id:"owasp-top-10",name:"OWASP Top 10",description:"OWASP Top 10 most critical security risks",ruleCount:45,categories:["injection","broken-auth","sensitive-data","xxe","access-control","security-misconfiguration","xss","insecure-deserialization","vulnerable-components","insufficient-logging"]},{id:"cwe-sans-25",name:"CWE/SANS Top 25",description:"Most dangerous software errors",ruleCount:38,categories:["injection","xss","access-control","sensitive-data","broken-auth"]},{id:"nodejs-security",name:"Node.js Security",description:"Node.js specific security rules",ruleCount:25,categories:["injection","xss","sensitive-data","security-misconfiguration"]},{id:"typescript-security",name:"TypeScript Security",description:"TypeScript specific security rules",ruleCount:20,categories:["injection","xss","sensitive-data"]}];S();J();S();J();import{execFile as uCu}from"child_process";import{promisify as eCu}from"util";import*as rE from"path";var bl=eCu(uCu);async function Xa(){try{return await bl("semgrep",["--version"],{timeout:5e3}),!0}catch{return!1}}async function aE(){try{let{stdout:s}=await bl("semgrep",["--version"],{timeout:5e3});return s.trim()}catch{return null}}async function aCu(s){let e={target:s.target||".",config:s.config||"auto",exclude:s.exclude||["node_modules",".git","dist","build","coverage"],maxFileSize:s.maxFileSize||5e6,timeout:s.timeout||300,verbose:s.verbose||!1};if(!await Xa())return{success:!1,findings:[],errors:["Semgrep is not installed. Install with: pip install semgrep"]};try{let a=["scan",`--config=${e.config}`,"--json",e.verbose?"--verbose":"--quiet",`--max-target-bytes=${e.maxFileSize}`];for(let o of e.exclude)a.push(`--exclude=${o}`);a.push(e.target);let t=(e.timeout??300)*1e3,{stdout:r,stderr:i}=await bl("semgrep",a,{timeout:t,maxBuffer:50*1024*1024,cwd:rE.isAbsolute(e.target)?void 0:process.cwd()}),n=tE(r);return i&&e.verbose&&n.errors.push(i),n.version=await aE()||void 0,n}catch(a){let t=a;if(t.stdout)try{let r=tE(t.stdout);return r.version=await aE()||void 0,r}catch{}return{success:!1,findings:[],errors:[t.message??String(a)]}}}function tE(s){try{let e=T(s),u=e.results||e.findings||[],a=e.errors?.map(t=>t.message||String(t))||[];return{success:!0,findings:u.map(t=>({check_id:t.check_id||t.rule_id||"unknown",path:t.path,start:{line:t.start?.line||1,col:t.start?.col||1},end:{line:t.end?.line||t.start?.line||1,col:t.end?.col||1},extra:{message:t.extra?.message||t.message||"Security issue detected",severity:t.extra?.severity||t.severity||"WARNING",lines:t.extra?.lines||"",metadata:{cwe:t.extra?.metadata?.cwe||t.metadata?.cwe,owasp:t.extra?.metadata?.owasp||t.metadata?.owasp,category:t.extra?.metadata?.category||t.metadata?.category,description:t.extra?.metadata?.description||t.metadata?.description,fix:t.extra?.metadata?.fix||t.extra?.fix,references:t.extra?.metadata?.references||t.metadata?.references,confidence:t.extra?.metadata?.confidence||t.metadata?.confidence}}})),errors:a}}catch(e){return{success:!1,findings:[],errors:[`Failed to parse semgrep output: ${k(e)}`]}}}async function li(s,e,u){let a={"owasp-top-10":"p/owasp-top-ten","cwe-sans-25":"p/cwe-top-25","nodejs-security":"p/nodejs","typescript-security":"p/typescript","javascript-security":"p/javascript","react-security":"p/react","express-security":"p/express",secrets:"p/secrets","sql-injection":"p/sql-injection",xss:"p/xss","command-injection":"p/command-injection","path-traversal":"p/path-traversal"},t=e.map(r=>a[r]||`p/${r}`).join(",");return aCu({...u,target:s,config:t||"auto"})}function tCu(s){return{ERROR:"high",WARNING:"medium",INFO:"low"}[s]||"medium"}function ci(s){return s.map(e=>({id:e.check_id,title:e.check_id.split(".").pop()||e.check_id,description:e.extra.message,severity:tCu(e.extra.severity),file:e.path,line:e.start.line,column:e.start.col,snippet:e.extra.lines,cweId:e.extra.metadata?.cwe?.[0],owaspCategory:e.extra.metadata?.owasp?.[0],remediation:e.extra.metadata?.fix||"Review and fix the identified security issue",references:e.extra.metadata?.references||[]}))}var rCu=B.create("security-compliance/sast-scanner"),z0=class{config;memory;llmRouter;activeScans;constructor(e,u,a,t){this.config=e,this.memory=u,this.llmRouter=a,this.activeScans=t||new Map}async scanFiles(e){return this.scanWithRules(e,this.config.defaultRuleSets)}async scanWithRules(e,u){let a=A();try{if(e.length===0)return m(new Error("No files provided for scanning"));this.activeScans.set(a,"running");let t=Date.now(),r=Ya.filter(h=>u.includes(h.id));if(r.length===0)return m(new Error(`No valid rule sets found: ${u.join(", ")}`));let[i,n]=await Promise.all([this.runPatternScanning(e,r),this.runSemgrepScanning(e,u)]),o=this.mergeVulnerabilities(i.vulnerabilities,n),l=i.linesScanned,c=Date.now()-t,E=this.calculateSummary(o,e.length,c),d=r.reduce((h,C)=>h+C.ruleCount,0),D={filesScanned:e.length,linesScanned:l,rulesApplied:d+(n.length>0?n.length:0)};return await this.storeScanResults(a,"sast",o,E),this.activeScans.set(a,"completed"),p({scanId:a,vulnerabilities:o,summary:E,coverage:D})}catch(t){return this.activeScans.set(a,"failed"),m(g(t))}}async runPatternScanning(e,u){let a=[],t=0;for(let r of e){let i=await this.analyzeFile(r,u);a.push(...i.vulnerabilities),t+=i.linesScanned}return{vulnerabilities:a,linesScanned:t}}async runSemgrepScanning(e,u){if(!this.config.enableSemgrep)return[];try{if(!await Xa())return[];let t=this.resolveTargetDirectory(e),r=await li(t,u);return!r.success||r.findings.length===0?[]:ci(r.findings).map(n=>({id:A(),cveId:void 0,title:n.title,description:`[semgrep] ${n.description}`,severity:n.severity,category:this.mapSemgrepCategory(n.owaspCategory),location:{file:n.file,line:n.line,column:n.column,snippet:n.snippet},remediation:{description:n.remediation,estimatedEffort:"moderate",automatable:!1},references:n.references}))}catch{return[]}}resolveTargetDirectory(e){if(e.length===0)return".";if(e.length===1)return e[0].directory||".";let u=e.map(n=>n.directory||"."),a=u[0],t=a.length;for(let n=1;n<u.length;n++){let o=u[n],l=Math.min(t,o.length),c=0;for(;c<l&&a[c]===o[c];)c++;t=c}let r=a.substring(0,t),i=r.lastIndexOf("/");return i>0?r.substring(0,i):r||"."}mapSemgrepCategory(e){if(!e)return"injection";let u={A01:"access-control",A02:"sensitive-data",A03:"injection",A04:"insecure-deserialization",A05:"security-misconfiguration",A06:"vulnerable-components",A07:"broken-auth",A08:"insecure-deserialization",A09:"insufficient-logging",A10:"xxe"};for(let[a,t]of Object.entries(u))if(e.startsWith(a))return t;return"injection"}mergeVulnerabilities(e,u){if(u.length===0)return e;if(e.length===0)return u;let a=new Set(e.map(r=>`${r.location.file}:${r.location.line??0}:${r.category}`)),t=u.filter(r=>!a.has(`${r.location.file}:${r.location.line??0}:${r.category}`));return[...e,...t]}async getAvailableRuleSets(){let e=await this.memory.get("security:custom-rule-sets");return[...Ya,...e||[]]}async checkFalsePositive(e){try{if(!this.config.enableFalsePositiveDetection)return p({isFalsePositive:!1,confidence:0,reason:"False positive detection is disabled"});let u=await this.analyzeFalsePositive(e);return await this.memory.set(`security:fp-check:${e.id}`,{vulnerability:e,analysis:u},{namespace:"security-compliance",ttl:86400*30}),p(u)}catch(u){return m(g(u))}}async analyzeFile(e,u){let a=[],t=e.value,r=e.extension,i,n;try{i=await(await import("fs/promises")).readFile(t,"utf-8"),n=i.split(`
2899
+ `).filter(o=>o.startsWith("Test")||o.startsWith("Example")||o.startsWith("Benchmark")),t=a.filter(o=>o.startsWith("Test")).length,r=a.filter(o=>o.startsWith("Test")&&!o.includes("Integration")&&!o.includes("E2E")).length,i=a.filter(o=>o.includes("Integration")).length,n=a.filter(o=>o.includes("E2E")).length;return{total:t,unit:r,integration:i,e2e:n,source:"go"}}catch{return{total:0,unit:0,integration:0,e2e:0,source:"go"}}}function qa(s,e){let u=0,a=0,t=0,r=0;function i(n){if(!Au(n))return;let o=ngu(n,{withFileTypes:!0});for(let l of o){let c=vu(n,l.name);if(l.isDirectory()){if(e.excludeDirs.includes(l.name))continue;i(c)}else if(l.isFile()&&mgu(l.name)){let E=ogu(l.name).toLowerCase(),d=0;[".ts",".tsx",".js",".jsx",".mjs"].includes(E)?d=V1(c):E===".py"?d=Dgu(c):E===".rs"?d=hgu(c):E===".go"&&(d=pgu(c)),u+=d;let D=c.toLowerCase();D.includes("e2e")||D.includes("end-to-end")?r+=d:D.includes("integration")?t+=d:a+=d}}}return i(s),{total:u,unit:a,integration:t,e2e:r,source:"fallback"}}function mgu(s){let e=s.toLowerCase();return e.includes(".test.")||e.includes(".spec.")||e.includes("_test.")||e.startsWith("test_")||e.endsWith("_test.ts")||e.endsWith("_test.js")||e.endsWith("_test.py")||e.endsWith("_test.go")||e.endsWith("_test.rs")}function V1(s){try{let e=Ua(s,"utf-8"),u=e.match(/\bit\s*\(/g)||[],a=e.match(/\btest\s*\(/g)||[];return u.length+a.length}catch{return 0}}function Dgu(s){try{let e=Ua(s,"utf-8"),u=e.match(/\bdef\s+test_\w+\s*\(/g)||[],a=e.match(/\basync\s+def\s+test_\w+\s*\(/g)||[];return u.length+a.length}catch{return 0}}function hgu(s){try{let e=Ua(s,"utf-8"),u=e.match(/#\[test\]/g)||[],a=e.match(/#\[tokio::test\]/g)||[],t=e.match(/#\[async_std::test\]/g)||[];return u.length+a.length+t.length}catch{return 0}}function pgu(s){try{return(Ua(s,"utf-8").match(/\bfunc\s+Test\w+\s*\(/g)||[]).length}catch{return 0}}function ti(s,e,u){let a=s,t=0,r=0;return(Au(vu(u,"tests","integration"))||Au(vu(u,"test","integration"))||Au(vu(u,"__tests__","integration")))&&(t=Math.floor(s*.2),a-=t),(Au(vu(u,"tests","e2e"))||Au(vu(u,"test","e2e"))||Au(vu(u,"e2e"))||Au(vu(u,"cypress")))&&(r=Math.floor(s*.1),a-=r),{total:s,unit:Math.max(0,a),integration:t,e2e:r,source:e}}var ml=class{config;cache=new Map;cacheHits=0;cacheMisses=0;constructor(e={}){this.config={...Ze,...e}}async collectAll(e){let u=`all:${e}`;if(this.config.enableCache){let c=this.getFromCache(u);if(c)return c}let[a,t,r]=await Promise.all([this.countLOC(e),this.countTests(e),this.countPatterns(e,this.detectLanguage(e))]),i=[];a.source!=="fallback"&&i.push(a.source),t.source!=="fallback"&&i.push(t.source);let n=a.source==="fallback"?"approximate":"accurate",o=t.source==="fallback"?"approximate":"accurate",l={loc:a,tests:t,patterns:r,collectedAt:new Date,toolsUsed:i,accuracy:{loc:n,tests:o,overall:n==="accurate"&&o==="accurate"?"accurate":"approximate"}};return this.config.enableCache&&this.setInCache(u,l),l}async countLOC(e){let u=`loc:${e}`;if(this.config.enableCache){let t=this.getFromCache(u);if(t)return t}let a=await sl(e,this.config);return this.config.enableCache&&this.setInCache(u,a),a}async countTests(e){let u=`tests:${e}`;if(this.config.enableCache){let t=this.getFromCache(u);if(t)return t}let a=await El(e,this.config);return this.config.enableCache&&this.setInCache(u,a),a}async countPatterns(e,u){let a=`patterns:${e}:${u}`;if(this.config.enableCache){let r=this.getFromCache(a);if(r)return r}let t=this.countPatternsInternal(e,u);return this.config.enableCache&&this.setInCache(a,t),t}checkTools(){let e=ll(),u=dl(process.cwd());return[...e,...u]}clearCache(){this.cache.clear(),this.cacheHits=0,this.cacheMisses=0}getCacheStats(){return{hits:this.cacheHits,misses:this.cacheMisses,size:this.cache.size}}getFromCache(e){let u=this.cache.get(e);return u&&Date.now()-u.timestamp<this.config.cacheTTL?(this.cacheHits++,u.data):(this.cacheMisses++,null)}setInCache(e,u){this.cache.set(e,{data:u,timestamp:Date.now()})}detectLanguage(e){return Qe(Ye(e,"Cargo.toml"))?"rust":Qe(Ye(e,"go.mod"))?"go":Qe(Ye(e,"pyproject.toml"))||Qe(Ye(e,"requirements.txt"))?"python":Qe(Ye(e,"package.json"))?Qe(Ye(e,"tsconfig.json"))?"typescript":"javascript":"unknown"}countPatternsInternal(e,u){let a={},t=0,r=0,i=0,n=0,o=this.getPatternsForLanguage(u);function l(c){if(!Qe(c))return;let E=Cgu(c,{withFileTypes:!0});for(let d of E){let D=Ye(c,d.name);if(d.isDirectory()){if(["node_modules","dist","coverage","build",".git","vendor","target"].includes(d.name))continue;l(D)}else if(d.isFile()){let h=Agu(d.name).toLowerCase();if(ygu(h,u)){let C=xgu(D,o);(C.unwraps>0||C.unsafeBlocks>0||C.todoComments>0||C.consoleStatements>0)&&(a[D]=C,t+=C.unwraps,r+=C.unsafeBlocks,i+=C.todoComments,n+=C.consoleStatements)}}}}return l(e),{unwraps:t,unsafeBlocks:r,todoComments:i,consoleStatements:n,byFile:a}}getPatternsForLanguage(e){switch(e){case"rust":return{unwrap:/\.unwrap\s*\(/g,unsafe:/\bunsafe\s*\{/g,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(println!|print!|eprintln!|eprint!|dbg!)\s*\(/g};case"python":return{unwrap:null,unsafe:null,todo:/#\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(print)\s*\(/g};case"go":return{unwrap:null,unsafe:/\bunsafe\./g,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\b(fmt\.Print|fmt\.Printf|fmt\.Println|log\.Print|log\.Printf|log\.Println)\s*\(/g};default:return{unwrap:null,unsafe:null,todo:/\/\/\s*(TODO|FIXME|HACK|XXX)[\s:]/gi,console:/\bconsole\.(log|debug|info|warn|error)\s*\(/g}}}};function ygu(s,e){switch(e){case"rust":return s===".rs";case"python":return[".py",".pyw"].includes(s);case"go":return s===".go";case"typescript":return[".ts",".tsx"].includes(s);case"javascript":return[".js",".jsx",".mjs",".cjs"].includes(s);default:return[".ts",".tsx",".js",".jsx",".py",".rs",".go"].includes(s)}}function xgu(s,e){try{let u=ggu(s,"utf-8");return{unwraps:e.unwrap?(u.match(e.unwrap)||[]).length:0,unsafeBlocks:e.unsafe?(u.match(e.unsafe)||[]).length:0,todoComments:(u.match(e.todo)||[]).length,consoleStatements:(u.match(e.console)||[]).length}}catch{return{unwraps:0,unsafeBlocks:0,todoComments:0,consoleStatements:0}}}function O1(s={}){return new ml(s)}N();S();cu();c0();S();c0();S();c0();S();c0();S();cu();c0();S();var $Hu=300*1e3;Qu();Qu();N();Qu();var nGu=B.create("temporal-compression");S();N();var cGu=B.create("ruvector-server-client");n3();import{Buffer as zgu}from"buffer";var gGu=zgu.from("COGCNTNR","ascii");Qu();Qu();var Ngu={capacity:1e4,minCoherenceThreshold:.3,highTierThreshold:.8,mediumTierThreshold:.5,highTierWeight:3,mediumTierWeight:1.5,lowTierWeight:1},Dl=class{config;cusumDetector;buffer;totalSeen=0;totalAdmitted=0;totalRejected=0;totalEvicted=0;totalSampled=0;constructor(e){this.config={...Ngu,...e},this.cusumDetector=new nn({threshold:this.config.cusumConfig?.threshold??5,slack:this.config.cusumConfig?.slack??.5,resetOnAlarm:!1,warmupSamples:20}),this.buffer=[]}admit(e,u,a){this.totalSeen++;let t=this.getEffectiveThreshold();if(a<t)return this.totalRejected++,!1;let r=this.classifyTier(a),i={id:e,data:u,coherenceScore:a,tier:r,admittedAt:Date.now(),replayCount:0};if(this.buffer.length<this.config.capacity)return this.buffer.push(i),this.totalAdmitted++,!0;let n=Math.floor(Math.random()*this.totalAdmitted),o=this.getTierWeight(r),l=Math.floor(n/o);if(l<this.config.capacity){let c=this.selectEvictionTarget(l);return this.buffer[c]=i,this.totalEvicted++,this.totalAdmitted++,!0}return this.totalRejected++,!1}sample(e,u){if(this.buffer.length===0)return[];let a=u!==void 0?this.buffer.filter(n=>n.coherenceScore>=u):this.buffer;if(a.length===0)return[];if(e>=a.length){let n=[...a];for(let o of n)o.replayCount++;return this.totalSampled+=n.length,n}let t=a.map(n=>this.getTierWeight(n.tier)),r=[],i=new Set;for(;r.length<e&&i.size<a.length;){let n=0;for(let c=0;c<a.length;c++)i.has(c)||(n+=t[c]);if(n<=0)break;let o=Math.random()*n,l=-1;for(let c=0;c<a.length;c++)if(!i.has(c)&&(o-=t[c],o<=0)){l=c;break}if(l===-1){for(let c=0;c<a.length;c++)if(!i.has(c)){l=c;break}}l>=0&&(i.add(l),a[l].replayCount++,r.push(a[l]))}return this.totalSampled+=r.length,r}size(){return this.buffer.length}getStats(){let e={high:0,medium:0,low:0};for(let u of this.buffer)e[u.tier]++;return{size:this.buffer.length,capacity:this.config.capacity,totalAdmitted:this.totalAdmitted,totalRejected:this.totalRejected,totalEvicted:this.totalEvicted,tierCounts:e,totalSampled:this.totalSampled}}getByTier(e){return this.buffer.filter(u=>u.tier===e)}clear(){this.buffer.length=0,this.totalSeen=0,this.totalAdmitted=0,this.totalRejected=0,this.totalEvicted=0,this.totalSampled=0,this.cusumDetector.reset()}getCusumState(e){return this.cusumDetector.getState(e)}observeCoherence(e,u){return this.cusumDetector.update(e,u)}classifyTier(e){return e>=this.config.highTierThreshold?"high":e>=this.config.mediumTierThreshold?"medium":"low"}getTierWeight(e){switch(e){case"high":return this.config.highTierWeight;case"medium":return this.config.mediumTierWeight;case"low":return this.config.lowTierWeight}}getEffectiveThreshold(){let e=["retrieve","write","learn","act"],u=!1;for(let a of e)if(this.cusumDetector.getState(a).driftDetected){u=!0;break}return u?Math.min(this.config.minCoherenceThreshold*1.5,.9):this.config.minCoherenceThreshold}selectEvictionTarget(e){let u=Math.min(10,this.buffer.length),a=Math.max(0,e-Math.floor(u/2)),t=Math.min(this.buffer.length,a+u),r=e,i=this.buffer[e].coherenceScore;for(let n=a;n<t;n++)this.buffer[n].coherenceScore<i&&(i=this.buffer[n].coherenceScore,r=n);return r}};cu();var M0=B.create("code-intelligence/gnn");async function _1(s,e,u){try{for(let a of u)try{let t=await e.readFile(a);if(t.success&&t.value){let i={vector:await hl(a,t.value),dimension:384,namespace:"code",text:t.value.slice(0,1e3),timestamp:Date.now(),quantization:"none",metadata:{path:a}};s.addEmbedding(i)}}catch(t){M0.error(`Failed to index ${a}:`,t instanceof Error?t:void 0)}M0.info(`Indexed ${u.length} code embeddings`)}catch(a){M0.error("Failed to index code embeddings:",a instanceof Error?a:void 0)}}async function hl(s,e){let u=[],a=s.split(".").pop(),t=ii(a||"");u.push(t%1e3/1e3),u.push(Math.min(1,e.length/1e4));let r=e.match(/function\s+\w+/g)||[],i=e.match(/class\s+\w+/g)||[];u.push(Math.min(1,(r.length+i.length)/50));let n=e.match(/import\s+.*from|require\s*\(/g)||[];u.push(Math.min(1,n.length/20));let o=e.match(/for\s*\(|while\s*\(/g)||[],l=e.match(/if\s*\(/g)||[];u.push(Math.min(1,(o.length+l.length)/30));let c=e.match(/\/\/.*|\/\*[\s\S]*?\*\//g)||[];u.push(Math.min(1,c.length/50));let E=ii(e.slice(0,500));for(let d=u.length;d<384;d++)u.push(E*(d+1)%1e4/1e4);return u.slice(0,384)}async function W1(s,e){try{let a={vector:await hl("query",e),dimension:384,namespace:"code",text:e,timestamp:Date.now(),quantization:"none"};return s.search(a,{limit:10,namespace:"code"}).map(r=>({file:r.metadata?.path??`file-${r.id}`,similarity:1-r.distance}))}catch(u){return M0.error("Failed to search with GNN:",u instanceof Error?u:void 0),[]}}async function $1(s,e,u){try{for(let a of u.changedFiles){let t=await e.readFile(a);if(t.success&&t.value){let i={vector:await hl(a,t.value),dimension:384,namespace:"code",text:t.value.slice(0,1e3),timestamp:Date.now(),quantization:"none",metadata:{path:a}},n=s.search(i,{limit:5,namespace:"code"});M0.info(`Found ${n.length} semantically similar files to ${a}`)}}}catch(a){M0.error("Failed to enhance impact analysis:",a instanceof Error?a:void 0)}}function q1(s,e){let u=new Map,a=new Map;for(let t of s)u.set(t.file,t.score),a.set(t.file,t);for(let t of e){let r=u.get(t.file);r!==void 0?u.set(t.file,(r+t.similarity)/2):(u.set(t.file,t.similarity*.8),a.set(t.file,{file:t.file,snippet:"",score:t.similarity*.8,highlights:[]}))}return Array.from(a.values()).map(t=>({...t,score:u.get(t.file)??t.score})).sort((t,r)=>r.score-t.score).slice(0,20)}function ii(s){let e=0;for(let u=0;u<s.length;u++)e=(e<<5)-e+s.charCodeAt(u),e=e|0;return Math.abs(e)}N();S();var qu=B.create("code-intelligence/hypergraph");async function J1(s,e,u){try{let a=await s.findUntestedFunctions();if(qu.info(`[CodeIntelligence] Found ${a.length} untested functions via hypergraph`),u){let t=L("code-intelligence.UntestedFunctionsFound","code-intelligence",{count:a.length,functions:a.slice(0,10).map(r=>({name:r.name,file:r.filePath,complexity:r.complexity}))});await e.publish(t)}return{success:!0,value:a}}catch(a){let t=g(a);return qu.error("Failed to find untested functions:"),m(t)}}async function U1(s,e,u,a){if(e.length===0)return{success:!0,value:[]};try{let t=await s.findImpactedTests(e);if(qu.info(`[CodeIntelligence] Found ${t.length} impacted tests for ${e.length} changed files via hypergraph`),a){let r=L("code-intelligence.ImpactedTestsFound","code-intelligence",{changedFiles:e,testCount:t.length,tests:t.slice(0,10).map(i=>({name:i.name,file:i.filePath}))});await u.publish(r)}return{success:!0,value:t}}catch(t){let r=g(t);return qu.error("Failed to find impacted tests:"),m(r)}}async function Z1(s,e,u,a){try{let t=await s.findCoverageGaps(e);if(qu.info(`[CodeIntelligence] Found ${t.length} coverage gaps (functions with <=${e}% coverage) via hypergraph`),a){let r=L("code-intelligence.CoverageGapsFound","code-intelligence",{maxCoverage:e,gapCount:t.length,gaps:t.slice(0,10).map(i=>({name:i.name,file:i.filePath,coverage:i.coverage,complexity:i.complexity}))});await u.publish(r)}return{success:!0,value:t}}catch(t){let r=g(t);return qu.error("Failed to find coverage gaps:"),m(r)}}async function Q1(s,e,u,a,t){try{qu.info(`[CodeIntelligence] Building hypergraph from ${e.files.length} indexed files`);let r=await s.buildFromIndexResult(e);if(qu.info(`[CodeIntelligence] Hypergraph built: ${r.nodesCreated} nodes created, ${r.nodesUpdated} nodes updated, ${r.edgesCreated} edges created (${r.durationMs}ms)`),await u.set("hypergraph:build:latest",{timestamp:new Date().toISOString(),...r},{namespace:"code-intelligence",persist:!0}),t){let i=L("code-intelligence.HypergraphBuilt","code-intelligence",{nodesCreated:r.nodesCreated,nodesUpdated:r.nodesUpdated,edgesCreated:r.edgesCreated,durationMs:r.durationMs,errorCount:r.errors.length});await a.publish(i)}return{success:!0,value:r}}catch(r){let i=g(r);return qu.error("Failed to build hypergraph:"),m(i)}}async function Y1(s,e,u){try{let a=await s.findImpactedTests(e.changedFiles),t=new Set([...u.impactedTests,...a.map(n=>n.filePath||n.name)]),r=u.riskLevel;if(a.length>u.impactedTests.length){let n=u.directImpact.length+u.transitiveImpact.length;n>10&&t.size>20?r="critical":n>5&&t.size>10&&(r="high")}let i=[...u.recommendations];return a.length>0&&i.push(`Hypergraph analysis found ${a.length} additional test(s) to run`),{...u,impactedTests:Array.from(t),riskLevel:r,recommendations:i}}catch(a){return qu.error("Failed to enhance impact with hypergraph:",a instanceof Error?a:void 0),u}}N();var R0=B.create("code-intelligence/consensus");async function X1(s,e,u,a){let t=O({id:A(),type:"code-pattern-detection",confidence:e,description:`Verify code pattern: ${s.name} (${s.type}) at ${s.location}`,payload:s,detectedBy:"code-intelligence-coordinator",severity:e>.9?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info(`Code pattern '${s.name}' verified by consensus`),!0):(R0.warn(`Code pattern '${s.name}' NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function uE(s,e,u,a){let t=O({id:A(),type:"impact-analysis",confidence:e,description:`Verify impact analysis: ${s.changedFiles.length} files, risk=${s.riskLevel}, ${s.impactedTests.length} tests`,payload:s,detectedBy:"code-intelligence-coordinator",severity:s.riskLevel==="critical"||s.riskLevel==="high"?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info(`Impact analysis verified by consensus (risk=${s.riskLevel})`),!0):(R0.warn(`Impact analysis NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function eE(s,e,u,a){let t=O({id:A(),type:"dependency-mapping",confidence:e,description:`Verify dependency: ${s.source} -> ${s.targets.length} targets (${s.type})`,payload:s,detectedBy:"code-intelligence-coordinator",severity:e>.85?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(R0.info("Dependency mapping verified by consensus"),!0):(R0.warn(`Dependency mapping NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}var Xgu={maxConcurrentWorkflows:5,defaultTimeout:12e4,publishEvents:!0,enableIncrementalIndex:!0,enableGNN:!0,enableSONA:!0,enableMetricCollector:!0,enableHypergraph:!0,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},su=B.create("code-intelligence"),Qa=class extends Y{constructor(u,a,t,r={}){let i={...Xgu,...r};super(u,"code-intelligence",i,{verifyFindingTypes:["code-pattern-detection","impact-analysis","dependency-mapping"]});this.memory=a;this.agentCoordinator=t;this.knowledgeGraph=new ze(a),this.semanticAnalyzer=new Ue(a),this.impactAnalyzer=new ea(a,this.knowledgeGraph),this.fileReader=new ju,this.productFactorsBridge=new ei(u,a,{publishEvents:this.config.publishEvents})}knowledgeGraph;semanticAnalyzer;impactAnalyzer;fileReader;gnnIndex;sonaEngine;rlInitialized=!1;metricCollector;hypergraph;hypergraphDb;productFactorsBridge;async onInitialize(){this.subscribeToEvents(),await this.loadWorkflowState(),(this.config.enableGNN||this.config.enableSONA)&&await this.initializeRLIntegrations(),this.config.enableMetricCollector&&(this.metricCollector=O1({enableCache:!0,cacheTTL:3e5}),su.info("MetricCollector initialized for real code metrics")),this.config.enableHypergraph&&await this.initializeHypergraph(),await this.productFactorsBridge.initialize()}async initializeHypergraph(){try{let{openDatabase:u}=await import("./safe-db-CCKCBZ5I.js"),a=await import("fs"),t=await import("path"),{findProjectRoot:r}=await import("./unified-memory-RBHCTAWW.js"),i=r(),n=this.config.hypergraphDbPath||t.join(i,".agentic-qe","memory.db"),o=t.dirname(n);a.existsSync(o)||a.mkdirSync(o,{recursive:!0}),this.hypergraphDb=u(n),this.hypergraph=await Ct({db:this.hypergraphDb,maxTraversalDepth:10,maxQueryResults:1e3,enableVectorSearch:this.config.enableGNN}),su.info(`Hypergraph Engine initialized at ${n}`)}catch(u){let a=u instanceof Error?u.message:String(u);if(su.warn(`Hypergraph Engine initialization failed (feature degraded): ${a}`),this.hypergraph=void 0,this.hypergraphDb=void 0,this.config.publishEvents){let t=L("code-intelligence.HypergraphDegraded","code-intelligence",{reason:a});this.eventBus.publish(t).catch(()=>{})}}}async initializeRLIntegrations(){try{if(this.config.enableGNN&&(rn(),this.gnnIndex=gt.getInstance("code-intelligence",{M:16,efConstruction:200,efSearch:50,dimension:384,metric:"cosine"}),this.gnnIndex.initializeIndex("code"),this.gnnIndex.initializeIndex("test")),this.config.enableSONA)try{this.sonaEngine=await gu({domain:"code-intelligence",loadOnInit:!0,autoSaveInterval:6e4,maxPatterns:1e4,minConfidence:.6}),su.info("PersistentSONAEngine initialized for code pattern learning")}catch(u){su.error("Failed to initialize PersistentSONAEngine:",u instanceof Error?u:void 0),this.sonaEngine=void 0}this.rlInitialized=!0}catch(u){throw su.error("Failed to initialize RL integrations:",u instanceof Error?u:void 0),u}}async onDispose(){if(await this.saveWorkflowState(),this.gnnIndex&&gt.closeInstance("code-intelligence"),this.sonaEngine)try{await this.sonaEngine.close(),this.sonaEngine=void 0}catch(u){su.error("Error closing SONA engine:",u instanceof Error?u:void 0)}if(this.hypergraphDb){try{this.hypergraphDb.close()}catch(u){su.error("Error closing hypergraph database:",u instanceof Error?u:void 0)}this.hypergraphDb=void 0}this.hypergraph=void 0,await this.productFactorsBridge.dispose()}getActiveWorkflows(){return super.getActiveWorkflows()}async index(u){let a=A();try{if(this.startWorkflow(a,"index"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&su.warn("Topology degraded, using conservative strategy"),this.minCutMixin.shouldPauseOperations())return m(new Error("Indexing paused: topology is in critical state"));if(!this.agentCoordinator.canSpawn())return m(new Error("Agent limit reached, cannot spawn indexing agents"));let t=await this.spawnIndexerAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value),this.updateWorkflowProgress(a,10);let r=await this.knowledgeGraph.index(u);if(r.success){if(this.updateWorkflowProgress(a,40),this.config.enableGNN&&this.gnnIndex&&u.paths.length>0&&await this.indexCodeEmbeddings(u.paths),this.updateWorkflowProgress(a,60),this.config.enableMetricCollector&&this.metricCollector&&u.paths.length>0){let i=this.getProjectRootFromPaths(u.paths);i&&await this.collectProjectMetrics(i)}if(this.updateWorkflowProgress(a,70),u.paths.length>0&&await this.indexForSemanticSearch(u.paths),this.updateWorkflowProgress(a,85),this.config.enableHypergraph&&this.hypergraph&&u.paths.length>0)try{let i=await this.buildCodeIndexResultFromPaths(u.paths);i.files.length>0&&(await this.hypergraph.buildFromIndexResult(i),su.info(`Hypergraph rebuilt from ${i.files.length} indexed files`))}catch(i){su.warn(`Hypergraph rebuild skipped: ${i instanceof Error?i.message:i}`)}this.updateWorkflowProgress(a,100),this.completeWorkflow(a),this.config.publishEvents&&await this.publishKnowledgeGraphUpdated(r.value)}else this.failWorkflow(a,r.error.message);return await this.agentCoordinator.stop(t.value),r}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async search(u){let a=A();try{this.startWorkflow(a,"search");let t=await this.spawnSearchAgent(a,u);if(t.success&&this.addAgentToWorkflow(a,t.value),this.config.enableSONA&&this.sonaEngine){let n=await this.adaptSearchPattern(u);n.success&&n.pattern&&su.info(`Adapted search pattern with ${n.similarity.toFixed(3)} similarity`)}let r=[];this.config.enableGNN&&this.gnnIndex&&(r=await this.searchCodeWithGNN(u));let i=await this.semanticAnalyzer.search(u);return i.success?(r.length>0&&(i.value.results=this.mergeSearchResults(i.value.results,r)),this.completeWorkflow(a),this.config.publishEvents&&await this.publishSemanticSearchCompleted(u,i.value)):this.failWorkflow(a,i.error.message),t.success&&await this.agentCoordinator.stop(t.value),i}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async analyzeImpact(u){let a=A();try{if(this.startWorkflow(a,"impact"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&su.warn("Topology degraded, using conservative impact analysis"),this.minCutMixin.shouldPauseOperations())return m(new Error("Impact analysis paused: topology is in critical state"));let t=await this.spawnImpactAnalyzerAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value),this.updateWorkflowProgress(a,20),this.config.enableGNN&&this.gnnIndex&&await this.enhanceImpactAnalysisWithGNN(u);let r=await this.impactAnalyzer.analyzeImpact(u);if(r.success){this.updateWorkflowProgress(a,80);let i=r.value;return this.config.enableHypergraph&&this.hypergraph&&(i=await this.enhanceImpactWithHypergraph(u,r.value)),this.updateWorkflowProgress(a,100),this.completeWorkflow(a),this.config.enableSONA&&this.sonaEngine&&await this.storeImpactPattern(u,i),this.config.publishEvents&&await this.publishImpactAnalysisCompleted(u,i),{success:!0,value:i}}else this.failWorkflow(a,r.error.message);return await this.agentCoordinator.stop(t.value),r}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async mapDependencies(u){let a=A();try{this.startWorkflow(a,"dependency");let t=await this.knowledgeGraph.mapDependencies(u);return t.success?this.completeWorkflow(a):this.failWorkflow(a,t.error.message),t}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async queryKG(u){let a=A();try{this.startWorkflow(a,"query");let t=await this.knowledgeGraph.query(u);return t.success?this.completeWorkflow(a):this.failWorkflow(a,t.error.message),t}catch(t){let r=g(t);return this.failWorkflow(a,r.message),m(r)}}async indexCodeEmbeddings(u){!this.gnnIndex||!this.rlInitialized||await _1(this.gnnIndex,this.fileReader,u)}async searchCodeWithGNN(u){return!this.gnnIndex||!this.rlInitialized?[]:W1(this.gnnIndex,u.query)}async enhanceImpactAnalysisWithGNN(u){!this.gnnIndex||!this.rlInitialized||await $1(this.gnnIndex,this.fileReader,u)}async adaptSearchPattern(u){if(!this.sonaEngine||!this.rlInitialized)return{success:!1,pattern:null,similarity:0};try{let a=Array.isArray(u.filters)?u.filters.find(i=>i.field==="language")?.value:void 0,t={id:`search-${u.type}`,features:[u.query.length,u.type==="semantic"?1:0,u.type==="exact"?1:0,a==="typescript"?1:0,a==="javascript"?1:0]},r=await this.sonaEngine.adaptPattern(t,"coverage-optimization","code-intelligence");return{success:r.success,pattern:r.pattern,similarity:r.similarity}}catch(a){return su.error("Failed to adapt search pattern:",a instanceof Error?a:void 0),{success:!1,pattern:null,similarity:0}}}async storeImpactPattern(u,a){if(!(!this.sonaEngine||!this.rlInitialized))try{let t={id:`impact-${u.changedFiles.join(",")}`,features:[u.changedFiles.length,u.depth||1,a.directImpact.length,a.transitiveImpact.length,a.impactedTests.length,a.riskLevel==="high"?1:a.riskLevel==="medium"?.5:0]},r={type:"analyze-impact",value:a.riskLevel},i={reward:a.riskLevel==="high"?.8:a.riskLevel==="medium"?.5:.3,success:a.impactedTests.length>0,quality:(a.directImpact.length+a.transitiveImpact.length)/100},n=this.sonaEngine.createPattern(t,r,i,"coverage-optimization","code-intelligence",{changedFiles:u.changedFiles,impactCount:a.directImpact.length+a.transitiveImpact.length,testImpactCount:a.impactedTests.length});su.info(`Stored impact pattern ${n.id}`)}catch(t){su.error("Failed to store impact pattern:",t instanceof Error?t:void 0)}}mergeSearchResults(u,a){return q1(u,a)}hashCode(u){return ii(u)}async spawnIndexerAgent(u,a){let t={name:`kg-indexer-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["indexing","ast-parsing","graph-building"],config:{workflowId:u,paths:a.paths,incremental:a.incremental}};return this.agentCoordinator.spawn(t)}async spawnSearchAgent(u,a){let t={name:`semantic-search-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["semantic-search","vector-similarity",a.type],config:{workflowId:u,query:a.query,type:a.type}};return this.agentCoordinator.spawn(t)}async spawnImpactAnalyzerAgent(u,a){let t={name:`impact-analyzer-${u.slice(0,8)}`,domain:"code-intelligence",type:"analyzer",capabilities:["impact-analysis","dependency-traversal","risk-assessment"],config:{workflowId:u,changedFiles:a.changedFiles,depth:a.depth}};return this.agentCoordinator.spawn(t)}async publishKnowledgeGraphUpdated(u){let a={nodes:u.nodesCreated,edges:u.edgesCreated,filesIndexed:u.filesIndexed,duration:u.duration},t=L(Ee.KnowledgeGraphUpdated,"code-intelligence",a);await this.eventBus.publish(t)}async publishImpactAnalysisCompleted(u,a){let t={analysisId:A(),changedFiles:u.changedFiles,impactedFiles:[...a.directImpact.map(i=>i.file),...a.transitiveImpact.map(i=>i.file)],impactedTests:a.impactedTests,riskLevel:a.riskLevel},r=L(Ee.ImpactAnalysisCompleted,"code-intelligence",t);await this.eventBus.publish(r)}async publishSemanticSearchCompleted(u,a){let t=L(Ee.SemanticSearchCompleted,"code-intelligence",{query:u.query,type:u.type,resultCount:a.total,searchTime:a.searchTime});await this.eventBus.publish(t)}subscribeToEvents(){this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("source-control.FilesChanged",this.handleFilesChanged.bind(this))}async handleTestRunCompleted(u){let a=u.payload;await this.memory.set(`code-intelligence:test-correlation:${a.runId}`,a,{namespace:"code-intelligence",ttl:86400})}async handleFilesChanged(u){if(!this.config.enableIncrementalIndex)return;let a=u.payload;a.files&&a.files.length>0&&await this.memory.set(`code-intelligence:pending-index:${Date.now()}`,{files:a.files,timestamp:new Date().toISOString()},{namespace:"code-intelligence",ttl:3600})}async indexForSemanticSearch(u){let a=u.slice(0,100);for(let t of a)try{let r=await this.fileReader.readFile(t);r.success&&r.value&&await this.semanticAnalyzer.indexCode(t,r.value)}catch{}}async loadWorkflowState(){let u=await this.memory.get("code-intelligence:coordinator:workflows");if(u)for(let a of u)a.status==="running"&&(a.status="failed",a.error="Coordinator restarted",a.completedAt=new Date),this.workflows.set(a.id,a)}async saveWorkflowState(){let u=Array.from(this.workflows.values());await this.memory.set("code-intelligence:coordinator:workflows",u,{namespace:"code-intelligence",persist:!0})}async generateC4Diagrams(u,a){let t=A();try{this.startWorkflow(t,"query");let r={projectPath:u,detectExternalSystems:a?.detectExternalSystems??!0,analyzeComponents:a?.analyzeComponents??!0,analyzeCoupling:a?.analyzeCoupling??!0,includeContext:a?.includeContext??!0,includeContainer:a?.includeContainer??!0,includeComponent:a?.includeComponent??!0,includeDependency:a?.includeDependency??!1,excludePatterns:a?.excludePatterns};this.updateWorkflowProgress(t,20);let i=await this.productFactorsBridge.requestC4Diagrams(r);return i.success?(this.updateWorkflowProgress(t,80),await this.storeC4DiagramsInMemory(u,i.value),this.updateWorkflowProgress(t,100),this.completeWorkflow(t),su.info(`[CodeIntelligenceCoordinator] C4 diagrams generated for ${u}: ${i.value.components.length} components, ${i.value.externalSystems.length} external systems`)):this.failWorkflow(t,i.error.message),i}catch(r){let i=g(r);return this.failWorkflow(t,i.message),m(i)}}getProductFactorsBridge(){return this.productFactorsBridge}async storeC4DiagramsInMemory(u,a){let t=`c4-diagrams:latest:${this.hashCode(u)}`;await this.memory.set(t,a,{namespace:"code-intelligence",persist:!0,ttl:36e5}),await this.memory.set(`c4-components:${this.hashCode(u)}`,a.components,{namespace:"code-intelligence",ttl:36e5}),await this.memory.set(`c4-external-systems:${this.hashCode(u)}`,a.externalSystems,{namespace:"code-intelligence",ttl:36e5})}async collectProjectMetrics(u){if(!this.config.enableMetricCollector||!this.metricCollector)return m(new Error("MetricCollector is not enabled"));try{su.info(`Collecting real metrics for ${u}`);let a=await this.metricCollector.collectAll(u),t=a.toolsUsed.length>0?a.toolsUsed.join(", "):a.loc.source==="node-native"?"node-native":"fallback";if(su.info(`[CodeIntelligence] Real metrics collected: ${a.loc.total} LOC, ${a.tests.total} tests, tools: ${t}`),a.loc.source==="node-native"&&su.info("[CodeIntelligence] Using Node.js-native line counter (no cloc/tokei needed)"),await this.storeProjectMetricsInMemory(u,a),this.config.publishEvents){let r=L("code-intelligence.MetricsCollected","code-intelligence",{projectPath:u,loc:a.loc.total,tests:a.tests.total,toolsUsed:a.toolsUsed});await this.eventBus.publish(r)}return{success:!0,value:a}}catch(a){let t=g(a);return su.error("Failed to collect metrics:"),m(t)}}async storeProjectMetricsInMemory(u,a){let t=`project-metrics:latest:${this.hashCode(u)}`;await this.memory.set(t,a,{namespace:"code-intelligence",persist:!0,ttl:3e5}),await this.memory.set(`loc-metrics:${this.hashCode(u)}`,a.loc,{namespace:"code-intelligence",ttl:3e5}),await this.memory.set(`test-metrics:${this.hashCode(u)}`,a.tests,{namespace:"code-intelligence",ttl:3e5})}getMetricCollector(){return this.metricCollector}getProjectRootFromPaths(u){if(u.length===0)return null;let a=u[0],t=a.split("/"),r="";for(let n of t){r=r?`${r}/${n}`:n;let o=["package.json","Cargo.toml","go.mod","pyproject.toml",".git"];for(let l of o)try{let c=`${r}/${l}`;if(Ji("fs").existsSync(c))return r}catch{}}let i=a.lastIndexOf("/");return i>0?a.substring(0,i):a}isHypergraphEnabled(){return this.config.enableHypergraph&&this.hypergraph!==void 0}async findUntestedFunctions(){return this.hypergraph?J1(this.hypergraph,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async findImpactedTestsFromHypergraph(u){return this.hypergraph?U1(this.hypergraph,u,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async findCoverageGapsFromHypergraph(u=50){return this.hypergraph?Z1(this.hypergraph,u,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}async buildHypergraphFromIndex(u){return this.hypergraph?Q1(this.hypergraph,u,this.memory,this.eventBus,this.config.publishEvents):m(new Error("Hypergraph is not enabled or not initialized"))}getHypergraph(){return this.hypergraph}async enhanceImpactWithHypergraph(u,a){return this.hypergraph?Y1(this.hypergraph,u,a):a}async buildCodeIndexResultFromPaths(u){let{extractCodeIndex:a}=await import("./code-index-extractor-II6IRWU6.js");return a(u)}async verifyCodePatternDetection(u,a){return X1(u,a,this.consensusMixin,this.domainName)}async verifyImpactAnalysis(u,a){return uE(u,a,this.consensusMixin,this.domainName)}async verifyDependencyMapping(u,a){return eE(u,a,this.consensusMixin,this.domainName)}};S();var ni=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;knowledgeGraph=null;semanticAnalyzer=null;impactAnalyzer=null;pluginConfig;get name(){return"code-intelligence"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{index:this.index.bind(this),search:this.search.bind(this),analyzeImpact:this.analyzeImpact.bind(this),mapDependencies:this.mapDependencies.bind(this),getDependencies:this.mapDependencies.bind(this),queryKG:this.queryKG.bind(this),getMetrics:this.getMetrics.bind(this),getCoordinator:()=>this.coordinator,getKnowledgeGraph:()=>this.knowledgeGraph,getSemanticAnalyzer:()=>this.semanticAnalyzer,getImpactAnalyzer:()=>this.impactAnalyzer}}getTaskHandlers(){return new Map([["index",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.paths;if(!a||a.length===0)return m(new Error("Invalid index payload: missing paths"));let t=u.language?[u.language]:u.languages;return this.coordinator.index({paths:a,languages:t})}],["search",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.query;return a?this.coordinator.search({query:a,type:u.type??"semantic",limit:u.limit}):m(new Error("Invalid search payload: missing query"))}],["analyze-impact",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.changedFiles;return!a||a.length===0?m(new Error("Invalid analyze-impact payload: missing changedFiles")):this.coordinator.analyzeImpact({changedFiles:a})}],["query-dependencies",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.file,r=u.files??(a?[a]:void 0);return!r||r.length===0?m(new Error("Invalid query-dependencies payload: missing file or files")):this.coordinator.mapDependencies({files:r,direction:u.direction??"both",depth:u.depth})}]])}async onInitialize(){this.knowledgeGraph=new ze(this.memory,this.pluginConfig.knowledgeGraph),this.semanticAnalyzer=new Ue(this.memory,this.pluginConfig.semanticAnalyzer),this.impactAnalyzer=new ea(this.memory,this.knowledgeGraph,this.pluginConfig.impactAnalyzer),this.coordinator=new Qa(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null,this.knowledgeGraph=null,this.semanticAnalyzer=null,this.impactAnalyzer=null}subscribeToEvents(){this.eventBus.subscribe("test-generation.TestGenerated",this.handleTestGenerated.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("defect-intelligence.DefectPredicted",this.handleDefectPredicted.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"test-generation.TestGenerated":await this.handleTestGenerated(u);break;case"coverage-analysis.CoverageGapDetected":await this.handleCoverageGap(u);break;case"defect-intelligence.DefectPredicted":await this.handleDefectPredicted(u);break;default:break}}async index(u){this.ensureInitialized();try{let a=await this.coordinator.index(u);return a.success?this.trackSuccessfulOperation("index",a.value):this.trackFailedOperation("index",a.error),a}catch(a){return this.handleError(a)}}async search(u){this.ensureInitialized();try{let a=await this.coordinator.search(u);return a.success?this.trackSuccessfulOperation("search",a.value):this.trackFailedOperation("search",a.error),a}catch(a){return this.handleError(a)}}async analyzeImpact(u){this.ensureInitialized();try{let a=await this.coordinator.analyzeImpact(u);return a.success?this.trackSuccessfulOperation("impact",a.value):this.trackFailedOperation("impact",a.error),a}catch(a){return this.handleError(a)}}async mapDependencies(u){this.ensureInitialized();try{let a=await this.coordinator.mapDependencies(u);return a.success?this.trackSuccessfulOperation("dependency",a.value):this.trackFailedOperation("dependency",a.error),a}catch(a){return this.handleError(a)}}async queryKG(u){this.ensureInitialized();try{let a=await this.coordinator.queryKG(u);return a.success?this.trackSuccessfulOperation("query",a.value):this.trackFailedOperation("query",a.error),a}catch(a){return this.handleError(a)}}async getMetrics(){this.ensureInitialized();try{let u=this.getHealth();return{success:!0,value:{indexed:u.agents.total,queries:u.agents.idle,impacts:u.agents.active}}}catch(u){return this.handleError(u)}}async handleTestGenerated(u){let a=u.payload;await this.memory.set(`code-intelligence:test-mapping:${a.testId}`,{testFile:a.testFile,sourceFile:a.sourceFile,generatedAt:new Date().toISOString()},{namespace:"code-intelligence",ttl:86400*30})}async handleCoverageGap(u){let a=u.payload;await this.memory.set(`code-intelligence:coverage-gap:${a.gapId}`,a,{namespace:"code-intelligence",ttl:86400*7})}async handleDefectPredicted(u){let a=u.payload;await this.memory.set(`code-intelligence:defect-prediction:${a.predictionId}`,a,{namespace:"code-intelligence",ttl:86400*7})}ensureInitialized(){if(!this._initialized)throw new Error("CodeIntelligencePlugin is not initialized");if(!this.coordinator||!this.knowledgeGraph||!this.semanticAnalyzer||!this.impactAnalyzer)throw new Error("CodeIntelligencePlugin services are not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),{success:!1,error:a}}trackSuccessfulOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,total:t.agents.total+1,idle:t.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,failed:t.agents.failed+1},errors:[...t.errors.slice(-9),a.message]})}};function pl(s,e,u,a){return new ni(s,e,u,a)}N();S();var yu=class s{constructor(e){this._value=e;if(!e||e.trim()==="")throw new Error("FilePath cannot be empty")}get value(){return this._value}get extension(){let e=this._value.split(".");return e.length>1?e[e.length-1]:""}get directory(){let e=this._value.lastIndexOf("/");return e>0?this._value.substring(0,e):""}get filename(){let e=this._value.lastIndexOf("/");return e>=0?this._value.substring(e+1):this._value}equals(e){return this._value===e._value}static create(e){return new s(e)}};var P0=class s{constructor(e){this._value=e;if(e<0||e>1)throw new Error("RiskScore must be between 0 and 1")}get value(){return this._value}get percentage(){return this._value*100}get level(){return this._value>=.8?"critical":this._value>=.6?"high":this._value>=.3?"medium":"low"}isHigherThan(e){return this._value>e._value}equals(e){return this._value===e._value}static create(e){return new s(e)}static fromPercentage(e){return new s(e/100)}},Ju=class s{constructor(e,u){this._start=e;this._end=u;if(e>u)throw new Error("Start date cannot be after end date")}get start(){return this._start}get end(){return this._end}get durationMs(){return this._end.getTime()-this._start.getTime()}get durationSeconds(){return this.durationMs/1e3}contains(e){return e>=this._start&&e<=this._end}overlaps(e){return this._start<=e._end&&e._start<=this._end}equals(e){return this._start.getTime()===e._start.getTime()&&this._end.getTime()===e._end.getTime()}static create(e,u){return new s(e,u)}static lastNDays(e){let u=new Date,a=new Date(u.getTime()-e*24*60*60*1e3);return new s(a,u)}},Xe=class s{constructor(e,u,a,t){this._major=e;this._minor=u;this._patch=a;this._prerelease=t}get major(){return this._major}get minor(){return this._minor}get patch(){return this._patch}get prerelease(){return this._prerelease}toString(){let e=`${this._major}.${this._minor}.${this._patch}`;return this._prerelease?`${e}-${this._prerelease}`:e}isNewerThan(e){return this._major!==e._major?this._major>e._major:this._minor!==e._minor?this._minor>e._minor:this._patch>e._patch}equals(e){return this._major===e._major&&this._minor===e._minor&&this._patch===e._patch&&this._prerelease===e._prerelease}static create(e,u,a,t){return new s(e,u,a,t)}static parse(e){let u=e.match(/^(\d+)\.(\d+)\.(\d+)(?:-(.+))?$/);if(!u)throw new Error(`Invalid version format: ${e}`);return new s(parseInt(u[1]),parseInt(u[2]),parseInt(u[3]),u[4])}};var oi={defaultRuleSets:["owasp-top-10","cwe-sans-25"],maxConcurrentScans:4,timeout:3e5,enableFalsePositiveDetection:!0,dastMaxDepth:5,dastActiveScanning:!1,enableLLMAnalysis:!0,llmModelTier:4,enableSemgrep:!0};N();var gl=[{id:"sqli-string-concat",pattern:/query\s*\(\s*['"`].*\+.*['"`]\s*\)/g,category:"injection",severity:"critical",title:"SQL Injection via String Concatenation",description:"SQL query constructed using string concatenation with potentially untrusted input",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Use parameterized queries or prepared statements instead of string concatenation",fixExample:'db.query("SELECT * FROM users WHERE id = $1", [userId])'},{id:"sqli-template-literal",pattern:/execute\s*\(\s*`[^`]*\$\{[^}]+\}[^`]*`\s*\)/g,category:"injection",severity:"critical",title:"SQL Injection via Template Literal",description:"SQL query constructed using template literals with embedded expressions",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Use parameterized queries instead of template literals for SQL",fixExample:'db.execute("DELETE FROM users WHERE id = ?", [userId])'},{id:"sqli-raw-query",pattern:/\.raw\s*\(\s*['"`].*\+|\.raw\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"high",title:"SQL Injection via Raw Query",description:"Raw SQL query with potential user input interpolation",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Avoid raw queries with user input; use ORM methods or parameterized queries"},{id:"sqli-exec",pattern:/exec(?:ute)?(?:Sql|Query)?\s*\([^)]*\+[^)]*\)/gi,category:"injection",severity:"critical",title:"SQL Injection via Dynamic Execution",description:"Dynamic SQL execution with string concatenation detected",owaspId:"A03:2021",cweId:"CWE-89",remediation:"Never concatenate user input into SQL queries"}],Cl=[{id:"xss-innerhtml",pattern:/\.innerHTML\s*=\s*[^'"`;\n]+/g,category:"xss",severity:"high",title:"XSS via innerHTML Assignment",description:"Direct innerHTML assignment with potentially unsanitized content",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Use textContent for text, or sanitize HTML with DOMPurify before innerHTML assignment",fixExample:"element.textContent = userInput; // or DOMPurify.sanitize(userInput)"},{id:"xss-document-write",pattern:/document\.write\s*\([^)]+\)/g,category:"xss",severity:"high",title:"XSS via document.write",description:"document.write() can execute scripts from untrusted data",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Avoid document.write(); use DOM manipulation methods instead",fixExample:"document.body.appendChild(document.createTextNode(text))"},{id:"xss-dangerously-set",pattern:/dangerouslySetInnerHTML\s*=\s*\{/g,category:"xss",severity:"medium",title:"React dangerouslySetInnerHTML Usage",description:"dangerouslySetInnerHTML bypasses React XSS protections",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Sanitize HTML content with DOMPurify before using dangerouslySetInnerHTML",fixExample:"dangerouslySetInnerHTML={{ __html: DOMPurify.sanitize(content) }}"},{id:"xss-eval",pattern:/eval\s*\([^)]+\)/g,category:"xss",severity:"critical",title:"Code Injection via eval()",description:"eval() executes arbitrary code and is a major security risk",owaspId:"A03:2021",cweId:"CWE-95",remediation:"Never use eval(); use JSON.parse() for JSON data or safer alternatives",fixExample:"JSON.parse(jsonString) // instead of eval(jsonString)"},{id:"xss-new-function",pattern:/new\s+Function\s*\([^)]+\)/g,category:"xss",severity:"critical",title:"Code Injection via Function Constructor",description:"Function constructor can execute arbitrary code like eval()",owaspId:"A03:2021",cweId:"CWE-95",remediation:"Avoid the Function constructor; use predefined functions instead"},{id:"xss-outerhtml",pattern:/\.outerHTML\s*=\s*[^'"`;\n]+/g,category:"xss",severity:"high",title:"XSS via outerHTML Assignment",description:"Direct outerHTML assignment with potentially unsanitized content",owaspId:"A03:2021",cweId:"CWE-79",remediation:"Sanitize content before outerHTML assignment"}],Al=[{id:"secret-aws-access-key",pattern:/['"`]AKIA[0-9A-Z]{16}['"`]/g,category:"sensitive-data",severity:"critical",title:"AWS Access Key Detected",description:"Hardcoded AWS Access Key ID found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or AWS Secrets Manager for credentials",fixExample:"const accessKey = process.env.AWS_ACCESS_KEY_ID"},{id:"secret-aws-secret-key",pattern:/['"`][A-Za-z0-9/+=]{40}['"`]/g,category:"sensitive-data",severity:"critical",title:"Potential AWS Secret Key Detected",description:"Potential hardcoded AWS Secret Access Key found",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Store secrets in environment variables or secrets manager"},{id:"secret-openai-key",pattern:/['"`]sk-[a-zA-Z0-9]{48,}['"`]/g,category:"sensitive-data",severity:"critical",title:"OpenAI API Key Detected",description:"Hardcoded OpenAI API key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for API keys",fixExample:"const apiKey = process.env.OPENAI_API_KEY"},{id:"secret-generic-password",pattern:/password\s*[:=]\s*['"`][^'"`]{4,}['"`]/gi,category:"sensitive-data",severity:"high",title:"Hardcoded Password Detected",description:"Hardcoded password found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Never hardcode passwords; use environment variables or secrets manager",fixExample:"const password = process.env.DB_PASSWORD"},{id:"secret-api-key",pattern:/api[_-]?key\s*[:=]\s*['"`][a-zA-Z0-9_\-]{16,}['"`]/gi,category:"sensitive-data",severity:"high",title:"Hardcoded API Key Detected",description:"Hardcoded API key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for API keys",fixExample:"const apiKey = process.env.API_KEY"},{id:"secret-jwt",pattern:/['"`]eyJ[A-Za-z0-9_-]+\.eyJ[A-Za-z0-9_-]+\.[A-Za-z0-9_-]+['"`]/g,category:"sensitive-data",severity:"high",title:"Hardcoded JWT Token Detected",description:"Hardcoded JWT token found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Generate JWT tokens dynamically; never hardcode them"},{id:"secret-private-key",pattern:/-----BEGIN\s+(RSA|EC|OPENSSH|DSA)?\s*PRIVATE\s+KEY-----/g,category:"sensitive-data",severity:"critical",title:"Private Key Detected",description:"Private key found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Store private keys in secure key management systems, not in code"},{id:"secret-github-token",pattern:/['"`]ghp_[a-zA-Z0-9]{36}['"`]|['"`]github_pat_[a-zA-Z0-9]{22}_[a-zA-Z0-9]{59}['"`]/g,category:"sensitive-data",severity:"critical",title:"GitHub Token Detected",description:"Hardcoded GitHub personal access token found",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or GitHub Actions secrets"},{id:"secret-slack-token",pattern:/['"`]xox[baprs]-[0-9]{10,13}-[0-9]{10,13}[a-zA-Z0-9-]*['"`]/g,category:"sensitive-data",severity:"high",title:"Slack Token Detected",description:"Hardcoded Slack token found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables for Slack tokens"},{id:"secret-generic-assignment",pattern:/\b\w*(?:SECRET|secret)(?:_KEY|_key|Key)?\s*[:=]\s*['"`][^'"`]{4,}['"`]/g,category:"sensitive-data",severity:"high",title:"Generic Secret Assignment Detected",description:"Hardcoded secret assignment (SECRET_KEY, JWT_SECRET, APP_SECRET, etc.) found in source code",owaspId:"A02:2021",cweId:"CWE-798",remediation:"Use environment variables or a secrets manager instead of hardcoding secrets",fixExample:"const secretKey = process.env.SECRET_KEY"}],yl=[{id:"path-traversal-readfile",pattern:/(?:readFile|readFileSync)\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via File Read",description:"File read operation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate and sanitize file paths; use path.resolve() and check against base directory",fixExample:"const safePath = path.resolve(baseDir, path.basename(userInput))"},{id:"path-traversal-pattern",pattern:/\.\.\/.*\.\.\//g,category:"access-control",severity:"medium",title:"Path Traversal Pattern Detected",description:"Suspicious path traversal pattern (../) found in code",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate paths and ensure they resolve within expected directories"},{id:"path-traversal-writefile",pattern:/(?:writeFile|writeFileSync)\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via File Write",description:"File write operation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate file paths before writing; ensure path is within allowed directory"},{id:"path-traversal-createstream",pattern:/createReadStream\s*\([^)]*\+/g,category:"access-control",severity:"high",title:"Path Traversal via Stream",description:"Stream creation with concatenated path may allow directory traversal",owaspId:"A01:2021",cweId:"CWE-22",remediation:"Validate and sanitize file paths before creating streams"}],xl=[{id:"cmd-injection-exec",pattern:/exec\s*\([^)]*\+[^)]*\)|exec\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"critical",title:"Command Injection via exec()",description:"Shell command execution with unsanitized input",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Use execFile() with argument array instead of exec() with string concatenation",fixExample:'execFile("command", [arg1, arg2], callback)'},{id:"cmd-injection-spawn",pattern:/spawn\s*\(\s*[^,]+\+|spawn\s*\(\s*`[^`]*\$\{/g,category:"injection",severity:"critical",title:"Command Injection via spawn()",description:"Process spawn with potentially unsanitized command",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Use spawn with command and args array; validate inputs",fixExample:'spawn("command", [sanitizedArg1, sanitizedArg2])'},{id:"cmd-injection-shell-true",pattern:/spawn\s*\([^)]+,\s*\{[^}]*shell\s*:\s*true/g,category:"injection",severity:"high",title:"Dangerous Shell Option in spawn()",description:"spawn() with shell: true can enable command injection",owaspId:"A03:2021",cweId:"CWE-78",remediation:"Avoid shell: true option; use direct command execution"}],fl=[{id:"misc-cors-wildcard",pattern:/cors\s*\(\s*\{[^}]*origin\s*:\s*['"]\*['"]/gi,category:"security-misconfiguration",severity:"medium",title:"Permissive CORS Configuration",description:"CORS allows all origins (*) which may expose sensitive data",owaspId:"A05:2021",cweId:"CWE-942",remediation:"Restrict CORS to specific trusted origins",fixExample:'cors({ origin: ["https://trusted-domain.com"] })'},{id:"misc-debug-enabled",pattern:/debug\s*[:=]\s*true|DEBUG\s*[:=]\s*['"]?true['"]?/gi,category:"security-misconfiguration",severity:"low",title:"Debug Mode Enabled",description:"Debug mode may expose sensitive information in production",owaspId:"A05:2021",cweId:"CWE-489",remediation:"Disable debug mode in production environments"},{id:"misc-ssl-disabled",pattern:/rejectUnauthorized\s*:\s*false|NODE_TLS_REJECT_UNAUTHORIZED\s*=\s*['"]?0['"]?/g,category:"security-misconfiguration",severity:"high",title:"TLS Certificate Validation Disabled",description:"Disabling TLS certificate validation exposes to MITM attacks",owaspId:"A05:2021",cweId:"CWE-295",remediation:"Always enable TLS certificate validation in production"},{id:"misc-helmet-missing",pattern:/app\.use\s*\(\s*express\s*\(\s*\)\s*\)/g,category:"security-misconfiguration",severity:"low",title:"Express App Without Security Headers",description:"Express app initialized without helmet or security headers",owaspId:"A05:2021",cweId:"CWE-693",remediation:"Use helmet middleware for security headers",fixExample:"app.use(helmet())"}],vl=[{id:"deser-yaml-load",pattern:/yaml\.load\s*\([^)]+\)/g,category:"insecure-deserialization",severity:"high",title:"Unsafe YAML Deserialization",description:"yaml.load() can execute arbitrary code from untrusted YAML",owaspId:"A08:2021",cweId:"CWE-502",remediation:"Use yaml.safeLoad() or schema-constrained loading",fixExample:"yaml.load(content, { schema: yaml.SAFE_SCHEMA })"},{id:"deser-serialize-js",pattern:/serialize\s*\([^)]+\)|unserialize\s*\([^)]+\)/g,category:"insecure-deserialization",severity:"high",title:"Unsafe Serialization Function",description:"Node serialize/unserialize functions can execute arbitrary code",owaspId:"A08:2021",cweId:"CWE-502",remediation:"Use JSON.parse/stringify for serialization"}],Fl=[{id:"auth-weak-jwt-secret",pattern:/jwt\.sign\s*\([^)]+,\s*['"][a-zA-Z0-9]{1,16}['"]/g,category:"broken-auth",severity:"high",title:"Weak JWT Secret",description:"JWT signed with a weak or short secret key",owaspId:"A07:2021",cweId:"CWE-327",remediation:"Use a strong, randomly generated secret of at least 256 bits"},{id:"auth-no-algorithm",pattern:/jwt\.verify\s*\([^)]+\)\s*(?!.*algorithm)/g,category:"broken-auth",severity:"medium",title:"JWT Without Algorithm Specification",description:"JWT verification without explicit algorithm can be exploited",owaspId:"A07:2021",cweId:"CWE-347",remediation:"Always specify the expected algorithm in JWT verification",fixExample:'jwt.verify(token, secret, { algorithms: ["HS256"] })'}],si=[...gl,...Cl,...Al,...yl,...xl,...fl,...vl,...Fl],Ya=[{id:"owasp-top-10",name:"OWASP Top 10",description:"OWASP Top 10 most critical security risks",ruleCount:45,categories:["injection","broken-auth","sensitive-data","xxe","access-control","security-misconfiguration","xss","insecure-deserialization","vulnerable-components","insufficient-logging"]},{id:"cwe-sans-25",name:"CWE/SANS Top 25",description:"Most dangerous software errors",ruleCount:38,categories:["injection","xss","access-control","sensitive-data","broken-auth"]},{id:"nodejs-security",name:"Node.js Security",description:"Node.js specific security rules",ruleCount:25,categories:["injection","xss","sensitive-data","security-misconfiguration"]},{id:"typescript-security",name:"TypeScript Security",description:"TypeScript specific security rules",ruleCount:20,categories:["injection","xss","sensitive-data"]}];S();J();S();J();import{execFile as uCu}from"child_process";import{promisify as eCu}from"util";import*as rE from"path";var bl=eCu(uCu);async function Xa(){try{return await bl("semgrep",["--version"],{timeout:5e3}),!0}catch{return!1}}async function aE(){try{let{stdout:s}=await bl("semgrep",["--version"],{timeout:5e3});return s.trim()}catch{return null}}async function aCu(s){let e={target:s.target||".",config:s.config||"auto",exclude:s.exclude||["node_modules",".git","dist","build","coverage"],maxFileSize:s.maxFileSize||5e6,timeout:s.timeout||300,verbose:s.verbose||!1};if(!await Xa())return{success:!1,findings:[],errors:["Semgrep is not installed. Install with: pip install semgrep"]};try{let a=["scan",`--config=${e.config}`,"--json",e.verbose?"--verbose":"--quiet",`--max-target-bytes=${e.maxFileSize}`];for(let o of e.exclude)a.push(`--exclude=${o}`);a.push(e.target);let t=(e.timeout??300)*1e3,{stdout:r,stderr:i}=await bl("semgrep",a,{timeout:t,maxBuffer:50*1024*1024,cwd:rE.isAbsolute(e.target)?void 0:process.cwd()}),n=tE(r);return i&&e.verbose&&n.errors.push(i),n.version=await aE()||void 0,n}catch(a){let t=a;if(t.stdout)try{let r=tE(t.stdout);return r.version=await aE()||void 0,r}catch{}return{success:!1,findings:[],errors:[t.message??String(a)]}}}function tE(s){try{let e=T(s),u=e.results||e.findings||[],a=e.errors?.map(t=>t.message||String(t))||[];return{success:!0,findings:u.map(t=>({check_id:t.check_id||t.rule_id||"unknown",path:t.path,start:{line:t.start?.line||1,col:t.start?.col||1},end:{line:t.end?.line||t.start?.line||1,col:t.end?.col||1},extra:{message:t.extra?.message||t.message||"Security issue detected",severity:t.extra?.severity||t.severity||"WARNING",lines:t.extra?.lines||"",metadata:{cwe:t.extra?.metadata?.cwe||t.metadata?.cwe,owasp:t.extra?.metadata?.owasp||t.metadata?.owasp,category:t.extra?.metadata?.category||t.metadata?.category,description:t.extra?.metadata?.description||t.metadata?.description,fix:t.extra?.metadata?.fix||t.extra?.fix,references:t.extra?.metadata?.references||t.metadata?.references,confidence:t.extra?.metadata?.confidence||t.metadata?.confidence}}})),errors:a}}catch(e){return{success:!1,findings:[],errors:[`Failed to parse semgrep output: ${k(e)}`]}}}async function li(s,e,u){let a={"owasp-top-10":"p/owasp-top-ten","cwe-sans-25":"p/cwe-top-25","nodejs-security":"p/nodejs","typescript-security":"p/typescript","javascript-security":"p/javascript","react-security":"p/react","express-security":"p/express",secrets:"p/secrets","sql-injection":"p/sql-injection",xss:"p/xss","command-injection":"p/command-injection","path-traversal":"p/path-traversal"},t=e.map(r=>a[r]||`p/${r}`).join(",");return aCu({...u,target:s,config:t||"auto"})}function tCu(s){return{ERROR:"high",WARNING:"medium",INFO:"low"}[s]||"medium"}function ci(s){return s.map(e=>({id:e.check_id,title:e.check_id.split(".").pop()||e.check_id,description:e.extra.message,severity:tCu(e.extra.severity),file:e.path,line:e.start.line,column:e.start.col,snippet:e.extra.lines,cweId:e.extra.metadata?.cwe?.[0],owaspCategory:e.extra.metadata?.owasp?.[0],remediation:e.extra.metadata?.fix||"Review and fix the identified security issue",references:e.extra.metadata?.references||[]}))}var rCu=B.create("security-compliance/sast-scanner"),z0=class{config;memory;llmRouter;activeScans;constructor(e,u,a,t){this.config=e,this.memory=u,this.llmRouter=a,this.activeScans=t||new Map}async scanFiles(e){return this.scanWithRules(e,this.config.defaultRuleSets)}async scanWithRules(e,u){let a=A();try{if(e.length===0)return m(new Error("No files provided for scanning"));this.activeScans.set(a,"running");let t=Date.now(),r=Ya.filter(h=>u.includes(h.id));if(r.length===0)return m(new Error(`No valid rule sets found: ${u.join(", ")}`));let[i,n]=await Promise.all([this.runPatternScanning(e,r),this.runSemgrepScanning(e,u)]),o=this.mergeVulnerabilities(i.vulnerabilities,n),l=i.linesScanned,c=Date.now()-t,E=this.calculateSummary(o,e.length,c),d=r.reduce((h,C)=>h+C.ruleCount,0),D={filesScanned:e.length,linesScanned:l,rulesApplied:d+(n.length>0?n.length:0)};return await this.storeScanResults(a,"sast",o,E),this.activeScans.set(a,"completed"),p({scanId:a,vulnerabilities:o,summary:E,coverage:D})}catch(t){return this.activeScans.set(a,"failed"),m(g(t))}}async runPatternScanning(e,u){let a=[],t=0;for(let r of e){let i=await this.analyzeFile(r,u);a.push(...i.vulnerabilities),t+=i.linesScanned}return{vulnerabilities:a,linesScanned:t}}async runSemgrepScanning(e,u){if(!this.config.enableSemgrep)return[];try{if(!await Xa())return[];let t=this.resolveTargetDirectory(e),r=await li(t,u);return!r.success||r.findings.length===0?[]:ci(r.findings).map(n=>({id:A(),cveId:void 0,title:n.title,description:`[semgrep] ${n.description}`,severity:n.severity,category:this.mapSemgrepCategory(n.owaspCategory),location:{file:n.file,line:n.line,column:n.column,snippet:n.snippet},remediation:{description:n.remediation,estimatedEffort:"moderate",automatable:!1},references:n.references}))}catch{return[]}}resolveTargetDirectory(e){if(e.length===0)return".";if(e.length===1)return e[0].directory||".";let u=e.map(n=>n.directory||"."),a=u[0],t=a.length;for(let n=1;n<u.length;n++){let o=u[n],l=Math.min(t,o.length),c=0;for(;c<l&&a[c]===o[c];)c++;t=c}let r=a.substring(0,t),i=r.lastIndexOf("/");return i>0?r.substring(0,i):r||"."}mapSemgrepCategory(e){if(!e)return"injection";let u={A01:"access-control",A02:"sensitive-data",A03:"injection",A04:"insecure-deserialization",A05:"security-misconfiguration",A06:"vulnerable-components",A07:"broken-auth",A08:"insecure-deserialization",A09:"insufficient-logging",A10:"xxe"};for(let[a,t]of Object.entries(u))if(e.startsWith(a))return t;return"injection"}mergeVulnerabilities(e,u){if(u.length===0)return e;if(e.length===0)return u;let a=new Set(e.map(r=>`${r.location.file}:${r.location.line??0}:${r.category}`)),t=u.filter(r=>!a.has(`${r.location.file}:${r.location.line??0}:${r.category}`));return[...e,...t]}async getAvailableRuleSets(){let e=await this.memory.get("security:custom-rule-sets");return[...Ya,...e||[]]}async checkFalsePositive(e){try{if(!this.config.enableFalsePositiveDetection)return p({isFalsePositive:!1,confidence:0,reason:"False positive detection is disabled"});let u=await this.analyzeFalsePositive(e);return await this.memory.set(`security:fp-check:${e.id}`,{vulnerability:e,analysis:u},{namespace:"security-compliance",ttl:86400*30}),p(u)}catch(u){return m(g(u))}}async analyzeFile(e,u){let a=[],t=e.value,r=e.extension,i,n;try{i=await(await import("fs/promises")).readFile(t,"utf-8"),n=i.split(`
2900
2900
  `)}catch{return{vulnerabilities:[],linesScanned:0}}let o=n.length;if(!["ts","tsx","js","jsx","mjs","cjs"].includes(r))return{vulnerabilities:[],linesScanned:o};let c=new Set(u.flatMap(d=>d.categories)),E=si.filter(d=>c.has(d.category));for(let d of E){let D=this.findPatternMatches(i,n,d);for(let h of D)this.isInComment(i,h.index)||this.isInDocumentation(h.snippet)||this.hasNosecAnnotation(n,h.line)||a.push(this.createVulnerabilityFromPattern(d,t,h))}return{vulnerabilities:a,linesScanned:o}}findPatternMatches(e,u,a){let t=[],r=new RegExp(a.pattern.source,a.pattern.flags),i;for(;(i=r.exec(e))!==null;){let n=i.index,{line:o,column:l}=this.getLineAndColumn(e,n),c=[],E=Math.max(0,o-2),d=Math.min(u.length-1,o+1);for(let h=E;h<=d;h++)c.push(u[h]);let D=c.join(`
2901
2901
  `);t.push({index:n,line:o+1,column:l+1,snippet:D})}return t}getLineAndColumn(e,u){let t=e.substring(0,u).split(`
2902
2902
  `),r=t.length-1,i=t[t.length-1].length;return{line:r,column:i}}isInComment(e,u){let a=e.substring(0,u),t=a.lastIndexOf(`
@@ -3026,4 +3026,4 @@ Provide:
3026
3026
  3. Recommendations for pattern application`}],maxTokens:this.config.llmMaxTokens})).content}catch{return _E.warn("LLM synthesis failed:"),null}}async learnPattern(e){try{if(e.length<this.config.minExperiencesForPattern)return m(new Error(`Need at least ${this.config.minExperiencesForPattern} experiences to learn a pattern`));let u=this.extractCommonActions(e),a=this.calculateSuccessRate(e);if(a<this.config.patternConfidenceThreshold)return m(new Error(`Success rate ${a} below threshold ${this.config.patternConfidenceThreshold}`));let t=this.inferPatternType(e),r=e[0].domain,i=this.generatePatternTemplate(e,u),n=this.extractPatternContext(e),o={id:A(),type:t,domain:r,name:`${t}-${r}-${Date.now()}`,description:`Learned pattern from ${e.length} experiences with ${a*100}% success rate`,confidence:a,usageCount:0,successRate:a,context:n,template:i,createdAt:new Date,lastUsedAt:new Date};return await this.storePattern(o),await this.recordPatternCreation(o,e),p(o)}catch(u){return m(g(u))}}async findMatchingPatterns(e,u=10){try{let a=[],t=await this.memory.search("learning:pattern:*",100);for(let r of t){let i=await this.memory.get(r);i&&this.matchesContext(i,e)&&a.push(i)}return a.sort((r,i)=>{let n=r.confidence*.6+r.successRate*.4;return i.confidence*.6+i.successRate*.4-n}),p(a.slice(0,u))}catch(a){return m(g(a))}}async applyPattern(e,u){try{let a=e.template.content;for(let t of e.template.variables){let r=u[t.name]??t.defaultValue;if(t.required&&r===void 0)return m(new Error(`Required variable ${t.name} not provided`));a=a.replace(new RegExp(`\\{\\{${t.name}\\}\\}`,"g"),String(r??""))}return await this.updatePatternUsage(e.id),p(a)}catch(a){return m(g(a))}}async updatePatternFeedback(e,u){try{let a=`learning:pattern:${e}`,t=await this.memory.get(a);if(!t)return m(new Error(`Pattern ${e} not found`));let r=.1,i=r*(u?1:0)+(1-r)*t.successRate,n=Math.min(t.usageCount/100,1),o=i*.7+n*.3,l={...t,successRate:i,confidence:o,usageCount:t.usageCount+1,lastUsedAt:new Date};return await this.memory.set(a,l,{namespace:"learning-optimization",persist:!0}),p(void 0)}catch(a){return m(g(a))}}async consolidatePatterns(e){try{if(e.length<2)return m(new Error("Need at least 2 patterns to consolidate"));let u=[];for(let i of e){let n=await this.memory.get(`learning:pattern:${i}`);n&&u.push(n)}if(u.length<2)return m(new Error("Not enough valid patterns found"));let a=u.reduce((i,n)=>n.successRate>i.successRate?n:i),t={language:a.context.language,framework:a.context.framework,testType:a.context.testType,codeContext:a.context.codeContext,tags:[...new Set(u.flatMap(i=>i.context.tags))]},r={id:A(),type:a.type,domain:a.domain,name:`consolidated-${a.name}`,description:`Consolidated from ${u.length} patterns`,confidence:this.calculateConsolidatedConfidence(u),usageCount:u.reduce((i,n)=>i+n.usageCount,0),successRate:this.calculateWeightedSuccessRate(u),context:t,template:a.template,createdAt:new Date,lastUsedAt:new Date};await this.storePattern(r);for(let i of u)await this.archivePattern(i.id);return p(r)}catch(u){return m(g(u))}}async getPatternStats(e){try{let u=await this.memory.search("learning:pattern:*",500),a=[];for(let l of u){let c=await this.memory.get(l);c&&(!e||c.domain===e)&&a.push(c)}let t={"test-pattern":0,"fix-pattern":0,"optimization-pattern":0,"detection-pattern":0,"workflow-pattern":0,"failure-pattern":0},r={"test-generation":0,"test-execution":0,"coverage-analysis":0,"quality-assessment":0,"defect-intelligence":0,"requirements-validation":0,"code-intelligence":0,"security-compliance":0,"contract-testing":0,"visual-accessibility":0,"chaos-resilience":0,"learning-optimization":0,"enterprise-integration":0,coordination:0},i=0,n=0;for(let l of a)t[l.type]++,r[l.domain]++,i+=l.confidence,n+=l.successRate;let o=a.sort((l,c)=>c.successRate-l.successRate).slice(0,10);return p({totalPatterns:a.length,byType:t,byDomain:r,avgConfidence:a.length>0?i/a.length:0,avgSuccessRate:a.length>0?n/a.length:0,topPatterns:o})}catch(u){return m(g(u))}}async recordExperience(e){try{let u=A(),a={...e,id:u,timestamp:new Date};return await this.memory.set(`learning:experience:${u}`,a,{namespace:"learning-optimization",ttl:86400*30}),await this.indexExperience(a),p(u)}catch(u){return m(g(u))}}async mineExperiences(e,u){try{let a=await this.getExperiencesByDomainAndTime(e,u);if(a.length===0)return p({experienceCount:0,successRate:0,avgReward:0,patterns:[],anomalies:[],recommendations:["No experiences found in the given time range"]});let t=this.calculateSuccessRate(a),r=this.calculateAverageReward(a),i=await this.extractPatternsFromExperiences(a),n=this.detectAnomalies(a),o=this.generateRecommendations(a,t,n);return p({experienceCount:a.length,successRate:t,avgReward:r,patterns:i,anomalies:n,recommendations:o})}catch(a){return m(g(a))}}calculateReward(e,u){let a=e.outcome[u.metric]??0,t;u.direction==="maximize"?t=Math.min(a/100,1):t=Math.max(1-a/100,0);let r=0;for(let o of u.constraints){let l=e.outcome[o.metric]??0;this.isConstraintViolated(o,l)&&(r+=.2)}let i=e.success?.5:0,n=Math.max(0,t+i-r);return Math.min(1,n)}async getReplayBuffer(e,u=100){try{let a=await this.memory.search(`learning:experience:index:agent:${e.value}:*`,u),t=[];for(let r of a){let i=await this.memory.get(r);if(i){let n=await this.memory.get(`learning:experience:${i}`);n&&t.push(n)}}return t.sort((r,i)=>i.timestamp.getTime()-r.timestamp.getTime()),p(t.slice(0,u))}catch(a){return m(g(a))}}async clusterExperiences(e){try{if(e.length===0)return p([]);let u=new Map;for(let r of e){let i=!1;for(let[n,o]of u)if(this.actionsSimilar(r.action,n)){o.push(r),i=!0;break}i||u.set(r.action,[r])}let a=[],t=0;for(let[r,i]of u)if(i.length>=2){let n=this.calculateCentroid(i),o=this.extractCommonActions(i),l=this.calculateAverageReward(i);a.push({id:`cluster-${t++}`,centroid:n,experiences:i,commonActions:o,avgReward:l})}return p(a)}catch(u){return m(g(u))}}async storePattern(e){await this.memory.set(`learning:pattern:${e.id}`,e,{namespace:"learning-optimization",persist:!0})}async archivePattern(e){let u=`learning:pattern:${e}`,a=await this.memory.get(u);a&&(await this.memory.set(`learning:pattern:archived:${e}`,a,{namespace:"learning-optimization",persist:!0}),await this.memory.delete(u))}async updatePatternUsage(e){let u=`learning:pattern:${e}`,a=await this.memory.get(u);if(a){let t={...a,usageCount:a.usageCount+1,lastUsedAt:new Date};await this.memory.set(u,t,{namespace:"learning-optimization",persist:!0})}}async recordPatternCreation(e,u){await this.memory.set(`learning:pattern:creation:${e.id}`,{patternId:e.id,experienceIds:u.map(a=>a.id),createdAt:new Date},{namespace:"learning-optimization",persist:!0})}async indexExperience(e){await this.memory.set(`learning:experience:index:agent:${e.agentId.value}:${e.id}`,e.id,{namespace:"learning-optimization",ttl:86400*30}),await this.memory.set(`learning:experience:index:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",ttl:86400*30})}async getExperiencesByDomainAndTime(e,u){let a=await this.memory.search(`learning:experience:index:domain:${e}:*`,1e3),t=[];for(let r of a){let i=await this.memory.get(r);if(i){let n=await this.memory.get(`learning:experience:${i}`);n&&u.contains(n.timestamp)&&t.push(n)}}return t}async extractPatternsFromExperiences(e){let u=e.filter(r=>r.result.success),a=new Map;for(let r of u){let i=a.get(r.action)||[];i.push(r),a.set(r.action,i)}let t=[];for(let[r,i]of a)if(i.length>=this.config.minExperiencesForPattern){let n=await this.learnPattern(i);n.success&&t.push(n.value)}return t}matchesContext(e,u){return!(u.language&&e.context.language!==u.language||u.framework&&e.context.framework!==u.framework||u.testType&&e.context.testType!==u.testType||u.tags.length>0&&!u.tags.some(t=>e.context.tags.includes(t)))}extractCommonActions(e){let u=new Map;for(let a of e){let t=u.get(a.action)||0;u.set(a.action,t+1)}return Array.from(u.entries()).filter(([a,t])=>t>=e.length*.3).map(([a])=>a)}calculateAverageReward(e){return e.length===0?0:e.reduce((a,t)=>a+t.reward,0)/e.length}calculateSuccessRate(e){return e.length===0?0:e.filter(a=>a.result.success).length/e.length}inferPatternType(e){let u=e.map(a=>a.action.toLowerCase());return u.some(a=>a.includes("test")||a.includes("generate"))?"test-pattern":u.some(a=>a.includes("fix")||a.includes("repair"))?"fix-pattern":u.some(a=>a.includes("optimize")||a.includes("improve"))?"optimization-pattern":u.some(a=>a.includes("detect")||a.includes("find"))?"detection-pattern":u.some(a=>a.includes("workflow")||a.includes("process"))?"workflow-pattern":u.some(a=>a.includes("fail")||a.includes("error"))?"failure-pattern":"workflow-pattern"}generatePatternTemplate(e,u){let a=[{name:"domain",type:"string",required:!0,description:"Target domain for the pattern"},{name:"action",type:"string",required:!0,defaultValue:u[0],description:"Primary action to execute"}];return{type:"workflow",content:`// Pattern learned from ${e.length} experiences
3027
3027
  // Common actions: ${u.join(", ")}
3028
3028
  // Apply to domain: {{domain}}
3029
- // Execute action: {{action}}`,variables:a}}extractPatternContext(e){let u=new Set,a,t;for(let r of e){let i=r.state.context;if(i.language&&(a=i.language),i.framework&&(t=i.framework),i.tags&&Array.isArray(i.tags))for(let n of i.tags)u.add(n)}return{language:a,framework:t,tags:Array.from(u)}}calculateConsolidatedConfidence(e){let u=e.reduce((t,r)=>t+r.usageCount,0),a=0;for(let t of e){let r=u>0?t.usageCount/u:1/e.length;a+=t.confidence*r}return a}calculateWeightedSuccessRate(e){let u=e.reduce((t,r)=>t+r.usageCount,0),a=0;for(let t of e){let r=u>0?t.usageCount/u:1/e.length;a+=t.successRate*r}return a}detectAnomalies(e){let u=[],a=this.calculateAverageReward(e),t=this.calculateStdDev(e.map(r=>r.reward));for(let r of e){let i=Math.abs(r.reward-a)/(t||1);if(i>this.config.anomalyDeviationThreshold){let n="outlier-reward";r.result.success&&r.reward<a?n="unexpected-success":!r.result.success&&r.reward>a&&(n="unexpected-failure"),u.push({experienceId:r.id,type:n,description:`Reward ${r.reward.toFixed(2)} deviates ${i.toFixed(2)} std from mean ${a.toFixed(2)}`,deviation:i})}}return u}calculateStdDev(e){if(e.length===0)return 0;let u=e.reduce((t,r)=>t+r,0)/e.length,a=e.map(t=>Math.pow(t-u,2));return Math.sqrt(a.reduce((t,r)=>t+r,0)/e.length)}generateRecommendations(e,u,a){let t=[];return u<.5&&t.push("Low success rate detected. Consider reviewing the approach or gathering more training data."),a.length>e.length*.1&&t.push("High anomaly rate detected. Investigate unexpected outcomes for potential improvements."),e.reduce((i,n)=>i+n.result.duration,0)/e.length>6e4&&t.push("Average operation duration is high. Consider optimizing performance."),e.length<10&&t.push("Limited experience data. Collect more data points for better insights."),t.length===0&&t.push("Performance metrics are within acceptable ranges. Continue monitoring."),t}actionsSimilar(e,u){let a=i=>i.toLowerCase().replace(/[^a-z]/g,""),t=a(e),r=a(u);return!!(t===r||t.includes(r)||r.includes(t))}calculateCentroid(e){let u={},a={};for(let t of e)for(let[r,i]of Object.entries(t.state.metrics))u[r]=(u[r]||0)+i,a[r]=(a[r]||0)+1;for(let t of Object.keys(u))u[t]/=a[t];return{context:{},metrics:u}}isConstraintViolated(e,u){switch(e.operator){case"lt":return u>=e.value;case"gt":return u<=e.value;case"lte":return u>e.value;case"gte":return u<e.value;case"eq":return u!==e.value;default:return!1}}};S();var P2u={maxKnowledgeItems:1e3,relevanceThreshold:.5,transferDecayFactor:.1,crossDomainBoost:.2},t0=class{constructor(e,u={}){this.memory=e;this.config={...P2u,...u}}config;async shareKnowledge(e,u){try{await this.memory.set(`learning:knowledge:shared:${e.id}`,e,{namespace:"learning-optimization",persist:!0});for(let a of u)await this.memory.set(`learning:knowledge:access:${a.value}:${e.id}`,{knowledgeId:e.id,agentId:a.value,sharedAt:new Date,accessed:!1},{namespace:"learning-optimization",ttl:86400*7});return await this.recordSharingEvent(e,u),p(void 0)}catch(a){return m(g(a))}}async queryKnowledge(e){try{let u=[],a;e.domain?a=await this.memory.search(`learning:knowledge:*:${e.domain}:*`,e.limit||100):a=await this.memory.search("learning:knowledge:shared:*",e.limit||100);for(let t of a){let r=await this.memory.get(t);r&&this.matchesQuery(r,e)&&u.push(r)}if(u.sort((t,r)=>r.relevanceScore-t.relevanceScore),e.embedding&&e.embedding.length>0){let t=await this.memory.vectorSearch(e.embedding,e.limit||10);for(let r of t){let i=await this.memory.get(r.key);i&&!u.some(n=>n.id===i.id)&&this.matchesQuery(i,e)&&u.push(i)}}return p(u.slice(0,e.limit||100))}catch(u){return m(g(u))}}async synthesizeKnowledge(e){try{if(e.length<2)return m(new Error("Need at least 2 knowledge items to synthesize"));let u=[];for(let l of e){let c=await this.getKnowledgeById(l);c&&u.push(c)}if(u.length<2)return m(new Error("Not enough valid knowledge items found"));let a=this.determineSynthesizedType(u),t=this.determineSynthesizedDomain(u),r=this.mergeKnowledgeContent(u),i=u.reduce((l,c)=>l+c.relevanceScore,0)/u.length,n=Math.min(1,i+this.config.crossDomainBoost),o={id:A(),type:a,domain:t,content:r,sourceAgentId:u[0].sourceAgentId,targetDomains:this.mergeTargetDomains(u),relevanceScore:n,version:1,createdAt:new Date};return await this.storeKnowledge(o),await this.recordSynthesisEvent(o,e),p(o)}catch(u){return m(g(u))}}async transferKnowledge(e,u){try{if(e.domain===u)return m(new Error("Cannot transfer knowledge to the same domain"));let a=this.calculateTransferredRelevance(e,u);if(a<this.config.relevanceThreshold)return m(new Error(`Transferred relevance ${a} below threshold ${this.config.relevanceThreshold}`));let t=await this.adaptContentForDomain(e.content,e.domain,u),r={id:A(),type:e.type,domain:u,content:t,sourceAgentId:e.sourceAgentId,targetDomains:[u],relevanceScore:a,version:e.version+1,createdAt:new Date};return await this.storeKnowledge(r),await this.recordTransferEvent(e,r),p(r)}catch(a){return m(g(a))}}async validateRelevance(e,u){try{let a=e.relevanceScore;if(u.language&&e.content.metadata?.language===u.language&&(a+=.1),u.framework&&e.content.metadata?.framework===u.framework&&(a+=.1),u.tags.length>0&&e.content.metadata?.tags){let n=e.content.metadata.tags,o=u.tags.filter(l=>n.includes(l));a+=o.length/u.tags.length*.2}let r=(Date.now()-e.createdAt.getTime())/(1e3*60*60*24),i=Math.exp(-this.config.transferDecayFactor*r/30);return a*=i,e.expiresAt&&new Date>e.expiresAt&&(a*=.5),p(Math.min(1,Math.max(0,a)))}catch(a){return m(g(a))}}async createKnowledge(e,u,a,t,r=[],i){try{let n={id:A(),type:e,domain:u,content:{format:this.inferContentFormat(a),data:a,metadata:i},sourceAgentId:t,targetDomains:r,relevanceScore:1,version:1,createdAt:new Date};return await this.storeKnowledge(n),e==="embedding"&&Array.isArray(a)&&await this.memory.storeVector(`learning:knowledge:vector:${n.id}`,a,{knowledgeId:n.id}),p(n)}catch(n){return m(g(n))}}async getKnowledgeById(e){return await this.memory.get(`learning:knowledge:shared:${e}`)||null}async bulkTransfer(e,u,a){try{let t=await this.memory.search(`learning:knowledge:project:${e}:*`,500),r=[];for(let i of t){let n=await this.memory.get(i);if(!n||a?.types&&!a.types.includes(n.type)||a?.minRelevance&&n.relevanceScore<a.minRelevance)continue;let o=await this.adaptContentForProject(n.content,e,u),l={...n,id:A(),content:o,relevanceScore:n.relevanceScore*(1-this.config.transferDecayFactor),version:n.version+1,createdAt:new Date};await this.memory.set(`learning:knowledge:project:${u}:${l.id}`,l,{namespace:"learning-optimization",persist:!0}),r.push({knowledgeId:l.id,sourceDomain:n.domain,targetDomain:n.domain,originalRelevance:n.relevanceScore,transferredRelevance:l.relevanceScore,adaptations:["project-context-adapted"]})}return p(r)}catch(t){return m(g(t))}}async storeKnowledge(e){await this.memory.set(`learning:knowledge:shared:${e.id}`,e,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:knowledge:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:knowledge:type:${e.type}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}matchesQuery(e,u){if(u.type&&e.type!==u.type||u.domain&&e.domain!==u.domain||u.minRelevance!==void 0&&e.relevanceScore<u.minRelevance)return!1;if(u.tags&&u.tags.length>0){let a=e.content.metadata?.tags||[];if(!u.tags.some(r=>a.includes(r)))return!1}return!0}determineSynthesizedType(e){let u=new Map;for(let r of e)u.set(r.type,(u.get(r.type)||0)+1);let a=e[0].type,t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}determineSynthesizedDomain(e){let u=new Map;for(let r of e)u.set(r.domain,(u.get(r.domain)||0)+1);let a=e[0].domain,t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}mergeKnowledgeContent(e){let u={},a=[];for(let t of e)if(a.push(t.content.data),t.content.metadata)for(let[r,i]of Object.entries(t.content.metadata))if(Array.isArray(i)){let n=u[r]||[];u[r]=[...new Set([...n,...i])]}else u[r]=i;return{format:"json",data:{synthesized:!0,sources:a},metadata:{...u,synthesizedFrom:e.map(t=>t.id),synthesizedAt:new Date().toISOString()}}}mergeTargetDomains(e){let u=new Set;for(let a of e){u.add(a.domain);for(let t of a.targetDomains)u.add(t)}return Array.from(u)}calculateTransferredRelevance(e,u){let a=e.relevanceScore;a*=1-this.config.transferDecayFactor;let t=this.getDomainCompatibility(e.domain,u);return a*=t,e.targetDomains.includes(u)&&(a+=this.config.crossDomainBoost),Math.min(1,Math.max(0,a))}getDomainCompatibility(e,u){let a={"test-generation":["test-execution","coverage-analysis"],"test-execution":["test-generation","coverage-analysis","quality-assessment"],"coverage-analysis":["test-generation","test-execution","quality-assessment"],"quality-assessment":["test-execution","coverage-analysis","defect-intelligence"],"defect-intelligence":["quality-assessment","code-intelligence"],"requirements-validation":["test-generation","quality-assessment"],"code-intelligence":["defect-intelligence","security-compliance"],"security-compliance":["code-intelligence","quality-assessment"],"contract-testing":["test-generation","test-execution"],"visual-accessibility":["quality-assessment"],"chaos-resilience":["test-execution","quality-assessment"],"learning-optimization":["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence"],"enterprise-integration":["contract-testing","security-compliance","quality-assessment"],coordination:Fu.filter(t=>t!=="coordination")};return e===u?1:a[e]?.includes(u)?.8:.5}async adaptContentForDomain(e,u,a){return{...e,metadata:{...e.metadata||{},adaptedFrom:u,adaptedTo:a,adaptedAt:new Date().toISOString()}}}async adaptContentForProject(e,u,a){return{...e,metadata:{...e.metadata||{},sourceProject:u,targetProject:a,transferredAt:new Date().toISOString()}}}inferContentFormat(e){return typeof e=="string"?"text":Array.isArray(e)&&e.every(u=>typeof u=="number")?"embedding":"json"}async recordSharingEvent(e,u){await this.memory.set(`learning:knowledge:events:share:${e.id}:${Date.now()}`,{type:"share",knowledgeId:e.id,targetAgents:u.map(a=>a.value),timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}async recordSynthesisEvent(e,u){await this.memory.set(`learning:knowledge:events:synthesis:${e.id}`,{type:"synthesis",synthesizedId:e.id,sourceIds:u,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}async recordTransferEvent(e,u){await this.memory.set(`learning:knowledge:events:transfer:${u.id}`,{type:"transfer",originalId:e.id,transferredId:u.id,originalDomain:e.domain,targetDomain:u.domain,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}};S();cu();var z2u={defaultConfidenceLevel:.95,minSamplesForOptimization:20,maxOptimizationIterations:100,improvementThreshold:.05,explorationRate:.1},L2u=["__proto__","constructor","prototype"];function st(s){return!L2u.includes(s)}var r0=class{constructor(e,u={}){this.memory=e;this.config={...z2u,...u}}config;async optimizeStrategy(e,u,a){try{if(a.length<this.config.minSamplesForOptimization)return m(new Error(`Need at least ${this.config.minSamplesForOptimization} experiences for optimization`));let t=this.evaluateStrategyPerformance(e,a,u),r=await this.optimizeParameters(e.parameters,a,u),i={name:`${e.name}-optimized`,parameters:r,expectedOutcome:this.predictOutcome(r,a)},n=await this.validateOptimization(e,i,a.slice(-10)),o=this.evaluateStrategyPerformance(i,a,u),l=this.calculateImprovement(t,o,u),c=this.calculateOptimizationConfidence(a.length,l,n),E=this.inferDomainFromExperiences(a),d={id:A(),domain:E,objective:u,currentStrategy:e,optimizedStrategy:i,improvement:l,confidence:c,validationResults:n};return await this.storeOptimizationResult(d),p(d)}catch(t){return m(g(t))}}async runABTest(e,u,a){try{let t=await this.collectStrategyMetrics(e,a.metric,a.minSamples),r=await this.collectStrategyMetrics(u,a.metric,a.minSamples),i=this.calculateMean(t),n=this.calculateMean(r),o=this.calculateStdDev(t),l=this.calculateStdDev(r),c=this.calculatePValue(t,r),E;c<1-a.confidenceLevel?E=i>n?"A":"B":E="inconclusive";let d={winner:E,strategyAMetrics:{[a.metric]:i,stdDev:o,samples:t.length},strategyBMetrics:{[a.metric]:n,stdDev:l,samples:r.length},pValue:c,sampleSizeA:t.length,sampleSizeB:r.length};return await this.storeABTestResult(e,u,d),p(d)}catch(t){return m(g(t))}}async recommendStrategy(e){try{let u=await this.memory.search("learning:strategy:optimized:*",100),a=[];for(let t of u){let r=await this.memory.get(t);if(r&&r.confidence>.6){let i=this.scoreContextMatch(r,e),n=r.improvement*r.confidence;a.push({strategy:r.optimizedStrategy,score:i*.4+n*.6})}}return a.length===0?p({name:"default-strategy",parameters:this.getDefaultParameters(e),expectedOutcome:{success_rate:.7}}):(a.sort((t,r)=>r.score-t.score),p(a[0].strategy))}catch(u){return m(g(u))}}async evaluateStrategy(e,u){try{let a={},t=this.calculateSuccessRate(u),r=this.calculateAverageDuration(u),i=this.calculateAverageReward(u);a.success_rate=t,a.avg_duration_ms=r,a.avg_reward=i;let n=[];t>.8&&n.push("High success rate"),r<5e3&&n.push("Fast execution"),i>.7&&n.push("Consistently good rewards");let o=[];t<.5&&o.push("Low success rate needs investigation"),r>3e4&&o.push("Slow execution time"),i<.3&&o.push("Low reward values");let l=this.identifyImprovementAreas(e,a,u),c={strategy:e,metrics:a,strengths:n,weaknesses:o,improvementAreas:l};return await this.storeStrategyEvaluation(c),p(c)}catch(a){return m(g(a))}}async trackMetrics(e,u){try{let a={strategyId:e,metrics:u,timestamp:new Date,samples:1},t=`learning:metrics:history:${e}:${Date.now()}`;return await this.memory.set(t,a,{namespace:"learning-optimization",ttl:86400*30}),await this.updateAggregatedMetrics(e,u),p(void 0)}catch(a){return m(g(a))}}async getMetricsHistory(e,u=100){try{let a=await this.memory.search(`learning:metrics:history:${e}:*`,u),t=[];for(let r of a){let i=await this.memory.get(r);i&&t.push(i)}return t.sort((r,i)=>r.timestamp.getTime()-i.timestamp.getTime()),p(t)}catch(a){return m(g(a))}}async gridSearchOptimize(e,u,a){try{let t=this.generateParameterCombinations(e),r={},i=u.direction==="maximize"?-1/0:1/0;for(let n of t){let o=this.scoreParameters(n,a,u);(u.direction==="maximize"?o>i:o<i)&&(i=o,r=n)}return p(r)}catch(t){return m(g(t))}}evaluateStrategyPerformance(e,u,a){let t=0,r=0;for(let i of u){let n=i.result.outcome[a.metric]??0;t+=n,r++}return r>0?t/r:0}async optimizeParameters(e,u,a){let t={...e};for(let[r,i]of Object.entries(e))if(st(r)&&typeof i=="number"){let n=[-.1,-.05,0,.05,.1],o=0,l=this.scoreParameters(t,u,a);for(let c of n){let E={...t,[r]:i*(1+c)},d=this.scoreParameters(E,u,a);(a.direction==="maximize"?d>l:d<l)&&(l=d,o=c)}t[r]=i*(1+o)}return t}scoreParameters(e,u,a){let t=0,r=0;for(let i of u){let n=i.result.success?1:.5,o=this.calculateParamSimilarity(e,i.state.context),l=i.result.outcome[a.metric]??0;t+=o*l*n,r+=n}return r>0?t/r:0}calculateParamSimilarity(e,u){let a=0,t=0;for(let[r,i]of Object.entries(e))if(u[r]!==void 0)if(t++,typeof i=="number"&&typeof u[r]=="number"){let n=Math.abs(i-u[r]),o=Math.max(Math.abs(i),Math.abs(u[r]),1);a+=1-n/o}else i===u[r]&&a++;return t>0?a/t:.5}predictOutcome(e,u){let a={},t={},r={};for(let i of u)if(i.result.success)for(let[n,o]of Object.entries(i.result.outcome))st(n)&&typeof o=="number"&&(t[n]=(t[n]||0)+o,r[n]=(r[n]||0)+1);for(let[i,n]of Object.entries(t))st(i)&&(a[i]=n/r[i]);return a}async validateOptimization(e,u,a){let t=[];for(let r of a){let i=u.expectedOutcome,n=Object.entries(i).every(([o,l])=>{let c=r.result.outcome[o]??0;return Math.abs(c-l)/Math.max(l,1)<.2});t.push({testId:r.id,passed:n,metrics:r.state.metrics})}return t}calculateImprovement(e,u,a){if(e===0)return u>0?1:0;let t=u-e,r=a.direction==="maximize"?t/e:-t/e;return Math.max(-1,Math.min(1,r))}calculateOptimizationConfidence(e,u,a){let t=Math.min(1,e/(this.config.minSamplesForOptimization*2)),r=a.filter(n=>n.passed).length/Math.max(a.length,1),i=Math.abs(u)>this.config.improvementThreshold?1:.5;return t*.3+r*.5+i*.2}inferDomainFromExperiences(e){let u=new Map;for(let r of e)u.set(r.domain,(u.get(r.domain)||0)+1);let a="learning-optimization",t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}async collectStrategyMetrics(e,u,a){let t=await this.memory.search("learning:metrics:history:*:*",a*2),r=[];for(let i of t){let n=await this.memory.get(i);n&&n.metrics[u]!==void 0&&r.push(n.metrics[u])}for(;r.length<a;){let i=e.expectedOutcome[u]||.5,n=(K()-.5)*.2;r.push(i+n)}return r}calculateMean(e){return e.length===0?0:e.reduce((u,a)=>u+a,0)/e.length}calculateStdDev(e){if(e.length===0)return 0;let u=this.calculateMean(e),a=e.map(t=>Math.pow(t-u,2));return Math.sqrt(a.reduce((t,r)=>t+r,0)/e.length)}calculatePValue(e,u){let a=this.calculateMean(e),t=this.calculateMean(u),r=Math.pow(this.calculateStdDev(e),2),i=Math.pow(this.calculateStdDev(u),2),n=e.length,o=u.length,l=Math.sqrt(r/n+i/o);if(l===0)return .5;let c=Math.abs(a-t)/l,E=2*(1-this.normalCDF(c));return Math.max(0,Math.min(1,E))}normalCDF(e){let u=.254829592,a=-.284496736,t=1.421413741,r=-1.453152027,i=1.061405429,n=.3275911,o=e<0?-1:1;e=Math.abs(e)/Math.sqrt(2);let l=1/(1+n*e),c=1-((((i*l+r)*l+t)*l+a)*l+u)*l*Math.exp(-e*e);return .5*(1+o*c)}scoreContextMatch(e,u){let a=0,t=0;return u.tags.some(r=>r===e.objective.metric)&&(a+=1),t+=1,u.tags.some(r=>r===e.domain)&&(a+=1),t+=1,t>0?a/t:.5}getDefaultParameters(e){let u={timeout:3e4,retryCount:3,concurrency:4};return e.framework&&(u.framework=e.framework),e.language&&(u.language=e.language),u}calculateSuccessRate(e){return e.length===0?0:e.filter(u=>u.result.success).length/e.length}calculateAverageDuration(e){return e.length===0?0:e.reduce((u,a)=>u+a.result.duration,0)/e.length}calculateAverageReward(e){return e.length===0?0:e.reduce((u,a)=>u+a.reward,0)/e.length}identifyImprovementAreas(e,u,a){let t=[];u.success_rate<.8&&t.push("Increase success rate by tuning parameters"),u.avg_duration_ms>1e4&&t.push("Optimize for faster execution"),u.avg_reward<.5&&t.push("Improve reward through better strategy selection");let r=e.parameters;return r.retryCount<2&&t.push("Consider increasing retry count for resilience"),r.concurrency>8&&t.push("High concurrency may cause resource contention"),t}generateParameterCombinations(e){let u=Object.keys(e);if(u.length===0)return[{}];let a=[];function t(r,i){if(r===u.length){a.push({...i});return}let n=u[r];if(!st(n)){t(r+1,i);return}for(let o of e[n])i[n]=o,t(r+1,i)}return t(0,{}),a}async updateAggregatedMetrics(e,u){let a=`learning:metrics:aggregated:${e}`,r=(await this.memory.get(a))?.metrics||{};for(let[i,n]of Object.entries(u))st(i)&&(r[i]||(r[i]={sum:0,count:0}),r[i].sum+=n,r[i].count+=1);await this.memory.set(a,{metrics:r,updatedAt:new Date},{namespace:"learning-optimization",persist:!0})}async storeOptimizationResult(e){await this.memory.set(`learning:strategy:optimized:${e.id}`,e,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:strategy:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}async storeABTestResult(e,u,a){let t=A();await this.memory.set(`learning:abtest:${t}`,{testId:t,strategyA:e.name,strategyB:u.name,result:a,timestamp:new Date},{namespace:"learning-optimization",persist:!0})}async storeStrategyEvaluation(e){let u=A();await this.memory.set(`learning:evaluation:${u}`,{...e,evaluatedAt:new Date},{namespace:"learning-optimization",ttl:86400*7})}};S();var N2u={metricsRetentionDays:90,anomalyThreshold:2.5,trendWindowSize:7,alertThresholds:{error_rate:.05,latency_p99:5e3,memory_usage:.9,cpu_usage:.8}},i0=class{constructor(e,u={}){this.memory=e;this.config={...N2u,...u}}config;async recordMetric(e,u,a,t,r=[]){try{let i={id:A(),name:e,value:u,unit:a,domain:t,tags:r,timestamp:new Date};return await this.memory.set(`production:metric:${i.id}`,i,{namespace:"learning-optimization",ttl:this.config.metricsRetentionDays*86400}),await this.indexMetric(i),await this.checkForAnomalies(i),p(i.id)}catch(i){return m(g(i))}}async recordMetricsBatch(e){try{let u=[];for(let a of e){let t=await this.recordMetric(a.name,a.value,a.unit,a.domain,a.tags);t.success&&u.push(t.value)}return p(u)}catch(u){return m(g(u))}}async getMetricsHistory(e,u,a){try{let t=a?`production:metric:index:${e}:${a}:*`:`production:metric:index:${e}:*`,r=await this.memory.search(t,1e3),i=[];for(let n of r){let o=await this.memory.get(n);if(o){let l=await this.memory.get(`production:metric:${o}`);l&&u.contains(l.timestamp)&&i.push(l)}}return i.sort((n,o)=>n.timestamp.getTime()-o.timestamp.getTime()),p(i)}catch(t){return m(g(t))}}async recordIncident(e,u,a,t,r){try{let i={id:A(),severity:e,title:u,description:a,domain:t,metrics:r,startedAt:new Date};return await this.memory.set(`production:incident:${i.id}`,i,{namespace:"learning-optimization",persist:!0}),await this.indexIncident(i),await this.createExperienceFromIncident(i),p(i)}catch(i){return m(g(i))}}async resolveIncident(e,u,a){try{let t=await this.memory.get(`production:incident:${e}`);if(!t)return m(new Error(`Incident ${e} not found`));let r={...t,rootCause:u,resolution:a,resolvedAt:new Date};return await this.memory.set(`production:incident:${e}`,r,{namespace:"learning-optimization",persist:!0}),await this.updateExperienceWithResolution(r),p(r)}catch(t){return m(g(t))}}async getRecentIncidents(e=10,u){try{let a=u?`production:incident:index:domain:${u}:*`:"production:incident:*",t=await this.memory.search(a,e*2),r=[];for(let n of t)if(n.includes(":index:")){let o=await this.memory.get(n);if(o){let l=await this.memory.get(`production:incident:${o}`);l&&r.push(l)}}else{let o=await this.memory.get(n);o&&r.push(o)}r.sort((n,o)=>o.startedAt.getTime()-n.startedAt.getTime());let i=Array.from(new Map(r.map(n=>[n.id,n])).values());return p(i.slice(0,e))}catch(a){return m(g(a))}}async getProductionHealth(){try{let e=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","code-intelligence","security-compliance","learning-optimization"],u={},a={},t="healthy",r=0,i=0;for(let E of e){let d=await this.getDomainHealth(E);u[E]=d,d.status==="degraded"&&r++,d.status==="unhealthy"&&i++;for(let[D,h]of Object.entries(d.metrics))a[`${E}_${D}`]=h}i>0?t="unhealthy":r>e.length/3&&(t="degraded");let n=await this.calculateTrends(),o=await this.getRecentIncidents(5),l=o.success?o.value:[],c=this.generateHealthRecommendations(u,a,l);return p({overall:t,domains:u,metrics:a,trends:n,recentIncidents:l,recommendations:c})}catch(e){return m(g(e))}}async getDomainHealth(e){let u=Ju.lastNDays(1),a=await this.getMetricsHistory("*",u,e),t={};if(a.success)for(let o of a.value)t[o.name],t[o.name]=o.value;let r=await this.getRecentIncidents(100,e),i=r.success?r.value.filter(o=>!o.resolvedAt).length:0,n="healthy";return i>2?n="unhealthy":i>0&&(n="degraded"),t.error_rate>this.config.alertThresholds.error_rate?n="unhealthy":t.latency_p99>this.config.alertThresholds.latency_p99&&(n="degraded"),{status:n,metrics:t,activeIncidents:i}}async calculateTrends(){let e=[],u=["error_rate","latency_p99","success_rate"],a=this.config.trendWindowSize;for(let t of u)for(let r=0;r<a;r++){let i=new Date;i.setDate(i.getDate()-r),i.setHours(0,0,0,0);let n=new Date(i);n.setHours(23,59,59,999);let o=Ju.create(i,n),l=await this.getMetricsHistory(t,o);if(l.success&&l.value.length>0){let c=l.value.reduce((E,d)=>E+d.value,0)/l.value.length;e.push({timestamp:i,metric:t,value:c})}}return e}generateHealthRecommendations(e,u,a){let t=[];for(let[n,o]of Object.entries(e))o.status==="unhealthy"?t.push(`Domain ${n} is unhealthy. Review active incidents and metrics.`):o.status==="degraded"&&t.push(`Domain ${n} is degraded. Monitor closely.`);for(let[n,o]of Object.entries(u)){let l=n.split("_").slice(-2).join("_"),c=this.config.alertThresholds[l];c&&o>c&&t.push(`Metric ${n} (${o.toFixed(2)}) exceeds threshold (${c})`)}let r=a.filter(n=>!n.resolvedAt);return r.length>3&&t.push(`${r.length} unresolved incidents require attention`),a.reduce((n,o)=>(n[o.severity]=(n[o.severity]||0)+1,n),{}).critical>2&&t.push("Multiple critical incidents detected. Consider system-wide review."),t.length===0&&t.push("All systems operating within normal parameters."),t}async extractInsights(e,u){try{let a=await this.getMetricsHistory("*",e,u),t=a.success?a.value:[],r=await this.getRecentIncidents(50,u),i=r.success?r.value:[],n=t.length,o=i.filter(D=>D.resolvedAt),l=i.length>0?o.length/i.length:1,c=this.calculateRewardFromIncidents(i),E=this.generateInsightRecommendations(t,i),d=this.detectMetricAnomalies(t);return p({experienceCount:n,successRate:l,avgReward:c,patterns:[],anomalies:d,recommendations:E})}catch(a){return m(g(a))}}async recordMilestone(e,u,a){try{let t={name:e,achievedAt:new Date,domain:u};return await this.memory.set(`production:milestone:${A()}`,{...t,metrics:a},{namespace:"learning-optimization",persist:!0}),p(t)}catch(t){return m(g(t))}}async getRecentMilestones(e=10){try{let u=await this.memory.search("production:milestone:*",e),a=[];for(let t of u){let r=await this.memory.get(t);r&&a.push(r)}return a.sort((t,r)=>r.achievedAt.getTime()-t.achievedAt.getTime()),p(a.slice(0,e))}catch(u){return m(g(u))}}async indexMetric(e){await this.memory.set(`production:metric:index:${e.name}:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",ttl:this.config.metricsRetentionDays*86400})}async indexIncident(e){await this.memory.set(`production:incident:index:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`production:incident:index:severity:${e.severity}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}async checkForAnomalies(e){let u=Ju.lastNDays(7),a=await this.getMetricsHistory(e.name,u,e.domain);if(!a.success||a.value.length<10)return;let t=a.value.map(o=>o.value),r=t.reduce((o,l)=>o+l,0)/t.length,i=Math.sqrt(t.reduce((o,l)=>o+Math.pow(l-r,2),0)/t.length),n=Math.abs(e.value-r)/(i||1);n>this.config.anomalyThreshold&&await this.memory.set(`production:anomaly:${A()}`,{metricId:e.id,metricName:e.name,value:e.value,mean:r,stdDev:i,deviation:n,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*7})}async createExperienceFromIncident(e){let u={context:{incidentId:e.id,severity:e.severity,domain:e.domain},metrics:e.metrics},a={success:!1,outcome:e.metrics,duration:0},t={id:A(),agentId:{value:"production-intel",domain:"learning-optimization",type:"analyzer"},domain:e.domain,action:`incident-${e.severity}`,state:u,result:a,reward:this.calculateIncidentReward(e),timestamp:e.startedAt};await this.memory.set(`learning:experience:${t.id}`,t,{namespace:"learning-optimization",ttl:86400*30})}async updateExperienceWithResolution(e){if(!e.resolvedAt)return;let u={context:{incidentId:e.id,rootCause:e.rootCause,resolution:e.resolution},metrics:e.metrics},a=e.resolvedAt.getTime()-e.startedAt.getTime(),t={success:!0,outcome:{...e.metrics,resolution_time_ms:a},duration:a},r={id:A(),agentId:{value:"production-intel",domain:"learning-optimization",type:"analyzer"},domain:e.domain,action:`resolution-${e.severity}`,state:u,result:t,reward:1-this.calculateIncidentReward(e),timestamp:e.resolvedAt};await this.memory.set(`learning:experience:${r.id}`,r,{namespace:"learning-optimization",ttl:86400*30})}calculateIncidentReward(e){return-({critical:.9,high:.7,medium:.4,low:.2}[e.severity]||.5)}calculateRewardFromIncidents(e){if(e.length===0)return .8;let u={critical:.1,high:.3,medium:.6,low:.8},a=0,t=0;for(let r of e){let i=u[r.severity]||.5,n=r.resolvedAt?.2:0;a+=i+n,t++}return t>0?a/t:.8}generateInsightRecommendations(e,u){let a=[],t=new Map;for(let r of e){let i=t.get(r.name)||[];i.push(r.value),t.set(r.name,i)}for(let[r,i]of t){let n=this.calculateTrendDirection(i);n==="increasing"&&r.includes("error")?a.push(`${r} is trending upward. Investigate root causes.`):n==="decreasing"&&r.includes("success")&&a.push(`${r} is declining. Review recent changes.`)}if(u.length>0){let r=new Map;for(let i of u)r.set(i.domain,(r.get(i.domain)||0)+1);for(let[i,n]of r)n>3&&a.push(`Domain ${i} has ${n} incidents. Consider preventive measures.`)}return a}detectMetricAnomalies(e){let u=[],a=new Map;for(let t of e){let r=a.get(t.name)||[];r.push(t),a.set(t.name,r)}for(let[t,r]of a){if(r.length<5)continue;let i=r.map(l=>l.value),n=i.reduce((l,c)=>l+c,0)/i.length,o=Math.sqrt(i.reduce((l,c)=>l+Math.pow(c-n,2),0)/i.length);for(let l of r){let c=Math.abs(l.value-n)/(o||1);c>this.config.anomalyThreshold&&u.push({experienceId:l.id,type:"outlier-reward",description:`${t} value ${l.value.toFixed(2)} is ${c.toFixed(1)} std deviations from mean`,deviation:c})}}return u}calculateTrendDirection(e){if(e.length<3)return"stable";let u=e.slice(0,Math.floor(e.length/2)),a=e.slice(Math.floor(e.length/2)),t=u.reduce((n,o)=>n+o,0)/u.length,i=(a.reduce((n,o)=>n+o,0)/a.length-t)/(t||1);return i>.1?"increasing":i<-.1?"decreasing":"stable"}};async function WE(s,e,u){await s.set(`learning:strategy:current:${e}`,u,{namespace:"learning-optimization",persist:!0})}function $E(s,e){let u=s.map(a=>a.result.outcome[e]??0).filter(a=>!isNaN(a));return u.length===0?0:u.reduce((a,t)=>a+t,0)/u.length}function qE(s){return{"test-generation":["test-execution","coverage-analysis"],"test-execution":["test-generation","coverage-analysis","quality-assessment"],"coverage-analysis":["test-generation","test-execution","quality-assessment"],"quality-assessment":["test-execution","coverage-analysis","defect-intelligence"],"defect-intelligence":["quality-assessment","code-intelligence"],"requirements-validation":["test-generation","quality-assessment"],"code-intelligence":["defect-intelligence","security-compliance"],"security-compliance":["code-intelligence","quality-assessment"],"contract-testing":["test-generation","test-execution"],"visual-accessibility":["quality-assessment"],"chaos-resilience":["test-execution","quality-assessment"],"learning-optimization":Fu.filter(u=>u!=="learning-optimization"),"enterprise-integration":["contract-testing","security-compliance","quality-assessment"],coordination:Fu.filter(u=>u!=="coordination")}[s]||[]}function JE(s){let e=[],u=new Set;for(let a of s){if(u.has(a.id))continue;let t=[a];u.add(a.id);for(let r of s)u.has(r.id)||a.type===r.type&&a.domain===r.domain&&I2u(a.context,r.context)&&(t.push(r),u.add(r.id));t.length>=2&&e.push(t)}return e}function I2u(s,e){return s.tags.some(u=>e.tags.includes(u))}function UE(s,e,u){let a=JSON.stringify({patternCount:s.length,knowledgeCount:e.length,strategyCount:u.length,patternIds:s.map(r=>r.id).sort(),knowledgeIds:e.map(r=>r.id).sort(),strategyIds:u.map(r=>r.id).sort()}),t=0;for(let r=0;r<a.length;r++){let i=a.charCodeAt(r);t=(t<<5)-t+i,t=t&t}return Math.abs(t).toString(16)}N();var q0=B.create("learning-optimization/consensus");async function ZE(s,e,u,a){let t=O({id:A(),type:"pattern-recommendation",confidence:e,description:`Verify pattern recommendation: ${s.name} (${s.type}) for domain ${s.domain}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:e>.9?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Pattern recommendation '${s.name}' verified by consensus`),!0):(q0.warn(`Pattern recommendation '${s.name}' NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function QE(s,e,u,a){let t=O({id:A(),type:"optimization-suggestion",confidence:e,description:`Verify optimization: ${s.metric} from ${s.currentValue} to ${s.targetValue} via ${s.strategy}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:e>.85?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Optimization suggestion for '${s.metric}' verified by consensus`),!0):(q0.warn(`Optimization suggestion for '${s.metric}' NOT verified`),!1)}return!0}async function YE(s,e,u,a){let t=O({id:A(),type:"cross-domain-insight",confidence:e,description:`Verify cross-domain insight: ${s.description}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:"high"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Cross-domain insight verified by consensus for ${s.targetDomains.length} target domains`),!0):(q0.warn(`Cross-domain insight NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}var H2u={maxConcurrentWorkflows:3,defaultTimeout:12e4,enableAutoOptimization:!0,publishEvents:!0,learningCycleIntervalMs:36e5,enableDreamScheduler:!0,dreamCycleIntervalMs:36e5,enableExperienceTrigger:!0,experienceThreshold:50,enableQualityGateFailureTrigger:!0,autoApplyHighConfidenceInsights:!1,autoApplyConfidenceThreshold:.8,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},Tu=B.create("learning-optimization"),_i=class extends Y{constructor(u,a,t,r={}){let i={...H2u,...r};super(u,"learning-optimization",i,{verifyFindingTypes:["pattern-recommendation","optimization-suggestion","cross-domain-insight"]});this.memory=a;this.agentCoordinator=t;this.learningService=new a0({memory:a}),this.transferService=new t0(a),this.optimizerService=new r0(a),this.productionIntel=new i0(a)}learningService;transferService;optimizerService;productionIntel;sona=null;dreamScheduler=null;async onInitialize(){try{this.sona=await gu({domain:"learning-optimization",loadOnInit:!0,autoSaveInterval:6e4,maxPatterns:1e4,minConfidence:.5}),Tu.info("PersistentSONAEngine initialized for pattern learning")}catch(u){Tu.error("Failed to initialize PersistentSONAEngine:",u instanceof Error?u:void 0),Tu.warn("Continuing without SONA pattern persistence"),this.sona=null}if(this.config.enableDreamScheduler)try{let u=await D4();await u.initialize(),this.dreamScheduler=h4({dreamEngine:u,eventBus:this.eventBus,memoryBackend:this.memory},{autoScheduleIntervalMs:this.config.dreamCycleIntervalMs,enableExperienceTrigger:this.config.enableExperienceTrigger,experienceThreshold:this.config.experienceThreshold,enableQualityGateFailureTrigger:this.config.enableQualityGateFailureTrigger,autoApplyHighConfidenceInsights:this.config.autoApplyHighConfidenceInsights,insightConfidenceThreshold:this.config.autoApplyConfidenceThreshold}),await this.dreamScheduler.initialize(),this.dreamScheduler.start(),Tu.info("DreamScheduler initialized and started")}catch{Tu.warn("Failed to initialize DreamScheduler:")}this.subscribeToEvents(),await this.loadWorkflowState()}async onDispose(){if(await this.saveWorkflowState(),this.dreamScheduler){try{await this.dreamScheduler.dispose(),Tu.info("DreamScheduler disposed")}catch(u){Tu.error("Error disposing DreamScheduler:",u instanceof Error?u:void 0)}this.dreamScheduler=null}if(this.initialized&&this.sona)try{await this.sona.close()}catch(u){Tu.error("Error closing SONA engine:",u instanceof Error?u:void 0)}}getActiveWorkflows(){return super.getActiveWorkflows()}async runLearningCycle(u){let a=A();try{if(this.startWorkflow(a,"learning-cycle"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, using conservative strategy for learning cycle"),this.minCutMixin.shouldPauseOperations())return m(new Error("Learning cycle paused: topology is in critical state"));let t=await this.spawnLearningAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value);let r=Ju.lastNDays(1),i=await this.getExperiencesForDomain(u,r),n=i.success?i.value:[];this.updateWorkflowProgress(a,20);let o=await this.learningService.mineExperiences(u,r),l=o.success?o.value.patterns.length:0;this.updateWorkflowProgress(a,50);let c=0,E=[];if(n.length>=10){let h={metric:"success_rate",direction:"maximize",constraints:[]},C=await this.getCurrentStrategy(u),y=await this.optimizerService.optimizeStrategy(C,h,n);y.success&&(c=1,E.push({metric:h.metric,before:this.calculateMetricValue(n,h.metric),after:y.value.optimizedStrategy.expectedOutcome[h.metric]||0,percentChange:y.value.improvement*100}))}this.updateWorkflowProgress(a,80);let d=0;o.success&&o.value.recommendations.length>0&&(await this.transferService.createKnowledge("heuristic",u,o.value.recommendations,{value:`learning-agent-${a.slice(0,8)}`,domain:"learning-optimization",type:"analyzer"},[u])).success&&(d=1),this.completeWorkflow(a),await this.agentCoordinator.stop(t.value);let D={domain:u,experiencesProcessed:n.length,patternsLearned:l,strategiesOptimized:c,knowledgeGenerated:d,improvements:E};return this.config.publishEvents&&l>0&&await this.publishPatternConsolidated(l,[u]),p(D)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async optimizeAllStrategies(){let u=A();try{if(this.startWorkflow(u,"optimization"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, using conservative optimization strategy"),this.minCutMixin.shouldPauseOperations())return m(new Error("Optimization paused: topology is in critical state"));let a={},t=0,r=0,i=0,n=Fu.filter(l=>l!=="learning-optimization");for(let l=0;l<n.length;l++){let c=n[l];this.updateWorkflowProgress(u,Math.round(l/n.length*100));let E=Ju.lastNDays(7),d=await this.getExperiencesForDomain(c,E);if(!d.success||d.value.length<10)continue;let D=d.value,h={metric:"success_rate",direction:"maximize",constraints:[]},C=await this.getCurrentStrategy(c),y=await this.optimizerService.optimizeStrategy(C,h,D);y.success&&(t++,r+=y.value.improvement,i++,a[c]={strategiesOptimized:1,avgImprovement:y.value.improvement,bestStrategy:y.value.optimizedStrategy},await this.storeStrategy(c,y.value.optimizedStrategy))}this.completeWorkflow(u);let o={domainsOptimized:i,totalStrategies:t,avgImprovement:t>0?r/t:0,byDomain:a};return this.config.publishEvents&&t>0&&await this.publishOptimizationApplied(o),p(o)}catch(a){return this.failWorkflow(u,String(a)),m(g(a))}}async shareCrossDomainLearnings(){let u=A();try{if(this.startWorkflow(u,"transfer"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, limiting cross-domain transfer scope"),this.minCutMixin.shouldPauseOperations())return m(new Error("Cross-domain sharing paused: topology is in critical state"));let a=0,t=[],r=0,i=0,n=0,o=await this.transferService.queryKnowledge({minRelevance:.7,limit:100});if(!o.success)return this.failWorkflow(u,o.error.message),m(o.error);let l=o.value;for(let d of l){let D=this.getRelatedDomains(d.domain);for(let h of D){if(h===d.domain)continue;i++,(await this.transferService.transferKnowledge(d,h)).success&&(n++,a++,t.includes(h)||t.push(h))}this.updateWorkflowProgress(u,Math.round(a/(l.length*2)*100))}let c=await this.learningService.getPatternStats();if(c.success){let d=c.value.topPatterns;if(d.length>=2){let D=this.findSimilarPatterns(d);for(let h of D)h.length>=2&&(await this.learningService.consolidatePatterns(h.map(y=>y.id))).success&&r++}}this.completeWorkflow(u);let E={knowledgeShared:a,domainsUpdated:t,transferSuccessRate:i>0?n/i:1,newPatternsCreated:r};return this.config.publishEvents&&a>0&&await this.publishTransferCompleted(E),p(E)}catch(a){return this.failWorkflow(u,String(a)),m(g(a))}}async getLearningDashboard(){try{let u=await this.learningService.getPatternStats(),a=u.success?u.value:null,t=await this.transferService.queryKnowledge({limit:1e3}),r=t.success?t.value.length:0,i=Ju.lastNDays(1),n=0;for(let C of Fu){let y=await this.getExperiencesForDomain(C,i);y.success&&(n+=y.value.length)}let o=await this.productionIntel.getProductionHealth(),l=o.success?o.value.trends:[],c=await this.productionIntel.getRecentMilestones(5),E=c.success?c.value:[],d=a?a.avgSuccessRate*.6+a.avgConfidence*.4:.5,D=[];if(a){let C=Object.entries(a.byDomain).filter(([y,x])=>x>0).map(([y,x])=>({domain:y,score:x})).sort((y,x)=>x.score-y.score);D.push(...C.slice(0,3).map(y=>y.domain))}let h={overallLearningRate:d,totalPatterns:a?.totalPatterns||0,totalKnowledge:r,experiencesLast24h:n,topPerformingDomains:D,learningTrend:l,recentMilestones:E};return p(h)}catch(u){return m(g(u))}}learnPattern(u,a,t,r,i,n){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.createPattern(u,a,t,r,i,n)}ensureInitialized(){if(!this.initialized)throw new Error("[LearningOptimizationCoordinator] Not initialized. Call initialize() first.")}ensureSONAAvailable(){if(!this.sona)throw new Error("[LearningOptimizationCoordinator] SONA engine is not available. Pattern persistence failed during initialization.")}async adaptPattern(u,a,t){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.adaptPattern(u,a,t)}getSONAStats(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getStats()}getSONAPatterns(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getAllPatterns()}getSONAPatternsByType(u){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getPatternsByType(u)}getSONAPatternsByDomain(u){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getPatternsByDomain(u)}updateSONAPattern(u,a,t){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.updatePattern(u,a,t)}forceSONALearning(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.forceLearn()}isSONAAvailable(){return this.initialized&&this.sona!==null}exportSONAPatterns(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.exportPatterns()}importSONAPatterns(u){this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.importPatterns(u)}async verifySONAPerformance(u=100){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.verifyPerformance(u)}async triggerDreamCycle(u){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");let a=await this.dreamScheduler.triggerDream(u);return this.config.publishEvents&&await this.publishDreamCycleCompleted(a.cycle.id,a.cycle.durationMs??0,a.cycle.conceptsProcessed,a.insights.map(t=>({id:t.id,type:t.type,description:t.description,noveltyScore:t.noveltyScore,confidenceScore:t.confidenceScore,actionable:t.actionable,suggestedAction:t.suggestedAction,sourceConcepts:t.sourceConcepts})),a.patternsCreated),a}getDreamStatus(){return this.dreamScheduler?.getStatus()??null}isDreamSchedulerAvailable(){return this.dreamScheduler!==null}getLastDreamResult(){return this.dreamScheduler?.getLastDreamResult()??null}async triggerQuickDream(){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");return this.dreamScheduler.triggerQuickDream()}async triggerFullDream(){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");return this.dreamScheduler.triggerFullDream()}async exportModels(u){let a=A();try{this.startWorkflow(a,"export");let t=u||Fu,r=[],i=[],n=[];for(let d of t){let D=await this.memory.search("learning:pattern:*",500);for(let h of D){let C=await this.memory.get(h);C&&t.includes(C.domain)&&r.push(C)}this.updateWorkflowProgress(a,Math.round(r.length/100*30))}let o=await this.transferService.queryKnowledge({limit:1e3});if(o.success)for(let d of o.value)t.includes(d.domain)&&i.push(d);this.updateWorkflowProgress(a,60);let l=await this.memory.search("learning:strategy:optimized:*",200);for(let d of l){let D=await this.memory.get(d);D&&t.includes(D.domain)&&n.push(D)}this.updateWorkflowProgress(a,90);let c=this.calculateChecksum(r,i,n);return this.completeWorkflow(a),p({version:"1.0.0",exportedAt:new Date,patterns:r,knowledge:i,strategies:n,checksum:c})}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async importModels(u){let a=A();try{if(this.startWorkflow(a,"import"),this.calculateChecksum(u.patterns,u.knowledge,u.strategies)!==u.checksum)return this.failWorkflow(a,"Checksum mismatch"),m(new Error("Import failed: checksum mismatch"));let r=0,i=0,n=0,o=[];for(let c of u.patterns){let E=await this.memory.get(`learning:pattern:${c.id}`);E?E.confidence<c.confidence?(await this.memory.set(`learning:pattern:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),r++,o.push({type:"pattern",id:c.id,reason:"Existing pattern had lower confidence",resolution:"overwrite"})):o.push({type:"pattern",id:c.id,reason:"Existing pattern has higher confidence",resolution:"skip"}):(await this.memory.set(`learning:pattern:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),r++),this.updateWorkflowProgress(a,Math.round(r/u.patterns.length*30))}for(let c of u.knowledge){let E=await this.memory.get(`learning:knowledge:shared:${c.id}`);E?c.version>E.version?(await this.memory.set(`learning:knowledge:shared:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),i++,o.push({type:"knowledge",id:c.id,reason:"Import has newer version",resolution:"overwrite"})):o.push({type:"knowledge",id:c.id,reason:"Existing knowledge is same or newer version",resolution:"skip"}):(await this.memory.set(`learning:knowledge:shared:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),i++),this.updateWorkflowProgress(a,30+Math.round(i/u.knowledge.length*30))}for(let c of u.strategies){let E=await this.memory.get(`learning:strategy:optimized:${c.id}`);E?c.confidence>E.confidence?(await this.memory.set(`learning:strategy:optimized:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),n++,o.push({type:"strategy",id:c.id,reason:"Import has higher confidence",resolution:"overwrite"})):o.push({type:"strategy",id:c.id,reason:"Existing strategy has higher confidence",resolution:"skip"}):(await this.memory.set(`learning:strategy:optimized:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),n++),this.updateWorkflowProgress(a,60+Math.round(n/u.strategies.length*40))}return this.completeWorkflow(a),p({patternsImported:r,knowledgeImported:i,strategiesImported:n,conflicts:o,resolved:!0})}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}subscribeToEvents(){this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("learning.ExperienceCaptured",this.handleExperienceCaptured.bind(this))}async handleTestRunCompleted(u){let{runId:a,passed:t,failed:r,duration:i}=u.payload,n=t+r>0?t/(t+r):0;await this.learningService.recordExperience({agentId:{value:"test-execution",domain:"test-execution",type:"tester"},domain:"test-execution",action:"test-run",state:{context:{runId:a},metrics:{passed:t,failed:r,duration:i}},result:{success:n>.8,outcome:{success_rate:n,passed:t,failed:r},duration:i},reward:n})}async handleCoverageGap(u){let{gapId:a,file:t,riskScore:r}=u.payload;await this.learningService.recordExperience({agentId:{value:"coverage-analysis",domain:"coverage-analysis",type:"analyzer"},domain:"coverage-analysis",action:"gap-detection",state:{context:{gapId:a,file:t},metrics:{riskScore:r}},result:{success:!0,outcome:{risk_score:r},duration:0},reward:1-r})}async handleQualityGate(u){let{gateId:a,passed:t}=u.payload;await this.learningService.recordExperience({agentId:{value:"quality-assessment",domain:"quality-assessment",type:"validator"},domain:"quality-assessment",action:"gate-evaluation",state:{context:{gateId:a},metrics:{passed:t?1:0}},result:{success:t,outcome:{gate_passed:t?1:0},duration:0},reward:t?1:0})}async handleExperienceCaptured(u){let{experience:a}=u.payload;if(!a.success||a.quality<.7)return;let t=a.domain||"learning-optimization";if(await this.learningService.recordExperience({agentId:{value:a.agent||"unknown",domain:t,type:"specialist"},domain:t,action:a.task,state:{context:{experienceId:a.id,trajectoryId:a.trajectoryId,model:a.model},metrics:{durationMs:a.durationMs,stepCount:a.steps.length,quality:a.quality}},result:{success:a.success,outcome:{quality:a.quality,patterns_extracted:a.patterns?.length||0},duration:a.durationMs},reward:a.quality}),a.patterns&&a.patterns.length>0&&a.domain){let r=this.getRelatedDomains(a.domain);for(let i of r)i!==a.domain&&await this.transferService.transferKnowledge({id:`exp-${a.id}`,domain:a.domain,type:"workflow",content:{format:"json",data:{task:a.task,steps:a.steps,quality:a.quality,patterns:a.patterns}},sourceAgentId:{value:a.agent||"experience-capture",domain:a.domain,type:"specialist"},targetDomains:[i],relevanceScore:a.quality,version:1,createdAt:new Date(a.startedAt)},i);Tu.info(`[LearningOptimizationCoordinator] Experience ${a.id} transferred to ${r.length} related domains`)}this.dreamScheduler&&this.dreamScheduler.recordExperience({id:a.id,agentType:a.agent||"unknown",domain:t,taskType:a.task,success:a.success,duration:a.durationMs,context:{quality:a.quality,steps:a.steps.length,patterns:a.patterns?.length||0},timestamp:new Date(a.startedAt)})}async publishPatternConsolidated(u,a){let t={patternCount:u,domains:a,improvements:0},r=L(Yu.PatternConsolidated,"learning-optimization",t);await this.eventBus.publish(r)}async publishTransferCompleted(u){let a={sourceProject:"current",targetProject:"current",patternsTransferred:u.knowledgeShared,successRate:u.transferSuccessRate},t=L(Yu.TransferCompleted,"learning-optimization",a);await this.eventBus.publish(t)}async publishOptimizationApplied(u){let a=L(Yu.OptimizationApplied,"learning-optimization",{domainsOptimized:u.domainsOptimized,avgImprovement:u.avgImprovement});await this.eventBus.publish(a)}async publishDreamCycleCompleted(u,a,t,r,i){if(!this.config.publishEvents)return;let n={cycleId:u,durationMs:a,conceptsProcessed:t,insights:r,patternsCreated:i},o=L(Yu.DreamCycleCompleted,"learning-optimization",n);await this.eventBus.publish(o),Tu.info(`[LearningOptimizationCoordinator] Published dream cycle completion: ${r.length} insights for ${t} concepts`)}async spawnLearningAgent(u,a){if(!this.agentCoordinator.canSpawn())return m(new Error("Agent limit reached"));let t={name:`learning-agent-${u.slice(0,8)}`,domain:"learning-optimization",type:"optimizer",capabilities:["pattern-learning","experience-mining",a],config:{workflowId:u,targetDomain:a}};return this.agentCoordinator.spawn(t)}async loadWorkflowState(){let u=await this.memory.get("learning-optimization:coordinator:workflows");if(u)for(let a of u)a.status==="running"&&(a.status="failed",a.error="Coordinator restarted",a.completedAt=new Date),this.workflows.set(a.id,a)}async saveWorkflowState(){let u=Array.from(this.workflows.values());await this.memory.set("learning-optimization:coordinator:workflows",u,{namespace:"learning-optimization",persist:!0})}async getExperiencesForDomain(u,a){let t=await this.memory.search(`learning:experience:index:domain:${u}:*`,500),r=[];for(let i of t){let n=await this.memory.get(i);if(n){let o=await this.memory.get(`learning:experience:${n}`);o&&a.contains(o.timestamp)&&r.push(o)}}return p(r)}async getCurrentStrategy(u){let a=`learning:strategy:current:${u}`,t=await this.memory.get(a);return t||{name:`default-${u}`,parameters:{timeout:3e4,retryCount:3,concurrency:4},expectedOutcome:{success_rate:.8}}}async storeStrategy(u,a){await WE(this.memory,u,a)}calculateMetricValue(u,a){return $E(u,a)}getRelatedDomains(u){return qE(u)}findSimilarPatterns(u){return JE(u)}calculateChecksum(u,a,t){return UE(u,a,t)}async verifyPatternRecommendation(u,a){return ZE(u,a,this.consensusMixin,this.domainName)}async verifyOptimizationSuggestion(u,a){return QE(u,a,this.consensusMixin,this.domainName)}async verifyCrossDomainInsight(u,a){return YE(u,a,this.consensusMixin,this.domainName)}};S();var ql=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;learningService=null;transferService=null;optimizerService=null;productionIntel=null;pluginConfig;get name(){return"learning-optimization"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{isSONAAvailable:()=>this.coordinator?.isSONAAvailable()??!1,runLearningCycle:this.runLearningCycle.bind(this),optimizeAllStrategies:this.optimizeAllStrategies.bind(this),shareCrossDomainLearnings:this.shareCrossDomainLearnings.bind(this),getLearningDashboard:this.getLearningDashboard.bind(this),exportModels:this.exportModels.bind(this),importModels:this.importModels.bind(this),learnPattern:this.learnPattern.bind(this),findMatchingPatterns:this.findMatchingPatterns.bind(this),applyPattern:this.applyPattern.bind(this),updatePatternFeedback:this.updatePatternFeedback.bind(this),getPatternStats:this.getPatternStats.bind(this),queryKnowledge:this.queryKnowledge.bind(this),transferKnowledge:this.transferKnowledge.bind(this),optimizeStrategy:this.optimizeStrategy.bind(this),runABTest:this.runABTest.bind(this),recommendStrategy:this.recommendStrategy.bind(this),evaluateStrategy:this.evaluateStrategy.bind(this),getCoordinator:()=>this.coordinator,getActiveWorkflows:()=>this.coordinator?.getActiveWorkflows()||[],getLearningService:()=>this.learningService,getTransferService:()=>this.transferService,getOptimizerService:()=>this.optimizerService,getProductionIntelService:()=>this.productionIntel}}getTaskHandlers(){return new Map([["run-learning-cycle",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.domain;return a?this.coordinator.runLearningCycle(a):m(new Error("Invalid run-learning-cycle payload: missing domain"))}],["optimize-strategies",async u=>this.coordinator?this.coordinator.optimizeAllStrategies():m(new Error("Coordinator not initialized"))],["share-learnings",async u=>this.coordinator?this.coordinator.shareCrossDomainLearnings():m(new Error("Coordinator not initialized"))],["learn-pattern",async u=>{if(!this.learningService)return m(new Error("Learning service not initialized"));let a=u.experiences;return!a||a.length===0?m(new Error("Invalid learn-pattern payload: missing experiences")):this.learningService.learnPattern(a)}],["query-knowledge",async u=>{if(!this.transferService)return m(new Error("Transfer service not initialized"));let a=u.query;return a?this.transferService.queryKnowledge(a):m(new Error("Invalid query-knowledge payload: missing query"))}]])}async onInitialize(){this.learningService=new a0({memory:this.memory},this.pluginConfig.learningService),this.transferService=new t0(this.memory,this.pluginConfig.transferService),this.optimizerService=new r0(this.memory,this.pluginConfig.optimizerService),this.productionIntel=new i0(this.memory,this.pluginConfig.productionIntel),this.coordinator=new _i(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null,this.learningService=null,this.transferService=null,this.optimizerService=null,this.productionIntel=null}subscribeToEvents(){this.eventBus.subscribe("test-generation.TestGenerated",this.handleTestGenerated.bind(this)),this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("defect-intelligence.DefectPredicted",this.handleDefectPredicted.bind(this)),this.eventBus.subscribe("code-intelligence.ImpactAnalysisCompleted",this.handleImpactAnalysis.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"test-generation.TestGenerated":await this.handleTestGenerated(u);break;case"test-execution.TestRunCompleted":await this.handleTestRunCompleted(u);break;case"coverage-analysis.CoverageGapDetected":await this.handleCoverageGap(u);break;default:break}}async runLearningCycle(u){this.ensureInitialized();try{let a=await this.coordinator.runLearningCycle(u);return a.success?this.trackSuccessfulOperation("learning-cycle"):this.trackFailedOperation("learning-cycle",a.error),a}catch(a){return this.handleError(a)}}async optimizeAllStrategies(){this.ensureInitialized();try{let u=await this.coordinator.optimizeAllStrategies();return u.success?this.trackSuccessfulOperation("optimization"):this.trackFailedOperation("optimization",u.error),u}catch(u){return this.handleError(u)}}async shareCrossDomainLearnings(){this.ensureInitialized();try{return await this.coordinator.shareCrossDomainLearnings()}catch(u){return this.handleError(u)}}async getLearningDashboard(){this.ensureInitialized();try{return await this.coordinator.getLearningDashboard()}catch(u){return this.handleError(u)}}async exportModels(u){this.ensureInitialized();try{return await this.coordinator.exportModels(u)}catch(a){return this.handleError(a)}}async importModels(u){this.ensureInitialized();try{return await this.coordinator.importModels(u)}catch(a){return this.handleError(a)}}async learnPattern(u){this.ensureInitialized();try{return await this.learningService.learnPattern(u)}catch(a){return this.handleError(a)}}async findMatchingPatterns(u,a){this.ensureInitialized();try{return await this.learningService.findMatchingPatterns(u,a)}catch(t){return this.handleError(t)}}async applyPattern(u,a){this.ensureInitialized();try{return await this.learningService.applyPattern(u,a)}catch(t){return this.handleError(t)}}async updatePatternFeedback(u,a){this.ensureInitialized();try{return await this.learningService.updatePatternFeedback(u,a)}catch(t){return this.handleError(t)}}async getPatternStats(u){this.ensureInitialized();try{return await this.learningService.getPatternStats(u)}catch(a){return this.handleError(a)}}async queryKnowledge(u){this.ensureInitialized();try{return await this.transferService.queryKnowledge(u)}catch(a){return this.handleError(a)}}async transferKnowledge(u,a){this.ensureInitialized();try{return await this.transferService.transferKnowledge(u,a)}catch(t){return this.handleError(t)}}async optimizeStrategy(u,a,t){this.ensureInitialized();try{return await this.optimizerService.optimizeStrategy(u,a,t)}catch(r){return this.handleError(r)}}async runABTest(u,a,t){this.ensureInitialized();try{return await this.optimizerService.runABTest(u,a,t)}catch(r){return this.handleError(r)}}async recommendStrategy(u){this.ensureInitialized();try{return await this.optimizerService.recommendStrategy(u)}catch(a){return this.handleError(a)}}async evaluateStrategy(u,a){this.ensureInitialized();try{return await this.optimizerService.evaluateStrategy(u,a)}catch(t){return this.handleError(t)}}async handleTestGenerated(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"test-generation",domain:"test-generation",type:"generator"},domain:"test-generation",action:"test-generated",state:{context:{testId:a.testId,testType:a.testType},metrics:{}},result:{success:!0,outcome:{generated:1},duration:0},reward:.8})}async handleTestRunCompleted(u){let a=u.payload,t=a.passed+a.failed>0?a.passed/(a.passed+a.failed):0;await this.learningService.recordExperience({agentId:{value:"test-execution",domain:"test-execution",type:"tester"},domain:"test-execution",action:"test-run",state:{context:{runId:a.runId},metrics:{passed:a.passed,failed:a.failed,duration:a.duration}},result:{success:t>.8,outcome:{success_rate:t,passed:a.passed,failed:a.failed},duration:a.duration},reward:t}),await this.productionIntel.recordMetric("test_success_rate",t,"ratio","test-execution",["automated"])}async handleCoverageGap(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"coverage-analysis",domain:"coverage-analysis",type:"analyzer"},domain:"coverage-analysis",action:"gap-detection",state:{context:{gapId:a.gapId,file:a.file},metrics:{riskScore:a.riskScore}},result:{success:!0,outcome:{risk_score:a.riskScore},duration:0},reward:1-a.riskScore})}async handleQualityGate(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"quality-assessment",domain:"quality-assessment",type:"validator"},domain:"quality-assessment",action:"gate-evaluation",state:{context:{gateId:a.gateId},metrics:{passed:a.passed?1:0}},result:{success:a.passed,outcome:{gate_passed:a.passed?1:0},duration:0},reward:a.passed?1:0})}async handleDefectPredicted(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"defect-intelligence",domain:"defect-intelligence",type:"analyzer"},domain:"defect-intelligence",action:"defect-prediction",state:{context:{predictionId:a.predictionId},metrics:{probability:a.probability}},result:{success:!0,outcome:{probability:a.probability},duration:0},reward:.7})}async handleImpactAnalysis(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"code-intelligence",domain:"code-intelligence",type:"analyzer"},domain:"code-intelligence",action:"impact-analysis",state:{context:{analysisId:a.analysisId},metrics:{changedFiles:a.changedFiles.length,impactedFiles:a.impactedFiles.length}},result:{success:!0,outcome:{changed_count:a.changedFiles.length,impacted_count:a.impactedFiles.length},duration:0},reward:.8})}ensureInitialized(){if(!this._initialized)throw new Error("LearningOptimizationPlugin is not initialized");if(!this.coordinator||!this.learningService||!this.transferService||!this.optimizerService||!this.productionIntel)throw new Error("LearningOptimizationPlugin services are not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),m(a)}trackSuccessfulOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,total:a.agents.total+1,idle:a.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,failed:t.agents.failed+1},errors:[...t.errors.slice(-9),a.message]})}};function XE(s,e,u,a){return new ql(s,e,u,a)}var Jl=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}workflowOrchestrator=null;pluginConfig;get name(){return"coordination"}get version(){return"1.0.0"}get dependencies(){return Fu.filter(u=>u!=="coordination")}getAPI(){return{listWorkflows:async()=>{if(!this.workflowOrchestrator)throw new Error("Workflow orchestrator not initialized");return this.workflowOrchestrator.listWorkflows()}}}async onInitialize(){this.workflowOrchestrator=p4(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.workflowConfig),await this.workflowOrchestrator.initialize(),this.updateHealth({status:"healthy",agents:{total:0,active:0,idle:0,failed:0}})}async onDispose(){this.workflowOrchestrator&&(await this.workflowOrchestrator.dispose(),this.workflowOrchestrator=null)}async onEvent(u){u.type.startsWith("coordination.")&&await this.handleCoordinationEvent(u)}subscribeToEvents(){this.eventBus.subscribe("coordination.workflow.execute",async u=>{await this.handleEvent(u)})}async handleCoordinationEvent(u){u.type.split(".")[1]==="workflow"&&await this.handleWorkflowEvent(u)}async handleWorkflowEvent(u){this.workflowOrchestrator}};function u3(s,e,u,a){return new Jl(s,e,u,a)}var Mu={CoverageAnalyzerService:"coverage-analysis.CoverageAnalyzerService",SecurityScannerService:"security-compliance.SecurityScannerService",isSemgrepAvailable:"security-compliance.isSemgrepAvailable",runSemgrepWithRules:"security-compliance.runSemgrepWithRules",convertSemgrepFindings:"security-compliance.convertSemgrepFindings",createTestGeneratorService:"test-generation.createTestGeneratorService",KnowledgeGraphService:"code-intelligence.KnowledgeGraphService",QualityAnalyzerService:"quality-assessment.QualityAnalyzerService"},Ul=class{factories=new Map;register(e,u){this.factories.set(e,u)}resolve(e){let u=this.factories.get(e);if(!u)throw new Error(`DomainServiceRegistry: service '${e}' not registered. Ensure the domain module is initialized before coordination.`);return u}has(e){return this.factories.has(e)}clear(){this.factories.clear()}keys(){return Array.from(this.factories.keys())}},Ru=new Ul;Ru.register(Mu.createTestGeneratorService,s=>Ie(s));Ru.register(Mu.CoverageAnalyzerService,s=>new ve(s));Ru.register(Mu.SecurityScannerService,s=>new Ou(s));Ru.register(Mu.isSemgrepAvailable,Xa);Ru.register(Mu.runSemgrepWithRules,li);Ru.register(Mu.convertSemgrepFindings,ci);Ru.register(Mu.KnowledgeGraphService,s=>new ze(s));S();Ru.register(Mu.QualityAnalyzerService,s=>new oe(s));S();N();S();var n0={SoapOperationTested:"enterprise-integration.SoapOperationTested",MessageFlowTested:"enterprise-integration.MessageFlowTested",BapiTested:"enterprise-integration.BapiTested",IDocValidated:"enterprise-integration.IDocValidated",ODataTested:"enterprise-integration.ODataTested",SodAnalyzed:"enterprise-integration.SodAnalyzed",MiddlewareFlowTested:"enterprise-integration.MiddlewareFlowTested",IntegrationValidationFailed:"enterprise-integration.IntegrationValidationFailed"},_2u={maxConcurrentWorkflows:8,defaultTimeout:12e4,publishEvents:!0,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},Wi=B.create("enterprise-integration"),$i=class extends Y{constructor(u,a,t,r={}){let i={..._2u,...r};super(u,"enterprise-integration",i,{verifyFindingTypes:["soap-fault","message-ordering-violation","rfc-compatibility-break","idoc-validation-failure","odata-contract-break","sod-conflict"],modelTimeout:12e4});this.memory=a;this.agentCoordinator=t}async onInitialize(){this.subscribeToEvents(),Wi.info("Enterprise Integration Coordinator initialized")}async onDispose(){}subscribeToEvents(){this.eventBus.subscribe("contract-testing.ContractVerified",this.handleContractVerified.bind(this)),this.eventBus.subscribe("chaos-resilience.FaultInjected",this.handleFaultInjected.bind(this))}getActiveWorkflows(){return super.getActiveWorkflows()}async validateWsdl(u){let a=A();try{if(this.startWorkflow(a,"soap"),this.minCutMixin.shouldPauseOperations())return m(new Error("WSDL validation paused: topology is in critical state"));let t=await this.spawnAgent(a,"qe-soap-tester",{task:"validate-wsdl",url:u});if(!t.success)return this.failWorkflow(a,t.error.message),t;let r={url:u,version:"1.1",services:[],schemas:[]};return await this.memory.set(`enterprise-integration:wsdl:${encodeURIComponent(u)}`,r,{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(a),p(r)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async testSoapOperation(u,a,t){let r=A();try{this.startWorkflow(r,"soap");let i=await this.spawnAgent(r,"qe-soap-tester",{task:"test-operation",wsdl:u,operation:a,input:t});if(!i.success)return this.failWorkflow(r,i.error.message),m(i.error);let n={operation:a,passed:!0,request:JSON.stringify(t),response:"",validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.SoapOperationTested,this.domainName,{operation:a,wsdlUrl:u.url,passed:n.passed,errors:n.validationErrors.length})),this.completeWorkflow(r),p(n)}catch(i){return this.failWorkflow(r,String(i)),m(g(i))}}async testMessageFlow(u,a){let t=A();try{this.startWorkflow(t,"messaging");let r=await this.spawnAgent(t,"qe-message-broker-tester",{task:"test-message-flow",brokerConfig:u,testCase:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={testCaseId:a.id,passed:!0,sentAt:new Date,receivedAt:new Date,latency:0,actualOutcome:a.expectedOutcome,errors:[]};return this.config.publishEvents&&await this.eventBus.publish(L(n0.MessageFlowTested,this.domainName,{protocol:u.protocol,queue:a.queue,passed:i.passed,latency:i.latency})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async testDlqHandling(u,a){let t=A();try{this.startWorkflow(t,"messaging");let r=await this.spawnAgent(t,"qe-message-broker-tester",{task:"test-dlq",brokerConfig:u,queue:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={queue:a,messageCount:0,poisonMessages:0,reprocessable:0,errors:[]};return this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async testBapiCall(u,a){let t=A();try{if(this.startWorkflow(t,"rfc"),this.minCutMixin.shouldPauseOperations())return m(new Error("BAPI testing paused: topology is in critical state"));let r=await this.spawnAgent(t,"qe-sap-rfc-tester",{task:"test-bapi",connection:u,bapi:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={bapiName:a.name,passed:!0,returnMessages:[],exportValues:{},tableData:{},duration:0,transactionCommitted:!1};return this.config.publishEvents&&await this.eventBus.publish(L(n0.BapiTested,this.domainName,{bapiName:a.name,passed:i.passed,returnType:i.returnMessages.length>0?i.returnMessages[0].type:"S"})),await this.memory.set(`enterprise-integration:bapi:${a.name}:${Date.now()}`,{bapiName:a.name,importParams:Object.keys(a.importParams),passed:i.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateIdoc(u,a){let t=A();try{this.startWorkflow(t,"idoc");let r=await this.spawnAgent(t,"qe-sap-idoc-tester",{task:"validate-idoc",definition:u,content:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={idocType:u.type,direction:"inbound",passed:!0,statusCode:3,statusMessage:"IDoc validated successfully",segmentValidation:[],processingTime:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.IDocValidated,this.domainName,{idocType:u.type,direction:i.direction,passed:i.passed,statusCode:i.statusCode})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateODataMetadata(u){let a=A();try{this.startWorkflow(a,"odata");let t=await this.spawnAgent(a,"qe-odata-contract-tester",{task:"validate-metadata",serviceUrl:u});if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);let r={version:"v4",serviceUrl:u,entitySets:[],functionImports:[],actions:[]};return await this.memory.set(`enterprise-integration:odata:${encodeURIComponent(u)}`,r,{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(a),p(r)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async testODataEntitySet(u,a){let t=A();try{this.startWorkflow(t,"odata");let r=await this.spawnAgent(t,"qe-odata-contract-tester",{task:"test-entity-set",metadata:u,entitySet:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={entitySet:a,operation:"CRUD",passed:!0,statusCode:200,validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.ODataTested,this.domainName,{entitySet:a,operation:i.operation,passed:i.passed,version:u.version})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateMessageFlow(u,a){let t=A();try{this.startWorkflow(t,"middleware");let r=await this.spawnAgent(t,"qe-middleware-validator",{task:"validate-flow",flow:u,input:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={flowName:u.name,passed:!0,routingCorrect:!0,transformationCorrect:!0,errorHandlingCorrect:!0,validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.MiddlewareFlowTested,this.domainName,{flowName:u.name,passed:i.passed,routingCorrect:i.routingCorrect,transformationCorrect:i.transformationCorrect})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateTransformation(u,a,t){let r=A();try{this.startWorkflow(r,"middleware");let i=await this.spawnAgent(r,"qe-middleware-validator",{task:"validate-transformation",spec:u,input:a,expectedOutput:t});return i.success?(this.completeWorkflow(r),p(!0)):(this.failWorkflow(r,i.error.message),m(i.error))}catch(i){return this.failWorkflow(r,String(i)),m(g(i))}}async analyzeSod(u,a){let t=A();try{this.startWorkflow(t,"sod");let r=await this.spawnAgent(t,"qe-sod-analyzer",{task:"analyze-sod",userId:u,ruleset:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={userId:u,conflicts:[],riskScore:0,compliant:!0,recommendations:[]};return this.config.publishEvents&&await this.eventBus.publish(L(n0.SodAnalyzed,this.domainName,{userId:u,conflicts:i.conflicts.length,compliant:i.compliant,riskScore:i.riskScore})),await this.memory.set(`enterprise-integration:sod:${u}:${Date.now()}`,{userId:u,ruleset:a.name,conflicts:i.conflicts.length,compliant:i.compliant,riskScore:i.riskScore,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async spawnAgent(u,a,t){let r={name:`${a}-${u.slice(0,8)}`,domain:"enterprise-integration",type:a,capabilities:[a],config:{workflowId:u,...t}},i=await this.agentCoordinator.spawn(r);return i.success&&this.addAgentToWorkflow(u,i.value),i}async verifyCriticalFinding(u,a){let t=O({id:A(),type:u.type,confidence:a,description:u.description,payload:u.payload,detectedBy:"enterprise-integration-coordinator",severity:a>.9?"critical":"high"});if(this.consensusMixin.requiresConsensus(t)){let r=await this.consensusMixin.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(Wi.info(`Finding verified by consensus: ${u.type}`),!0):(Wi.warn(`Finding NOT verified: ${u.type}`),!1)}return!0}async handleContractVerified(u){let a=u.payload;(a?.contractType==="soap"||a?.contractType==="odata")&&await this.memory.set(`enterprise-integration:contract-event:${Date.now()}`,{contractId:a.contractId,type:a.contractType,passed:a.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleFaultInjected(u){let a=u.payload;(a?.targetService?.includes("middleware")||a?.targetService?.includes("esb"))&&Wi.info(`Middleware fault injection detected: ${a.targetService}`)}};var Zl=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;pluginConfig;get name(){return"enterprise-integration"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{validateWsdl:this.validateWsdl.bind(this),testSoapOperation:this.testSoapOperation.bind(this),testMessageFlow:this.testMessageFlow.bind(this),testDlqHandling:this.testDlqHandling.bind(this),testBapiCall:this.testBapiCall.bind(this),validateIdoc:this.validateIdoc.bind(this),validateODataMetadata:this.validateODataMetadata.bind(this),testODataEntitySet:this.testODataEntitySet.bind(this),validateMessageFlow:this.validateMessageFlow.bind(this),validateTransformation:this.validateTransformation.bind(this),analyzeSod:this.analyzeSod.bind(this),getCoordinator:()=>this.coordinator,getActiveWorkflows:()=>this.coordinator?.getActiveWorkflows()||[]}}getTaskHandlers(){return new Map([["enterprise-integration:soap-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.wsdl,t=u.operation,r=u.input;return u.url&&!a?this.coordinator.validateWsdl(u.url):!a||!t?m(new Error("Invalid soap-test payload: missing wsdl or operation")):this.coordinator.testSoapOperation(a,t,r)}],["enterprise-integration:message-broker-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.brokerConfig,t=u.testCase,r=u.queue;return a?r&&!t?this.coordinator.testDlqHandling(a,r):t?this.coordinator.testMessageFlow(a,t):m(new Error("Invalid message-broker-test payload: missing testCase")):m(new Error("Invalid message-broker-test payload: missing brokerConfig"))}],["enterprise-integration:sap-rfc-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.connection,t=u.bapi;return!a||!t?m(new Error("Invalid sap-rfc-test payload: missing connection or bapi")):this.coordinator.testBapiCall(a,t)}],["enterprise-integration:sap-idoc-validate",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.definition,t=u.content;return!a||!t?m(new Error("Invalid sap-idoc-validate payload: missing definition or content")):this.coordinator.validateIdoc(a,t)}],["enterprise-integration:odata-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.serviceUrl,t=u.metadata,r=u.entitySet;return a&&!t?this.coordinator.validateODataMetadata(a):!t||!r?m(new Error("Invalid odata-test payload: missing metadata or entitySet")):this.coordinator.testODataEntitySet(t,r)}],["enterprise-integration:esb-flow-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.flow,t=u.input,r=u.spec;if(r){let i=u.transformInput,n=u.expectedOutput;return!i||!n?m(new Error("Invalid esb-flow-test payload: missing transformInput or expectedOutput for transformation")):this.coordinator.validateTransformation(r,i,n)}return!a||!t?m(new Error("Invalid esb-flow-test payload: missing flow or input")):this.coordinator.validateMessageFlow(a,t)}],["enterprise-integration:sod-analyze",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.userId,t=u.ruleset;return!a||!t?m(new Error("Invalid sod-analyze payload: missing userId or ruleset")):this.coordinator.analyzeSod(a,t)}]])}async onInitialize(){this.coordinator=new $i(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null}subscribeToEvents(){this.eventBus.subscribe("contract-testing.ContractVerified",this.handleContractVerified.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("chaos-resilience.FaultInjected",this.handleFaultInjected.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"contract-testing.ContractVerified":await this.handleContractVerified(u);break;case"quality-assessment.QualityGateEvaluated":await this.handleQualityGate(u);break;case"chaos-resilience.FaultInjected":await this.handleFaultInjected(u);break;default:break}}async validateWsdl(u){this.ensureInitialized();try{let a=await this.coordinator.validateWsdl(u);return a.success?this.trackSuccessfulOperation("validateWsdl"):this.trackFailedOperation(new Error(a.error.message)),a}catch(a){return this.handleError(a)}}async testSoapOperation(u,a,t){this.ensureInitialized();try{let r=await this.coordinator.testSoapOperation(u,a,t);return r.success?this.trackSuccessfulOperation("testSoapOperation"):this.trackFailedOperation(new Error(r.error.message)),r}catch(r){return this.handleError(r)}}async testMessageFlow(u,a){this.ensureInitialized();try{let t=await this.coordinator.testMessageFlow(u,a);return t.success?this.trackSuccessfulOperation("testMessageFlow"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async testDlqHandling(u,a){this.ensureInitialized();try{let t=await this.coordinator.testDlqHandling(u,a);return t.success?this.trackSuccessfulOperation("testDlqHandling"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async testBapiCall(u,a){this.ensureInitialized();try{let t=await this.coordinator.testBapiCall(u,a);return t.success?this.trackSuccessfulOperation("testBapiCall"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateIdoc(u,a){this.ensureInitialized();try{let t=await this.coordinator.validateIdoc(u,a);return t.success?this.trackSuccessfulOperation("validateIdoc"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateODataMetadata(u){this.ensureInitialized();try{let a=await this.coordinator.validateODataMetadata(u);return a.success?this.trackSuccessfulOperation("validateODataMetadata"):this.trackFailedOperation(new Error(a.error.message)),a}catch(a){return this.handleError(a)}}async testODataEntitySet(u,a){this.ensureInitialized();try{let t=await this.coordinator.testODataEntitySet(u,a);return t.success?this.trackSuccessfulOperation("testODataEntitySet"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateMessageFlow(u,a){this.ensureInitialized();try{let t=await this.coordinator.validateMessageFlow(u,a);return t.success?this.trackSuccessfulOperation("validateMessageFlow"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateTransformation(u,a,t){this.ensureInitialized();try{let r=await this.coordinator.validateTransformation(u,a,t);return r.success?this.trackSuccessfulOperation("validateTransformation"):this.trackFailedOperation(new Error(r.error.message)),r}catch(r){return this.handleError(r)}}async analyzeSod(u,a){this.ensureInitialized();try{let t=await this.coordinator.analyzeSod(u,a);return t.success?this.trackSuccessfulOperation("analyzeSod"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async handleContractVerified(u){let a=u.payload;(a.contractType==="soap"||a.contractType==="odata")&&await this.memory.set(`enterprise-integration:contract-verified:${a.contractId}`,{contractId:a.contractId,type:a.contractType,passed:a.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleQualityGate(u){let a=u.payload;a.checks.find(r=>r.name==="enterprise-integration")||await this.memory.set(`enterprise-integration:quality-gate-warning:${a.gateId}`,{warning:"Enterprise integration testing not included in quality gate",timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleFaultInjected(u){let a=u.payload;(a.targetService?.includes("middleware")||a.targetService?.includes("esb")||a.targetService?.includes("broker")||a.targetService?.includes("mq"))&&await this.memory.set(`enterprise-integration:fault-correlation:${a.faultId||Date.now()}`,{targetService:a.targetService,faultType:a.faultType,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:3600})}ensureInitialized(){if(!this._initialized)throw new Error("EnterpriseIntegrationPlugin is not initialized");if(!this.coordinator)throw new Error("EnterpriseIntegrationPlugin coordinator is not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),{success:!1,error:a}}trackSuccessfulOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,total:a.agents.total+1,idle:a.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,failed:a.agents.failed+1},errors:[...a.errors.slice(-9),u.message]})}};function a3(s,e,u,a){return new Zl(s,e,u,a)}var t3={"test-generation":(s,e,u)=>Cs(s,e,u),"test-execution":(s,e)=>Qc(s,e),"coverage-analysis":(s,e)=>Ws(s,e),"quality-assessment":(s,e,u)=>el(s,e,u),"defect-intelligence":(s,e,u)=>P1(s,e,u),"requirements-validation":(s,e,u)=>I1(s,e,u),"code-intelligence":(s,e,u)=>pl(s,e,u),"security-compliance":(s,e,u)=>jl(s,e,u),"contract-testing":(s,e,u)=>bE(s,e,u),"visual-accessibility":(s,e,u)=>HE(s,e,u),"chaos-resilience":(s,e,u)=>OE(s,e,u),"learning-optimization":(s,e,u)=>XE(s,e,u),"enterprise-integration":(s,e,u)=>a3(s,e,u),coordination:(s,e,u)=>u3(s,e,u)},$2u={maxConcurrentAgents:J0.MAX_CONCURRENT_AGENTS,memoryBackend:"hybrid",hnswEnabled:!0,lazyLoading:!0,enabledDomains:[...Fu],dataDir:void 0},Ql=class{_eventBus;_coordinator;_plugins;_memory;_config;_startTime;_initialized=!1;_loopTracker;constructor(e={}){this._config={...$2u,...e},this._startTime=new Date,this._memory=new Qi,this._eventBus=new xt,this._coordinator=new ft(this._config.maxConcurrentAgents),this._plugins=new aa(this._eventBus,this._memory,this._config.lazyLoading),this._loopTracker=new vt}get eventBus(){return this._eventBus}get coordinator(){return this._coordinator}get plugins(){return this._plugins}get memory(){return this._memory}async initialize(){if(this._initialized)return;let e=u4(),u=this._config.dataDir||o0.join(e,".agentic-qe");if(qi.existsSync(u)||qi.mkdirSync(u,{recursive:!0}),this._config.memoryBackend==="memory"){let t=o0.join(Ji("os").tmpdir(),`aqe-test-${Date.now()}-${W2u().slice(0,12)}.db`);await a4({dbPath:t})}else this._memory=new e4({sqlite:{path:o0.join(u,"memory.db"),walMode:!0,poolSize:3,busyTimeout:Xl.BUSY_TIMEOUT_MS},enableFallback:!0,defaultNamespace:"qe-kernel"}),this._plugins=new aa(this._eventBus,this._memory,this._config.lazyLoading);for(let t of this._config.enabledDomains){let r=t3[t];r&&this._plugins.registerFactory(t,async(i,n)=>Promise.resolve(r(i,n,this._coordinator)))}await this._memory.initialize();let a=new bt({agentId:"qe-kernel"});this._eventBus.registerMiddleware(a);try{let t=o0.join(u,"plugins"),r=new t4({cacheDir:t}),n=new r4({cache:r}).resolveLoadOrder();for(let o of n.ordered){let l=o.manifest,c=r.get(l.name,l.version);if(!c)continue;let E=o0.join(c.path,l.entryPoint);for(let d of l.domains){let D=d;if(t3[D])continue;this._plugins.registerFactory(D,async(C,y)=>{let x=await import(E),b=x.default??x.createPlugin;if(typeof b!="function")throw new Error(`Plugin "${l.name}" entry point must export a default function or "createPlugin" function`);return b(C,y,this._coordinator)})}}}catch{}this._config.lazyLoading||await this._plugins.loadAll();try{let{isAgentMemoryBranchingEnabled:t,isRVFPatternStoreEnabled:r}=await import("./feature-flags-R4QZYTIW.js");if(t()&&r()){let{getSharedRvfAdapter:i}=await import("./shared-rvf-adapter-6I2Z5UGL.js"),{AgentMemoryBranch:n}=await import("./agent-memory-branch-UFPKWUFK.js"),o=i(u,384);if(o){let l=new n(o,{branchDir:o0.join(u,"branches")});this._coordinator.setMemoryBranch(l)}}}catch{}try{let{getRvfMigrationStage:t}=await import("./feature-flags-R4QZYTIW.js"),r=t();if(r>=2){let{RvfMigrationCoordinator:i}=await import("./rvf-migration-coordinator-SIQVJB5S.js");await i.getInstance({stage:r}).initialize()}}catch{}this._initialized=!0}async dispose(){await this._plugins.disposeAll(),await this._coordinator.dispose(),await this._eventBus.dispose(),await this._memory.dispose(),this._initialized=!1}getDomainAPI(e){return this._plugins.getPlugin(e)?.getAPI()}async getDomainAPIAsync(e){let u=this._plugins.getPlugin(e);if(!u&&this._config.lazyLoading&&this._config.enabledDomains.includes(e))try{u=await this._plugins.load(e)}catch(a){console.error(`[QEKernel] Failed to lazy load domain ${e}:`,a);return}return u?.getAPI()}async ensureDomainLoaded(e){if(this._plugins.isLoaded(e))return!0;if(!this._config.enabledDomains.includes(e))return console.warn(`[QEKernel] Domain ${e} is not enabled`),!1;try{return await this._plugins.load(e),!0}catch(u){return console.error(`[QEKernel] Failed to load domain ${e}:`,u),!1}}isDomainLoaded(e){return this._plugins.isLoaded(e)}getLoadedDomains(){return this._plugins.getLoaded()}getPendingDomains(){let e=new Set(this._plugins.getLoaded());return this._config.enabledDomains.filter(u=>!e.has(u))}getHealth(){let e=this._coordinator.listAgents(),u={};for(let l of this._plugins.getLoaded()){let c=this._plugins.getPlugin(l);c&&(u[l]=c.getHealth())}for(let l of Fu)if(!u[l]){let c=this._config.enabledDomains.includes(l),E=this._config.lazyLoading&&c;u[l]={status:E?"healthy":c?"degraded":"healthy",agents:{total:0,active:0,idle:0,failed:0},errors:E?[]:c?["Domain not yet loaded"]:[],loaded:!1,lazyLoadable:E}}let a=this._coordinator.getActiveCount(),t=0,r=Number.MAX_SAFE_INTEGER;if(this._memory instanceof Qi){let l=this._memory.getStats();t=l.entries+l.vectors}else t=0;let n=this._eventBus.getMiddlewares().find(l=>l.name==="semantic-anti-drift"),o=n?n.getStats():void 0;return{status:this.determineOverallStatus(u),uptime:Date.now()-this._startTime.getTime(),domains:u,agents:{total:e.length,active:a,maxAllowed:this._config.maxConcurrentAgents},memory:{used:t,available:r},...o?{antiDrift:o}:{}}}determineOverallStatus(e){let u=Object.values(e).map(a=>a.status);return u.some(a=>a==="unhealthy")?"unhealthy":u.some(a=>a==="degraded")?"degraded":"healthy"}getConfig(){return{...this._config}}checkToolCall(e,u,a){if(process.env.AQE_LOOP_DETECTION_ENABLED==="false")return this._loopTracker.trackCall(e,u,a);let t=this._loopTracker.trackCall(e,u,a);if(t.action==="warn"){let r={id:`loop-warn-${e}-${Date.now()}`,type:on.LOOP_WARNING,timestamp:new Date,source:"coordination",correlationId:e,payload:{agentId:e,toolName:u,callCount:t.callCount,signature:t.signature}};this._eventBus.publish(r)}else if(t.action==="steer"){let r={id:`loop-detected-${e}-${Date.now()}`,type:on.LOOP_DETECTED,timestamp:new Date,source:"coordination",correlationId:e,payload:{agentId:e,toolName:u,callCount:t.callCount,signature:t.signature,steeringMessage:t.steeringMessage}};this._eventBus.publish(r)}return t}get loopTracker(){return this._loopTracker}};function dre(s){return new Ql(s)}export{Ie as a,ve as b,f0 as c,b0 as d,Ue as e,Dl as f,yu as g,Ju as h,Xe as i,Al as j,si as k,K0 as l,j0 as m,Ni as n,V0 as o,_0 as p,a0 as q,t0 as r,r0 as s,Mu as t,Ru as u,Ql as v,dre as w};
3029
+ // Execute action: {{action}}`,variables:a}}extractPatternContext(e){let u=new Set,a,t;for(let r of e){let i=r.state.context;if(i.language&&(a=i.language),i.framework&&(t=i.framework),i.tags&&Array.isArray(i.tags))for(let n of i.tags)u.add(n)}return{language:a,framework:t,tags:Array.from(u)}}calculateConsolidatedConfidence(e){let u=e.reduce((t,r)=>t+r.usageCount,0),a=0;for(let t of e){let r=u>0?t.usageCount/u:1/e.length;a+=t.confidence*r}return a}calculateWeightedSuccessRate(e){let u=e.reduce((t,r)=>t+r.usageCount,0),a=0;for(let t of e){let r=u>0?t.usageCount/u:1/e.length;a+=t.successRate*r}return a}detectAnomalies(e){let u=[],a=this.calculateAverageReward(e),t=this.calculateStdDev(e.map(r=>r.reward));for(let r of e){let i=Math.abs(r.reward-a)/(t||1);if(i>this.config.anomalyDeviationThreshold){let n="outlier-reward";r.result.success&&r.reward<a?n="unexpected-success":!r.result.success&&r.reward>a&&(n="unexpected-failure"),u.push({experienceId:r.id,type:n,description:`Reward ${r.reward.toFixed(2)} deviates ${i.toFixed(2)} std from mean ${a.toFixed(2)}`,deviation:i})}}return u}calculateStdDev(e){if(e.length===0)return 0;let u=e.reduce((t,r)=>t+r,0)/e.length,a=e.map(t=>Math.pow(t-u,2));return Math.sqrt(a.reduce((t,r)=>t+r,0)/e.length)}generateRecommendations(e,u,a){let t=[];return u<.5&&t.push("Low success rate detected. Consider reviewing the approach or gathering more training data."),a.length>e.length*.1&&t.push("High anomaly rate detected. Investigate unexpected outcomes for potential improvements."),e.reduce((i,n)=>i+n.result.duration,0)/e.length>6e4&&t.push("Average operation duration is high. Consider optimizing performance."),e.length<10&&t.push("Limited experience data. Collect more data points for better insights."),t.length===0&&t.push("Performance metrics are within acceptable ranges. Continue monitoring."),t}actionsSimilar(e,u){let a=i=>i.toLowerCase().replace(/[^a-z]/g,""),t=a(e),r=a(u);return!!(t===r||t.includes(r)||r.includes(t))}calculateCentroid(e){let u={},a={};for(let t of e)for(let[r,i]of Object.entries(t.state.metrics))u[r]=(u[r]||0)+i,a[r]=(a[r]||0)+1;for(let t of Object.keys(u))u[t]/=a[t];return{context:{},metrics:u}}isConstraintViolated(e,u){switch(e.operator){case"lt":return u>=e.value;case"gt":return u<=e.value;case"lte":return u>e.value;case"gte":return u<e.value;case"eq":return u!==e.value;default:return!1}}};S();var P2u={maxKnowledgeItems:1e3,relevanceThreshold:.5,transferDecayFactor:.1,crossDomainBoost:.2},t0=class{constructor(e,u={}){this.memory=e;this.config={...P2u,...u}}config;async shareKnowledge(e,u){try{await this.memory.set(`learning:knowledge:shared:${e.id}`,e,{namespace:"learning-optimization",persist:!0});for(let a of u)await this.memory.set(`learning:knowledge:access:${a.value}:${e.id}`,{knowledgeId:e.id,agentId:a.value,sharedAt:new Date,accessed:!1},{namespace:"learning-optimization",ttl:86400*7});return await this.recordSharingEvent(e,u),p(void 0)}catch(a){return m(g(a))}}async queryKnowledge(e){try{let u=[],a;e.domain?a=await this.memory.search(`learning:knowledge:*:${e.domain}:*`,e.limit||100):a=await this.memory.search("learning:knowledge:shared:*",e.limit||100);for(let t of a){let r=await this.memory.get(t);r&&this.matchesQuery(r,e)&&u.push(r)}if(u.sort((t,r)=>r.relevanceScore-t.relevanceScore),e.embedding&&e.embedding.length>0){let t=await this.memory.vectorSearch(e.embedding,e.limit||10);for(let r of t){let i=await this.memory.get(r.key);i&&!u.some(n=>n.id===i.id)&&this.matchesQuery(i,e)&&u.push(i)}}return p(u.slice(0,e.limit||100))}catch(u){return m(g(u))}}async synthesizeKnowledge(e){try{if(e.length<2)return m(new Error("Need at least 2 knowledge items to synthesize"));let u=[];for(let l of e){let c=await this.getKnowledgeById(l);c&&u.push(c)}if(u.length<2)return m(new Error("Not enough valid knowledge items found"));let a=this.determineSynthesizedType(u),t=this.determineSynthesizedDomain(u),r=this.mergeKnowledgeContent(u),i=u.reduce((l,c)=>l+c.relevanceScore,0)/u.length,n=Math.min(1,i+this.config.crossDomainBoost),o={id:A(),type:a,domain:t,content:r,sourceAgentId:u[0].sourceAgentId,targetDomains:this.mergeTargetDomains(u),relevanceScore:n,version:1,createdAt:new Date};return await this.storeKnowledge(o),await this.recordSynthesisEvent(o,e),p(o)}catch(u){return m(g(u))}}async transferKnowledge(e,u){try{if(e.domain===u)return m(new Error("Cannot transfer knowledge to the same domain"));let a=this.calculateTransferredRelevance(e,u);if(a<this.config.relevanceThreshold)return m(new Error(`Transferred relevance ${a} below threshold ${this.config.relevanceThreshold}`));let t=await this.adaptContentForDomain(e.content,e.domain,u),r={id:A(),type:e.type,domain:u,content:t,sourceAgentId:e.sourceAgentId,targetDomains:[u],relevanceScore:a,version:e.version+1,createdAt:new Date};return await this.storeKnowledge(r),await this.recordTransferEvent(e,r),p(r)}catch(a){return m(g(a))}}async validateRelevance(e,u){try{let a=e.relevanceScore;if(u.language&&e.content.metadata?.language===u.language&&(a+=.1),u.framework&&e.content.metadata?.framework===u.framework&&(a+=.1),u.tags.length>0&&e.content.metadata?.tags){let n=e.content.metadata.tags,o=u.tags.filter(l=>n.includes(l));a+=o.length/u.tags.length*.2}let r=(Date.now()-e.createdAt.getTime())/(1e3*60*60*24),i=Math.exp(-this.config.transferDecayFactor*r/30);return a*=i,e.expiresAt&&new Date>e.expiresAt&&(a*=.5),p(Math.min(1,Math.max(0,a)))}catch(a){return m(g(a))}}async createKnowledge(e,u,a,t,r=[],i){try{let n={id:A(),type:e,domain:u,content:{format:this.inferContentFormat(a),data:a,metadata:i},sourceAgentId:t,targetDomains:r,relevanceScore:1,version:1,createdAt:new Date};return await this.storeKnowledge(n),e==="embedding"&&Array.isArray(a)&&await this.memory.storeVector(`learning:knowledge:vector:${n.id}`,a,{knowledgeId:n.id}),p(n)}catch(n){return m(g(n))}}async getKnowledgeById(e){return await this.memory.get(`learning:knowledge:shared:${e}`)||null}async bulkTransfer(e,u,a){try{let t=await this.memory.search(`learning:knowledge:project:${e}:*`,500),r=[];for(let i of t){let n=await this.memory.get(i);if(!n||a?.types&&!a.types.includes(n.type)||a?.minRelevance&&n.relevanceScore<a.minRelevance)continue;let o=await this.adaptContentForProject(n.content,e,u),l={...n,id:A(),content:o,relevanceScore:n.relevanceScore*(1-this.config.transferDecayFactor),version:n.version+1,createdAt:new Date};await this.memory.set(`learning:knowledge:project:${u}:${l.id}`,l,{namespace:"learning-optimization",persist:!0}),r.push({knowledgeId:l.id,sourceDomain:n.domain,targetDomain:n.domain,originalRelevance:n.relevanceScore,transferredRelevance:l.relevanceScore,adaptations:["project-context-adapted"]})}return p(r)}catch(t){return m(g(t))}}async storeKnowledge(e){await this.memory.set(`learning:knowledge:shared:${e.id}`,e,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:knowledge:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:knowledge:type:${e.type}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}matchesQuery(e,u){if(u.type&&e.type!==u.type||u.domain&&e.domain!==u.domain||u.minRelevance!==void 0&&e.relevanceScore<u.minRelevance)return!1;if(u.tags&&u.tags.length>0){let a=e.content.metadata?.tags||[];if(!u.tags.some(r=>a.includes(r)))return!1}return!0}determineSynthesizedType(e){let u=new Map;for(let r of e)u.set(r.type,(u.get(r.type)||0)+1);let a=e[0].type,t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}determineSynthesizedDomain(e){let u=new Map;for(let r of e)u.set(r.domain,(u.get(r.domain)||0)+1);let a=e[0].domain,t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}mergeKnowledgeContent(e){let u={},a=[];for(let t of e)if(a.push(t.content.data),t.content.metadata)for(let[r,i]of Object.entries(t.content.metadata))if(Array.isArray(i)){let n=u[r]||[];u[r]=[...new Set([...n,...i])]}else u[r]=i;return{format:"json",data:{synthesized:!0,sources:a},metadata:{...u,synthesizedFrom:e.map(t=>t.id),synthesizedAt:new Date().toISOString()}}}mergeTargetDomains(e){let u=new Set;for(let a of e){u.add(a.domain);for(let t of a.targetDomains)u.add(t)}return Array.from(u)}calculateTransferredRelevance(e,u){let a=e.relevanceScore;a*=1-this.config.transferDecayFactor;let t=this.getDomainCompatibility(e.domain,u);return a*=t,e.targetDomains.includes(u)&&(a+=this.config.crossDomainBoost),Math.min(1,Math.max(0,a))}getDomainCompatibility(e,u){let a={"test-generation":["test-execution","coverage-analysis"],"test-execution":["test-generation","coverage-analysis","quality-assessment"],"coverage-analysis":["test-generation","test-execution","quality-assessment"],"quality-assessment":["test-execution","coverage-analysis","defect-intelligence"],"defect-intelligence":["quality-assessment","code-intelligence"],"requirements-validation":["test-generation","quality-assessment"],"code-intelligence":["defect-intelligence","security-compliance"],"security-compliance":["code-intelligence","quality-assessment"],"contract-testing":["test-generation","test-execution"],"visual-accessibility":["quality-assessment"],"chaos-resilience":["test-execution","quality-assessment"],"learning-optimization":["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence"],"enterprise-integration":["contract-testing","security-compliance","quality-assessment"],coordination:Fu.filter(t=>t!=="coordination")};return e===u?1:a[e]?.includes(u)?.8:.5}async adaptContentForDomain(e,u,a){return{...e,metadata:{...e.metadata||{},adaptedFrom:u,adaptedTo:a,adaptedAt:new Date().toISOString()}}}async adaptContentForProject(e,u,a){return{...e,metadata:{...e.metadata||{},sourceProject:u,targetProject:a,transferredAt:new Date().toISOString()}}}inferContentFormat(e){return typeof e=="string"?"text":Array.isArray(e)&&e.every(u=>typeof u=="number")?"embedding":"json"}async recordSharingEvent(e,u){await this.memory.set(`learning:knowledge:events:share:${e.id}:${Date.now()}`,{type:"share",knowledgeId:e.id,targetAgents:u.map(a=>a.value),timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}async recordSynthesisEvent(e,u){await this.memory.set(`learning:knowledge:events:synthesis:${e.id}`,{type:"synthesis",synthesizedId:e.id,sourceIds:u,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}async recordTransferEvent(e,u){await this.memory.set(`learning:knowledge:events:transfer:${u.id}`,{type:"transfer",originalId:e.id,transferredId:u.id,originalDomain:e.domain,targetDomain:u.domain,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*30})}};S();cu();var z2u={defaultConfidenceLevel:.95,minSamplesForOptimization:20,maxOptimizationIterations:100,improvementThreshold:.05,explorationRate:.1},L2u=["__proto__","constructor","prototype"];function st(s){return!L2u.includes(s)}var r0=class{constructor(e,u={}){this.memory=e;this.config={...z2u,...u}}config;async optimizeStrategy(e,u,a){try{if(a.length<this.config.minSamplesForOptimization)return m(new Error(`Need at least ${this.config.minSamplesForOptimization} experiences for optimization`));let t=this.evaluateStrategyPerformance(e,a,u),r=await this.optimizeParameters(e.parameters,a,u),i={name:`${e.name}-optimized`,parameters:r,expectedOutcome:this.predictOutcome(r,a)},n=await this.validateOptimization(e,i,a.slice(-10)),o=this.evaluateStrategyPerformance(i,a,u),l=this.calculateImprovement(t,o,u),c=this.calculateOptimizationConfidence(a.length,l,n),E=this.inferDomainFromExperiences(a),d={id:A(),domain:E,objective:u,currentStrategy:e,optimizedStrategy:i,improvement:l,confidence:c,validationResults:n};return await this.storeOptimizationResult(d),p(d)}catch(t){return m(g(t))}}async runABTest(e,u,a){try{let t=await this.collectStrategyMetrics(e,a.metric,a.minSamples),r=await this.collectStrategyMetrics(u,a.metric,a.minSamples),i=this.calculateMean(t),n=this.calculateMean(r),o=this.calculateStdDev(t),l=this.calculateStdDev(r),c=this.calculatePValue(t,r),E;c<1-a.confidenceLevel?E=i>n?"A":"B":E="inconclusive";let d={winner:E,strategyAMetrics:{[a.metric]:i,stdDev:o,samples:t.length},strategyBMetrics:{[a.metric]:n,stdDev:l,samples:r.length},pValue:c,sampleSizeA:t.length,sampleSizeB:r.length};return await this.storeABTestResult(e,u,d),p(d)}catch(t){return m(g(t))}}async recommendStrategy(e){try{let u=await this.memory.search("learning:strategy:optimized:*",100),a=[];for(let t of u){let r=await this.memory.get(t);if(r&&r.confidence>.6){let i=this.scoreContextMatch(r,e),n=r.improvement*r.confidence;a.push({strategy:r.optimizedStrategy,score:i*.4+n*.6})}}return a.length===0?p({name:"default-strategy",parameters:this.getDefaultParameters(e),expectedOutcome:{success_rate:.7}}):(a.sort((t,r)=>r.score-t.score),p(a[0].strategy))}catch(u){return m(g(u))}}async evaluateStrategy(e,u){try{let a={},t=this.calculateSuccessRate(u),r=this.calculateAverageDuration(u),i=this.calculateAverageReward(u);a.success_rate=t,a.avg_duration_ms=r,a.avg_reward=i;let n=[];t>.8&&n.push("High success rate"),r<5e3&&n.push("Fast execution"),i>.7&&n.push("Consistently good rewards");let o=[];t<.5&&o.push("Low success rate needs investigation"),r>3e4&&o.push("Slow execution time"),i<.3&&o.push("Low reward values");let l=this.identifyImprovementAreas(e,a,u),c={strategy:e,metrics:a,strengths:n,weaknesses:o,improvementAreas:l};return await this.storeStrategyEvaluation(c),p(c)}catch(a){return m(g(a))}}async trackMetrics(e,u){try{let a={strategyId:e,metrics:u,timestamp:new Date,samples:1},t=`learning:metrics:history:${e}:${Date.now()}`;return await this.memory.set(t,a,{namespace:"learning-optimization",ttl:86400*30}),await this.updateAggregatedMetrics(e,u),p(void 0)}catch(a){return m(g(a))}}async getMetricsHistory(e,u=100){try{let a=await this.memory.search(`learning:metrics:history:${e}:*`,u),t=[];for(let r of a){let i=await this.memory.get(r);i&&t.push(i)}return t.sort((r,i)=>r.timestamp.getTime()-i.timestamp.getTime()),p(t)}catch(a){return m(g(a))}}async gridSearchOptimize(e,u,a){try{let t=this.generateParameterCombinations(e),r={},i=u.direction==="maximize"?-1/0:1/0;for(let n of t){let o=this.scoreParameters(n,a,u);(u.direction==="maximize"?o>i:o<i)&&(i=o,r=n)}return p(r)}catch(t){return m(g(t))}}evaluateStrategyPerformance(e,u,a){let t=0,r=0;for(let i of u){let n=i.result.outcome[a.metric]??0;t+=n,r++}return r>0?t/r:0}async optimizeParameters(e,u,a){let t={...e};for(let[r,i]of Object.entries(e))if(st(r)&&typeof i=="number"){let n=[-.1,-.05,0,.05,.1],o=0,l=this.scoreParameters(t,u,a);for(let c of n){let E={...t,[r]:i*(1+c)},d=this.scoreParameters(E,u,a);(a.direction==="maximize"?d>l:d<l)&&(l=d,o=c)}t[r]=i*(1+o)}return t}scoreParameters(e,u,a){let t=0,r=0;for(let i of u){let n=i.result.success?1:.5,o=this.calculateParamSimilarity(e,i.state.context),l=i.result.outcome[a.metric]??0;t+=o*l*n,r+=n}return r>0?t/r:0}calculateParamSimilarity(e,u){let a=0,t=0;for(let[r,i]of Object.entries(e))if(u[r]!==void 0)if(t++,typeof i=="number"&&typeof u[r]=="number"){let n=Math.abs(i-u[r]),o=Math.max(Math.abs(i),Math.abs(u[r]),1);a+=1-n/o}else i===u[r]&&a++;return t>0?a/t:.5}predictOutcome(e,u){let a={},t={},r={};for(let i of u)if(i.result.success)for(let[n,o]of Object.entries(i.result.outcome))st(n)&&typeof o=="number"&&(t[n]=(t[n]||0)+o,r[n]=(r[n]||0)+1);for(let[i,n]of Object.entries(t))st(i)&&(a[i]=n/r[i]);return a}async validateOptimization(e,u,a){let t=[];for(let r of a){let i=u.expectedOutcome,n=Object.entries(i).every(([o,l])=>{let c=r.result.outcome[o]??0;return Math.abs(c-l)/Math.max(l,1)<.2});t.push({testId:r.id,passed:n,metrics:r.state.metrics})}return t}calculateImprovement(e,u,a){if(e===0)return u>0?1:0;let t=u-e,r=a.direction==="maximize"?t/e:-t/e;return Math.max(-1,Math.min(1,r))}calculateOptimizationConfidence(e,u,a){let t=Math.min(1,e/(this.config.minSamplesForOptimization*2)),r=a.filter(n=>n.passed).length/Math.max(a.length,1),i=Math.abs(u)>this.config.improvementThreshold?1:.5;return t*.3+r*.5+i*.2}inferDomainFromExperiences(e){let u=new Map;for(let r of e)u.set(r.domain,(u.get(r.domain)||0)+1);let a="learning-optimization",t=0;for(let[r,i]of u)i>t&&(t=i,a=r);return a}async collectStrategyMetrics(e,u,a){let t=await this.memory.search("learning:metrics:history:*:*",a*2),r=[];for(let i of t){let n=await this.memory.get(i);n&&n.metrics[u]!==void 0&&r.push(n.metrics[u])}for(;r.length<a;){let i=e.expectedOutcome[u]||.5,n=(K()-.5)*.2;r.push(i+n)}return r}calculateMean(e){return e.length===0?0:e.reduce((u,a)=>u+a,0)/e.length}calculateStdDev(e){if(e.length===0)return 0;let u=this.calculateMean(e),a=e.map(t=>Math.pow(t-u,2));return Math.sqrt(a.reduce((t,r)=>t+r,0)/e.length)}calculatePValue(e,u){let a=this.calculateMean(e),t=this.calculateMean(u),r=Math.pow(this.calculateStdDev(e),2),i=Math.pow(this.calculateStdDev(u),2),n=e.length,o=u.length,l=Math.sqrt(r/n+i/o);if(l===0)return .5;let c=Math.abs(a-t)/l,E=2*(1-this.normalCDF(c));return Math.max(0,Math.min(1,E))}normalCDF(e){let u=.254829592,a=-.284496736,t=1.421413741,r=-1.453152027,i=1.061405429,n=.3275911,o=e<0?-1:1;e=Math.abs(e)/Math.sqrt(2);let l=1/(1+n*e),c=1-((((i*l+r)*l+t)*l+a)*l+u)*l*Math.exp(-e*e);return .5*(1+o*c)}scoreContextMatch(e,u){let a=0,t=0;return u.tags.some(r=>r===e.objective.metric)&&(a+=1),t+=1,u.tags.some(r=>r===e.domain)&&(a+=1),t+=1,t>0?a/t:.5}getDefaultParameters(e){let u={timeout:3e4,retryCount:3,concurrency:4};return e.framework&&(u.framework=e.framework),e.language&&(u.language=e.language),u}calculateSuccessRate(e){return e.length===0?0:e.filter(u=>u.result.success).length/e.length}calculateAverageDuration(e){return e.length===0?0:e.reduce((u,a)=>u+a.result.duration,0)/e.length}calculateAverageReward(e){return e.length===0?0:e.reduce((u,a)=>u+a.reward,0)/e.length}identifyImprovementAreas(e,u,a){let t=[];u.success_rate<.8&&t.push("Increase success rate by tuning parameters"),u.avg_duration_ms>1e4&&t.push("Optimize for faster execution"),u.avg_reward<.5&&t.push("Improve reward through better strategy selection");let r=e.parameters;return r.retryCount<2&&t.push("Consider increasing retry count for resilience"),r.concurrency>8&&t.push("High concurrency may cause resource contention"),t}generateParameterCombinations(e){let u=Object.keys(e);if(u.length===0)return[{}];let a=[];function t(r,i){if(r===u.length){a.push({...i});return}let n=u[r];if(!st(n)){t(r+1,i);return}for(let o of e[n])i[n]=o,t(r+1,i)}return t(0,{}),a}async updateAggregatedMetrics(e,u){let a=`learning:metrics:aggregated:${e}`,r=(await this.memory.get(a))?.metrics||{};for(let[i,n]of Object.entries(u))st(i)&&(r[i]||(r[i]={sum:0,count:0}),r[i].sum+=n,r[i].count+=1);await this.memory.set(a,{metrics:r,updatedAt:new Date},{namespace:"learning-optimization",persist:!0})}async storeOptimizationResult(e){await this.memory.set(`learning:strategy:optimized:${e.id}`,e,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`learning:strategy:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}async storeABTestResult(e,u,a){let t=A();await this.memory.set(`learning:abtest:${t}`,{testId:t,strategyA:e.name,strategyB:u.name,result:a,timestamp:new Date},{namespace:"learning-optimization",persist:!0})}async storeStrategyEvaluation(e){let u=A();await this.memory.set(`learning:evaluation:${u}`,{...e,evaluatedAt:new Date},{namespace:"learning-optimization",ttl:86400*7})}};S();var N2u={metricsRetentionDays:90,anomalyThreshold:2.5,trendWindowSize:7,alertThresholds:{error_rate:.05,latency_p99:5e3,memory_usage:.9,cpu_usage:.8}},i0=class{constructor(e,u={}){this.memory=e;this.config={...N2u,...u}}config;async recordMetric(e,u,a,t,r=[]){try{let i={id:A(),name:e,value:u,unit:a,domain:t,tags:r,timestamp:new Date};return await this.memory.set(`production:metric:${i.id}`,i,{namespace:"learning-optimization",ttl:this.config.metricsRetentionDays*86400}),await this.indexMetric(i),await this.checkForAnomalies(i),p(i.id)}catch(i){return m(g(i))}}async recordMetricsBatch(e){try{let u=[];for(let a of e){let t=await this.recordMetric(a.name,a.value,a.unit,a.domain,a.tags);t.success&&u.push(t.value)}return p(u)}catch(u){return m(g(u))}}async getMetricsHistory(e,u,a){try{let t=a?`production:metric:index:${e}:${a}:*`:`production:metric:index:${e}:*`,r=await this.memory.search(t,1e3),i=[];for(let n of r){let o=await this.memory.get(n);if(o){let l=await this.memory.get(`production:metric:${o}`);l&&u.contains(l.timestamp)&&i.push(l)}}return i.sort((n,o)=>n.timestamp.getTime()-o.timestamp.getTime()),p(i)}catch(t){return m(g(t))}}async recordIncident(e,u,a,t,r){try{let i={id:A(),severity:e,title:u,description:a,domain:t,metrics:r,startedAt:new Date};return await this.memory.set(`production:incident:${i.id}`,i,{namespace:"learning-optimization",persist:!0}),await this.indexIncident(i),await this.createExperienceFromIncident(i),p(i)}catch(i){return m(g(i))}}async resolveIncident(e,u,a){try{let t=await this.memory.get(`production:incident:${e}`);if(!t)return m(new Error(`Incident ${e} not found`));let r={...t,rootCause:u,resolution:a,resolvedAt:new Date};return await this.memory.set(`production:incident:${e}`,r,{namespace:"learning-optimization",persist:!0}),await this.updateExperienceWithResolution(r),p(r)}catch(t){return m(g(t))}}async getRecentIncidents(e=10,u){try{let a=u?`production:incident:index:domain:${u}:*`:"production:incident:*",t=await this.memory.search(a,e*2),r=[];for(let n of t)if(n.includes(":index:")){let o=await this.memory.get(n);if(o){let l=await this.memory.get(`production:incident:${o}`);l&&r.push(l)}}else{let o=await this.memory.get(n);o&&r.push(o)}r.sort((n,o)=>o.startedAt.getTime()-n.startedAt.getTime());let i=Array.from(new Map(r.map(n=>[n.id,n])).values());return p(i.slice(0,e))}catch(a){return m(g(a))}}async getProductionHealth(){try{let e=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","code-intelligence","security-compliance","learning-optimization"],u={},a={},t="healthy",r=0,i=0;for(let E of e){let d=await this.getDomainHealth(E);u[E]=d,d.status==="degraded"&&r++,d.status==="unhealthy"&&i++;for(let[D,h]of Object.entries(d.metrics))a[`${E}_${D}`]=h}i>0?t="unhealthy":r>e.length/3&&(t="degraded");let n=await this.calculateTrends(),o=await this.getRecentIncidents(5),l=o.success?o.value:[],c=this.generateHealthRecommendations(u,a,l);return p({overall:t,domains:u,metrics:a,trends:n,recentIncidents:l,recommendations:c})}catch(e){return m(g(e))}}async getDomainHealth(e){let u=Ju.lastNDays(1),a=await this.getMetricsHistory("*",u,e),t={};if(a.success)for(let o of a.value)t[o.name],t[o.name]=o.value;let r=await this.getRecentIncidents(100,e),i=r.success?r.value.filter(o=>!o.resolvedAt).length:0,n="healthy";return i>2?n="unhealthy":i>0&&(n="degraded"),t.error_rate>this.config.alertThresholds.error_rate?n="unhealthy":t.latency_p99>this.config.alertThresholds.latency_p99&&(n="degraded"),{status:n,metrics:t,activeIncidents:i}}async calculateTrends(){let e=[],u=["error_rate","latency_p99","success_rate"],a=this.config.trendWindowSize;for(let t of u)for(let r=0;r<a;r++){let i=new Date;i.setDate(i.getDate()-r),i.setHours(0,0,0,0);let n=new Date(i);n.setHours(23,59,59,999);let o=Ju.create(i,n),l=await this.getMetricsHistory(t,o);if(l.success&&l.value.length>0){let c=l.value.reduce((E,d)=>E+d.value,0)/l.value.length;e.push({timestamp:i,metric:t,value:c})}}return e}generateHealthRecommendations(e,u,a){let t=[];for(let[n,o]of Object.entries(e))o.status==="unhealthy"?t.push(`Domain ${n} is unhealthy. Review active incidents and metrics.`):o.status==="degraded"&&t.push(`Domain ${n} is degraded. Monitor closely.`);for(let[n,o]of Object.entries(u)){let l=n.split("_").slice(-2).join("_"),c=this.config.alertThresholds[l];c&&o>c&&t.push(`Metric ${n} (${o.toFixed(2)}) exceeds threshold (${c})`)}let r=a.filter(n=>!n.resolvedAt);return r.length>3&&t.push(`${r.length} unresolved incidents require attention`),a.reduce((n,o)=>(n[o.severity]=(n[o.severity]||0)+1,n),{}).critical>2&&t.push("Multiple critical incidents detected. Consider system-wide review."),t.length===0&&t.push("All systems operating within normal parameters."),t}async extractInsights(e,u){try{let a=await this.getMetricsHistory("*",e,u),t=a.success?a.value:[],r=await this.getRecentIncidents(50,u),i=r.success?r.value:[],n=t.length,o=i.filter(D=>D.resolvedAt),l=i.length>0?o.length/i.length:1,c=this.calculateRewardFromIncidents(i),E=this.generateInsightRecommendations(t,i),d=this.detectMetricAnomalies(t);return p({experienceCount:n,successRate:l,avgReward:c,patterns:[],anomalies:d,recommendations:E})}catch(a){return m(g(a))}}async recordMilestone(e,u,a){try{let t={name:e,achievedAt:new Date,domain:u};return await this.memory.set(`production:milestone:${A()}`,{...t,metrics:a},{namespace:"learning-optimization",persist:!0}),p(t)}catch(t){return m(g(t))}}async getRecentMilestones(e=10){try{let u=await this.memory.search("production:milestone:*",e),a=[];for(let t of u){let r=await this.memory.get(t);r&&a.push(r)}return a.sort((t,r)=>r.achievedAt.getTime()-t.achievedAt.getTime()),p(a.slice(0,e))}catch(u){return m(g(u))}}async indexMetric(e){await this.memory.set(`production:metric:index:${e.name}:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",ttl:this.config.metricsRetentionDays*86400})}async indexIncident(e){await this.memory.set(`production:incident:index:domain:${e.domain}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0}),await this.memory.set(`production:incident:index:severity:${e.severity}:${e.id}`,e.id,{namespace:"learning-optimization",persist:!0})}async checkForAnomalies(e){let u=Ju.lastNDays(7),a=await this.getMetricsHistory(e.name,u,e.domain);if(!a.success||a.value.length<10)return;let t=a.value.map(o=>o.value),r=t.reduce((o,l)=>o+l,0)/t.length,i=Math.sqrt(t.reduce((o,l)=>o+Math.pow(l-r,2),0)/t.length),n=Math.abs(e.value-r)/(i||1);n>this.config.anomalyThreshold&&await this.memory.set(`production:anomaly:${A()}`,{metricId:e.id,metricName:e.name,value:e.value,mean:r,stdDev:i,deviation:n,timestamp:new Date},{namespace:"learning-optimization",ttl:86400*7})}async createExperienceFromIncident(e){let u={context:{incidentId:e.id,severity:e.severity,domain:e.domain},metrics:e.metrics},a={success:!1,outcome:e.metrics,duration:0},t={id:A(),agentId:{value:"production-intel",domain:"learning-optimization",type:"analyzer"},domain:e.domain,action:`incident-${e.severity}`,state:u,result:a,reward:this.calculateIncidentReward(e),timestamp:e.startedAt};await this.memory.set(`learning:experience:${t.id}`,t,{namespace:"learning-optimization",ttl:86400*30})}async updateExperienceWithResolution(e){if(!e.resolvedAt)return;let u={context:{incidentId:e.id,rootCause:e.rootCause,resolution:e.resolution},metrics:e.metrics},a=e.resolvedAt.getTime()-e.startedAt.getTime(),t={success:!0,outcome:{...e.metrics,resolution_time_ms:a},duration:a},r={id:A(),agentId:{value:"production-intel",domain:"learning-optimization",type:"analyzer"},domain:e.domain,action:`resolution-${e.severity}`,state:u,result:t,reward:1-this.calculateIncidentReward(e),timestamp:e.resolvedAt};await this.memory.set(`learning:experience:${r.id}`,r,{namespace:"learning-optimization",ttl:86400*30})}calculateIncidentReward(e){return-({critical:.9,high:.7,medium:.4,low:.2}[e.severity]||.5)}calculateRewardFromIncidents(e){if(e.length===0)return .8;let u={critical:.1,high:.3,medium:.6,low:.8},a=0,t=0;for(let r of e){let i=u[r.severity]||.5,n=r.resolvedAt?.2:0;a+=i+n,t++}return t>0?a/t:.8}generateInsightRecommendations(e,u){let a=[],t=new Map;for(let r of e){let i=t.get(r.name)||[];i.push(r.value),t.set(r.name,i)}for(let[r,i]of t){let n=this.calculateTrendDirection(i);n==="increasing"&&r.includes("error")?a.push(`${r} is trending upward. Investigate root causes.`):n==="decreasing"&&r.includes("success")&&a.push(`${r} is declining. Review recent changes.`)}if(u.length>0){let r=new Map;for(let i of u)r.set(i.domain,(r.get(i.domain)||0)+1);for(let[i,n]of r)n>3&&a.push(`Domain ${i} has ${n} incidents. Consider preventive measures.`)}return a}detectMetricAnomalies(e){let u=[],a=new Map;for(let t of e){let r=a.get(t.name)||[];r.push(t),a.set(t.name,r)}for(let[t,r]of a){if(r.length<5)continue;let i=r.map(l=>l.value),n=i.reduce((l,c)=>l+c,0)/i.length,o=Math.sqrt(i.reduce((l,c)=>l+Math.pow(c-n,2),0)/i.length);for(let l of r){let c=Math.abs(l.value-n)/(o||1);c>this.config.anomalyThreshold&&u.push({experienceId:l.id,type:"outlier-reward",description:`${t} value ${l.value.toFixed(2)} is ${c.toFixed(1)} std deviations from mean`,deviation:c})}}return u}calculateTrendDirection(e){if(e.length<3)return"stable";let u=e.slice(0,Math.floor(e.length/2)),a=e.slice(Math.floor(e.length/2)),t=u.reduce((n,o)=>n+o,0)/u.length,i=(a.reduce((n,o)=>n+o,0)/a.length-t)/(t||1);return i>.1?"increasing":i<-.1?"decreasing":"stable"}};async function WE(s,e,u){await s.set(`learning:strategy:current:${e}`,u,{namespace:"learning-optimization",persist:!0})}function $E(s,e){let u=s.map(a=>a.result.outcome[e]??0).filter(a=>!isNaN(a));return u.length===0?0:u.reduce((a,t)=>a+t,0)/u.length}function qE(s){return{"test-generation":["test-execution","coverage-analysis"],"test-execution":["test-generation","coverage-analysis","quality-assessment"],"coverage-analysis":["test-generation","test-execution","quality-assessment"],"quality-assessment":["test-execution","coverage-analysis","defect-intelligence"],"defect-intelligence":["quality-assessment","code-intelligence"],"requirements-validation":["test-generation","quality-assessment"],"code-intelligence":["defect-intelligence","security-compliance"],"security-compliance":["code-intelligence","quality-assessment"],"contract-testing":["test-generation","test-execution"],"visual-accessibility":["quality-assessment"],"chaos-resilience":["test-execution","quality-assessment"],"learning-optimization":Fu.filter(u=>u!=="learning-optimization"),"enterprise-integration":["contract-testing","security-compliance","quality-assessment"],coordination:Fu.filter(u=>u!=="coordination")}[s]||[]}function JE(s){let e=[],u=new Set;for(let a of s){if(u.has(a.id))continue;let t=[a];u.add(a.id);for(let r of s)u.has(r.id)||a.type===r.type&&a.domain===r.domain&&I2u(a.context,r.context)&&(t.push(r),u.add(r.id));t.length>=2&&e.push(t)}return e}function I2u(s,e){return s.tags.some(u=>e.tags.includes(u))}function UE(s,e,u){let a=JSON.stringify({patternCount:s.length,knowledgeCount:e.length,strategyCount:u.length,patternIds:s.map(r=>r.id).sort(),knowledgeIds:e.map(r=>r.id).sort(),strategyIds:u.map(r=>r.id).sort()}),t=0;for(let r=0;r<a.length;r++){let i=a.charCodeAt(r);t=(t<<5)-t+i,t=t&t}return Math.abs(t).toString(16)}N();var q0=B.create("learning-optimization/consensus");async function ZE(s,e,u,a){let t=O({id:A(),type:"pattern-recommendation",confidence:e,description:`Verify pattern recommendation: ${s.name} (${s.type}) for domain ${s.domain}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:e>.9?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Pattern recommendation '${s.name}' verified by consensus`),!0):(q0.warn(`Pattern recommendation '${s.name}' NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}async function QE(s,e,u,a){let t=O({id:A(),type:"optimization-suggestion",confidence:e,description:`Verify optimization: ${s.metric} from ${s.currentValue} to ${s.targetValue} via ${s.strategy}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:e>.85?"high":"medium"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Optimization suggestion for '${s.metric}' verified by consensus`),!0):(q0.warn(`Optimization suggestion for '${s.metric}' NOT verified`),!1)}return!0}async function YE(s,e,u,a){let t=O({id:A(),type:"cross-domain-insight",confidence:e,description:`Verify cross-domain insight: ${s.description}`,payload:s,detectedBy:"learning-optimization-coordinator",severity:"high"});if(u.requiresConsensus(t)){let r=await u.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(q0.info(`Cross-domain insight verified by consensus for ${s.targetDomains.length} target domains`),!0):(q0.warn(`Cross-domain insight NOT verified: ${r.success?r.value.verdict:r.error.message}`),!1)}return!0}var H2u={maxConcurrentWorkflows:3,defaultTimeout:12e4,enableAutoOptimization:!0,publishEvents:!0,learningCycleIntervalMs:36e5,enableDreamScheduler:!0,dreamCycleIntervalMs:36e5,enableExperienceTrigger:!0,experienceThreshold:50,enableQualityGateFailureTrigger:!0,autoApplyHighConfidenceInsights:!1,autoApplyConfidenceThreshold:.8,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},Tu=B.create("learning-optimization"),_i=class extends Y{constructor(u,a,t,r={}){let i={...H2u,...r};super(u,"learning-optimization",i,{verifyFindingTypes:["pattern-recommendation","optimization-suggestion","cross-domain-insight"]});this.memory=a;this.agentCoordinator=t;this.learningService=new a0({memory:a}),this.transferService=new t0(a),this.optimizerService=new r0(a),this.productionIntel=new i0(a)}learningService;transferService;optimizerService;productionIntel;sona=null;dreamScheduler=null;async onInitialize(){try{this.sona=await gu({domain:"learning-optimization",loadOnInit:!0,autoSaveInterval:6e4,maxPatterns:1e4,minConfidence:.5}),Tu.info("PersistentSONAEngine initialized for pattern learning")}catch(u){Tu.error("Failed to initialize PersistentSONAEngine:",u instanceof Error?u:void 0),Tu.warn("Continuing without SONA pattern persistence"),this.sona=null}if(this.config.enableDreamScheduler)try{let u=await D4();await u.initialize(),this.dreamScheduler=h4({dreamEngine:u,eventBus:this.eventBus,memoryBackend:this.memory},{autoScheduleIntervalMs:this.config.dreamCycleIntervalMs,enableExperienceTrigger:this.config.enableExperienceTrigger,experienceThreshold:this.config.experienceThreshold,enableQualityGateFailureTrigger:this.config.enableQualityGateFailureTrigger,autoApplyHighConfidenceInsights:this.config.autoApplyHighConfidenceInsights,insightConfidenceThreshold:this.config.autoApplyConfidenceThreshold}),await this.dreamScheduler.initialize(),this.dreamScheduler.start(),Tu.info("DreamScheduler initialized and started")}catch{Tu.warn("Failed to initialize DreamScheduler:")}this.subscribeToEvents(),await this.loadWorkflowState()}async onDispose(){if(await this.saveWorkflowState(),this.dreamScheduler){try{await this.dreamScheduler.dispose(),Tu.info("DreamScheduler disposed")}catch(u){Tu.error("Error disposing DreamScheduler:",u instanceof Error?u:void 0)}this.dreamScheduler=null}if(this.initialized&&this.sona)try{await this.sona.close()}catch(u){Tu.error("Error closing SONA engine:",u instanceof Error?u:void 0)}}getActiveWorkflows(){return super.getActiveWorkflows()}async runLearningCycle(u){let a=A();try{if(this.startWorkflow(a,"learning-cycle"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, using conservative strategy for learning cycle"),this.minCutMixin.shouldPauseOperations())return m(new Error("Learning cycle paused: topology is in critical state"));let t=await this.spawnLearningAgent(a,u);if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);this.addAgentToWorkflow(a,t.value);let r=Ju.lastNDays(1),i=await this.getExperiencesForDomain(u,r),n=i.success?i.value:[];this.updateWorkflowProgress(a,20);let o=await this.learningService.mineExperiences(u,r),l=o.success?o.value.patterns.length:0;this.updateWorkflowProgress(a,50);let c=0,E=[];if(n.length>=10){let h={metric:"success_rate",direction:"maximize",constraints:[]},C=await this.getCurrentStrategy(u),y=await this.optimizerService.optimizeStrategy(C,h,n);y.success&&(c=1,E.push({metric:h.metric,before:this.calculateMetricValue(n,h.metric),after:y.value.optimizedStrategy.expectedOutcome[h.metric]||0,percentChange:y.value.improvement*100}))}this.updateWorkflowProgress(a,80);let d=0;o.success&&o.value.recommendations.length>0&&(await this.transferService.createKnowledge("heuristic",u,o.value.recommendations,{value:`learning-agent-${a.slice(0,8)}`,domain:"learning-optimization",type:"analyzer"},[u])).success&&(d=1),this.completeWorkflow(a),await this.agentCoordinator.stop(t.value);let D={domain:u,experiencesProcessed:n.length,patternsLearned:l,strategiesOptimized:c,knowledgeGenerated:d,improvements:E};return this.config.publishEvents&&l>0&&await this.publishPatternConsolidated(l,[u]),p(D)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async optimizeAllStrategies(){let u=A();try{if(this.startWorkflow(u,"optimization"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, using conservative optimization strategy"),this.minCutMixin.shouldPauseOperations())return m(new Error("Optimization paused: topology is in critical state"));let a={},t=0,r=0,i=0,n=Fu.filter(l=>l!=="learning-optimization");for(let l=0;l<n.length;l++){let c=n[l];this.updateWorkflowProgress(u,Math.round(l/n.length*100));let E=Ju.lastNDays(7),d=await this.getExperiencesForDomain(c,E);if(!d.success||d.value.length<10)continue;let D=d.value,h={metric:"success_rate",direction:"maximize",constraints:[]},C=await this.getCurrentStrategy(c),y=await this.optimizerService.optimizeStrategy(C,h,D);y.success&&(t++,r+=y.value.improvement,i++,a[c]={strategiesOptimized:1,avgImprovement:y.value.improvement,bestStrategy:y.value.optimizedStrategy},await this.storeStrategy(c,y.value.optimizedStrategy))}this.completeWorkflow(u);let o={domainsOptimized:i,totalStrategies:t,avgImprovement:t>0?r/t:0,byDomain:a};return this.config.publishEvents&&t>0&&await this.publishOptimizationApplied(o),p(o)}catch(a){return this.failWorkflow(u,String(a)),m(g(a))}}async shareCrossDomainLearnings(){let u=A();try{if(this.startWorkflow(u,"transfer"),this.config.enableMinCutAwareness&&!this.isTopologyHealthy()&&Tu.warn("Topology degraded, limiting cross-domain transfer scope"),this.minCutMixin.shouldPauseOperations())return m(new Error("Cross-domain sharing paused: topology is in critical state"));let a=0,t=[],r=0,i=0,n=0,o=await this.transferService.queryKnowledge({minRelevance:.7,limit:100});if(!o.success)return this.failWorkflow(u,o.error.message),m(o.error);let l=o.value;for(let d of l){let D=this.getRelatedDomains(d.domain);for(let h of D){if(h===d.domain)continue;i++,(await this.transferService.transferKnowledge(d,h)).success&&(n++,a++,t.includes(h)||t.push(h))}this.updateWorkflowProgress(u,Math.round(a/(l.length*2)*100))}let c=await this.learningService.getPatternStats();if(c.success){let d=c.value.topPatterns;if(d.length>=2){let D=this.findSimilarPatterns(d);for(let h of D)h.length>=2&&(await this.learningService.consolidatePatterns(h.map(y=>y.id))).success&&r++}}this.completeWorkflow(u);let E={knowledgeShared:a,domainsUpdated:t,transferSuccessRate:i>0?n/i:1,newPatternsCreated:r};return this.config.publishEvents&&a>0&&await this.publishTransferCompleted(E),p(E)}catch(a){return this.failWorkflow(u,String(a)),m(g(a))}}async getLearningDashboard(){try{let u=await this.learningService.getPatternStats(),a=u.success?u.value:null,t=await this.transferService.queryKnowledge({limit:1e3}),r=t.success?t.value.length:0,i=Ju.lastNDays(1),n=0;for(let C of Fu){let y=await this.getExperiencesForDomain(C,i);y.success&&(n+=y.value.length)}let o=await this.productionIntel.getProductionHealth(),l=o.success?o.value.trends:[],c=await this.productionIntel.getRecentMilestones(5),E=c.success?c.value:[],d=a?a.avgSuccessRate*.6+a.avgConfidence*.4:.5,D=[];if(a){let C=Object.entries(a.byDomain).filter(([y,x])=>x>0).map(([y,x])=>({domain:y,score:x})).sort((y,x)=>x.score-y.score);D.push(...C.slice(0,3).map(y=>y.domain))}let h={overallLearningRate:d,totalPatterns:a?.totalPatterns||0,totalKnowledge:r,experiencesLast24h:n,topPerformingDomains:D,learningTrend:l,recentMilestones:E};return p(h)}catch(u){return m(g(u))}}learnPattern(u,a,t,r,i,n){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.createPattern(u,a,t,r,i,n)}ensureInitialized(){if(!this.initialized)throw new Error("[LearningOptimizationCoordinator] Not initialized. Call initialize() first.")}ensureSONAAvailable(){if(!this.sona)throw new Error("[LearningOptimizationCoordinator] SONA engine is not available. Pattern persistence failed during initialization.")}async adaptPattern(u,a,t){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.adaptPattern(u,a,t)}getSONAStats(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getStats()}getSONAPatterns(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getAllPatterns()}getSONAPatternsByType(u){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getPatternsByType(u)}getSONAPatternsByDomain(u){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.getPatternsByDomain(u)}updateSONAPattern(u,a,t){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.updatePattern(u,a,t)}forceSONALearning(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.forceLearn()}isSONAAvailable(){return this.initialized&&this.sona!==null}exportSONAPatterns(){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.exportPatterns()}importSONAPatterns(u){this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.importPatterns(u)}async verifySONAPerformance(u=100){return this.ensureInitialized(),this.ensureSONAAvailable(),this.sona.verifyPerformance(u)}async triggerDreamCycle(u){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");let a=await this.dreamScheduler.triggerDream(u);return this.config.publishEvents&&await this.publishDreamCycleCompleted(a.cycle.id,a.cycle.durationMs??0,a.cycle.conceptsProcessed,a.insights.map(t=>({id:t.id,type:t.type,description:t.description,noveltyScore:t.noveltyScore,confidenceScore:t.confidenceScore,actionable:t.actionable,suggestedAction:t.suggestedAction,sourceConcepts:t.sourceConcepts})),a.patternsCreated),a}getDreamStatus(){return this.dreamScheduler?.getStatus()??null}isDreamSchedulerAvailable(){return this.dreamScheduler!==null}getLastDreamResult(){return this.dreamScheduler?.getLastDreamResult()??null}async triggerQuickDream(){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");return this.dreamScheduler.triggerQuickDream()}async triggerFullDream(){if(!this.dreamScheduler)throw new Error("[LearningOptimizationCoordinator] DreamScheduler not initialized");return this.dreamScheduler.triggerFullDream()}async exportModels(u){let a=A();try{this.startWorkflow(a,"export");let t=u||Fu,r=[],i=[],n=[];for(let d of t){let D=await this.memory.search("learning:pattern:*",500);for(let h of D){let C=await this.memory.get(h);C&&t.includes(C.domain)&&r.push(C)}this.updateWorkflowProgress(a,Math.round(r.length/100*30))}let o=await this.transferService.queryKnowledge({limit:1e3});if(o.success)for(let d of o.value)t.includes(d.domain)&&i.push(d);this.updateWorkflowProgress(a,60);let l=await this.memory.search("learning:strategy:optimized:*",200);for(let d of l){let D=await this.memory.get(d);D&&t.includes(D.domain)&&n.push(D)}this.updateWorkflowProgress(a,90);let c=this.calculateChecksum(r,i,n);return this.completeWorkflow(a),p({version:"1.0.0",exportedAt:new Date,patterns:r,knowledge:i,strategies:n,checksum:c})}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async importModels(u){let a=A();try{if(this.startWorkflow(a,"import"),this.calculateChecksum(u.patterns,u.knowledge,u.strategies)!==u.checksum)return this.failWorkflow(a,"Checksum mismatch"),m(new Error("Import failed: checksum mismatch"));let r=0,i=0,n=0,o=[];for(let c of u.patterns){let E=await this.memory.get(`learning:pattern:${c.id}`);E?E.confidence<c.confidence?(await this.memory.set(`learning:pattern:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),r++,o.push({type:"pattern",id:c.id,reason:"Existing pattern had lower confidence",resolution:"overwrite"})):o.push({type:"pattern",id:c.id,reason:"Existing pattern has higher confidence",resolution:"skip"}):(await this.memory.set(`learning:pattern:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),r++),this.updateWorkflowProgress(a,Math.round(r/u.patterns.length*30))}for(let c of u.knowledge){let E=await this.memory.get(`learning:knowledge:shared:${c.id}`);E?c.version>E.version?(await this.memory.set(`learning:knowledge:shared:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),i++,o.push({type:"knowledge",id:c.id,reason:"Import has newer version",resolution:"overwrite"})):o.push({type:"knowledge",id:c.id,reason:"Existing knowledge is same or newer version",resolution:"skip"}):(await this.memory.set(`learning:knowledge:shared:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),i++),this.updateWorkflowProgress(a,30+Math.round(i/u.knowledge.length*30))}for(let c of u.strategies){let E=await this.memory.get(`learning:strategy:optimized:${c.id}`);E?c.confidence>E.confidence?(await this.memory.set(`learning:strategy:optimized:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),n++,o.push({type:"strategy",id:c.id,reason:"Import has higher confidence",resolution:"overwrite"})):o.push({type:"strategy",id:c.id,reason:"Existing strategy has higher confidence",resolution:"skip"}):(await this.memory.set(`learning:strategy:optimized:${c.id}`,c,{namespace:"learning-optimization",persist:!0}),n++),this.updateWorkflowProgress(a,60+Math.round(n/u.strategies.length*40))}return this.completeWorkflow(a),p({patternsImported:r,knowledgeImported:i,strategiesImported:n,conflicts:o,resolved:!0})}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}subscribeToEvents(){this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("learning.ExperienceCaptured",this.handleExperienceCaptured.bind(this))}async handleTestRunCompleted(u){let{runId:a,passed:t,failed:r,duration:i}=u.payload,n=t+r>0?t/(t+r):0;await this.learningService.recordExperience({agentId:{value:"test-execution",domain:"test-execution",type:"tester"},domain:"test-execution",action:"test-run",state:{context:{runId:a},metrics:{passed:t,failed:r,duration:i}},result:{success:n>.8,outcome:{success_rate:n,passed:t,failed:r},duration:i},reward:n})}async handleCoverageGap(u){let{gapId:a,file:t,riskScore:r}=u.payload;await this.learningService.recordExperience({agentId:{value:"coverage-analysis",domain:"coverage-analysis",type:"analyzer"},domain:"coverage-analysis",action:"gap-detection",state:{context:{gapId:a,file:t},metrics:{riskScore:r}},result:{success:!0,outcome:{risk_score:r},duration:0},reward:1-r})}async handleQualityGate(u){let{gateId:a,passed:t}=u.payload;await this.learningService.recordExperience({agentId:{value:"quality-assessment",domain:"quality-assessment",type:"validator"},domain:"quality-assessment",action:"gate-evaluation",state:{context:{gateId:a},metrics:{passed:t?1:0}},result:{success:t,outcome:{gate_passed:t?1:0},duration:0},reward:t?1:0})}async handleExperienceCaptured(u){let{experience:a}=u.payload;if(!a.success||a.quality<.7)return;let t=a.domain||"learning-optimization";if(await this.learningService.recordExperience({agentId:{value:a.agent||"unknown",domain:t,type:"specialist"},domain:t,action:a.task,state:{context:{experienceId:a.id,trajectoryId:a.trajectoryId,model:a.model},metrics:{durationMs:a.durationMs,stepCount:a.steps.length,quality:a.quality}},result:{success:a.success,outcome:{quality:a.quality,patterns_extracted:a.patterns?.length||0},duration:a.durationMs},reward:a.quality}),a.patterns&&a.patterns.length>0&&a.domain){let r=this.getRelatedDomains(a.domain);for(let i of r)i!==a.domain&&await this.transferService.transferKnowledge({id:`exp-${a.id}`,domain:a.domain,type:"workflow",content:{format:"json",data:{task:a.task,steps:a.steps,quality:a.quality,patterns:a.patterns}},sourceAgentId:{value:a.agent||"experience-capture",domain:a.domain,type:"specialist"},targetDomains:[i],relevanceScore:a.quality,version:1,createdAt:new Date(a.startedAt)},i);Tu.info(`[LearningOptimizationCoordinator] Experience ${a.id} transferred to ${r.length} related domains`)}this.dreamScheduler&&this.dreamScheduler.recordExperience({id:a.id,agentType:a.agent||"unknown",domain:t,taskType:a.task,success:a.success,duration:a.durationMs,context:{quality:a.quality,steps:a.steps.length,patterns:a.patterns?.length||0},timestamp:new Date(a.startedAt)})}async publishPatternConsolidated(u,a){let t={patternCount:u,domains:a,improvements:0},r=L(Yu.PatternConsolidated,"learning-optimization",t);await this.eventBus.publish(r)}async publishTransferCompleted(u){let a={sourceProject:"current",targetProject:"current",patternsTransferred:u.knowledgeShared,successRate:u.transferSuccessRate},t=L(Yu.TransferCompleted,"learning-optimization",a);await this.eventBus.publish(t)}async publishOptimizationApplied(u){let a=L(Yu.OptimizationApplied,"learning-optimization",{domainsOptimized:u.domainsOptimized,avgImprovement:u.avgImprovement});await this.eventBus.publish(a)}async publishDreamCycleCompleted(u,a,t,r,i){if(!this.config.publishEvents)return;let n={cycleId:u,durationMs:a,conceptsProcessed:t,insights:r,patternsCreated:i},o=L(Yu.DreamCycleCompleted,"learning-optimization",n);await this.eventBus.publish(o),Tu.info(`[LearningOptimizationCoordinator] Published dream cycle completion: ${r.length} insights for ${t} concepts`)}async spawnLearningAgent(u,a){if(!this.agentCoordinator.canSpawn())return m(new Error("Agent limit reached"));let t={name:`learning-agent-${u.slice(0,8)}`,domain:"learning-optimization",type:"optimizer",capabilities:["pattern-learning","experience-mining",a],config:{workflowId:u,targetDomain:a}};return this.agentCoordinator.spawn(t)}async loadWorkflowState(){let u=await this.memory.get("learning-optimization:coordinator:workflows");if(u)for(let a of u)a.status==="running"&&(a.status="failed",a.error="Coordinator restarted",a.completedAt=new Date),this.workflows.set(a.id,a)}async saveWorkflowState(){let u=Array.from(this.workflows.values());await this.memory.set("learning-optimization:coordinator:workflows",u,{namespace:"learning-optimization",persist:!0})}async getExperiencesForDomain(u,a){let t=await this.memory.search(`learning:experience:index:domain:${u}:*`,500),r=[];for(let i of t){let n=await this.memory.get(i);if(n){let o=await this.memory.get(`learning:experience:${n}`);o&&a.contains(o.timestamp)&&r.push(o)}}return p(r)}async getCurrentStrategy(u){let a=`learning:strategy:current:${u}`,t=await this.memory.get(a);return t||{name:`default-${u}`,parameters:{timeout:3e4,retryCount:3,concurrency:4},expectedOutcome:{success_rate:.8}}}async storeStrategy(u,a){await WE(this.memory,u,a)}calculateMetricValue(u,a){return $E(u,a)}getRelatedDomains(u){return qE(u)}findSimilarPatterns(u){return JE(u)}calculateChecksum(u,a,t){return UE(u,a,t)}async verifyPatternRecommendation(u,a){return ZE(u,a,this.consensusMixin,this.domainName)}async verifyOptimizationSuggestion(u,a){return QE(u,a,this.consensusMixin,this.domainName)}async verifyCrossDomainInsight(u,a){return YE(u,a,this.consensusMixin,this.domainName)}};S();var ql=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;learningService=null;transferService=null;optimizerService=null;productionIntel=null;pluginConfig;get name(){return"learning-optimization"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{isSONAAvailable:()=>this.coordinator?.isSONAAvailable()??!1,runLearningCycle:this.runLearningCycle.bind(this),optimizeAllStrategies:this.optimizeAllStrategies.bind(this),shareCrossDomainLearnings:this.shareCrossDomainLearnings.bind(this),getLearningDashboard:this.getLearningDashboard.bind(this),exportModels:this.exportModels.bind(this),importModels:this.importModels.bind(this),learnPattern:this.learnPattern.bind(this),findMatchingPatterns:this.findMatchingPatterns.bind(this),applyPattern:this.applyPattern.bind(this),updatePatternFeedback:this.updatePatternFeedback.bind(this),getPatternStats:this.getPatternStats.bind(this),queryKnowledge:this.queryKnowledge.bind(this),transferKnowledge:this.transferKnowledge.bind(this),optimizeStrategy:this.optimizeStrategy.bind(this),runABTest:this.runABTest.bind(this),recommendStrategy:this.recommendStrategy.bind(this),evaluateStrategy:this.evaluateStrategy.bind(this),getCoordinator:()=>this.coordinator,getActiveWorkflows:()=>this.coordinator?.getActiveWorkflows()||[],getLearningService:()=>this.learningService,getTransferService:()=>this.transferService,getOptimizerService:()=>this.optimizerService,getProductionIntelService:()=>this.productionIntel}}getTaskHandlers(){return new Map([["run-learning-cycle",async u=>{if(!this.coordinator)return m(new Error("Coordinator not initialized"));let a=u.domain;return a?this.coordinator.runLearningCycle(a):m(new Error("Invalid run-learning-cycle payload: missing domain"))}],["optimize-strategies",async u=>this.coordinator?this.coordinator.optimizeAllStrategies():m(new Error("Coordinator not initialized"))],["share-learnings",async u=>this.coordinator?this.coordinator.shareCrossDomainLearnings():m(new Error("Coordinator not initialized"))],["learn-pattern",async u=>{if(!this.learningService)return m(new Error("Learning service not initialized"));let a=u.experiences;return!a||a.length===0?m(new Error("Invalid learn-pattern payload: missing experiences")):this.learningService.learnPattern(a)}],["query-knowledge",async u=>{if(!this.transferService)return m(new Error("Transfer service not initialized"));let a=u.query;return a?this.transferService.queryKnowledge(a):m(new Error("Invalid query-knowledge payload: missing query"))}]])}async onInitialize(){this.learningService=new a0({memory:this.memory},this.pluginConfig.learningService),this.transferService=new t0(this.memory,this.pluginConfig.transferService),this.optimizerService=new r0(this.memory,this.pluginConfig.optimizerService),this.productionIntel=new i0(this.memory,this.pluginConfig.productionIntel),this.coordinator=new _i(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null,this.learningService=null,this.transferService=null,this.optimizerService=null,this.productionIntel=null}subscribeToEvents(){this.eventBus.subscribe("test-generation.TestGenerated",this.handleTestGenerated.bind(this)),this.eventBus.subscribe("test-execution.TestRunCompleted",this.handleTestRunCompleted.bind(this)),this.eventBus.subscribe("coverage-analysis.CoverageGapDetected",this.handleCoverageGap.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("defect-intelligence.DefectPredicted",this.handleDefectPredicted.bind(this)),this.eventBus.subscribe("code-intelligence.ImpactAnalysisCompleted",this.handleImpactAnalysis.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"test-generation.TestGenerated":await this.handleTestGenerated(u);break;case"test-execution.TestRunCompleted":await this.handleTestRunCompleted(u);break;case"coverage-analysis.CoverageGapDetected":await this.handleCoverageGap(u);break;default:break}}async runLearningCycle(u){this.ensureInitialized();try{let a=await this.coordinator.runLearningCycle(u);return a.success?this.trackSuccessfulOperation("learning-cycle"):this.trackFailedOperation("learning-cycle",a.error),a}catch(a){return this.handleError(a)}}async optimizeAllStrategies(){this.ensureInitialized();try{let u=await this.coordinator.optimizeAllStrategies();return u.success?this.trackSuccessfulOperation("optimization"):this.trackFailedOperation("optimization",u.error),u}catch(u){return this.handleError(u)}}async shareCrossDomainLearnings(){this.ensureInitialized();try{return await this.coordinator.shareCrossDomainLearnings()}catch(u){return this.handleError(u)}}async getLearningDashboard(){this.ensureInitialized();try{return await this.coordinator.getLearningDashboard()}catch(u){return this.handleError(u)}}async exportModels(u){this.ensureInitialized();try{return await this.coordinator.exportModels(u)}catch(a){return this.handleError(a)}}async importModels(u){this.ensureInitialized();try{return await this.coordinator.importModels(u)}catch(a){return this.handleError(a)}}async learnPattern(u){this.ensureInitialized();try{return await this.learningService.learnPattern(u)}catch(a){return this.handleError(a)}}async findMatchingPatterns(u,a){this.ensureInitialized();try{return await this.learningService.findMatchingPatterns(u,a)}catch(t){return this.handleError(t)}}async applyPattern(u,a){this.ensureInitialized();try{return await this.learningService.applyPattern(u,a)}catch(t){return this.handleError(t)}}async updatePatternFeedback(u,a){this.ensureInitialized();try{return await this.learningService.updatePatternFeedback(u,a)}catch(t){return this.handleError(t)}}async getPatternStats(u){this.ensureInitialized();try{return await this.learningService.getPatternStats(u)}catch(a){return this.handleError(a)}}async queryKnowledge(u){this.ensureInitialized();try{return await this.transferService.queryKnowledge(u)}catch(a){return this.handleError(a)}}async transferKnowledge(u,a){this.ensureInitialized();try{return await this.transferService.transferKnowledge(u,a)}catch(t){return this.handleError(t)}}async optimizeStrategy(u,a,t){this.ensureInitialized();try{return await this.optimizerService.optimizeStrategy(u,a,t)}catch(r){return this.handleError(r)}}async runABTest(u,a,t){this.ensureInitialized();try{return await this.optimizerService.runABTest(u,a,t)}catch(r){return this.handleError(r)}}async recommendStrategy(u){this.ensureInitialized();try{return await this.optimizerService.recommendStrategy(u)}catch(a){return this.handleError(a)}}async evaluateStrategy(u,a){this.ensureInitialized();try{return await this.optimizerService.evaluateStrategy(u,a)}catch(t){return this.handleError(t)}}async handleTestGenerated(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"test-generation",domain:"test-generation",type:"generator"},domain:"test-generation",action:"test-generated",state:{context:{testId:a.testId,testType:a.testType},metrics:{}},result:{success:!0,outcome:{generated:1},duration:0},reward:.8})}async handleTestRunCompleted(u){let a=u.payload,t=a.passed+a.failed>0?a.passed/(a.passed+a.failed):0;await this.learningService.recordExperience({agentId:{value:"test-execution",domain:"test-execution",type:"tester"},domain:"test-execution",action:"test-run",state:{context:{runId:a.runId},metrics:{passed:a.passed,failed:a.failed,duration:a.duration}},result:{success:t>.8,outcome:{success_rate:t,passed:a.passed,failed:a.failed},duration:a.duration},reward:t}),await this.productionIntel.recordMetric("test_success_rate",t,"ratio","test-execution",["automated"])}async handleCoverageGap(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"coverage-analysis",domain:"coverage-analysis",type:"analyzer"},domain:"coverage-analysis",action:"gap-detection",state:{context:{gapId:a.gapId,file:a.file},metrics:{riskScore:a.riskScore}},result:{success:!0,outcome:{risk_score:a.riskScore},duration:0},reward:1-a.riskScore})}async handleQualityGate(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"quality-assessment",domain:"quality-assessment",type:"validator"},domain:"quality-assessment",action:"gate-evaluation",state:{context:{gateId:a.gateId},metrics:{passed:a.passed?1:0}},result:{success:a.passed,outcome:{gate_passed:a.passed?1:0},duration:0},reward:a.passed?1:0})}async handleDefectPredicted(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"defect-intelligence",domain:"defect-intelligence",type:"analyzer"},domain:"defect-intelligence",action:"defect-prediction",state:{context:{predictionId:a.predictionId},metrics:{probability:a.probability}},result:{success:!0,outcome:{probability:a.probability},duration:0},reward:.7})}async handleImpactAnalysis(u){let a=u.payload;await this.learningService.recordExperience({agentId:{value:"code-intelligence",domain:"code-intelligence",type:"analyzer"},domain:"code-intelligence",action:"impact-analysis",state:{context:{analysisId:a.analysisId},metrics:{changedFiles:a.changedFiles.length,impactedFiles:a.impactedFiles.length}},result:{success:!0,outcome:{changed_count:a.changedFiles.length,impacted_count:a.impactedFiles.length},duration:0},reward:.8})}ensureInitialized(){if(!this._initialized)throw new Error("LearningOptimizationPlugin is not initialized");if(!this.coordinator||!this.learningService||!this.transferService||!this.optimizerService||!this.productionIntel)throw new Error("LearningOptimizationPlugin services are not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),m(a)}trackSuccessfulOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,total:a.agents.total+1,idle:a.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u,a){let t=this.getHealth();this.updateHealth({agents:{...t.agents,failed:t.agents.failed+1},errors:[...t.errors.slice(-9),a.message]})}};function XE(s,e,u,a){return new ql(s,e,u,a)}var Jl=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}workflowOrchestrator=null;pluginConfig;get name(){return"coordination"}get version(){return"1.0.0"}get dependencies(){return Fu.filter(u=>u!=="coordination")}getAPI(){return{listWorkflows:async()=>{if(!this.workflowOrchestrator)throw new Error("Workflow orchestrator not initialized");return this.workflowOrchestrator.listWorkflows()}}}async onInitialize(){this.workflowOrchestrator=p4(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.workflowConfig),await this.workflowOrchestrator.initialize(),this.updateHealth({status:"healthy",agents:{total:0,active:0,idle:0,failed:0}})}async onDispose(){this.workflowOrchestrator&&(await this.workflowOrchestrator.dispose(),this.workflowOrchestrator=null)}async onEvent(u){u.type.startsWith("coordination.")&&await this.handleCoordinationEvent(u)}subscribeToEvents(){this.eventBus.subscribe("coordination.workflow.execute",async u=>{await this.handleEvent(u)})}async handleCoordinationEvent(u){u.type.split(".")[1]==="workflow"&&await this.handleWorkflowEvent(u)}async handleWorkflowEvent(u){this.workflowOrchestrator}};function u3(s,e,u,a){return new Jl(s,e,u,a)}var Mu={CoverageAnalyzerService:"coverage-analysis.CoverageAnalyzerService",SecurityScannerService:"security-compliance.SecurityScannerService",isSemgrepAvailable:"security-compliance.isSemgrepAvailable",runSemgrepWithRules:"security-compliance.runSemgrepWithRules",convertSemgrepFindings:"security-compliance.convertSemgrepFindings",createTestGeneratorService:"test-generation.createTestGeneratorService",KnowledgeGraphService:"code-intelligence.KnowledgeGraphService",QualityAnalyzerService:"quality-assessment.QualityAnalyzerService"},Ul=class{factories=new Map;register(e,u){this.factories.set(e,u)}resolve(e){let u=this.factories.get(e);if(!u)throw new Error(`DomainServiceRegistry: service '${e}' not registered. Ensure the domain module is initialized before coordination.`);return u}has(e){return this.factories.has(e)}clear(){this.factories.clear()}keys(){return Array.from(this.factories.keys())}},Ru=new Ul;Ru.register(Mu.createTestGeneratorService,s=>Ie(s));Ru.register(Mu.CoverageAnalyzerService,s=>new ve(s));Ru.register(Mu.SecurityScannerService,s=>new Ou(s));Ru.register(Mu.isSemgrepAvailable,Xa);Ru.register(Mu.runSemgrepWithRules,li);Ru.register(Mu.convertSemgrepFindings,ci);Ru.register(Mu.KnowledgeGraphService,s=>new ze(s));S();Ru.register(Mu.QualityAnalyzerService,s=>new oe(s));S();N();S();var n0={SoapOperationTested:"enterprise-integration.SoapOperationTested",MessageFlowTested:"enterprise-integration.MessageFlowTested",BapiTested:"enterprise-integration.BapiTested",IDocValidated:"enterprise-integration.IDocValidated",ODataTested:"enterprise-integration.ODataTested",SodAnalyzed:"enterprise-integration.SodAnalyzed",MiddlewareFlowTested:"enterprise-integration.MiddlewareFlowTested",IntegrationValidationFailed:"enterprise-integration.IntegrationValidationFailed"},_2u={maxConcurrentWorkflows:8,defaultTimeout:12e4,publishEvents:!0,enableMinCutAwareness:!0,topologyHealthThreshold:.5,pauseOnCriticalTopology:!1,enableConsensus:!0,consensusThreshold:.7,consensusStrategy:"weighted",consensusMinModels:2},Wi=B.create("enterprise-integration"),$i=class extends Y{constructor(u,a,t,r={}){let i={..._2u,...r};super(u,"enterprise-integration",i,{verifyFindingTypes:["soap-fault","message-ordering-violation","rfc-compatibility-break","idoc-validation-failure","odata-contract-break","sod-conflict"],modelTimeout:12e4});this.memory=a;this.agentCoordinator=t}async onInitialize(){this.subscribeToEvents(),Wi.info("Enterprise Integration Coordinator initialized")}async onDispose(){}subscribeToEvents(){this.eventBus.subscribe("contract-testing.ContractVerified",this.handleContractVerified.bind(this)),this.eventBus.subscribe("chaos-resilience.FaultInjected",this.handleFaultInjected.bind(this))}getActiveWorkflows(){return super.getActiveWorkflows()}async validateWsdl(u){let a=A();try{if(this.startWorkflow(a,"soap"),this.minCutMixin.shouldPauseOperations())return m(new Error("WSDL validation paused: topology is in critical state"));let t=await this.spawnAgent(a,"qe-soap-tester",{task:"validate-wsdl",url:u});if(!t.success)return this.failWorkflow(a,t.error.message),t;let r={url:u,version:"1.1",services:[],schemas:[]};return await this.memory.set(`enterprise-integration:wsdl:${encodeURIComponent(u)}`,r,{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(a),p(r)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async testSoapOperation(u,a,t){let r=A();try{this.startWorkflow(r,"soap");let i=await this.spawnAgent(r,"qe-soap-tester",{task:"test-operation",wsdl:u,operation:a,input:t});if(!i.success)return this.failWorkflow(r,i.error.message),m(i.error);let n={operation:a,passed:!0,request:JSON.stringify(t),response:"",validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.SoapOperationTested,this.domainName,{operation:a,wsdlUrl:u.url,passed:n.passed,errors:n.validationErrors.length})),this.completeWorkflow(r),p(n)}catch(i){return this.failWorkflow(r,String(i)),m(g(i))}}async testMessageFlow(u,a){let t=A();try{this.startWorkflow(t,"messaging");let r=await this.spawnAgent(t,"qe-message-broker-tester",{task:"test-message-flow",brokerConfig:u,testCase:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={testCaseId:a.id,passed:!0,sentAt:new Date,receivedAt:new Date,latency:0,actualOutcome:a.expectedOutcome,errors:[]};return this.config.publishEvents&&await this.eventBus.publish(L(n0.MessageFlowTested,this.domainName,{protocol:u.protocol,queue:a.queue,passed:i.passed,latency:i.latency})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async testDlqHandling(u,a){let t=A();try{this.startWorkflow(t,"messaging");let r=await this.spawnAgent(t,"qe-message-broker-tester",{task:"test-dlq",brokerConfig:u,queue:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={queue:a,messageCount:0,poisonMessages:0,reprocessable:0,errors:[]};return this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async testBapiCall(u,a){let t=A();try{if(this.startWorkflow(t,"rfc"),this.minCutMixin.shouldPauseOperations())return m(new Error("BAPI testing paused: topology is in critical state"));let r=await this.spawnAgent(t,"qe-sap-rfc-tester",{task:"test-bapi",connection:u,bapi:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={bapiName:a.name,passed:!0,returnMessages:[],exportValues:{},tableData:{},duration:0,transactionCommitted:!1};return this.config.publishEvents&&await this.eventBus.publish(L(n0.BapiTested,this.domainName,{bapiName:a.name,passed:i.passed,returnType:i.returnMessages.length>0?i.returnMessages[0].type:"S"})),await this.memory.set(`enterprise-integration:bapi:${a.name}:${Date.now()}`,{bapiName:a.name,importParams:Object.keys(a.importParams),passed:i.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateIdoc(u,a){let t=A();try{this.startWorkflow(t,"idoc");let r=await this.spawnAgent(t,"qe-sap-idoc-tester",{task:"validate-idoc",definition:u,content:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={idocType:u.type,direction:"inbound",passed:!0,statusCode:3,statusMessage:"IDoc validated successfully",segmentValidation:[],processingTime:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.IDocValidated,this.domainName,{idocType:u.type,direction:i.direction,passed:i.passed,statusCode:i.statusCode})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateODataMetadata(u){let a=A();try{this.startWorkflow(a,"odata");let t=await this.spawnAgent(a,"qe-odata-contract-tester",{task:"validate-metadata",serviceUrl:u});if(!t.success)return this.failWorkflow(a,t.error.message),m(t.error);let r={version:"v4",serviceUrl:u,entitySets:[],functionImports:[],actions:[]};return await this.memory.set(`enterprise-integration:odata:${encodeURIComponent(u)}`,r,{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(a),p(r)}catch(t){return this.failWorkflow(a,String(t)),m(g(t))}}async testODataEntitySet(u,a){let t=A();try{this.startWorkflow(t,"odata");let r=await this.spawnAgent(t,"qe-odata-contract-tester",{task:"test-entity-set",metadata:u,entitySet:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={entitySet:a,operation:"CRUD",passed:!0,statusCode:200,validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.ODataTested,this.domainName,{entitySet:a,operation:i.operation,passed:i.passed,version:u.version})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateMessageFlow(u,a){let t=A();try{this.startWorkflow(t,"middleware");let r=await this.spawnAgent(t,"qe-middleware-validator",{task:"validate-flow",flow:u,input:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={flowName:u.name,passed:!0,routingCorrect:!0,transformationCorrect:!0,errorHandlingCorrect:!0,validationErrors:[],duration:0};return this.config.publishEvents&&await this.eventBus.publish(L(n0.MiddlewareFlowTested,this.domainName,{flowName:u.name,passed:i.passed,routingCorrect:i.routingCorrect,transformationCorrect:i.transformationCorrect})),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async validateTransformation(u,a,t){let r=A();try{this.startWorkflow(r,"middleware");let i=await this.spawnAgent(r,"qe-middleware-validator",{task:"validate-transformation",spec:u,input:a,expectedOutput:t});return i.success?(this.completeWorkflow(r),p(!0)):(this.failWorkflow(r,i.error.message),m(i.error))}catch(i){return this.failWorkflow(r,String(i)),m(g(i))}}async analyzeSod(u,a){let t=A();try{this.startWorkflow(t,"sod");let r=await this.spawnAgent(t,"qe-sod-analyzer",{task:"analyze-sod",userId:u,ruleset:a});if(!r.success)return this.failWorkflow(t,r.error.message),m(r.error);let i={userId:u,conflicts:[],riskScore:0,compliant:!0,recommendations:[]};return this.config.publishEvents&&await this.eventBus.publish(L(n0.SodAnalyzed,this.domainName,{userId:u,conflicts:i.conflicts.length,compliant:i.compliant,riskScore:i.riskScore})),await this.memory.set(`enterprise-integration:sod:${u}:${Date.now()}`,{userId:u,ruleset:a.name,conflicts:i.conflicts.length,compliant:i.compliant,riskScore:i.riskScore,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",persist:!0}),this.completeWorkflow(t),p(i)}catch(r){return this.failWorkflow(t,String(r)),m(g(r))}}async spawnAgent(u,a,t){let r={name:`${a}-${u.slice(0,8)}`,domain:"enterprise-integration",type:a,capabilities:[a],config:{workflowId:u,...t}},i=await this.agentCoordinator.spawn(r);return i.success&&this.addAgentToWorkflow(u,i.value),i}async verifyCriticalFinding(u,a){let t=O({id:A(),type:u.type,confidence:a,description:u.description,payload:u.payload,detectedBy:"enterprise-integration-coordinator",severity:a>.9?"critical":"high"});if(this.consensusMixin.requiresConsensus(t)){let r=await this.consensusMixin.verifyFinding(t);return r.success&&r.value.verdict==="verified"?(Wi.info(`Finding verified by consensus: ${u.type}`),!0):(Wi.warn(`Finding NOT verified: ${u.type}`),!1)}return!0}async handleContractVerified(u){let a=u.payload;(a?.contractType==="soap"||a?.contractType==="odata")&&await this.memory.set(`enterprise-integration:contract-event:${Date.now()}`,{contractId:a.contractId,type:a.contractType,passed:a.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleFaultInjected(u){let a=u.payload;(a?.targetService?.includes("middleware")||a?.targetService?.includes("esb"))&&Wi.info(`Middleware fault injection detected: ${a.targetService}`)}};var Zl=class extends U{constructor(u,a,t,r={}){super(u,a);this.agentCoordinator=t;this.pluginConfig=r}coordinator=null;pluginConfig;get name(){return"enterprise-integration"}get version(){return"1.0.0"}get dependencies(){return[]}getAPI(){return{validateWsdl:this.validateWsdl.bind(this),testSoapOperation:this.testSoapOperation.bind(this),testMessageFlow:this.testMessageFlow.bind(this),testDlqHandling:this.testDlqHandling.bind(this),testBapiCall:this.testBapiCall.bind(this),validateIdoc:this.validateIdoc.bind(this),validateODataMetadata:this.validateODataMetadata.bind(this),testODataEntitySet:this.testODataEntitySet.bind(this),validateMessageFlow:this.validateMessageFlow.bind(this),validateTransformation:this.validateTransformation.bind(this),analyzeSod:this.analyzeSod.bind(this),getCoordinator:()=>this.coordinator,getActiveWorkflows:()=>this.coordinator?.getActiveWorkflows()||[]}}getTaskHandlers(){return new Map([["enterprise-integration:soap-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.wsdl,t=u.operation,r=u.input;return u.url&&!a?this.coordinator.validateWsdl(u.url):!a||!t?m(new Error("Invalid soap-test payload: missing wsdl or operation")):this.coordinator.testSoapOperation(a,t,r)}],["enterprise-integration:message-broker-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.brokerConfig,t=u.testCase,r=u.queue;return a?r&&!t?this.coordinator.testDlqHandling(a,r):t?this.coordinator.testMessageFlow(a,t):m(new Error("Invalid message-broker-test payload: missing testCase")):m(new Error("Invalid message-broker-test payload: missing brokerConfig"))}],["enterprise-integration:sap-rfc-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.connection,t=u.bapi;return!a||!t?m(new Error("Invalid sap-rfc-test payload: missing connection or bapi")):this.coordinator.testBapiCall(a,t)}],["enterprise-integration:sap-idoc-validate",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.definition,t=u.content;return!a||!t?m(new Error("Invalid sap-idoc-validate payload: missing definition or content")):this.coordinator.validateIdoc(a,t)}],["enterprise-integration:odata-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.serviceUrl,t=u.metadata,r=u.entitySet;return a&&!t?this.coordinator.validateODataMetadata(a):!t||!r?m(new Error("Invalid odata-test payload: missing metadata or entitySet")):this.coordinator.testODataEntitySet(t,r)}],["enterprise-integration:esb-flow-test",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.flow,t=u.input,r=u.spec;if(r){let i=u.transformInput,n=u.expectedOutput;return!i||!n?m(new Error("Invalid esb-flow-test payload: missing transformInput or expectedOutput for transformation")):this.coordinator.validateTransformation(r,i,n)}return!a||!t?m(new Error("Invalid esb-flow-test payload: missing flow or input")):this.coordinator.validateMessageFlow(a,t)}],["enterprise-integration:sod-analyze",async u=>{if(!this.coordinator)return m(new Error("Enterprise integration coordinator not initialized"));let a=u.userId,t=u.ruleset;return!a||!t?m(new Error("Invalid sod-analyze payload: missing userId or ruleset")):this.coordinator.analyzeSod(a,t)}]])}async onInitialize(){this.coordinator=new $i(this.eventBus,this.memory,this.agentCoordinator,this.pluginConfig.coordinator),await this.coordinator.initialize(),this.updateHealth({status:"idle",agents:{total:0,active:0,idle:0,failed:0},lastActivity:new Date,errors:[]})}async onDispose(){this.coordinator&&await this.coordinator.dispose(),this.coordinator=null}subscribeToEvents(){this.eventBus.subscribe("contract-testing.ContractVerified",this.handleContractVerified.bind(this)),this.eventBus.subscribe("quality-assessment.QualityGateEvaluated",this.handleQualityGate.bind(this)),this.eventBus.subscribe("chaos-resilience.FaultInjected",this.handleFaultInjected.bind(this))}async onEvent(u){switch(this.updateHealth({lastActivity:new Date}),u.type){case"contract-testing.ContractVerified":await this.handleContractVerified(u);break;case"quality-assessment.QualityGateEvaluated":await this.handleQualityGate(u);break;case"chaos-resilience.FaultInjected":await this.handleFaultInjected(u);break;default:break}}async validateWsdl(u){this.ensureInitialized();try{let a=await this.coordinator.validateWsdl(u);return a.success?this.trackSuccessfulOperation("validateWsdl"):this.trackFailedOperation(new Error(a.error.message)),a}catch(a){return this.handleError(a)}}async testSoapOperation(u,a,t){this.ensureInitialized();try{let r=await this.coordinator.testSoapOperation(u,a,t);return r.success?this.trackSuccessfulOperation("testSoapOperation"):this.trackFailedOperation(new Error(r.error.message)),r}catch(r){return this.handleError(r)}}async testMessageFlow(u,a){this.ensureInitialized();try{let t=await this.coordinator.testMessageFlow(u,a);return t.success?this.trackSuccessfulOperation("testMessageFlow"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async testDlqHandling(u,a){this.ensureInitialized();try{let t=await this.coordinator.testDlqHandling(u,a);return t.success?this.trackSuccessfulOperation("testDlqHandling"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async testBapiCall(u,a){this.ensureInitialized();try{let t=await this.coordinator.testBapiCall(u,a);return t.success?this.trackSuccessfulOperation("testBapiCall"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateIdoc(u,a){this.ensureInitialized();try{let t=await this.coordinator.validateIdoc(u,a);return t.success?this.trackSuccessfulOperation("validateIdoc"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateODataMetadata(u){this.ensureInitialized();try{let a=await this.coordinator.validateODataMetadata(u);return a.success?this.trackSuccessfulOperation("validateODataMetadata"):this.trackFailedOperation(new Error(a.error.message)),a}catch(a){return this.handleError(a)}}async testODataEntitySet(u,a){this.ensureInitialized();try{let t=await this.coordinator.testODataEntitySet(u,a);return t.success?this.trackSuccessfulOperation("testODataEntitySet"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateMessageFlow(u,a){this.ensureInitialized();try{let t=await this.coordinator.validateMessageFlow(u,a);return t.success?this.trackSuccessfulOperation("validateMessageFlow"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async validateTransformation(u,a,t){this.ensureInitialized();try{let r=await this.coordinator.validateTransformation(u,a,t);return r.success?this.trackSuccessfulOperation("validateTransformation"):this.trackFailedOperation(new Error(r.error.message)),r}catch(r){return this.handleError(r)}}async analyzeSod(u,a){this.ensureInitialized();try{let t=await this.coordinator.analyzeSod(u,a);return t.success?this.trackSuccessfulOperation("analyzeSod"):this.trackFailedOperation(new Error(t.error.message)),t}catch(t){return this.handleError(t)}}async handleContractVerified(u){let a=u.payload;(a.contractType==="soap"||a.contractType==="odata")&&await this.memory.set(`enterprise-integration:contract-verified:${a.contractId}`,{contractId:a.contractId,type:a.contractType,passed:a.passed,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleQualityGate(u){let a=u.payload;a.checks.find(r=>r.name==="enterprise-integration")||await this.memory.set(`enterprise-integration:quality-gate-warning:${a.gateId}`,{warning:"Enterprise integration testing not included in quality gate",timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:86400})}async handleFaultInjected(u){let a=u.payload;(a.targetService?.includes("middleware")||a.targetService?.includes("esb")||a.targetService?.includes("broker")||a.targetService?.includes("mq"))&&await this.memory.set(`enterprise-integration:fault-correlation:${a.faultId||Date.now()}`,{targetService:a.targetService,faultType:a.faultType,timestamp:new Date().toISOString()},{namespace:"enterprise-integration",ttl:3600})}ensureInitialized(){if(!this._initialized)throw new Error("EnterpriseIntegrationPlugin is not initialized");if(!this.coordinator)throw new Error("EnterpriseIntegrationPlugin coordinator is not available")}handleError(u){let a=g(u),t=this.getHealth();return this.updateHealth({errors:[...t.errors.slice(-9),a.message],status:t.errors.length>=5?"degraded":t.status}),{success:!1,error:a}}trackSuccessfulOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,total:a.agents.total+1,idle:a.agents.idle+1},lastActivity:new Date})}trackFailedOperation(u){let a=this.getHealth();this.updateHealth({agents:{...a.agents,failed:a.agents.failed+1},errors:[...a.errors.slice(-9),u.message]})}};function a3(s,e,u,a){return new Zl(s,e,u,a)}var t3={"test-generation":(s,e,u)=>Cs(s,e,u),"test-execution":(s,e)=>Qc(s,e),"coverage-analysis":(s,e)=>Ws(s,e),"quality-assessment":(s,e,u)=>el(s,e,u),"defect-intelligence":(s,e,u)=>P1(s,e,u),"requirements-validation":(s,e,u)=>I1(s,e,u),"code-intelligence":(s,e,u)=>pl(s,e,u),"security-compliance":(s,e,u)=>jl(s,e,u),"contract-testing":(s,e,u)=>bE(s,e,u),"visual-accessibility":(s,e,u)=>HE(s,e,u),"chaos-resilience":(s,e,u)=>OE(s,e,u),"learning-optimization":(s,e,u)=>XE(s,e,u),"enterprise-integration":(s,e,u)=>a3(s,e,u),coordination:(s,e,u)=>u3(s,e,u)},$2u={maxConcurrentAgents:J0.MAX_CONCURRENT_AGENTS,memoryBackend:"hybrid",hnswEnabled:!0,lazyLoading:!0,enabledDomains:[...Fu],dataDir:void 0},Ql=class{_eventBus;_coordinator;_plugins;_memory;_config;_startTime;_initialized=!1;_loopTracker;constructor(e={}){this._config={...$2u,...e},this._startTime=new Date,this._memory=new Qi,this._eventBus=new xt,this._coordinator=new ft(this._config.maxConcurrentAgents),this._plugins=new aa(this._eventBus,this._memory,this._config.lazyLoading),this._loopTracker=new vt}get eventBus(){return this._eventBus}get coordinator(){return this._coordinator}get plugins(){return this._plugins}get memory(){return this._memory}async initialize(){if(this._initialized)return;let e=u4(),u=this._config.dataDir||o0.join(e,".agentic-qe");if(qi.existsSync(u)||qi.mkdirSync(u,{recursive:!0}),this._config.memoryBackend==="memory"){let t=o0.join(Ji("os").tmpdir(),`aqe-test-${Date.now()}-${W2u().slice(0,12)}.db`);await a4({dbPath:t})}else this._memory=new e4({sqlite:{path:o0.join(u,"memory.db"),walMode:!0,poolSize:3,busyTimeout:Xl.BUSY_TIMEOUT_MS},enableFallback:!0,defaultNamespace:"qe-kernel"}),this._plugins=new aa(this._eventBus,this._memory,this._config.lazyLoading);for(let t of this._config.enabledDomains){let r=t3[t];r&&this._plugins.registerFactory(t,async(i,n)=>Promise.resolve(r(i,n,this._coordinator)))}await this._memory.initialize();let a=new bt({agentId:"qe-kernel"});this._eventBus.registerMiddleware(a);try{let t=o0.join(u,"plugins"),r=new t4({cacheDir:t}),n=new r4({cache:r}).resolveLoadOrder();for(let o of n.ordered){let l=o.manifest,c=r.get(l.name,l.version);if(!c)continue;let E=o0.join(c.path,l.entryPoint);for(let d of l.domains){let D=d;if(t3[D])continue;this._plugins.registerFactory(D,async(C,y)=>{let x=await import(E),b=x.default??x.createPlugin;if(typeof b!="function")throw new Error(`Plugin "${l.name}" entry point must export a default function or "createPlugin" function`);return b(C,y,this._coordinator)})}}}catch{}this._config.lazyLoading||await this._plugins.loadAll();try{let{isAgentMemoryBranchingEnabled:t,isRVFPatternStoreEnabled:r}=await import("./feature-flags-ZJ42B4IL.js");if(t()&&r()){let{getSharedRvfAdapter:i}=await import("./shared-rvf-adapter-VCJNSACZ.js"),{AgentMemoryBranch:n}=await import("./agent-memory-branch-SQ3KDIG6.js"),o=i(u,384);if(o){let l=new n(o,{branchDir:o0.join(u,"branches")});this._coordinator.setMemoryBranch(l)}}}catch{}try{let{getRvfMigrationStage:t}=await import("./feature-flags-ZJ42B4IL.js"),r=t();if(r>=2){let{RvfMigrationCoordinator:i}=await import("./rvf-migration-coordinator-SX2C7777.js");await i.getInstance({stage:r}).initialize()}}catch{}this._initialized=!0}async dispose(){await this._plugins.disposeAll(),await this._coordinator.dispose(),await this._eventBus.dispose(),await this._memory.dispose(),this._initialized=!1}getDomainAPI(e){return this._plugins.getPlugin(e)?.getAPI()}async getDomainAPIAsync(e){let u=this._plugins.getPlugin(e);if(!u&&this._config.lazyLoading&&this._config.enabledDomains.includes(e))try{u=await this._plugins.load(e)}catch(a){console.error(`[QEKernel] Failed to lazy load domain ${e}:`,a);return}return u?.getAPI()}async ensureDomainLoaded(e){if(this._plugins.isLoaded(e))return!0;if(!this._config.enabledDomains.includes(e))return console.warn(`[QEKernel] Domain ${e} is not enabled`),!1;try{return await this._plugins.load(e),!0}catch(u){return console.error(`[QEKernel] Failed to load domain ${e}:`,u),!1}}isDomainLoaded(e){return this._plugins.isLoaded(e)}getLoadedDomains(){return this._plugins.getLoaded()}getPendingDomains(){let e=new Set(this._plugins.getLoaded());return this._config.enabledDomains.filter(u=>!e.has(u))}getHealth(){let e=this._coordinator.listAgents(),u={};for(let l of this._plugins.getLoaded()){let c=this._plugins.getPlugin(l);c&&(u[l]=c.getHealth())}for(let l of Fu)if(!u[l]){let c=this._config.enabledDomains.includes(l),E=this._config.lazyLoading&&c;u[l]={status:E?"healthy":c?"degraded":"healthy",agents:{total:0,active:0,idle:0,failed:0},errors:E?[]:c?["Domain not yet loaded"]:[],loaded:!1,lazyLoadable:E}}let a=this._coordinator.getActiveCount(),t=0,r=Number.MAX_SAFE_INTEGER;if(this._memory instanceof Qi){let l=this._memory.getStats();t=l.entries+l.vectors}else t=0;let n=this._eventBus.getMiddlewares().find(l=>l.name==="semantic-anti-drift"),o=n?n.getStats():void 0;return{status:this.determineOverallStatus(u),uptime:Date.now()-this._startTime.getTime(),domains:u,agents:{total:e.length,active:a,maxAllowed:this._config.maxConcurrentAgents},memory:{used:t,available:r},...o?{antiDrift:o}:{}}}determineOverallStatus(e){let u=Object.values(e).map(a=>a.status);return u.some(a=>a==="unhealthy")?"unhealthy":u.some(a=>a==="degraded")?"degraded":"healthy"}getConfig(){return{...this._config}}checkToolCall(e,u,a){if(process.env.AQE_LOOP_DETECTION_ENABLED==="false")return this._loopTracker.trackCall(e,u,a);let t=this._loopTracker.trackCall(e,u,a);if(t.action==="warn"){let r={id:`loop-warn-${e}-${Date.now()}`,type:on.LOOP_WARNING,timestamp:new Date,source:"coordination",correlationId:e,payload:{agentId:e,toolName:u,callCount:t.callCount,signature:t.signature}};this._eventBus.publish(r)}else if(t.action==="steer"){let r={id:`loop-detected-${e}-${Date.now()}`,type:on.LOOP_DETECTED,timestamp:new Date,source:"coordination",correlationId:e,payload:{agentId:e,toolName:u,callCount:t.callCount,signature:t.signature,steeringMessage:t.steeringMessage}};this._eventBus.publish(r)}return t}get loopTracker(){return this._loopTracker}};function dre(s){return new Ql(s)}export{Ie as a,ve as b,f0 as c,b0 as d,Ue as e,Dl as f,yu as g,Ju as h,Xe as i,Al as j,si as k,K0 as l,j0 as m,Ni as n,V0 as o,_0 as p,a0 as q,t0 as r,r0 as s,Mu as t,Ru as u,Ql as v,dre as w};