agentic-qe 3.9.0 → 3.9.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.claude/skills/skills-manifest.json +1 -1
- package/CHANGELOG.md +43 -0
- package/dist/audit/witness-chain.d.ts +1 -1
- package/dist/cli/bundle.js +8 -8
- package/dist/cli/chunks/adapter-53WBPKXU.js +2 -0
- package/dist/cli/chunks/{agent-booster-wasm-PQYB7VRU.js → agent-booster-wasm-AKAOHSCX.js} +2 -2
- package/dist/cli/chunks/{agent-handler-QDAB5NQS.js → agent-handler-MTGPOUVP.js} +2 -2
- package/dist/cli/chunks/agent-memory-branch-UFPKWUFK.js +2 -0
- package/dist/cli/chunks/aqe-learning-engine-MV7NGY24.js +2 -0
- package/dist/cli/chunks/{audit-S7JUYYVP.js → audit-VBEZHNHO.js} +2 -2
- package/dist/cli/chunks/base-DZVGMQN2.js +2 -0
- package/dist/cli/chunks/better-sqlite3-IRPHIXRU.js +2 -0
- package/dist/cli/chunks/brain-handler-7EO3FFRZ.js +68 -0
- package/dist/cli/chunks/{branch-enumerator-XK4V5W7L.js → branch-enumerator-MZRGP35N.js} +2 -2
- package/dist/cli/chunks/{browser-PALA5PL3.js → browser-VSIWQE7J.js} +2 -2
- package/dist/cli/chunks/browser-workflow-3J5YNMEI.js +2 -0
- package/dist/cli/chunks/chunk-25LFUL2K.js +79 -0
- package/dist/cli/chunks/{chunk-LHJQD2VU.js → chunk-2EC5Z2J4.js} +68 -68
- package/dist/cli/chunks/{chunk-4YOMLWEK.js → chunk-2VVV73PW.js} +1 -1
- package/dist/cli/chunks/{chunk-BPWXXEH2.js → chunk-2WBCYSUN.js} +128 -128
- package/dist/cli/chunks/{chunk-X3KI6JOY.js → chunk-2Z2TFEOL.js} +2 -2
- package/dist/cli/chunks/chunk-34U7JDCN.js +2 -0
- package/dist/cli/chunks/{chunk-24FKIJNC.js → chunk-3GZKAORV.js} +2 -2
- package/dist/cli/chunks/{chunk-72WOAVK6.js → chunk-4D2ZG2QO.js} +1 -1
- package/dist/cli/chunks/{chunk-B36CDR4U.js → chunk-4DAOZQ3V.js} +2 -2
- package/dist/cli/chunks/{chunk-CL6POIX4.js → chunk-4FMHBBG5.js} +1 -1
- package/dist/cli/chunks/{chunk-BXAXGEFC.js → chunk-4FT3PND7.js} +5 -5
- package/dist/cli/chunks/{chunk-IGJPMN4I.js → chunk-4LA7IW3V.js} +1 -1
- package/dist/cli/chunks/{chunk-JRYGQO2W.js → chunk-4PKXIBX2.js} +1 -1
- package/dist/cli/chunks/{chunk-YPFOCNOE.js → chunk-4UH25U4O.js} +1 -1
- package/dist/cli/chunks/{chunk-U5RN7YQW.js → chunk-4Z27TRQF.js} +2 -2
- package/dist/cli/chunks/{chunk-YW2THB5Q.js → chunk-563PJBDM.js} +2 -2
- package/dist/cli/chunks/{chunk-BDIEMZ22.js → chunk-56IWS2KY.js} +2 -2
- package/dist/cli/chunks/chunk-5AUKULWO.js +2 -0
- package/dist/cli/chunks/{chunk-VSVXUTJN.js → chunk-5L6AU3QK.js} +2 -2
- package/dist/cli/chunks/{chunk-RTGGL7D7.js → chunk-5RL66XSH.js} +2 -2
- package/dist/cli/chunks/{chunk-YANUP2RO.js → chunk-65M7C6SH.js} +1 -1
- package/dist/cli/chunks/{chunk-ESVQ6MEB.js → chunk-6SOJVEU7.js} +2 -2
- package/dist/cli/chunks/{chunk-UFUVUO3J.js → chunk-727BDQ3K.js} +2 -2
- package/dist/cli/chunks/{chunk-TLHP5EII.js → chunk-7NOIIC7G.js} +1 -1
- package/dist/cli/chunks/{chunk-N4TL73TH.js → chunk-7SLN2JGP.js} +8 -8
- package/dist/cli/chunks/{chunk-NZ2VCPN4.js → chunk-AA33R5U4.js} +2 -2
- package/dist/cli/chunks/{chunk-Y7BHKZFJ.js → chunk-AKSJQ6B3.js} +2 -2
- package/dist/cli/chunks/{chunk-3ZOONQG6.js → chunk-BIVIPF4O.js} +1 -1
- package/dist/cli/chunks/{chunk-VOS4NQSF.js → chunk-BKCTNRC5.js} +2 -2
- package/dist/cli/chunks/{chunk-B6LLWYQ6.js → chunk-BOH22AKC.js} +2 -2
- package/dist/cli/chunks/{chunk-OI5NGQO2.js → chunk-BY47GV4T.js} +2 -2
- package/dist/cli/chunks/chunk-CCYMJKWX.js +2 -0
- package/dist/cli/chunks/chunk-CL3K5EJK.js +2 -0
- package/dist/cli/chunks/{chunk-GPQ57KA4.js → chunk-CQBSGYRA.js} +2 -2
- package/dist/cli/chunks/{chunk-MZOFWJTM.js → chunk-CQP7ZFME.js} +2 -2
- package/dist/cli/chunks/chunk-DBE34QES.js +2 -0
- package/dist/cli/chunks/chunk-DHE66JRR.js +12 -0
- package/dist/cli/chunks/{chunk-2BZFNEN2.js → chunk-DNLMZTE2.js} +1 -1
- package/dist/cli/chunks/{chunk-XLRQYLWW.js → chunk-DSE57A5N.js} +1 -1
- package/dist/cli/chunks/{chunk-SUSEVMZT.js → chunk-E25S5E2D.js} +1 -1
- package/dist/cli/chunks/{chunk-FEKY7T6Q.js → chunk-FAXVVLPL.js} +2 -2
- package/dist/cli/chunks/chunk-FRJLP7IB.js +2 -0
- package/dist/cli/chunks/{chunk-CS2KS7LP.js → chunk-FUIHWBVF.js} +1 -1
- package/dist/cli/chunks/{chunk-LNQIY6BP.js → chunk-GCMVJS5X.js} +2 -2
- package/dist/cli/chunks/{chunk-XT2V2322.js → chunk-GITD7SRQ.js} +2 -2
- package/dist/cli/chunks/{chunk-JJO7Y4H3.js → chunk-GK72GUHA.js} +3 -3
- package/dist/cli/chunks/{chunk-6EOS7KX2.js → chunk-GPLERTZU.js} +2 -2
- package/dist/cli/chunks/{chunk-2E5NQNSU.js → chunk-HW4ISY5B.js} +11 -11
- package/dist/cli/chunks/{chunk-HRO6OZQD.js → chunk-ICDXWIFZ.js} +1 -1
- package/dist/cli/chunks/{chunk-3NZLZHJI.js → chunk-J4BS6IWE.js} +1 -1
- package/dist/cli/chunks/{chunk-4VUPRTVX.js → chunk-JOVINE23.js} +2 -2
- package/dist/cli/chunks/chunk-JV7LX6OT.js +95 -0
- package/dist/cli/chunks/{chunk-6SVX4DJC.js → chunk-KBA7FBK3.js} +3 -3
- package/dist/cli/chunks/chunk-KDDZYXP4.js +2 -0
- package/dist/cli/chunks/{chunk-GAOJV3OX.js → chunk-KNVAAVHH.js} +2 -2
- package/dist/cli/chunks/{chunk-CWFB6BSA.js → chunk-KQTJ2YLI.js} +4 -4
- package/dist/cli/chunks/{chunk-FGA7VIFR.js → chunk-KTYUCZEM.js} +3 -3
- package/dist/cli/chunks/{chunk-RU5WAHB7.js → chunk-KZTO5EVM.js} +2 -2
- package/dist/cli/chunks/{chunk-IFNIIK34.js → chunk-KZUJBZ7B.js} +3 -3
- package/dist/cli/chunks/{chunk-GKNNSCLC.js → chunk-L5WZUPZF.js} +2 -2
- package/dist/cli/chunks/{chunk-MDUHYUHF.js → chunk-L5YEPSDU.js} +2 -2
- package/dist/cli/chunks/chunk-LCAA6H4J.js +2 -0
- package/dist/cli/chunks/{chunk-XRE2HCWG.js → chunk-LMMEUVE5.js} +1 -1
- package/dist/cli/chunks/{chunk-7VDBAVTY.js → chunk-MN742FIH.js} +2 -2
- package/dist/cli/chunks/chunk-MY4LMIG7.js +180 -0
- package/dist/cli/chunks/{chunk-WGMPEW2T.js → chunk-N3F3CX4V.js} +2 -2
- package/dist/cli/chunks/{chunk-YVA65UZL.js → chunk-NJY7ZA77.js} +1 -1
- package/dist/cli/chunks/{chunk-3IHG3WOY.js → chunk-NM6TIEJ3.js} +3 -3
- package/dist/cli/chunks/{chunk-KP5NUODU.js → chunk-NRCKGXJJ.js} +1 -1
- package/dist/cli/chunks/{chunk-3ADGXLTM.js → chunk-PFNFC43Q.js} +1 -1
- package/dist/cli/chunks/{chunk-4VBTXZRM.js → chunk-PJFLO37I.js} +2 -2
- package/dist/cli/chunks/{chunk-XIBDETCS.js → chunk-PNL5G6TE.js} +2 -2
- package/dist/cli/chunks/{chunk-AFLLQ5PP.js → chunk-Q4A72ZTV.js} +2 -2
- package/dist/cli/chunks/{chunk-EHDQJQ6Y.js → chunk-QEQTC4WQ.js} +5 -5
- package/dist/cli/chunks/{chunk-IAV2JMIX.js → chunk-QIH3E775.js} +2 -2
- package/dist/cli/chunks/{chunk-GRUUQAR6.js → chunk-QNBQBSAI.js} +2 -2
- package/dist/cli/chunks/{chunk-WIEC7VKK.js → chunk-QODE4LM6.js} +2 -2
- package/dist/cli/chunks/{chunk-HY6PMO5W.js → chunk-QPRVX4H2.js} +2 -2
- package/dist/cli/chunks/chunk-RC5CPXON.js +2 -0
- package/dist/cli/chunks/{chunk-TWUWL5EJ.js → chunk-RITN3XR4.js} +2 -2
- package/dist/cli/chunks/{chunk-WBQSXPBI.js → chunk-RJROC5M3.js} +2 -2
- package/dist/cli/chunks/chunk-RQGYJK7H.js +2 -0
- package/dist/cli/chunks/{chunk-XO6PVK2P.js → chunk-S3RDH5CI.js} +2 -2
- package/dist/cli/chunks/{chunk-3IUNFTIF.js → chunk-SCF7NRVE.js} +1 -1
- package/dist/cli/chunks/chunk-SDTVHR63.js +2 -0
- package/dist/cli/chunks/chunk-SGAW2WLI.js +65 -0
- package/dist/cli/chunks/{chunk-N2NS2PHA.js → chunk-SNVM4YJS.js} +2 -2
- package/dist/cli/chunks/{chunk-JXM26HEE.js → chunk-SRRFWTNF.js} +2 -2
- package/dist/cli/chunks/{chunk-UQHYFOBX.js → chunk-STE42EMB.js} +2 -2
- package/dist/cli/chunks/{chunk-WJ3DLOXF.js → chunk-T5GV6UIO.js} +2 -2
- package/dist/cli/chunks/{chunk-4YS3IJ45.js → chunk-TKF447CW.js} +1 -1
- package/dist/cli/chunks/{chunk-ZAPS3UGQ.js → chunk-TTOE336G.js} +3 -3
- package/dist/cli/chunks/{chunk-YAGODYIG.js → chunk-UKDOMLBI.js} +3 -3
- package/dist/cli/chunks/{chunk-JBANAPWG.js → chunk-V6XBAZNH.js} +1 -1
- package/dist/cli/chunks/{chunk-BULKFVYX.js → chunk-VHVWAXCF.js} +1 -1
- package/dist/cli/chunks/{chunk-5SKGFSKD.js → chunk-VL7YOOC2.js} +2 -2
- package/dist/cli/chunks/{chunk-AKE543X2.js → chunk-VUAO4VFC.js} +2 -2
- package/dist/cli/chunks/{chunk-7R6YMLVS.js → chunk-WG4GHAML.js} +2 -2
- package/dist/cli/chunks/{chunk-BTREG4IW.js → chunk-WXWY2GAF.js} +2 -2
- package/dist/cli/chunks/chunk-X35GP7TR.js +1 -0
- package/dist/cli/chunks/chunk-X6LCMOGC.js +2 -0
- package/dist/cli/chunks/{chunk-BGXNSCXX.js → chunk-XFMKJ3UD.js} +1 -1
- package/dist/cli/chunks/{chunk-BLBRY5UD.js → chunk-XH53ARZD.js} +2 -2
- package/dist/cli/chunks/chunk-XIBVVZGB.js +2 -0
- package/dist/cli/chunks/chunk-XYJL6DKI.js +2 -0
- package/dist/cli/chunks/{chunk-5T2ZQWKF.js → chunk-Y6O7CDLI.js} +2 -2
- package/dist/cli/chunks/{chunk-4I2IOUS4.js → chunk-YXCU4CJX.js} +1 -1
- package/dist/cli/chunks/{chunk-YR6ZZGH7.js → chunk-Z2IKNC5M.js} +1 -1
- package/dist/cli/chunks/{chunk-OLHKGP35.js → chunk-Z54EO6E6.js} +2 -2
- package/dist/cli/chunks/{chunk-ZDATDCYN.js → chunk-Z5HXGVXZ.js} +1 -1
- package/dist/cli/chunks/{ci-J374KDLI.js → ci-2BCOBWFG.js} +2 -2
- package/dist/cli/chunks/ci-output-FB4OJHAC.js +2 -0
- package/dist/cli/chunks/{claude-flow-setup-245JLJCN.js → claude-flow-setup-NEEFZTMB.js} +2 -2
- package/dist/cli/chunks/client-EF555KYW.js +2 -0
- package/dist/cli/chunks/{cline-installer-LBA2M5N3.js → cline-installer-ODO2PS4K.js} +2 -2
- package/dist/cli/chunks/{code-U4N4WONM.js → code-NSOF62VE.js} +2 -2
- package/dist/cli/chunks/{code-index-extractor-A57Z6BO4.js → code-index-extractor-YQL5XN52.js} +2 -2
- package/dist/cli/chunks/{codex-installer-UXMK2N4T.js → codex-installer-SPEY6VYT.js} +2 -2
- package/dist/cli/chunks/{completions-W66BSCOE.js → completions-OWKBUMBE.js} +2 -2
- package/dist/cli/chunks/complexity-analyzer-PGTXKP73.js +2 -0
- package/dist/cli/chunks/{continuedev-installer-LRFZ2SJM.js → continuedev-installer-KGOXAC7L.js} +2 -2
- package/dist/cli/chunks/{copilot-installer-CQ3JYBIB.js → copilot-installer-BF3UA3TG.js} +2 -2
- package/dist/cli/chunks/cost-tracker-2HDJ66E2.js +2 -0
- package/dist/cli/chunks/{coverage-4PUEQXAY.js → coverage-KPA2PHIN.js} +3 -3
- package/dist/cli/chunks/cross-domain-router-GXFNK5TS.js +2 -0
- package/dist/cli/chunks/{cursor-installer-JZEDEDHA.js → cursor-installer-7CDZFHTV.js} +2 -2
- package/dist/cli/chunks/{daemon-B7TWGHXQ.js → daemon-4BPGCKDJ.js} +3 -3
- package/dist/cli/chunks/dag-attention-scheduler-2MAVGSBB.js +2 -0
- package/dist/cli/chunks/detect-WRPWTGP5.js +2 -0
- package/dist/cli/chunks/{domain-handler-FT5FLZWL.js → domain-handler-JZVSJ7AG.js} +2 -2
- package/dist/cli/chunks/domain-transfer-XGIZOR2X.js +2 -0
- package/dist/cli/chunks/dream-3IKF5XH4.js +2 -0
- package/dist/cli/chunks/esm-node-DHAE52OW.js +2 -0
- package/dist/cli/chunks/{eval-GHMPFGWV.js → eval-T7YPAS4G.js} +2 -2
- package/dist/cli/chunks/{fast-paths-B3R647KN.js → fast-paths-QECJTKCQ.js} +2 -2
- package/dist/cli/chunks/{feature-flags-DWS7ARSX.js → feature-flags-LIFURSFZ.js} +2 -2
- package/dist/cli/chunks/feature-flags-R4QZYTIW.js +2 -0
- package/dist/cli/chunks/file-discovery-4W3K3W4C.js +2 -0
- package/dist/cli/chunks/{fleet-EKOKMOMW.js → fleet-NLLQWCI5.js} +3 -3
- package/dist/cli/chunks/gnn-wrapper-XEII72LN.js +2 -0
- package/dist/cli/chunks/{heartbeat-handler-MBBS4IBU.js → heartbeat-handler-DJ65RE5D.js} +4 -4
- package/dist/cli/chunks/{heartbeat-scheduler-XDGMOT7X.js → heartbeat-scheduler-H664265Q.js} +2 -2
- package/dist/cli/chunks/hnsw-adapter-DML5KXQR.js +2 -0
- package/dist/cli/chunks/hnsw-index-BUPPGVR6.js +2 -0
- package/dist/cli/chunks/hnsw-legacy-bridge-SQIDTWAA.js +2 -0
- package/dist/cli/chunks/hnswlib-node-WICYCU5U.js +2 -0
- package/dist/cli/chunks/{hooks-L5VLZGEK.js → hooks-GZUHUD63.js} +6 -6
- package/dist/cli/chunks/hypergraph-engine-MLCDZ6BL.js +2 -0
- package/dist/cli/chunks/{hypergraph-handler-3HDGB5SZ.js → hypergraph-handler-NNDDI4R3.js} +3 -3
- package/dist/cli/chunks/impact-analyzer-DPTMJRYS.js +2 -0
- package/dist/cli/chunks/{init-handler-JDET6WUN.js → init-handler-IJ6BHE6A.js} +6 -6
- package/dist/cli/chunks/init-wizard-35PUDJPW.js +2 -0
- package/dist/cli/chunks/kernel-2HZ44ZJ4.js +2 -0
- package/dist/cli/chunks/{kilocode-installer-GZZG5AFW.js → kilocode-installer-EPZFFPFE.js} +2 -2
- package/dist/cli/chunks/{kiro-installer-IWNY5TKH.js → kiro-installer-5VACG3HU.js} +2 -2
- package/dist/cli/chunks/knowledge-graph-JL62G72U.js +2 -0
- package/dist/cli/chunks/{learning-722ZNSZ6.js → learning-6FITK6XY.js} +3 -3
- package/dist/cli/chunks/{llm-router-DNAV746L.js → llm-router-4DDC6AKJ.js} +2 -2
- package/dist/cli/chunks/{load-Y3GCUFM4.js → load-KGDNVUBX.js} +2 -2
- package/dist/cli/chunks/load-test-LN245SSD.js +2 -0
- package/dist/cli/chunks/{mcp-LKPIBZ3W.js → mcp-4LETGVIV.js} +2 -2
- package/dist/cli/chunks/{memory-L57MLFOP.js → memory-II4I4QMO.js} +5 -5
- package/dist/cli/chunks/memory-backend-SVM7YRIE.js +2 -0
- package/dist/cli/chunks/memory-handlers-TQXTOJGQ.js +2 -0
- package/dist/cli/chunks/opencode-installer-EU6JCWBW.js +3 -0
- package/dist/cli/chunks/{orchestrator-QHSBB2UC.js → orchestrator-YLMGJVSP.js} +5 -5
- package/dist/cli/chunks/{pipeline-D3QER35Z.js → pipeline-MPZJWYKK.js} +2 -2
- package/dist/cli/chunks/{platform-T4E7Q3RD.js → platform-YH35ZZFZ.js} +2 -2
- package/dist/cli/chunks/{plugin-JHW2YPRC.js → plugin-B7JYZFNQ.js} +2 -2
- package/dist/cli/chunks/{prime-radiant-advanced-wasm-G7CFNNQV.js → prime-radiant-advanced-wasm-KTUK6UE2.js} +2 -2
- package/dist/cli/chunks/protocol-executor-IEN2XB4L.js +2 -0
- package/dist/cli/chunks/{protocol-handler-2BQQ4HDM.js → protocol-handler-3NXMVU34.js} +2 -2
- package/dist/cli/chunks/{prove-UQ6JFT73.js → prove-H5LMGSUC.js} +2 -2
- package/dist/cli/chunks/qe-reasoning-bank-Q3ZV3JRG.js +2 -0
- package/dist/cli/chunks/{quality-JRZYMC77.js → quality-RCWHY6GO.js} +2 -2
- package/dist/cli/chunks/queen-coordinator-E6ON3JUR.js +2 -0
- package/dist/cli/chunks/real-embeddings-NKH4VURF.js +2 -0
- package/dist/cli/chunks/{roocode-installer-F4E2LAYR.js → roocode-installer-SB7QJYM3.js} +2 -2
- package/dist/cli/chunks/router-WMC3LZ3C.js +2 -0
- package/dist/cli/chunks/routing-feedback-VKCZRCE3.js +2 -0
- package/dist/cli/chunks/{routing-handler-VNKFUUGB.js → routing-handler-SY7GKG2W.js} +2 -2
- package/dist/cli/chunks/ruvector-commands-HATTO3UQ.js +8 -0
- package/dist/cli/chunks/rvf-dual-writer-D57EXQUD.js +2 -0
- package/dist/cli/chunks/rvf-migration-adapter-OWDYN6KD.js +2 -0
- package/dist/cli/chunks/rvf-migration-coordinator-SIQVJB5S.js +2 -0
- package/dist/cli/chunks/rvf-native-adapter-C7NBH5UN.js +2 -0
- package/dist/cli/chunks/safe-db-5KLXCNXN.js +2 -0
- package/dist/cli/chunks/schedule-HAWWOXWB.js +2 -0
- package/dist/cli/chunks/scheduler-HTRDY5BC.js +2 -0
- package/dist/cli/chunks/{security-EBEG2OPU.js → security-DS3XLZWN.js} +3 -3
- package/dist/cli/chunks/shared-rvf-adapter-6I2Z5UGL.js +2 -0
- package/dist/cli/chunks/shared-rvf-dual-writer-YB7AH6XJ.js +2 -0
- package/dist/cli/chunks/sqlite-persistence-WNNRGTGG.js +2 -0
- package/dist/cli/chunks/{status-handler-VZ32M4G4.js → status-handler-TUYHE4FT.js} +2 -2
- package/dist/cli/chunks/{structural-health-K6LRCKV6.js → structural-health-XNGBNRRD.js} +2 -2
- package/dist/cli/chunks/{sync-MHSHNLIM.js → sync-K6CIRKBB.js} +2 -2
- package/dist/cli/chunks/{task-handler-JNOIBZ2G.js → task-handler-7PJY67DR.js} +2 -2
- package/dist/cli/chunks/task-handlers-WB5CDWUR.js +2 -0
- package/dist/cli/chunks/{test-DO22BNIL.js → test-WV5ALEBB.js} +4 -4
- package/dist/cli/chunks/{test-scheduling-VLRQZEFL.js → test-scheduling-N55ZGGA2.js} +3 -3
- package/dist/cli/chunks/token-bootstrap-SINWHAKR.js +2 -0
- package/dist/cli/chunks/{token-usage-LG3PXRXH.js → token-usage-R7TGEVGL.js} +2 -2
- package/dist/cli/chunks/transformers-6DBLXPV7.js +2 -0
- package/dist/cli/chunks/{tree-sitter-wasm-parser-FT2KB66N.js → tree-sitter-wasm-parser-7C7FKMQW.js} +2 -2
- package/dist/cli/chunks/types-VNPMOKQT.js +2 -0
- package/dist/cli/chunks/unified-memory-72SKVZ7Y.js +2 -0
- package/dist/cli/chunks/unified-memory-hnsw-TMN2L77W.js +2 -0
- package/dist/cli/chunks/unified-persistence-MDN3SRCR.js +2 -0
- package/dist/cli/chunks/{validate-VQCRSVNQ.js → validate-53MNIRAF.js} +2 -2
- package/dist/cli/chunks/{validate-swarm-A5DHAWTP.js → validate-swarm-ZY4RGUFO.js} +2 -2
- package/dist/cli/chunks/{vibium-RZBSL4EB.js → vibium-PBADBIV6.js} +2 -2
- package/dist/cli/chunks/visual-security-TRBCXPIB.js +2 -0
- package/dist/cli/chunks/{web-tree-sitter-7C4NXEOF.js → web-tree-sitter-O7VI6RLB.js} +2 -2
- package/dist/cli/chunks/{windsurf-installer-ES3KPQG3.js → windsurf-installer-HV3C3TAD.js} +2 -2
- package/dist/cli/chunks/witness-chain-4WIMYP4X.js +2 -0
- package/dist/cli/chunks/witness-chain-JOI2YYGK.js +2 -0
- package/dist/cli/chunks/{workflow-JETHX4ML.js → workflow-5RVAQ4TM.js} +4 -4
- package/dist/cli/chunks/workflow-orchestrator-2NQ72S3C.js +2 -0
- package/dist/cli/chunks/{wrappers-WP5RH745.js → wrappers-RRHCCA3E.js} +2 -2
- package/dist/cli/commands/ruvector-commands.js +14 -2
- package/dist/cli/index.js +10 -15
- package/dist/coordination/agent-memory-branch.d.ts +117 -0
- package/dist/coordination/agent-memory-branch.js +213 -0
- package/dist/coordination/agent-teams/mailbox.d.ts +43 -0
- package/dist/coordination/agent-teams/mailbox.js +130 -4
- package/dist/coordination/handlers/handler-utils.d.ts +1 -0
- package/dist/coordination/handlers/handler-utils.js +9 -2
- package/dist/coordination/handlers/quality-handlers.js +7 -1
- package/dist/domains/contract-testing/coordinator.js +11 -0
- package/dist/domains/quality-assessment/coherence/gate-controller.d.ts +20 -1
- package/dist/domains/quality-assessment/coherence/gate-controller.js +64 -0
- package/dist/domains/quality-assessment/coherence/index.d.ts +3 -3
- package/dist/domains/quality-assessment/coherence/index.js +2 -2
- package/dist/domains/quality-assessment/coherence/types.d.ts +39 -0
- package/dist/domains/quality-assessment/coherence/types.js +11 -0
- package/dist/domains/quality-assessment/coordinator.d.ts +14 -0
- package/dist/domains/quality-assessment/coordinator.js +92 -0
- package/dist/domains/test-execution/coordinator.d.ts +19 -0
- package/dist/domains/test-execution/coordinator.js +102 -5
- package/dist/domains/test-generation/coordinator.js +11 -0
- package/dist/domains/test-generation/interfaces.d.ts +2 -0
- package/dist/domains/test-generation/services/test-generator.d.ts +9 -0
- package/dist/domains/test-generation/services/test-generator.js +37 -0
- package/dist/init/agents-installer.d.ts +5 -3
- package/dist/init/agents-installer.js +17 -43
- package/dist/init/find-package-root.d.ts +22 -0
- package/dist/init/find-package-root.js +46 -0
- package/dist/init/n8n-installer.d.ts +4 -2
- package/dist/init/n8n-installer.js +23 -23
- package/dist/init/opencode-installer.d.ts +0 -5
- package/dist/init/opencode-installer.js +12 -39
- package/dist/init/skills-installer.d.ts +5 -2
- package/dist/init/skills-installer.js +15 -37
- package/dist/integrations/embeddings/index/HNSWIndex.d.ts +9 -2
- package/dist/integrations/embeddings/index/HNSWIndex.js +110 -35
- package/dist/integrations/ruvector/cognitive-routing.d.ts +67 -0
- package/dist/integrations/ruvector/cognitive-routing.js +208 -0
- package/dist/integrations/ruvector/feature-flags.d.ts +84 -0
- package/dist/integrations/ruvector/feature-flags.js +59 -0
- package/dist/integrations/ruvector/hdc-fingerprint.d.ts +76 -0
- package/dist/integrations/ruvector/hdc-fingerprint.js +217 -0
- package/dist/integrations/ruvector/hyperbolic-hnsw.d.ts +59 -0
- package/dist/integrations/ruvector/hyperbolic-hnsw.js +194 -0
- package/dist/integrations/ruvector/index.d.ts +5 -2
- package/dist/integrations/ruvector/index.js +13 -2
- package/dist/integrations/ruvector/shared-rvf-adapter.d.ts +24 -0
- package/dist/integrations/ruvector/shared-rvf-adapter.js +55 -0
- package/dist/integrations/ruvector/shared-rvf-dual-writer.d.ts +6 -0
- package/dist/integrations/ruvector/shared-rvf-dual-writer.js +38 -0
- package/dist/integrations/ruvector/sona-persistence.d.ts +8 -0
- package/dist/integrations/ruvector/sona-persistence.js +10 -0
- package/dist/integrations/ruvector/vector-delta-tracker.d.ts +96 -0
- package/dist/integrations/ruvector/vector-delta-tracker.js +226 -0
- package/dist/kernel/agent-coordinator.d.ts +75 -1
- package/dist/kernel/agent-coordinator.js +250 -1
- package/dist/kernel/hnsw-legacy-bridge.d.ts +38 -0
- package/dist/kernel/hnsw-legacy-bridge.js +88 -0
- package/dist/kernel/hnsw-shadow-validator.d.ts +91 -0
- package/dist/kernel/hnsw-shadow-validator.js +139 -0
- package/dist/kernel/index.d.ts +1 -1
- package/dist/kernel/index.js +1 -1
- package/dist/kernel/interfaces.d.ts +39 -0
- package/dist/kernel/kernel.d.ts +23 -0
- package/dist/kernel/kernel.js +106 -1
- package/dist/kernel/unified-memory.d.ts +1 -1
- package/dist/kernel/unified-memory.js +7 -3
- package/dist/learning/aqe-learning-engine.d.ts +65 -0
- package/dist/learning/aqe-learning-engine.js +134 -0
- package/dist/learning/dream/dream-engine.d.ts +6 -1
- package/dist/learning/dream/dream-engine.js +37 -2
- package/dist/learning/dream/dream-scheduler.d.ts +25 -0
- package/dist/learning/dream/dream-scheduler.js +120 -0
- package/dist/learning/dream/rvcow-branch-manager.d.ts +6 -3
- package/dist/learning/dream/rvcow-branch-manager.js +60 -5
- package/dist/learning/experience-capture.d.ts +3 -3
- package/dist/learning/hyperbolic-pattern-index.d.ts +82 -0
- package/dist/learning/hyperbolic-pattern-index.js +142 -0
- package/dist/learning/index.d.ts +3 -3
- package/dist/learning/index.js +1 -1
- package/dist/learning/metrics-tracker.d.ts +44 -0
- package/dist/learning/metrics-tracker.js +37 -0
- package/dist/learning/pattern-promotion.d.ts +3 -3
- package/dist/learning/pattern-store.d.ts +45 -2
- package/dist/learning/pattern-store.js +239 -4
- package/dist/learning/qe-patterns.d.ts +1 -1
- package/dist/learning/qe-reasoning-bank.js +1 -1
- package/dist/learning/rvf-pattern-migration.d.ts +50 -0
- package/dist/learning/rvf-pattern-migration.js +106 -0
- package/dist/learning/rvf-pattern-store.d.ts +69 -0
- package/dist/learning/rvf-pattern-store.js +449 -0
- package/dist/mcp/bundle.js +1894 -1804
- package/dist/mcp/handlers/index.d.ts +1 -0
- package/dist/mcp/handlers/index.js +2 -0
- package/dist/mcp/handlers/migration-handlers.d.ts +52 -0
- package/dist/mcp/handlers/migration-handlers.js +85 -0
- package/dist/mcp/protocol-server.d.ts +1 -0
- package/dist/mcp/protocol-server.js +63 -2
- package/dist/mcp/types.d.ts +1 -1
- package/dist/optimization/early-exit-token-optimizer.d.ts +7 -7
- package/dist/optimization/early-exit-token-optimizer.js +3 -3
- package/dist/persistence/rvf-consistency-validator.d.ts +85 -0
- package/dist/persistence/rvf-consistency-validator.js +182 -0
- package/dist/persistence/rvf-migration-adapter.d.ts +125 -0
- package/dist/persistence/rvf-migration-adapter.js +303 -0
- package/dist/persistence/rvf-migration-coordinator.d.ts +115 -0
- package/dist/persistence/rvf-migration-coordinator.js +224 -0
- package/dist/persistence/rvf-stage-gate.d.ts +70 -0
- package/dist/persistence/rvf-stage-gate.js +163 -0
- package/package.json +10 -10
- package/dist/cli/chunks/adapter-WBR5NXS3.js +0 -2
- package/dist/cli/chunks/aqe-learning-engine-TK4JQCGT.js +0 -2
- package/dist/cli/chunks/base-2WXOSMBQ.js +0 -2
- package/dist/cli/chunks/better-sqlite3-7KY2RDXO.js +0 -2
- package/dist/cli/chunks/brain-handler-PPEGDCN4.js +0 -68
- package/dist/cli/chunks/browser-workflow-42F7GK5T.js +0 -2
- package/dist/cli/chunks/chunk-263XS447.js +0 -2
- package/dist/cli/chunks/chunk-2I7J3O6V.js +0 -2
- package/dist/cli/chunks/chunk-3JPRUND5.js +0 -2
- package/dist/cli/chunks/chunk-3THRQEZ2.js +0 -95
- package/dist/cli/chunks/chunk-4B6NCELM.js +0 -2
- package/dist/cli/chunks/chunk-62ADTHV7.js +0 -2
- package/dist/cli/chunks/chunk-BR26T7ZS.js +0 -180
- package/dist/cli/chunks/chunk-DRT3WKQW.js +0 -2
- package/dist/cli/chunks/chunk-FIA6X7UL.js +0 -2
- package/dist/cli/chunks/chunk-J3KWWR6Z.js +0 -1
- package/dist/cli/chunks/chunk-JZSDOIXA.js +0 -2
- package/dist/cli/chunks/chunk-MV6CMOJQ.js +0 -65
- package/dist/cli/chunks/chunk-N5UXCLFI.js +0 -2
- package/dist/cli/chunks/chunk-OF4D7MYI.js +0 -2
- package/dist/cli/chunks/chunk-QOVHWZEP.js +0 -1
- package/dist/cli/chunks/chunk-RFSN6IDA.js +0 -79
- package/dist/cli/chunks/chunk-X5IJGWYG.js +0 -2
- package/dist/cli/chunks/ci-output-7JN7F6CI.js +0 -2
- package/dist/cli/chunks/client-MCSNSH2C.js +0 -2
- package/dist/cli/chunks/complexity-analyzer-AB4OZARV.js +0 -2
- package/dist/cli/chunks/cost-tracker-4F723RB6.js +0 -2
- package/dist/cli/chunks/cross-domain-router-OWR5IJ5G.js +0 -2
- package/dist/cli/chunks/dag-attention-scheduler-JWO6XI6A.js +0 -2
- package/dist/cli/chunks/detect-L6ZZHUSX.js +0 -2
- package/dist/cli/chunks/domain-transfer-5Y4FGJAJ.js +0 -2
- package/dist/cli/chunks/dream-4TDBIYED.js +0 -2
- package/dist/cli/chunks/esm-node-2PKHKOTS.js +0 -2
- package/dist/cli/chunks/feature-flags-IVQ3AL4Q.js +0 -2
- package/dist/cli/chunks/file-discovery-QFPA6GMV.js +0 -2
- package/dist/cli/chunks/gnn-wrapper-OYC55N5E.js +0 -2
- package/dist/cli/chunks/hnsw-index-YO7CT23I.js +0 -2
- package/dist/cli/chunks/hnswlib-node-56YWVXFE.js +0 -2
- package/dist/cli/chunks/hypergraph-engine-A4Y2ZRAG.js +0 -2
- package/dist/cli/chunks/impact-analyzer-UEIGXSZ4.js +0 -2
- package/dist/cli/chunks/init-wizard-JWZUGIPJ.js +0 -2
- package/dist/cli/chunks/kernel-YNDTVKIW.js +0 -2
- package/dist/cli/chunks/knowledge-graph-NGJKFTSN.js +0 -2
- package/dist/cli/chunks/load-test-GZUBXFF3.js +0 -2
- package/dist/cli/chunks/memory-backend-3NQIZUXE.js +0 -2
- package/dist/cli/chunks/memory-handlers-MDZQ7HVW.js +0 -2
- package/dist/cli/chunks/opencode-installer-4HUB36H5.js +0 -3
- package/dist/cli/chunks/protocol-executor-SPUVRDWT.js +0 -2
- package/dist/cli/chunks/qe-reasoning-bank-3HBK2FVD.js +0 -2
- package/dist/cli/chunks/queen-coordinator-RW3NKO5A.js +0 -2
- package/dist/cli/chunks/real-embeddings-GK63VF35.js +0 -2
- package/dist/cli/chunks/router-RJGHWDQ3.js +0 -2
- package/dist/cli/chunks/routing-feedback-ZXBXFKX6.js +0 -2
- package/dist/cli/chunks/ruvector-commands-2TLNHC3A.js +0 -8
- package/dist/cli/chunks/rvf-dual-writer-MQW2SJLT.js +0 -2
- package/dist/cli/chunks/rvf-native-adapter-LKFKTMUN.js +0 -2
- package/dist/cli/chunks/safe-db-G22E5ROA.js +0 -2
- package/dist/cli/chunks/schedule-Y7VVCPYV.js +0 -2
- package/dist/cli/chunks/scheduler-AUQIFQB7.js +0 -2
- package/dist/cli/chunks/shared-rvf-dual-writer-BVSCQAFS.js +0 -2
- package/dist/cli/chunks/sqlite-persistence-JAVHUGGL.js +0 -2
- package/dist/cli/chunks/task-handlers-P5DSUKND.js +0 -2
- package/dist/cli/chunks/token-bootstrap-4VJKGVMK.js +0 -2
- package/dist/cli/chunks/transformers-GY7SIKEU.js +0 -2
- package/dist/cli/chunks/types-QJGNBKP2.js +0 -2
- package/dist/cli/chunks/unified-memory-XYGENQUT.js +0 -2
- package/dist/cli/chunks/unified-memory-hnsw-MVEGQBF3.js +0 -2
- package/dist/cli/chunks/unified-persistence-PFRCWEUG.js +0 -2
- package/dist/cli/chunks/visual-security-V47BLGJM.js +0 -2
- package/dist/cli/chunks/witness-chain-BR63P4A7.js +0 -2
- package/dist/cli/chunks/workflow-orchestrator-7PZMX3JZ.js +0 -2
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
if(process.argv.includes('--version')||process.argv.includes('-v')){console.log("3.9.
|
|
2
|
-
import{b as ye}from"./chunk-BULKFVYX.js";import{a as gt,b as pt}from"./chunk-4B6NCELM.js";import{a as ht}from"./chunk-KP5NUODU.js";import{b as mt,d as z}from"./chunk-ZDATDCYN.js";import{j as I}from"./chunk-AFLLQ5PP.js";import{a as ct}from"./chunk-TLHP5EII.js";import{a as fe}from"./chunk-4YS3IJ45.js";import{a as T,b as C,c as y}from"./chunk-3ZOONQG6.js";import{f}from"./chunk-SUSEVMZT.js";import{k as w,o as he}from"./chunk-JJO7Y4H3.js";import{a as ln}from"./chunk-3JPRUND5.js";import{c as ut}from"./chunk-4VUPRTVX.js";import{b as E,d as dt}from"./chunk-WGMPEW2T.js";import{a as p,b as lt,c as k}from"./chunk-JZSDOIXA.js";import{L as cn,M as un}from"./chunk-2I7J3O6V.js";import{c as G,e as on,g as ot}from"./chunk-4I2IOUS4.js";function Tt(s){let e=[],t=0;if(s.fileCount!==void 0&&(s.fileCount>20?(t+=25,e.push({name:"very-high-file-count",weight:25,description:`Task involves ${s.fileCount} files (>20)`})):s.fileCount>10?(t+=20,e.push({name:"high-file-count",weight:20,description:`Task involves ${s.fileCount} files (>10)`})):s.fileCount>5&&(t+=10,e.push({name:"moderate-file-count",weight:10,description:`Task involves ${s.fileCount} files (>5)`}))),s.domain&&(gn.includes(s.domain)?(t+=30,e.push({name:"complex-domain",weight:30,description:`Domain '${s.domain}' requires complex reasoning`})):pn.includes(s.domain)&&(t+=15,e.push({name:"moderate-domain",weight:15,description:`Domain '${s.domain}' has moderate complexity`}))),s.crossComponent&&(t+=25,e.push({name:"cross-component",weight:25,description:"Task spans multiple components/modules"})),s.priority==="critical"?(t+=25,e.push({name:"critical-priority",weight:25,description:"Critical priority requires careful attention"})):s.priority==="high"&&(t+=15,e.push({name:"high-priority",weight:15,description:"High priority task"})),s.requiredCapabilities){let r=s.requiredCapabilities.filter(a=>hn.includes(a)).length;if(r>0){let a=Math.min(20,r*10);t+=a,e.push({name:"complex-capabilities",weight:a,description:`Requires ${r} complex capabilit${r===1?"y":"ies"}`})}}s.requiresExternalApis&&(t+=10,e.push({name:"external-apis",weight:10,description:"Requires external API integration"})),s.involvesDatabaseOps&&(t+=10,e.push({name:"database-ops",weight:10,description:"Involves database operations"})),s.timeSensitive&&(t+=5,e.push({name:"time-sensitive",weight:5,description:"Time-sensitive task"})),s.estimatedLinesAffected!==void 0&&(s.estimatedLinesAffected>500?(t+=15,e.push({name:"large-change",weight:15,description:`Estimated ${s.estimatedLinesAffected} lines affected (>500)`})):s.estimatedLinesAffected>200&&(t+=10,e.push({name:"medium-change",weight:10,description:`Estimated ${s.estimatedLinesAffected} lines affected (>200)`}))),(s.type==="security-scan"||s.type==="vulnerability-assessment")&&(t+=20,e.push({name:"security-task",weight:20,description:"Security-related task requires careful analysis"}));let n=t>=S.critical?"critical":t>=S.complex?"complex":t>=S.moderate?"moderate":"simple",i=fn[n];return{complexity:n,recommendedModel:i,factors:e,score:t,timestamp:new Date}}var gn,pn,hn,S,fn,vt=G(()=>{"use strict";gn=["security-compliance","chaos-resilience","defect-intelligence"],pn=["code-intelligence","contract-testing","quality-assessment","learning-optimization"],hn=["sast","dast","vulnerability","owasp","chaos-testing","resilience","fault-injection","mutation-testing"],S={critical:70,complex:45,moderate:20},fn={critical:"opus",complex:"sonnet",moderate:"sonnet",simple:"haiku"}});var R,De=G(()=>{"use strict";R=class{weightsInputHidden;weightsHiddenOutput;biasHidden;biasOutput;learningRate;constructor(e=.01){this.learningRate=e,this.weightsInputHidden=this.xavierInit(4,32),this.weightsHiddenOutput=this.xavierInit(32,3),this.biasHidden=new Float32Array(32),this.biasOutput=new Float32Array(3)}xavierInit(e,t){let n=Math.sqrt(2/(e+t)),i=new Float32Array(e*t);for(let r=0;r<i.length;r++){let a=Math.random(),o=Math.random(),l=Math.sqrt(-2*Math.log(Math.max(a,1e-10)))*Math.cos(2*Math.PI*o);i[r]=l*n}return i}forward(e){if(e.length!==4)throw new Error(`Expected 4 features, got ${e.length}`);let t=new Float32Array(32);for(let i=0;i<32;i++){let r=this.biasHidden[i];for(let a=0;a<4;a++)r+=e[a]*this.weightsInputHidden[a*32+i];t[i]=Math.max(0,r)}let n=new Float32Array(3);for(let i=0;i<3;i++){let r=this.biasOutput[i];for(let a=0;a<32;a++)r+=t[a]*this.weightsHiddenOutput[a*3+i];n[i]=r}return this.softmax(n)}softmax(e){let t=Math.max(...e),n=new Float32Array(e.length),i=0;for(let a=0;a<e.length;a++)n[a]=Math.exp(e[a]-t),i+=n[a];let r=[];for(let a=0;a<e.length;a++)r.push(n[a]/i);return r}updateWeights(e,t,n){let i=new Float32Array(32);for(let c=0;c<32;c++){let u=this.biasHidden[c];for(let d=0;d<4;d++)u+=e[d]*this.weightsInputHidden[d*32+c];i[c]=Math.max(0,u)}let r=new Float32Array(3);for(let c=0;c<3;c++){let u=this.biasOutput[c];for(let d=0;d<32;d++)u+=i[d]*this.weightsHiddenOutput[d*3+c];r[c]=u}let a=this.softmax(r),o=new Float32Array(3);for(let c=0;c<3;c++)o[c]=(c===t?1:0)-a[c],o[c]*=n*this.learningRate;for(let c=0;c<32;c++)for(let u=0;u<3;u++)this.weightsHiddenOutput[c*3+u]+=i[c]*o[u];for(let c=0;c<3;c++)this.biasOutput[c]+=o[c];let l=new Float32Array(32);for(let c=0;c<32;c++){if(i[c]<=0)continue;let u=0;for(let d=0;d<3;d++)u+=o[d]*this.weightsHiddenOutput[c*3+d];l[c]=u}for(let c=0;c<4;c++)for(let u=0;u<32;u++)this.weightsInputHidden[c*32+u]+=e[c]*l[u];for(let c=0;c<32;c++)this.biasHidden[c]+=l[c]}serialize(){return{weightsInputHidden:Array.from(this.weightsInputHidden),weightsHiddenOutput:Array.from(this.weightsHiddenOutput),biasHidden:Array.from(this.biasHidden),biasOutput:Array.from(this.biasOutput)}}deserialize(e){e.weightsInputHidden.length===128&&(this.weightsInputHidden=new Float32Array(e.weightsInputHidden)),e.weightsHiddenOutput.length===96&&(this.weightsHiddenOutput=new Float32Array(e.weightsHiddenOutput)),e.biasHidden.length===32&&(this.biasHidden=new Float32Array(e.biasHidden)),e.biasOutput.length===3&&(this.biasOutput=new Float32Array(e.biasOutput))}}});var bt={};on(bt,{NeuralTinyDancerRouter:()=>V,SimpleNeuralRouter:()=>R,createNeuralTinyDancerRouter:()=>Dn});import{performance as Ct}from"perf_hooks";function Dn(s){return new V(s)}var yn,Tn,vn,Cn,bn,kn,Sn,xn,V,kt=G(()=>{"use strict";Ae();De();De();yn=1e3,Tn=.1,vn=.2,Cn=50,bn=.01,kn=["haiku","sonnet","opus"],Sn={haiku:0,sonnet:1,opus:2},xn={"test-generation":.1,"test-execution":.15,"coverage-analysis":.2,"quality-assessment":.3,"requirements-validation":.35,"code-intelligence":.4,"contract-testing":.45,"visual-accessibility":.5,"learning-optimization":.55,"defect-intelligence":.7,"chaos-resilience":.8,"security-compliance":.9},V=class{ruleRouter;neuralNet;circuitBreakerThreshold;shadowModeDecisionLimit;shadowModeMaxDisagreement;shadowModeActive;shadowDecisions=[];shadowDisagreements=0;circuitBreakerTripped=!1;recentOutcomes=[];totalNeuralDecisions=0;totalWeightUpdates=0;neuralPrimary=!1;calibrationScores=[];maxCalibrationScores=500;domainSuccessRates=new Map;config;nativeRouterAvailable=!1;constructor(e={}){this.config=e,this.ruleRouter=new H(e),this.neuralNet=new R(e.learningRate??bn),this.circuitBreakerThreshold=e.circuitBreakerThreshold??vn,this.shadowModeDecisionLimit=e.shadowModeDecisions??yn,this.shadowModeMaxDisagreement=e.shadowModeMaxDisagreement??Tn,e.forceShadowMode!==void 0?(this.shadowModeActive=e.forceShadowMode,this.neuralPrimary=!e.forceShadowMode):(this.shadowModeActive=!0,this.neuralPrimary=!1),this.tryLoadNativeRouter()}tryLoadNativeRouter(){this.nativeRouterAvailable=!1}async route(e){let t=Ct.now(),n=await this.ruleRouter.route(e);if(this.circuitBreakerTripped)return n;let i=this.extractFeatures(e,n.classification),r;try{r=this.neuralNet.forward(i)}catch{return this.tripCircuitBreaker(),n}let a=this.argmax(r),o=kn[a],l=r[a];if(this.totalNeuralDecisions++,this.shadowModeActive){let m=n.model===o;return m||this.shadowDisagreements++,this.shadowDecisions.push({taskDescription:e.description.slice(0,100),ruleDecision:n.model,neuralDecision:o,agreed:m,neuralConfidence:l,timestamp:new Date}),this.evaluateShadowModeExit(),n}let c=Ct.now()-t,u=this.computeEmpiricalConfidenceBounds(r);return l<.3||u.calibrationScore>.8?n:{model:o,confidence:l,uncertainty:1-l,triggerMultiModel:n.triggerMultiModel,triggerHumanReview:n.triggerHumanReview,complexity:n.complexity,classification:n.classification,latencyMs:c,reasoning:this.buildNeuralReasoning(o,l,r,n,u)}}extractFeatures(e,t){let n=Math.min(1,t.score/100),i=e.description.length,r=e.context?.code?.length??0,a=(i+r)/4,o=Math.min(1,a/1e4),l=e.domain??"",c=xn[l]??.25,u=this.domainSuccessRates.get(l),d=u?u.success/Math.max(1,u.total):.7;return[n,o,c,d]}recordNeuralOutcome(e,t,n,i=n?1:0,r=t.model,a=0){this.ruleRouter.recordOutcome(e,t,n,i,r,a);let o=e.domain??"unknown",l=this.domainSuccessRates.get(o)??{success:0,total:0};l.total++,n&&l.success++,this.domainSuccessRates.set(o,l),this.recentOutcomes.push(n),this.recentOutcomes.length>Cn&&this.recentOutcomes.shift(),this.checkCircuitBreaker();let c=this.extractFeatures(e,t.classification),u=Sn[r],d=(i-.5)*2;try{this.neuralNet.updateWeights(c,u,d),this.totalWeightUpdates++}catch{}let m=this.neuralNet.forward(c),h=this.argmax(m),b=1-m[u];this.calibrationScores.push(b),this.calibrationScores.length>this.maxCalibrationScores&&this.calibrationScores.shift()}computeEmpiricalConfidenceBounds(e){let n=Math.max(...e),i=1-n;if(this.calibrationScores.length<10)return{lower:0,upper:1,coverageLevel:.9,calibrationScore:i};let r=[...this.calibrationScores].sort((l,c)=>l-c),a=Math.ceil(.9*r.length)-1,o=r[Math.min(a,r.length-1)];return{lower:Math.max(0,n-o),upper:Math.min(1,n+o),coverageLevel:.9,calibrationScore:i}}computeConformalBounds(e){return this.computeEmpiricalConfidenceBounds(e)}evaluateShadowModeExit(){if(!this.shadowModeActive||this.config.forceShadowMode===!0)return;let e=this.shadowDecisions.length;if(e<this.shadowModeDecisionLimit)return;this.shadowDisagreements/e<=this.shadowModeMaxDisagreement&&(this.shadowModeActive=!1,this.neuralPrimary=!0)}checkCircuitBreaker(){if(this.recentOutcomes.length<10)return;let t=this.recentOutcomes.filter(n=>!n).length/this.recentOutcomes.length;t>this.circuitBreakerThreshold?this.tripCircuitBreaker():this.circuitBreakerTripped&&t<this.circuitBreakerThreshold*.5&&(this.circuitBreakerTripped=!1)}tripCircuitBreaker(){this.circuitBreakerTripped=!0,this.neuralPrimary=!1}buildNeuralReasoning(e,t,n,i,r){let a=[];return a.push(`[Neural] Routing to ${e.toUpperCase()}`),a.push(`with ${(t*100).toFixed(0)}% neural confidence.`),a.push(`Tier probabilities: haiku=${(n[0]*100).toFixed(0)}%,`),a.push(`sonnet=${(n[1]*100).toFixed(0)}%,`),a.push(`opus=${(n[2]*100).toFixed(0)}%.`),e!==i.model&&a.push(`Rule-based would choose ${i.model.toUpperCase()}.`),a.push(`Empirical bounds: [${r.lower.toFixed(2)}, ${r.upper.toFixed(2)}]`),a.push(`at ${(r.coverageLevel*100).toFixed(0)}% coverage.`),a.join(" ")}argmax(e){let t=0,n=e[0];for(let i=1;i<e.length;i++)e[i]>n&&(n=e[i],t=i);return t}getNeuralStats(){let e=this.shadowDecisions.length,t=e>0?this.shadowDisagreements/e:0,n=this.recentOutcomes.filter(r=>!r).length,i=this.recentOutcomes.length>0?n/this.recentOutcomes.length:0;return{shadowModeActive:this.shadowModeActive,shadowDecisions:e,disagreementRate:t,circuitBreakerTripped:this.circuitBreakerTripped,recentErrorRate:i,totalNeuralDecisions:this.totalNeuralDecisions,totalWeightUpdates:this.totalWeightUpdates,neuralPrimary:this.neuralPrimary}}getShadowDecisionLogs(){return this.shadowDecisions}getRuleRouter(){return this.ruleRouter}getNeuralNet(){return this.neuralNet}isNativeRouterAvailable(){return this.nativeRouterAvailable}isShadowModeActive(){return this.shadowModeActive}isNeuralPrimary(){return this.neuralPrimary}isCircuitBreakerTripped(){return this.circuitBreakerTripped}resetCircuitBreaker(){this.circuitBreakerTripped=!1,this.recentOutcomes=[]}getStats(){return this.ruleRouter.getStats()}getConfig(){return this.ruleRouter.getConfig()}reset(){this.ruleRouter.reset(),this.shadowDecisions=[],this.shadowDisagreements=0,this.circuitBreakerTripped=!1,this.recentOutcomes=[],this.totalNeuralDecisions=0,this.totalWeightUpdates=0,this.calibrationScores=[],this.domainSuccessRates.clear(),this.config.forceShadowMode!==void 0?(this.shadowModeActive=this.config.forceShadowMode,this.neuralPrimary=!this.config.forceShadowMode):(this.shadowModeActive=!0,this.neuralPrimary=!1)}}});import{performance as St}from"perf_hooks";function xt(s){try{let{getRuVectorFeatureFlags:e}=(un(),ot(cn));if(e().useNeuralRouting){let{NeuralTinyDancerRouter:n}=(kt(),ot(bt));return new n(s)}}catch(e){process.env.DEBUG&&console.debug("[Router] Neural router unavailable, using rule-based:",e instanceof Error?e.message:e)}return new H(s)}var H,Ae=G(()=>{"use strict";vt();H=class{confidenceThreshold;uncertaintyThreshold;securityConfidenceThreshold;enableLearning;verbose;totalRouted=0;routesByModel={haiku:0,sonnet:0,opus:0};routesByComplexity={simple:0,moderate:0,complex:0,critical:0};multiModelTriggers=0;humanReviewTriggers=0;totalConfidence=0;totalLatencyMs=0;outcomes=[];maxOutcomes=1e3;constructor(e={}){this.confidenceThreshold=e.confidenceThreshold??.8,this.uncertaintyThreshold=e.uncertaintyThreshold??.2,this.securityConfidenceThreshold=e.securityConfidenceThreshold??.85,this.enableLearning=e.enableLearning??!0,this.verbose=e.verbose??!1}async route(e){let t=St.now(),n=Tt(e),i=this.calculateConfidence(n),r=1-i,a=this.isSecurityTask(e),o=a&&i<this.securityConfidenceThreshold||i<this.confidenceThreshold&&n.complexity!=="simple",l=r>this.uncertaintyThreshold||a&&n.complexity==="critical",c=St.now()-t,u=this.buildReasoning(n,i,a,o,l),d={model:n.recommendedModel,confidence:i,uncertainty:r,triggerMultiModel:o,triggerHumanReview:l,complexity:n.complexity,classification:n,latencyMs:c,reasoning:u};return this.updateStats(d),this.verbose&&console.log(`[TinyDancer] Route: ${n.recommendedModel} (complexity=${n.complexity}, confidence=${(i*100).toFixed(1)}%)`),d}calculateConfidence(e){let{score:t,complexity:n}=e;if(n==="simple"&&t<10)return .9;if(n==="critical"&&t>85)return .92;let i=[S.moderate,S.complex,S.critical],r=1/0;for(let d of i){let m=Math.abs(t-d);m<r&&(r=m)}let a=.55,o=.35,l=Math.min(r/25,1),c=a+l*o,u=n!=="simple"?Math.min(.05,e.factors.length*.01):0;return Math.min(.95,c+u)}isSecurityTask(e){let t=e;if(t.type==="security-scan"||t.type==="vulnerability-assessment"||e.domain==="security-compliance")return!0;let n=["sast","dast","vulnerability","owasp","security-scanning"];if(e.requiredCapabilities?.some(a=>n.includes(a)))return!0;let i=["security","vulnerability","cve","owasp","exploit","injection"],r=e.description.toLowerCase();return!!i.some(a=>r.includes(a))}buildReasoning(e,t,n,i,r){let a=[];if(a.push(`Routing to ${e.recommendedModel.toUpperCase()}`),a.push(`(complexity: ${e.complexity}, score: ${e.score})`),a.push(`with ${(t*100).toFixed(0)}% confidence.`),e.factors.length>0){let o=e.factors.slice(0,3).map(l=>l.name).join(", ");a.push(`Key factors: ${o}.`)}return n&&a.push("Security-sensitive task detected."),i&&a.push("Multi-model verification recommended due to uncertainty."),r&&a.push("Human review flagged due to high uncertainty or criticality."),a.join(" ")}updateStats(e){this.totalRouted++,this.routesByModel[e.model]++,this.routesByComplexity[e.complexity]++,this.totalConfidence+=e.confidence,this.totalLatencyMs+=e.latencyMs,e.triggerMultiModel&&this.multiModelTriggers++,e.triggerHumanReview&&this.humanReviewTriggers++}recordOutcome(e,t,n,i=n?1:0,r=t.model,a=0){if(!this.enableLearning)return;let o={task:e,routeResult:t,success:n,qualityScore:i,actualModelUsed:r,durationMs:a,timestamp:new Date};this.outcomes.push(o),this.outcomes.length>this.maxOutcomes&&this.outcomes.shift(),this.verbose&&console.log(`[TinyDancer] Recorded outcome: success=${n}, quality=${(i*100).toFixed(0)}%, model=${r}`)}getStats(){return{totalRouted:this.totalRouted,routesByModel:{...this.routesByModel},routesByComplexity:{...this.routesByComplexity},multiModelTriggers:this.multiModelTriggers,humanReviewTriggers:this.humanReviewTriggers,avgConfidence:this.totalRouted>0?this.totalConfidence/this.totalRouted:0,avgLatencyMs:this.totalRouted>0?this.totalLatencyMs/this.totalRouted:0,outcomesRecorded:this.outcomes.length}}getOutcomes(){return this.outcomes}getSuccessRateByModel(){let e={haiku:{success:0,total:0},sonnet:{success:0,total:0},opus:{success:0,total:0}};for(let t of this.outcomes){let n=t.actualModelUsed;e[n].total++,t.success&&e[n].success++}return{haiku:e.haiku.total>0?e.haiku.success/e.haiku.total:0,sonnet:e.sonnet.total>0?e.sonnet.success/e.sonnet.total:0,opus:e.opus.total>0?e.opus.success/e.opus.total:0}}reset(){this.totalRouted=0,this.routesByModel={haiku:0,sonnet:0,opus:0},this.routesByComplexity={simple:0,moderate:0,complex:0,critical:0},this.multiModelTriggers=0,this.humanReviewTriggers=0,this.totalConfidence=0,this.totalLatencyMs=0,this.outcomes=[]}getConfig(){return{confidenceThreshold:this.confidenceThreshold,uncertaintyThreshold:this.uncertaintyThreshold,securityConfidenceThreshold:this.securityConfidenceThreshold,enableLearning:this.enableLearning,verbose:this.verbose}}}});var dn={enableConsoleLog:!0,maxEntries:1e3,logPrefix:"[TASK]"},q=class{entries=[];config;constructor(e={}){this.config={...dn,...e}}log(e,t,n){let i={timestamp:new Date,operation:e,taskId:t,agentId:n?.agentId,domain:n?.domain,details:n?.details};if(this.entries.push(i),this.entries.length>this.config.maxEntries&&this.entries.splice(0,this.entries.length-this.config.maxEntries),this.config.enableConsoleLog){let r=n?.agentId?` by ${n.agentId}`:"",a=n?.domain?` (${n.domain})`:"";console.log(`${this.config.logPrefix} ${e.toUpperCase()} ${t}${r}${a}`)}}logSubmit(e,t){this.log("submit",e,{details:t})}logAssign(e,t,n){this.log("assign",e,{agentId:t,domain:n})}logReassign(e,t,n,i){this.log("reassign",e,{agentId:n,domain:i,details:{fromAgent:t}})}logComplete(e,t){this.log("complete",e,{agentId:t})}logFail(e,t,n){this.log("fail",e,{agentId:t,details:n?{error:n}:void 0})}logCancel(e){this.log("cancel",e)}logSteal(e,t,n){this.log("steal",e,{domain:n,details:{fromDomain:t}})}logQueue(e,t){this.log("queue",e,{details:{position:t}})}logDequeue(e){this.log("dequeue",e)}getEntries(e){let t=[...this.entries];e&&(e.operation&&(t=t.filter(i=>i.operation===e.operation)),e.taskId&&(t=t.filter(i=>i.taskId===e.taskId)),e.agentId&&(t=t.filter(i=>i.agentId===e.agentId)),e.domain&&(t=t.filter(i=>i.domain===e.domain)),e.fromTimestamp&&(t=t.filter(i=>i.timestamp>=e.fromTimestamp)),e.toTimestamp&&(t=t.filter(i=>i.timestamp<=e.toTimestamp)));let n=e?.limit??t.length;return t.slice(-n)}getStatistics(){let e={submit:0,assign:0,reassign:0,complete:0,fail:0,cancel:0,steal:0,queue:0,dequeue:0},t=new Set,n=new Set;for(let i of this.entries)e[i.operation]++,t.add(i.taskId),i.agentId&&n.add(i.agentId);return{totalEntries:this.entries.length,operationCounts:e,taskCount:t.size,agentCount:n.size}}clear(){this.entries.length=0}};function Te(s){return new q(s)}var j={healthyThreshold:3,warningThreshold:2,checkIntervalMs:5e3,maxHistoryEntries:100,alertsEnabled:!0,alertCooldownMs:6e4,selfHealingEnabled:!1,maxHealingActionsPerMinute:5};var ve=class{calculator;config;eventBus;persistence;graph;history=[];alerts=new Map;lastAlertTime=new Map;monitoringInterval=null;isMonitoring=!1;constructor(e,t={},n,i){this.graph=e,this.config={...j,...t},this.calculator=mt(),this.eventBus=n,this.persistence=i}start(){this.isMonitoring||(this.isMonitoring=!0,this.monitoringInterval=setInterval(()=>this.checkHealth(),this.config.checkIntervalMs),this.checkHealth())}stop(){this.monitoringInterval&&(clearInterval(this.monitoringInterval),this.monitoringInterval=null),this.isMonitoring=!1}updateGraph(e){this.graph=e,this.isMonitoring&&this.checkHealth()}isEmptyTopology(){return this.graph.getVerticesByType("agent").length===0}checkHealth(){let e=this.calculator.getMinCutValue(this.graph),t=this.calculator.findWeakVertices(this.graph),n=this.isEmptyTopology()?"idle":this.determineStatus(e),i=this.calculateTrend();return this.recordHistory(e),this.isEmptyTopology()||this.checkAlertConditions(e,t,n),this.persistence&&t.length>0&&this.persistence.saveWeakVertices(t).catch(r=>console.warn("[MinCutHealthMonitor] Failed to persist weak vertices:",r)),this.emitEvent("mincut.updated",e,{status:n,weakVertexCount:t.length}),{status:n,minCutValue:e,healthyThreshold:this.config.healthyThreshold,warningThreshold:this.config.warningThreshold,weakVertexCount:t.length,topWeakVertices:t.slice(0,5),trend:i,history:this.history.slice(-20),lastUpdated:new Date}}getHealth(){let e=this.calculator.getMinCutValue(this.graph),t=this.calculator.findWeakVertices(this.graph);return{status:this.isEmptyTopology()?"idle":this.determineStatus(e),minCutValue:e,healthyThreshold:this.config.healthyThreshold,warningThreshold:this.config.warningThreshold,weakVertexCount:t.length,topWeakVertices:t.slice(0,5),trend:this.calculateTrend(),history:this.history.slice(-20),lastUpdated:new Date}}getMinCutValue(){return this.calculator.getMinCutValue(this.graph)}getWeakVertices(){return this.calculator.findWeakVertices(this.graph)}isCritical(){return this.calculator.getMinCutValue(this.graph)<this.config.warningThreshold}isHealthy(){return this.calculator.getMinCutValue(this.graph)>=this.config.healthyThreshold}getActiveAlerts(){return Array.from(this.alerts.values()).filter(e=>!e.acknowledged).sort((e,t)=>{let n={critical:0,high:1,medium:2,low:3,info:4};return n[e.severity]-n[t.severity]})}getAllAlerts(){return Array.from(this.alerts.values())}acknowledgeAlert(e){let t=this.alerts.get(e);return t?(t.acknowledged=!0,!0):!1}clearAcknowledgedAlerts(){let e=[];for(let[t,n]of this.alerts)n.acknowledged&&e.push(t);for(let t of e)this.alerts.delete(t);return e.length}getHistory(){return[...this.history]}getTrend(){return this.calculateTrend()}getStats(e=6e4){let t=Date.now()-e,n=this.history.filter(r=>r.timestamp.getTime()>t);if(n.length===0){let r=this.calculator.getMinCutValue(this.graph);return{min:r,max:r,average:r,count:0}}let i=n.map(r=>r.value);return{min:Math.min(...i),max:Math.max(...i),average:i.reduce((r,a)=>r+a,0)/i.length,count:n.length}}updateConfig(e){Object.assign(this.config,e),e.checkIntervalMs&&this.isMonitoring&&(this.stop(),this.start())}getConfig(){return{...this.config}}determineStatus(e){return e>=this.config.healthyThreshold?"healthy":e>=this.config.warningThreshold?"warning":"critical"}calculateTrend(){if(this.history.length<3)return"stable";let e=this.history.slice(-5),t=e[0].value,i=e[e.length-1].value-t,a=e.reduce((o,l)=>o+l.value,0)/e.length*.1;return i>a?"improving":i<-a?"degrading":"stable"}recordHistory(e){let t={timestamp:new Date,value:e,vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount};for(this.history.push(t);this.history.length>this.config.maxHistoryEntries;)this.history.shift()}checkAlertConditions(e,t,n){if(!this.config.alertsEnabled)return;let i=Date.now();n==="critical"?this.maybeGenerateAlert("critical-threshold","critical",`MinCut value (${e.toFixed(2)}) is below critical threshold (${this.config.warningThreshold})`,e,this.config.warningThreshold,t):n==="warning"&&this.maybeGenerateAlert("warning-threshold","high",`MinCut value (${e.toFixed(2)}) is below healthy threshold (${this.config.healthyThreshold})`,e,this.config.healthyThreshold,t);let r=t.filter(o=>o.weightedDegree===0);r.length>0&&this.maybeGenerateAlert("isolated-vertices","high",`${r.length} isolated vertex(es) detected`,e,0,r);let a=t.filter(o=>o.riskScore>.8);a.length>0&&this.maybeGenerateAlert("critical-vertices","medium",`${a.length} critical vertex(es) with high risk score`,e,0,a)}maybeGenerateAlert(e,t,n,i,r,a){let o=Date.now(),l=this.lastAlertTime.get(e)||0;if(o-l<this.config.alertCooldownMs)return;let c={id:f(),severity:t,message:n,minCutValue:i,threshold:r,affectedVertices:a.map(u=>u.vertexId),timestamp:new Date,acknowledged:!1,remediations:a.flatMap(u=>u.suggestions).slice(0,5)};this.alerts.set(c.id,c),this.persistence&&this.persistence.saveAlert(c).catch(u=>console.warn("[MinCutHealthMonitor] Failed to persist alert:",u)),this.lastAlertTime.set(e,o),this.emitEvent("mincut.alert.generated",i,{alert:c})}emitEvent(e,t,n){if(!this.eventBus)return;let i={id:f(),type:e,source:"coordination",timestamp:new Date,correlationId:f(),payload:{minCutValue:t,...n}};this.eventBus.publish(i).catch(r=>{console.error("Failed to publish MinCut event:",r)})}};function W(s,e,t,n){return new ve(s,e,t,n)}he();dt();var Ce=class{memory;initialized=!1;constructor(e){this.memory=e??w()}async initialize(){this.initialized||(this.memory.isInitialized()||await this.memory.initialize(),this.initialized=!0)}async saveSnapshot(e){this.ensureInitialized();let t=f();return this.memory.getDatabase().prepare(`
|
|
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 ye}from"./chunk-VHVWAXCF.js";import{a as ht,b as ft}from"./chunk-RC5CPXON.js";import{a as yt}from"./chunk-NRCKGXJJ.js";import{a as mt,b as pt}from"./chunk-KDDZYXP4.js";import{b as gt,d as z}from"./chunk-Z5HXGVXZ.js";import{j as I}from"./chunk-Q4A72ZTV.js";import{a as ct}from"./chunk-7NOIIC7G.js";import{a as fe}from"./chunk-TKF447CW.js";import{k as w,o as he}from"./chunk-GK72GUHA.js";import{a as un}from"./chunk-XIBVVZGB.js";import{c as ut}from"./chunk-JOVINE23.js";import{b as E,d as dt}from"./chunk-N3F3CX4V.js";import{a as T,b as C,c as y}from"./chunk-BIVIPF4O.js";import{a as p,b as lt,c as k}from"./chunk-SDTVHR63.js";import{f}from"./chunk-E25S5E2D.js";import{R as dn,S as gn}from"./chunk-DBE34QES.js";import{c as G,e as cn,g as ot}from"./chunk-YXCU4CJX.js";function Ct(s){let e=[],t=0;if(s.fileCount!==void 0&&(s.fileCount>20?(t+=25,e.push({name:"very-high-file-count",weight:25,description:`Task involves ${s.fileCount} files (>20)`})):s.fileCount>10?(t+=20,e.push({name:"high-file-count",weight:20,description:`Task involves ${s.fileCount} files (>10)`})):s.fileCount>5&&(t+=10,e.push({name:"moderate-file-count",weight:10,description:`Task involves ${s.fileCount} files (>5)`}))),s.domain&&(hn.includes(s.domain)?(t+=30,e.push({name:"complex-domain",weight:30,description:`Domain '${s.domain}' requires complex reasoning`})):fn.includes(s.domain)&&(t+=15,e.push({name:"moderate-domain",weight:15,description:`Domain '${s.domain}' has moderate complexity`}))),s.crossComponent&&(t+=25,e.push({name:"cross-component",weight:25,description:"Task spans multiple components/modules"})),s.priority==="critical"?(t+=25,e.push({name:"critical-priority",weight:25,description:"Critical priority requires careful attention"})):s.priority==="high"&&(t+=15,e.push({name:"high-priority",weight:15,description:"High priority task"})),s.requiredCapabilities){let r=s.requiredCapabilities.filter(a=>yn.includes(a)).length;if(r>0){let a=Math.min(20,r*10);t+=a,e.push({name:"complex-capabilities",weight:a,description:`Requires ${r} complex capabilit${r===1?"y":"ies"}`})}}s.requiresExternalApis&&(t+=10,e.push({name:"external-apis",weight:10,description:"Requires external API integration"})),s.involvesDatabaseOps&&(t+=10,e.push({name:"database-ops",weight:10,description:"Involves database operations"})),s.timeSensitive&&(t+=5,e.push({name:"time-sensitive",weight:5,description:"Time-sensitive task"})),s.estimatedLinesAffected!==void 0&&(s.estimatedLinesAffected>500?(t+=15,e.push({name:"large-change",weight:15,description:`Estimated ${s.estimatedLinesAffected} lines affected (>500)`})):s.estimatedLinesAffected>200&&(t+=10,e.push({name:"medium-change",weight:10,description:`Estimated ${s.estimatedLinesAffected} lines affected (>200)`}))),(s.type==="security-scan"||s.type==="vulnerability-assessment")&&(t+=20,e.push({name:"security-task",weight:20,description:"Security-related task requires careful analysis"}));let n=t>=S.critical?"critical":t>=S.complex?"complex":t>=S.moderate?"moderate":"simple",i=Tn[n];return{complexity:n,recommendedModel:i,factors:e,score:t,timestamp:new Date}}var hn,fn,yn,S,Tn,bt=G(()=>{"use strict";hn=["security-compliance","chaos-resilience","defect-intelligence"],fn=["code-intelligence","contract-testing","quality-assessment","learning-optimization"],yn=["sast","dast","vulnerability","owasp","chaos-testing","resilience","fault-injection","mutation-testing"],S={critical:70,complex:45,moderate:20},Tn={critical:"opus",complex:"sonnet",moderate:"sonnet",simple:"haiku"}});var R,De=G(()=>{"use strict";R=class{weightsInputHidden;weightsHiddenOutput;biasHidden;biasOutput;learningRate;constructor(e=.01){this.learningRate=e,this.weightsInputHidden=this.xavierInit(4,32),this.weightsHiddenOutput=this.xavierInit(32,3),this.biasHidden=new Float32Array(32),this.biasOutput=new Float32Array(3)}xavierInit(e,t){let n=Math.sqrt(2/(e+t)),i=new Float32Array(e*t);for(let r=0;r<i.length;r++){let a=Math.random(),o=Math.random(),l=Math.sqrt(-2*Math.log(Math.max(a,1e-10)))*Math.cos(2*Math.PI*o);i[r]=l*n}return i}forward(e){if(e.length!==4)throw new Error(`Expected 4 features, got ${e.length}`);let t=new Float32Array(32);for(let i=0;i<32;i++){let r=this.biasHidden[i];for(let a=0;a<4;a++)r+=e[a]*this.weightsInputHidden[a*32+i];t[i]=Math.max(0,r)}let n=new Float32Array(3);for(let i=0;i<3;i++){let r=this.biasOutput[i];for(let a=0;a<32;a++)r+=t[a]*this.weightsHiddenOutput[a*3+i];n[i]=r}return this.softmax(n)}softmax(e){let t=Math.max(...e),n=new Float32Array(e.length),i=0;for(let a=0;a<e.length;a++)n[a]=Math.exp(e[a]-t),i+=n[a];let r=[];for(let a=0;a<e.length;a++)r.push(n[a]/i);return r}updateWeights(e,t,n){let i=new Float32Array(32);for(let c=0;c<32;c++){let u=this.biasHidden[c];for(let d=0;d<4;d++)u+=e[d]*this.weightsInputHidden[d*32+c];i[c]=Math.max(0,u)}let r=new Float32Array(3);for(let c=0;c<3;c++){let u=this.biasOutput[c];for(let d=0;d<32;d++)u+=i[d]*this.weightsHiddenOutput[d*3+c];r[c]=u}let a=this.softmax(r),o=new Float32Array(3);for(let c=0;c<3;c++)o[c]=(c===t?1:0)-a[c],o[c]*=n*this.learningRate;for(let c=0;c<32;c++)for(let u=0;u<3;u++)this.weightsHiddenOutput[c*3+u]+=i[c]*o[u];for(let c=0;c<3;c++)this.biasOutput[c]+=o[c];let l=new Float32Array(32);for(let c=0;c<32;c++){if(i[c]<=0)continue;let u=0;for(let d=0;d<3;d++)u+=o[d]*this.weightsHiddenOutput[c*3+d];l[c]=u}for(let c=0;c<4;c++)for(let u=0;u<32;u++)this.weightsInputHidden[c*32+u]+=e[c]*l[u];for(let c=0;c<32;c++)this.biasHidden[c]+=l[c]}serialize(){return{weightsInputHidden:Array.from(this.weightsInputHidden),weightsHiddenOutput:Array.from(this.weightsHiddenOutput),biasHidden:Array.from(this.biasHidden),biasOutput:Array.from(this.biasOutput)}}deserialize(e){e.weightsInputHidden.length===128&&(this.weightsInputHidden=new Float32Array(e.weightsInputHidden)),e.weightsHiddenOutput.length===96&&(this.weightsHiddenOutput=new Float32Array(e.weightsHiddenOutput)),e.biasHidden.length===32&&(this.biasHidden=new Float32Array(e.biasHidden)),e.biasOutput.length===3&&(this.biasOutput=new Float32Array(e.biasOutput))}}});var St={};cn(St,{NeuralTinyDancerRouter:()=>V,SimpleNeuralRouter:()=>R,createNeuralTinyDancerRouter:()=>Mn});import{performance as kt}from"perf_hooks";function Mn(s){return new V(s)}var vn,Cn,bn,kn,Sn,xn,Dn,An,V,xt=G(()=>{"use strict";Ae();De();De();vn=1e3,Cn=.1,bn=.2,kn=50,Sn=.01,xn=["haiku","sonnet","opus"],Dn={haiku:0,sonnet:1,opus:2},An={"test-generation":.1,"test-execution":.15,"coverage-analysis":.2,"quality-assessment":.3,"requirements-validation":.35,"code-intelligence":.4,"contract-testing":.45,"visual-accessibility":.5,"learning-optimization":.55,"defect-intelligence":.7,"chaos-resilience":.8,"security-compliance":.9},V=class{ruleRouter;neuralNet;circuitBreakerThreshold;shadowModeDecisionLimit;shadowModeMaxDisagreement;shadowModeActive;shadowDecisions=[];shadowDisagreements=0;circuitBreakerTripped=!1;recentOutcomes=[];totalNeuralDecisions=0;totalWeightUpdates=0;neuralPrimary=!1;calibrationScores=[];maxCalibrationScores=500;domainSuccessRates=new Map;config;nativeRouterAvailable=!1;constructor(e={}){this.config=e,this.ruleRouter=new H(e),this.neuralNet=new R(e.learningRate??Sn),this.circuitBreakerThreshold=e.circuitBreakerThreshold??bn,this.shadowModeDecisionLimit=e.shadowModeDecisions??vn,this.shadowModeMaxDisagreement=e.shadowModeMaxDisagreement??Cn,e.forceShadowMode!==void 0?(this.shadowModeActive=e.forceShadowMode,this.neuralPrimary=!e.forceShadowMode):(this.shadowModeActive=!0,this.neuralPrimary=!1),this.tryLoadNativeRouter()}tryLoadNativeRouter(){this.nativeRouterAvailable=!1}async route(e){let t=kt.now(),n=await this.ruleRouter.route(e);if(this.circuitBreakerTripped)return n;let i=this.extractFeatures(e,n.classification),r;try{r=this.neuralNet.forward(i)}catch{return this.tripCircuitBreaker(),n}let a=this.argmax(r),o=xn[a],l=r[a];if(this.totalNeuralDecisions++,this.shadowModeActive){let g=n.model===o;return g||this.shadowDisagreements++,this.shadowDecisions.push({taskDescription:e.description.slice(0,100),ruleDecision:n.model,neuralDecision:o,agreed:g,neuralConfidence:l,timestamp:new Date}),this.evaluateShadowModeExit(),n}let c=kt.now()-t,u=this.computeEmpiricalConfidenceBounds(r);return l<.3||u.calibrationScore>.8?n:{model:o,confidence:l,uncertainty:1-l,triggerMultiModel:n.triggerMultiModel,triggerHumanReview:n.triggerHumanReview,complexity:n.complexity,classification:n.classification,latencyMs:c,reasoning:this.buildNeuralReasoning(o,l,r,n,u)}}extractFeatures(e,t){let n=Math.min(1,t.score/100),i=e.description.length,r=e.context?.code?.length??0,a=(i+r)/4,o=Math.min(1,a/1e4),l=e.domain??"",c=An[l]??.25,u=this.domainSuccessRates.get(l),d=u?u.success/Math.max(1,u.total):.7;return[n,o,c,d]}recordNeuralOutcome(e,t,n,i=n?1:0,r=t.model,a=0){this.ruleRouter.recordOutcome(e,t,n,i,r,a);let o=e.domain??"unknown",l=this.domainSuccessRates.get(o)??{success:0,total:0};l.total++,n&&l.success++,this.domainSuccessRates.set(o,l),this.recentOutcomes.push(n),this.recentOutcomes.length>kn&&this.recentOutcomes.shift(),this.checkCircuitBreaker();let c=this.extractFeatures(e,t.classification),u=Dn[r],d=(i-.5)*2;try{this.neuralNet.updateWeights(c,u,d),this.totalWeightUpdates++}catch{}let g=this.neuralNet.forward(c),h=this.argmax(g),b=1-g[u];this.calibrationScores.push(b),this.calibrationScores.length>this.maxCalibrationScores&&this.calibrationScores.shift()}computeEmpiricalConfidenceBounds(e){let n=Math.max(...e),i=1-n;if(this.calibrationScores.length<10)return{lower:0,upper:1,coverageLevel:.9,calibrationScore:i};let r=[...this.calibrationScores].sort((l,c)=>l-c),a=Math.ceil(.9*r.length)-1,o=r[Math.min(a,r.length-1)];return{lower:Math.max(0,n-o),upper:Math.min(1,n+o),coverageLevel:.9,calibrationScore:i}}computeConformalBounds(e){return this.computeEmpiricalConfidenceBounds(e)}evaluateShadowModeExit(){if(!this.shadowModeActive||this.config.forceShadowMode===!0)return;let e=this.shadowDecisions.length;if(e<this.shadowModeDecisionLimit)return;this.shadowDisagreements/e<=this.shadowModeMaxDisagreement&&(this.shadowModeActive=!1,this.neuralPrimary=!0)}checkCircuitBreaker(){if(this.recentOutcomes.length<10)return;let t=this.recentOutcomes.filter(n=>!n).length/this.recentOutcomes.length;t>this.circuitBreakerThreshold?this.tripCircuitBreaker():this.circuitBreakerTripped&&t<this.circuitBreakerThreshold*.5&&(this.circuitBreakerTripped=!1)}tripCircuitBreaker(){this.circuitBreakerTripped=!0,this.neuralPrimary=!1}buildNeuralReasoning(e,t,n,i,r){let a=[];return a.push(`[Neural] Routing to ${e.toUpperCase()}`),a.push(`with ${(t*100).toFixed(0)}% neural confidence.`),a.push(`Tier probabilities: haiku=${(n[0]*100).toFixed(0)}%,`),a.push(`sonnet=${(n[1]*100).toFixed(0)}%,`),a.push(`opus=${(n[2]*100).toFixed(0)}%.`),e!==i.model&&a.push(`Rule-based would choose ${i.model.toUpperCase()}.`),a.push(`Empirical bounds: [${r.lower.toFixed(2)}, ${r.upper.toFixed(2)}]`),a.push(`at ${(r.coverageLevel*100).toFixed(0)}% coverage.`),a.join(" ")}argmax(e){let t=0,n=e[0];for(let i=1;i<e.length;i++)e[i]>n&&(n=e[i],t=i);return t}getNeuralStats(){let e=this.shadowDecisions.length,t=e>0?this.shadowDisagreements/e:0,n=this.recentOutcomes.filter(r=>!r).length,i=this.recentOutcomes.length>0?n/this.recentOutcomes.length:0;return{shadowModeActive:this.shadowModeActive,shadowDecisions:e,disagreementRate:t,circuitBreakerTripped:this.circuitBreakerTripped,recentErrorRate:i,totalNeuralDecisions:this.totalNeuralDecisions,totalWeightUpdates:this.totalWeightUpdates,neuralPrimary:this.neuralPrimary}}getShadowDecisionLogs(){return this.shadowDecisions}getRuleRouter(){return this.ruleRouter}getNeuralNet(){return this.neuralNet}isNativeRouterAvailable(){return this.nativeRouterAvailable}isShadowModeActive(){return this.shadowModeActive}isNeuralPrimary(){return this.neuralPrimary}isCircuitBreakerTripped(){return this.circuitBreakerTripped}resetCircuitBreaker(){this.circuitBreakerTripped=!1,this.recentOutcomes=[]}getStats(){return this.ruleRouter.getStats()}getConfig(){return this.ruleRouter.getConfig()}reset(){this.ruleRouter.reset(),this.shadowDecisions=[],this.shadowDisagreements=0,this.circuitBreakerTripped=!1,this.recentOutcomes=[],this.totalNeuralDecisions=0,this.totalWeightUpdates=0,this.calibrationScores=[],this.domainSuccessRates.clear(),this.config.forceShadowMode!==void 0?(this.shadowModeActive=this.config.forceShadowMode,this.neuralPrimary=!this.config.forceShadowMode):(this.shadowModeActive=!0,this.neuralPrimary=!1)}}});import{performance as Dt}from"perf_hooks";function At(s){try{let{getRuVectorFeatureFlags:e}=(gn(),ot(dn));if(e().useNeuralRouting){let{NeuralTinyDancerRouter:n}=(xt(),ot(St));return new n(s)}}catch(e){process.env.DEBUG&&console.debug("[Router] Neural router unavailable, using rule-based:",e instanceof Error?e.message:e)}return new H(s)}var H,Ae=G(()=>{"use strict";bt();H=class{confidenceThreshold;uncertaintyThreshold;securityConfidenceThreshold;enableLearning;verbose;totalRouted=0;routesByModel={haiku:0,sonnet:0,opus:0};routesByComplexity={simple:0,moderate:0,complex:0,critical:0};multiModelTriggers=0;humanReviewTriggers=0;totalConfidence=0;totalLatencyMs=0;outcomes=[];maxOutcomes=1e3;constructor(e={}){this.confidenceThreshold=e.confidenceThreshold??.8,this.uncertaintyThreshold=e.uncertaintyThreshold??.2,this.securityConfidenceThreshold=e.securityConfidenceThreshold??.85,this.enableLearning=e.enableLearning??!0,this.verbose=e.verbose??!1}async route(e){let t=Dt.now(),n=Ct(e),i=this.calculateConfidence(n),r=1-i,a=this.isSecurityTask(e),o=a&&i<this.securityConfidenceThreshold||i<this.confidenceThreshold&&n.complexity!=="simple",l=r>this.uncertaintyThreshold||a&&n.complexity==="critical",c=Dt.now()-t,u=this.buildReasoning(n,i,a,o,l),d={model:n.recommendedModel,confidence:i,uncertainty:r,triggerMultiModel:o,triggerHumanReview:l,complexity:n.complexity,classification:n,latencyMs:c,reasoning:u};return this.updateStats(d),this.verbose&&console.log(`[TinyDancer] Route: ${n.recommendedModel} (complexity=${n.complexity}, confidence=${(i*100).toFixed(1)}%)`),d}calculateConfidence(e){let{score:t,complexity:n}=e;if(n==="simple"&&t<10)return .9;if(n==="critical"&&t>85)return .92;let i=[S.moderate,S.complex,S.critical],r=1/0;for(let d of i){let g=Math.abs(t-d);g<r&&(r=g)}let a=.55,o=.35,l=Math.min(r/25,1),c=a+l*o,u=n!=="simple"?Math.min(.05,e.factors.length*.01):0;return Math.min(.95,c+u)}isSecurityTask(e){let t=e;if(t.type==="security-scan"||t.type==="vulnerability-assessment"||e.domain==="security-compliance")return!0;let n=["sast","dast","vulnerability","owasp","security-scanning"];if(e.requiredCapabilities?.some(a=>n.includes(a)))return!0;let i=["security","vulnerability","cve","owasp","exploit","injection"],r=e.description.toLowerCase();return!!i.some(a=>r.includes(a))}buildReasoning(e,t,n,i,r){let a=[];if(a.push(`Routing to ${e.recommendedModel.toUpperCase()}`),a.push(`(complexity: ${e.complexity}, score: ${e.score})`),a.push(`with ${(t*100).toFixed(0)}% confidence.`),e.factors.length>0){let o=e.factors.slice(0,3).map(l=>l.name).join(", ");a.push(`Key factors: ${o}.`)}return n&&a.push("Security-sensitive task detected."),i&&a.push("Multi-model verification recommended due to uncertainty."),r&&a.push("Human review flagged due to high uncertainty or criticality."),a.join(" ")}updateStats(e){this.totalRouted++,this.routesByModel[e.model]++,this.routesByComplexity[e.complexity]++,this.totalConfidence+=e.confidence,this.totalLatencyMs+=e.latencyMs,e.triggerMultiModel&&this.multiModelTriggers++,e.triggerHumanReview&&this.humanReviewTriggers++}recordOutcome(e,t,n,i=n?1:0,r=t.model,a=0){if(!this.enableLearning)return;let o={task:e,routeResult:t,success:n,qualityScore:i,actualModelUsed:r,durationMs:a,timestamp:new Date};this.outcomes.push(o),this.outcomes.length>this.maxOutcomes&&this.outcomes.shift(),this.verbose&&console.log(`[TinyDancer] Recorded outcome: success=${n}, quality=${(i*100).toFixed(0)}%, model=${r}`)}getStats(){return{totalRouted:this.totalRouted,routesByModel:{...this.routesByModel},routesByComplexity:{...this.routesByComplexity},multiModelTriggers:this.multiModelTriggers,humanReviewTriggers:this.humanReviewTriggers,avgConfidence:this.totalRouted>0?this.totalConfidence/this.totalRouted:0,avgLatencyMs:this.totalRouted>0?this.totalLatencyMs/this.totalRouted:0,outcomesRecorded:this.outcomes.length}}getOutcomes(){return this.outcomes}getSuccessRateByModel(){let e={haiku:{success:0,total:0},sonnet:{success:0,total:0},opus:{success:0,total:0}};for(let t of this.outcomes){let n=t.actualModelUsed;e[n].total++,t.success&&e[n].success++}return{haiku:e.haiku.total>0?e.haiku.success/e.haiku.total:0,sonnet:e.sonnet.total>0?e.sonnet.success/e.sonnet.total:0,opus:e.opus.total>0?e.opus.success/e.opus.total:0}}reset(){this.totalRouted=0,this.routesByModel={haiku:0,sonnet:0,opus:0},this.routesByComplexity={simple:0,moderate:0,complex:0,critical:0},this.multiModelTriggers=0,this.humanReviewTriggers=0,this.totalConfidence=0,this.totalLatencyMs=0,this.outcomes=[]}getConfig(){return{confidenceThreshold:this.confidenceThreshold,uncertaintyThreshold:this.uncertaintyThreshold,securityConfidenceThreshold:this.securityConfidenceThreshold,enableLearning:this.enableLearning,verbose:this.verbose}}}});var mn={enableConsoleLog:!0,maxEntries:1e3,logPrefix:"[TASK]"},q=class{entries=[];config;constructor(e={}){this.config={...mn,...e}}log(e,t,n){let i={timestamp:new Date,operation:e,taskId:t,agentId:n?.agentId,domain:n?.domain,details:n?.details};if(this.entries.push(i),this.entries.length>this.config.maxEntries&&this.entries.splice(0,this.entries.length-this.config.maxEntries),this.config.enableConsoleLog){let r=n?.agentId?` by ${n.agentId}`:"",a=n?.domain?` (${n.domain})`:"";console.log(`${this.config.logPrefix} ${e.toUpperCase()} ${t}${r}${a}`)}}logSubmit(e,t){this.log("submit",e,{details:t})}logAssign(e,t,n){this.log("assign",e,{agentId:t,domain:n})}logReassign(e,t,n,i){this.log("reassign",e,{agentId:n,domain:i,details:{fromAgent:t}})}logComplete(e,t){this.log("complete",e,{agentId:t})}logFail(e,t,n){this.log("fail",e,{agentId:t,details:n?{error:n}:void 0})}logCancel(e){this.log("cancel",e)}logSteal(e,t,n){this.log("steal",e,{domain:n,details:{fromDomain:t}})}logQueue(e,t){this.log("queue",e,{details:{position:t}})}logDequeue(e){this.log("dequeue",e)}getEntries(e){let t=[...this.entries];e&&(e.operation&&(t=t.filter(i=>i.operation===e.operation)),e.taskId&&(t=t.filter(i=>i.taskId===e.taskId)),e.agentId&&(t=t.filter(i=>i.agentId===e.agentId)),e.domain&&(t=t.filter(i=>i.domain===e.domain)),e.fromTimestamp&&(t=t.filter(i=>i.timestamp>=e.fromTimestamp)),e.toTimestamp&&(t=t.filter(i=>i.timestamp<=e.toTimestamp)));let n=e?.limit??t.length;return t.slice(-n)}getStatistics(){let e={submit:0,assign:0,reassign:0,complete:0,fail:0,cancel:0,steal:0,queue:0,dequeue:0},t=new Set,n=new Set;for(let i of this.entries)e[i.operation]++,t.add(i.taskId),i.agentId&&n.add(i.agentId);return{totalEntries:this.entries.length,operationCounts:e,taskCount:t.size,agentCount:n.size}}clear(){this.entries.length=0}};function Te(s){return new q(s)}var j={healthyThreshold:3,warningThreshold:2,checkIntervalMs:5e3,maxHistoryEntries:100,alertsEnabled:!0,alertCooldownMs:6e4,selfHealingEnabled:!1,maxHealingActionsPerMinute:5};var ve=class{calculator;config;eventBus;persistence;graph;history=[];alerts=new Map;lastAlertTime=new Map;monitoringInterval=null;isMonitoring=!1;constructor(e,t={},n,i){this.graph=e,this.config={...j,...t},this.calculator=gt(),this.eventBus=n,this.persistence=i}start(){this.isMonitoring||(this.isMonitoring=!0,this.monitoringInterval=setInterval(()=>this.checkHealth(),this.config.checkIntervalMs),this.checkHealth())}stop(){this.monitoringInterval&&(clearInterval(this.monitoringInterval),this.monitoringInterval=null),this.isMonitoring=!1}updateGraph(e){this.graph=e,this.isMonitoring&&this.checkHealth()}isEmptyTopology(){return this.graph.getVerticesByType("agent").length===0}checkHealth(){let e=this.calculator.getMinCutValue(this.graph),t=this.calculator.findWeakVertices(this.graph),n=this.isEmptyTopology()?"idle":this.determineStatus(e),i=this.calculateTrend();return this.recordHistory(e),this.isEmptyTopology()||this.checkAlertConditions(e,t,n),this.persistence&&t.length>0&&this.persistence.saveWeakVertices(t).catch(r=>console.warn("[MinCutHealthMonitor] Failed to persist weak vertices:",r)),this.emitEvent("mincut.updated",e,{status:n,weakVertexCount:t.length}),{status:n,minCutValue:e,healthyThreshold:this.config.healthyThreshold,warningThreshold:this.config.warningThreshold,weakVertexCount:t.length,topWeakVertices:t.slice(0,5),trend:i,history:this.history.slice(-20),lastUpdated:new Date}}getHealth(){let e=this.calculator.getMinCutValue(this.graph),t=this.calculator.findWeakVertices(this.graph);return{status:this.isEmptyTopology()?"idle":this.determineStatus(e),minCutValue:e,healthyThreshold:this.config.healthyThreshold,warningThreshold:this.config.warningThreshold,weakVertexCount:t.length,topWeakVertices:t.slice(0,5),trend:this.calculateTrend(),history:this.history.slice(-20),lastUpdated:new Date}}getMinCutValue(){return this.calculator.getMinCutValue(this.graph)}getWeakVertices(){return this.calculator.findWeakVertices(this.graph)}isCritical(){return this.calculator.getMinCutValue(this.graph)<this.config.warningThreshold}isHealthy(){return this.calculator.getMinCutValue(this.graph)>=this.config.healthyThreshold}getActiveAlerts(){return Array.from(this.alerts.values()).filter(e=>!e.acknowledged).sort((e,t)=>{let n={critical:0,high:1,medium:2,low:3,info:4};return n[e.severity]-n[t.severity]})}getAllAlerts(){return Array.from(this.alerts.values())}acknowledgeAlert(e){let t=this.alerts.get(e);return t?(t.acknowledged=!0,!0):!1}clearAcknowledgedAlerts(){let e=[];for(let[t,n]of this.alerts)n.acknowledged&&e.push(t);for(let t of e)this.alerts.delete(t);return e.length}getHistory(){return[...this.history]}getTrend(){return this.calculateTrend()}getStats(e=6e4){let t=Date.now()-e,n=this.history.filter(r=>r.timestamp.getTime()>t);if(n.length===0){let r=this.calculator.getMinCutValue(this.graph);return{min:r,max:r,average:r,count:0}}let i=n.map(r=>r.value);return{min:Math.min(...i),max:Math.max(...i),average:i.reduce((r,a)=>r+a,0)/i.length,count:n.length}}updateConfig(e){Object.assign(this.config,e),e.checkIntervalMs&&this.isMonitoring&&(this.stop(),this.start())}getConfig(){return{...this.config}}determineStatus(e){return e>=this.config.healthyThreshold?"healthy":e>=this.config.warningThreshold?"warning":"critical"}calculateTrend(){if(this.history.length<3)return"stable";let e=this.history.slice(-5),t=e[0].value,i=e[e.length-1].value-t,a=e.reduce((o,l)=>o+l.value,0)/e.length*.1;return i>a?"improving":i<-a?"degrading":"stable"}recordHistory(e){let t={timestamp:new Date,value:e,vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount};for(this.history.push(t);this.history.length>this.config.maxHistoryEntries;)this.history.shift()}checkAlertConditions(e,t,n){if(!this.config.alertsEnabled)return;let i=Date.now();n==="critical"?this.maybeGenerateAlert("critical-threshold","critical",`MinCut value (${e.toFixed(2)}) is below critical threshold (${this.config.warningThreshold})`,e,this.config.warningThreshold,t):n==="warning"&&this.maybeGenerateAlert("warning-threshold","high",`MinCut value (${e.toFixed(2)}) is below healthy threshold (${this.config.healthyThreshold})`,e,this.config.healthyThreshold,t);let r=t.filter(o=>o.weightedDegree===0);r.length>0&&this.maybeGenerateAlert("isolated-vertices","high",`${r.length} isolated vertex(es) detected`,e,0,r);let a=t.filter(o=>o.riskScore>.8);a.length>0&&this.maybeGenerateAlert("critical-vertices","medium",`${a.length} critical vertex(es) with high risk score`,e,0,a)}maybeGenerateAlert(e,t,n,i,r,a){let o=Date.now(),l=this.lastAlertTime.get(e)||0;if(o-l<this.config.alertCooldownMs)return;let c={id:f(),severity:t,message:n,minCutValue:i,threshold:r,affectedVertices:a.map(u=>u.vertexId),timestamp:new Date,acknowledged:!1,remediations:a.flatMap(u=>u.suggestions).slice(0,5)};this.alerts.set(c.id,c),this.persistence&&this.persistence.saveAlert(c).catch(u=>console.warn("[MinCutHealthMonitor] Failed to persist alert:",u)),this.lastAlertTime.set(e,o),this.emitEvent("mincut.alert.generated",i,{alert:c})}emitEvent(e,t,n){if(!this.eventBus)return;let i={id:f(),type:e,source:"coordination",timestamp:new Date,correlationId:f(),payload:{minCutValue:t,...n}};this.eventBus.publish(i).catch(r=>{console.error("Failed to publish MinCut event:",r)})}};function W(s,e,t,n){return new ve(s,e,t,n)}he();dt();var Ce=class{memory;initialized=!1;constructor(e){this.memory=e??w()}async initialize(){this.initialized||(this.memory.isInitialized()||await this.memory.initialize(),this.initialized=!0)}async saveSnapshot(e){this.ensureInitialized();let t=f();return this.memory.getDatabase().prepare(`
|
|
3
3
|
INSERT INTO mincut_snapshots (
|
|
4
4
|
id, timestamp, vertex_count, edge_count, total_weight,
|
|
5
5
|
is_connected, component_count, vertices_json, edges_json
|
|
@@ -118,7 +118,7 @@ import{b as ye}from"./chunk-BULKFVYX.js";import{a as gt,b as pt}from"./chunk-4B6
|
|
|
118
118
|
`).run(new Date(n-r).toISOString()),c=t.prepare(`
|
|
119
119
|
DELETE FROM mincut_alerts
|
|
120
120
|
WHERE timestamp < ? AND acknowledged = 1
|
|
121
|
-
`).run(new Date(n-a).toISOString());return{historyDeleted:o.changes,snapshotsDeleted:l.changes,alertsDeleted:c.changes}}ensureInitialized(){if(!this.initialized)throw new Error("MinCutPersistence not initialized. Call initialize() first.")}rowToSnapshot(e){return{timestamp:new Date(e.timestamp),vertices:E(e.vertices_json),edges:E(e.edges_json),stats:{vertexCount:e.vertex_count,edgeCount:e.edge_count,totalWeight:e.total_weight,averageDegree:e.edge_count>0&&e.vertex_count>0?e.edge_count*2/e.vertex_count:0,density:e.vertex_count>1?e.edge_count/(e.vertex_count*(e.vertex_count-1)/2):0,isConnected:e.is_connected===1,componentCount:e.component_count}}}rowToAlert(e){return{id:e.id,severity:e.severity,message:e.message,minCutValue:e.mincut_value,threshold:e.threshold,affectedVertices:e.affected_vertices_json?E(e.affected_vertices_json):[],remediations:e.remediations_json?E(e.remediations_json):[],acknowledged:e.acknowledged===1,timestamp:new Date(e.timestamp)}}};function ft(s){return new Ce(s)}var mn={...j,autoUpdateFromEvents:!0,persistData:!0,snapshotIntervalMs:6e4,includeInQueenHealth:!0,minHealthIssueSeverity:"medium"},be=class{constructor(e,t,n={}){this.eventBus=e;this.agentCoordinator=t;this.config={...mn,...n},this.graph=n.sharedGraph??z(),this.monitor=W(this.graph,this.config,this.eventBus),this.persistence=ft()}config;graph;monitor;persistence;eventSubscriptions=[];snapshotTimer=null;initialized=!1;async initialize(){this.initialized||(this.config.persistData&&await this.persistence.initialize(),await this.buildGraphFromAgents(),this.config.autoUpdateFromEvents&&this.subscribeToEvents(),this.monitor.start(),this.config.persistData&&this.startSnapshotTimer(),this.initialized=!0)}async dispose(){this.monitor.stop(),this.snapshotTimer&&(clearInterval(this.snapshotTimer),this.snapshotTimer=null);for(let e of this.eventSubscriptions)e();if(this.eventSubscriptions=[],this.config.persistData)try{await this.saveSnapshot()}catch{}this.initialized=!1}async buildGraphFromAgents(){this.config.sharedGraph||this.graph.clear();let e=this.agentCoordinator.listAgents();for(let t of T)this.graph.addVertex({id:`domain:${t}`,type:"domain",domain:t,weight:2,createdAt:new Date});for(let t of e)this.addAgentVertex(t);this.buildCoordinationEdges(e)}addAgentVertex(e){let t=e,n={id:`agent:${e.id}`,type:"agent",domain:e.domain,capabilities:t.capabilities,weight:1,createdAt:e.startedAt??new Date,metadata:{status:e.status,taskCount:t.taskCount??0,health:t.health??1}};if(this.graph.addVertex(n),e.domain){let i=`domain:${e.domain}`;this.graph.hasVertex(i)&&this.graph.addEdge({source:`agent:${e.id}`,target:i,weight:1,type:"coordination",bidirectional:!0})}}buildCoordinationEdges(e){let t=new Map;for(let i of e)if(i.domain){let r=t.get(i.domain)||[];r.push(i),t.set(i.domain,r)}for(let[i,r]of t)for(let a=0;a<r.length;a++)for(let o=a+1;o<r.length;o++)this.graph.addEdge({source:`agent:${r[a].id}`,target:`agent:${r[o].id}`,weight:.5,type:"communication",bidirectional:!0});let n=[["test-generation","test-execution"],["test-execution","coverage-analysis"],["coverage-analysis","quality-assessment"],["quality-assessment","defect-intelligence"],["requirements-validation","test-generation"],["code-intelligence","test-generation"],["security-compliance","quality-assessment"],["contract-testing","test-execution"],["visual-accessibility","quality-assessment"],["chaos-resilience","test-execution"],["learning-optimization","defect-intelligence"]];for(let[i,r]of n){let a=`domain:${i}`,o=`domain:${r}`;this.graph.hasVertex(a)&&this.graph.hasVertex(o)&&this.graph.addEdge({source:a,target:o,weight:1.5,type:"workflow",bidirectional:!1})}}subscribeToEvents(){let e=async r=>{let{agentId:a,domain:o,type:l,capabilities:c}=r.payload;this.addAgentVertex({id:a,name:`${o}-${l}`,domain:o,type:l,status:"running",startedAt:new Date,capabilities:c,health:1,taskCount:0}),this.config.persistData&&await this.persistence.recordHistory({minCutValue:this.monitor.getMinCutValue(),vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount})},t=async r=>{let{agentId:a}=r.payload;this.graph.removeVertex(`agent:${a}`),this.monitor.checkHealth().status==="critical"&&await this.reportHealthIssue({severity:"high",message:`Agent ${a} termination caused critical MinCut degradation`,timestamp:new Date})},n=async r=>{let{agentId:a,status:o,domain:l}=r.payload,c=`agent:${a}`,u=this.graph.getVertex(c);u&&this.graph.addVertex({...u,metadata:{...u.metadata,status:o}})},i=async r=>{let{fromAgent:a,toAgent:o,messageType:l}=r.payload,c=`agent:${a}`,u=`agent:${o}`;if(this.graph.hasVertex(c)&&this.graph.hasVertex(u)){let d=this.graph.getEdge(c,u);d?this.graph.addEdge({...d,weight:Math.min(d.weight+.1,3),lastActivity:new Date,messageCount:(d.messageCount??0)+1}):this.graph.addEdge({source:c,target:u,weight:.5,type:"communication",bidirectional:!0,lastActivity:new Date,messageCount:1})}};this.eventSubscriptions.push(()=>{})}getMinCutHealth(){return this.monitor.getHealth()}isEmptyTopology(){return this.graph.getVerticesByType("agent").length===0}getHealthIssuesFromMinCut(){if(this.isEmptyTopology())return[];let e=this.monitor.getActiveAlerts(),t=[];for(let i of e){let r=this.mapSeverity(i.severity);this.severityValue(r)>=this.severityValue(this.config.minHealthIssueSeverity)&&t.push({severity:r,message:`MinCut: ${i.message}`,timestamp:i.timestamp})}let n=this.monitor.getWeakVertices();for(let i of n.slice(0,3))i.riskScore>.7&&t.push({severity:"high",message:`Weak agent topology: ${i.reason} (risk: ${(i.riskScore*100).toFixed(0)}%)`,timestamp:new Date,domain:i.vertex.domain});return t}extendQueenHealth(e){if(!this.config.includeInQueenHealth)return e;let t=this.getMinCutHealth(),n=this.getHealthIssuesFromMinCut(),i=e.status;return t.status==="critical"&&i==="healthy"&&(i="degraded"),{...e,status:i,issues:[...e.issues,...n],minCut:t}}extendQueenMetrics(e){let t=this.monitor.getHealth(),n=this.graph.getStats();return{...e,minCutValue:t.minCutValue,weakVertexCount:t.weakVertexCount,topologyDensity:n.density}}async saveSnapshot(){if(!this.config.persistData)return;let e=this.graph.snapshot();await this.persistence.saveSnapshot(e)}startSnapshotTimer(){this.snapshotTimer=setInterval(async()=>{await this.saveSnapshot(),await this.persistence.recordHistory({minCutValue:this.monitor.getMinCutValue(),vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount})},this.config.snapshotIntervalMs)}getGraph(){return this.graph}getMonitor(){return this.monitor}getPersistence(){return this.persistence}getMinCutValue(){return this.monitor.getMinCutValue()}getWeakVertices(){return this.monitor.getWeakVertices()}isTopologyCritical(){return this.monitor.isCritical()}addVertex(e){this.graph.addVertex(e)}addEdge(e){this.graph.addEdge(e)}removeVertex(e){return this.graph.removeVertex(e)}async refreshGraph(){await this.buildGraphFromAgents()}async reportHealthIssue(e){await this.eventBus.publish({id:f(),type:"MinCutHealthIssue",source:"mincut-bridge",timestamp:new Date,payload:{issue:e}})}mapSeverity(e){return e}severityValue(e){return{critical:5,high:4,medium:3,low:2,info:1}[e]}};function yt(s,e,t){return new be(s,e,t)}var ke=null,Se=null;function xe(){return ke||(ke=z()),ke}function ar(){return Se||(Se=W(xe())),Se}Ae();import{performance as wt}from"perf_hooks";var An={multiModel:.8,humanReview:.2,security:.85,escalation:.6},Mn={trivial:["booster","haiku"],simple:["haiku"],moderate:["sonnet"],complex:["sonnet","opus"],critical:["opus"]},En={enabled:!0,preferCheaperModels:!0,costPerMillionTokens:{haiku:{input:.25,output:1.25},sonnet:{input:3,output:15},opus:{input:15,output:75}},dailyCostLimit:0,costAlertThreshold:.8},wn={enabled:!0,maxAttempts:2,retryDelayMs:1e3,chain:{booster:"haiku",haiku:"sonnet",sonnet:"opus",opus:null}},x={confidence:An,tierMapping:Mn,costOptimization:En,fallback:wn,verbose:!1,enableEMACalibration:!0,enableAutoEscalation:!0,enableNeuralRouting:!1};function Dt(s=x){let e=structuredClone(s);return process.env.ROUTING_CONFIDENCE_MULTI_MODEL&&(e.confidence.multiModel=parseFloat(process.env.ROUTING_CONFIDENCE_MULTI_MODEL)),process.env.ROUTING_CONFIDENCE_HUMAN_REVIEW&&(e.confidence.humanReview=parseFloat(process.env.ROUTING_CONFIDENCE_HUMAN_REVIEW)),process.env.ROUTING_CONFIDENCE_SECURITY&&(e.confidence.security=parseFloat(process.env.ROUTING_CONFIDENCE_SECURITY)),process.env.ROUTING_CONFIDENCE_ESCALATION&&(e.confidence.escalation=parseFloat(process.env.ROUTING_CONFIDENCE_ESCALATION)),process.env.ROUTING_COST_DAILY_LIMIT&&(e.costOptimization.dailyCostLimit=parseFloat(process.env.ROUTING_COST_DAILY_LIMIT)),process.env.ROUTING_COST_PREFER_CHEAPER&&(e.costOptimization.preferCheaperModels=process.env.ROUTING_COST_PREFER_CHEAPER.toLowerCase()==="true"),process.env.ROUTING_FALLBACK_ENABLED&&(e.fallback.enabled=process.env.ROUTING_FALLBACK_ENABLED.toLowerCase()==="true"),process.env.ROUTING_FALLBACK_MAX_ATTEMPTS&&(e.fallback.maxAttempts=parseInt(process.env.ROUTING_FALLBACK_MAX_ATTEMPTS,10)),process.env.ROUTING_VERBOSE&&(e.verbose=process.env.ROUTING_VERBOSE.toLowerCase()==="true"),e}function At(s,e,t=x){if(e/100<=.2)return t.tierMapping.trivial;switch(s){case"simple":return t.tierMapping.simple;case"moderate":return t.tierMapping.moderate;case"complex":return t.tierMapping.complex;case"critical":return t.tierMapping.critical}}function Mt(s,e=x){return e.fallback.enabled?e.fallback.chain[s]??null:null}function Me(s){switch(s){case"booster":case"haiku":return"haiku";case"sonnet":return"sonnet";case"opus":return"opus"}}function Et(s,e,t,n=x){let i=n.costOptimization.costPerMillionTokens[s],r=e/1e6*i.input,a=t/1e6*i.output;return r+a}function Ee(s){let{confidence:e}=s;if(e.multiModel<0||e.multiModel>1)throw new Error("multiModel confidence must be between 0 and 1");if(e.humanReview<0||e.humanReview>1)throw new Error("humanReview confidence must be between 0 and 1");if(e.security<0||e.security>1)throw new Error("security confidence must be between 0 and 1");if(e.escalation<0||e.escalation>1)throw new Error("escalation confidence must be between 0 and 1");if(s.costOptimization.dailyCostLimit<0)throw new Error("dailyCostLimit must be non-negative");if(s.costOptimization.costAlertThreshold<0||s.costOptimization.costAlertThreshold>1)throw new Error("costAlertThreshold must be between 0 and 1");if(s.fallback.maxAttempts<0)throw new Error("maxAttempts must be non-negative");if(s.fallback.retryDelayMs<0)throw new Error("retryDelayMs must be non-negative")}var K=class{tinyDancer;routingConfig;enableCostTracking;avgInputTokens;avgOutputTokens;totalCost=0;costByModel={haiku:0,sonnet:0,opus:0};totalTasks=0;dailyCost=0;lastCostReset=new Date;outcomes=[];maxOutcomes=1e3;constructor(e={}){this.tinyDancer=xt(e.tinyDancer);let t=this.mergeRoutingConfig(e.routing);this.routingConfig=Dt(t),Ee(this.routingConfig),this.enableCostTracking=e.enableCostTracking??!0,this.avgInputTokens=e.avgInputTokens??2e3,this.avgOutputTokens=e.avgOutputTokens??500}async route(e){let t=wt.now();this.checkDailyCostReset();let n=await this.tinyDancer.route(e),r=At(n.complexity,n.classification.score,this.routingConfig)[0],a=Me(r),o=this.buildFallbackChain(r),l=this.enableCostTracking?Et(a,this.avgInputTokens,this.avgOutputTokens,this.routingConfig):0;this.checkCostLimits(l);let c=this.buildQueenReasoning(n,r,o,l),u=wt.now()-t,d={tier:r,model:a,complexity:n.complexity,confidence:n.confidence,triggerMultiModel:n.triggerMultiModel,triggerHumanReview:n.triggerHumanReview,fallbackTiers:o,estimatedCost:l,reasoning:c,latencyMs:u,tinyDancerResult:n,timestamp:new Date};return this.enableCostTracking&&(this.totalCost+=l,this.costByModel[a]+=l,this.dailyCost+=l),this.totalTasks++,this.routingConfig.verbose&&console.log(`[QueenRouter] Route: ${r} (${a}) complexity=${n.complexity}, confidence=${(n.confidence*100).toFixed(1)}%, cost=$${l.toFixed(4)}`),d}recordOutcome(e,t,n,i,r=i?1:0,a=0,o=0,l){let c={task:e,decision:t,usedTier:n,success:i,qualityScore:r,durationMs:a,fallbackAttempts:o,error:l,timestamp:new Date};this.outcomes.push(c),this.outcomes.length>this.maxOutcomes&&this.outcomes.shift(),this.tinyDancer.recordOutcome?.(e,t.tinyDancerResult,i,r,Me(n),a),this.routingConfig.verbose&&console.log(`[QueenRouter] Recorded outcome: tier=${n}, success=${i}, quality=${(r*100).toFixed(0)}%, fallbacks=${o}`)}getSuccessRateByTier(){let e={booster:{success:0,total:0},haiku:{success:0,total:0},sonnet:{success:0,total:0},opus:{success:0,total:0}};for(let t of this.outcomes){let n=t.usedTier;e[n].total++,t.success&&e[n].success++}return{booster:e.booster.total>0?e.booster.success/e.booster.total:0,haiku:e.haiku.total>0?e.haiku.success/e.haiku.total:0,sonnet:e.sonnet.total>0?e.sonnet.success/e.sonnet.total:0,opus:e.opus.total>0?e.opus.success/e.opus.total:0}}getFallbackStats(){let e=this.outcomes.filter(i=>i.fallbackAttempts>0),t=e.filter(i=>i.success),n=e.reduce((i,r)=>i+r.fallbackAttempts,0);return{totalWithFallback:e.length,avgFallbackAttempts:e.length>0?n/e.length:0,fallbackSuccessRate:e.length>0?t.length/e.length:0}}getCostStats(){return{totalCost:this.totalCost,costByModel:{...this.costByModel},totalTasks:this.totalTasks,avgCostPerTask:this.totalTasks>0?this.totalCost/this.totalTasks:0,dailyCost:this.dailyCost,lastReset:this.lastCostReset}}getOutcomes(){return this.outcomes}getConfig(){return this.routingConfig}updateConfidenceThresholds(e){Object.assign(this.routingConfig.confidence,e),Ee(this.routingConfig),this.routingConfig.verbose&&console.log("[QueenRouter] Updated confidence thresholds:",e)}reset(){this.totalCost=0,this.costByModel={haiku:0,sonnet:0,opus:0},this.totalTasks=0,this.dailyCost=0,this.lastCostReset=new Date,this.outcomes=[],this.tinyDancer.reset?.()}buildFallbackChain(e){let t=[];if(!this.routingConfig.fallback.enabled)return t;let n=e,i=0;for(;n&&i<this.routingConfig.fallback.maxAttempts;){let r=Mt(n,this.routingConfig);if(r)t.push(r),n=r;else break;i++}return t}buildQueenReasoning(e,t,n,i){let r=[];return r.push(e.reasoning),r.push(`Assigned to ${t.toUpperCase()} tier.`),n.length>0&&r.push(`Fallback chain: ${n.map(a=>a.toUpperCase()).join(" \u2192 ")}.`),this.enableCostTracking&&i>0&&r.push(`Estimated cost: $${i.toFixed(4)}.`),r.join(" ")}checkDailyCostReset(){let e=new Date,t=this.lastCostReset;(e.getUTCDate()!==t.getUTCDate()||e.getUTCMonth()!==t.getUTCMonth()||e.getUTCFullYear()!==t.getUTCFullYear())&&(this.dailyCost=0,this.lastCostReset=e,this.routingConfig.verbose&&console.log("[QueenRouter] Reset daily cost tracking"))}checkCostLimits(e){if(!this.routingConfig.costOptimization.enabled)return;let{dailyCostLimit:t,costAlertThreshold:n}=this.routingConfig.costOptimization;if(t>0){let i=this.dailyCost+e,r=i/t;i>t?console.warn(`[QueenRouter] COST LIMIT EXCEEDED: Daily cost $${i.toFixed(2)} exceeds limit of $${t.toFixed(2)}`):r>=n&&console.warn(`[QueenRouter] Cost alert: ${(r*100).toFixed(0)}% of daily limit ($${i.toFixed(2)} / $${t.toFixed(2)})`)}}mergeRoutingConfig(e){if(!e)return structuredClone(x);let t=structuredClone(x);return e.confidence&&(t.confidence={...t.confidence,...e.confidence}),e.tierMapping&&(t.tierMapping={...t.tierMapping,...e.tierMapping}),e.costOptimization&&(t.costOptimization={...t.costOptimization,...e.costOptimization,costPerMillionTokens:e.costOptimization.costPerMillionTokens?{...t.costOptimization.costPerMillionTokens,...e.costOptimization.costPerMillionTokens}:t.costOptimization.costPerMillionTokens}),e.fallback&&(t.fallback={...t.fallback,...e.fallback,chain:e.fallback.chain?{...t.fallback.chain,...e.fallback.chain}:t.fallback.chain}),e.verbose!==void 0&&(t.verbose=e.verbose),t}};k();var It=20,Ie=class{db=null;initialized=!1;initialize(e){if(!this.initialized){this.db=e;try{this.db.exec(`
|
|
121
|
+
`).run(new Date(n-a).toISOString());return{historyDeleted:o.changes,snapshotsDeleted:l.changes,alertsDeleted:c.changes}}ensureInitialized(){if(!this.initialized)throw new Error("MinCutPersistence not initialized. Call initialize() first.")}rowToSnapshot(e){return{timestamp:new Date(e.timestamp),vertices:E(e.vertices_json),edges:E(e.edges_json),stats:{vertexCount:e.vertex_count,edgeCount:e.edge_count,totalWeight:e.total_weight,averageDegree:e.edge_count>0&&e.vertex_count>0?e.edge_count*2/e.vertex_count:0,density:e.vertex_count>1?e.edge_count/(e.vertex_count*(e.vertex_count-1)/2):0,isConnected:e.is_connected===1,componentCount:e.component_count}}}rowToAlert(e){return{id:e.id,severity:e.severity,message:e.message,minCutValue:e.mincut_value,threshold:e.threshold,affectedVertices:e.affected_vertices_json?E(e.affected_vertices_json):[],remediations:e.remediations_json?E(e.remediations_json):[],acknowledged:e.acknowledged===1,timestamp:new Date(e.timestamp)}}};function Tt(s){return new Ce(s)}var pn={...j,autoUpdateFromEvents:!0,persistData:!0,snapshotIntervalMs:6e4,includeInQueenHealth:!0,minHealthIssueSeverity:"medium"},be=class{constructor(e,t,n={}){this.eventBus=e;this.agentCoordinator=t;this.config={...pn,...n},this.graph=n.sharedGraph??z(),this.monitor=W(this.graph,this.config,this.eventBus),this.persistence=Tt()}config;graph;monitor;persistence;eventSubscriptions=[];snapshotTimer=null;initialized=!1;async initialize(){this.initialized||(this.config.persistData&&await this.persistence.initialize(),await this.buildGraphFromAgents(),this.config.autoUpdateFromEvents&&this.subscribeToEvents(),this.monitor.start(),this.config.persistData&&this.startSnapshotTimer(),this.initialized=!0)}async dispose(){this.monitor.stop(),this.snapshotTimer&&(clearInterval(this.snapshotTimer),this.snapshotTimer=null);for(let e of this.eventSubscriptions)e();if(this.eventSubscriptions=[],this.config.persistData)try{await this.saveSnapshot()}catch{}this.initialized=!1}async buildGraphFromAgents(){this.config.sharedGraph||this.graph.clear();let e=this.agentCoordinator.listAgents();for(let t of T)this.graph.addVertex({id:`domain:${t}`,type:"domain",domain:t,weight:2,createdAt:new Date});for(let t of e)this.addAgentVertex(t);this.buildCoordinationEdges(e)}addAgentVertex(e){let t=e,n={id:`agent:${e.id}`,type:"agent",domain:e.domain,capabilities:t.capabilities,weight:1,createdAt:e.startedAt??new Date,metadata:{status:e.status,taskCount:t.taskCount??0,health:t.health??1}};if(this.graph.addVertex(n),e.domain){let i=`domain:${e.domain}`;this.graph.hasVertex(i)&&this.graph.addEdge({source:`agent:${e.id}`,target:i,weight:1,type:"coordination",bidirectional:!0})}}buildCoordinationEdges(e){let t=new Map;for(let i of e)if(i.domain){let r=t.get(i.domain)||[];r.push(i),t.set(i.domain,r)}for(let[i,r]of t)for(let a=0;a<r.length;a++)for(let o=a+1;o<r.length;o++)this.graph.addEdge({source:`agent:${r[a].id}`,target:`agent:${r[o].id}`,weight:.5,type:"communication",bidirectional:!0});let n=[["test-generation","test-execution"],["test-execution","coverage-analysis"],["coverage-analysis","quality-assessment"],["quality-assessment","defect-intelligence"],["requirements-validation","test-generation"],["code-intelligence","test-generation"],["security-compliance","quality-assessment"],["contract-testing","test-execution"],["visual-accessibility","quality-assessment"],["chaos-resilience","test-execution"],["learning-optimization","defect-intelligence"]];for(let[i,r]of n){let a=`domain:${i}`,o=`domain:${r}`;this.graph.hasVertex(a)&&this.graph.hasVertex(o)&&this.graph.addEdge({source:a,target:o,weight:1.5,type:"workflow",bidirectional:!1})}}subscribeToEvents(){let e=async r=>{let{agentId:a,domain:o,type:l,capabilities:c}=r.payload;this.addAgentVertex({id:a,name:`${o}-${l}`,domain:o,type:l,status:"running",startedAt:new Date,capabilities:c,health:1,taskCount:0}),this.config.persistData&&await this.persistence.recordHistory({minCutValue:this.monitor.getMinCutValue(),vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount})},t=async r=>{let{agentId:a}=r.payload;this.graph.removeVertex(`agent:${a}`),this.monitor.checkHealth().status==="critical"&&await this.reportHealthIssue({severity:"high",message:`Agent ${a} termination caused critical MinCut degradation`,timestamp:new Date})},n=async r=>{let{agentId:a,status:o,domain:l}=r.payload,c=`agent:${a}`,u=this.graph.getVertex(c);u&&this.graph.addVertex({...u,metadata:{...u.metadata,status:o}})},i=async r=>{let{fromAgent:a,toAgent:o,messageType:l}=r.payload,c=`agent:${a}`,u=`agent:${o}`;if(this.graph.hasVertex(c)&&this.graph.hasVertex(u)){let d=this.graph.getEdge(c,u);d?this.graph.addEdge({...d,weight:Math.min(d.weight+.1,3),lastActivity:new Date,messageCount:(d.messageCount??0)+1}):this.graph.addEdge({source:c,target:u,weight:.5,type:"communication",bidirectional:!0,lastActivity:new Date,messageCount:1})}};this.eventSubscriptions.push(()=>{})}getMinCutHealth(){return this.monitor.getHealth()}isEmptyTopology(){return this.graph.getVerticesByType("agent").length===0}getHealthIssuesFromMinCut(){if(this.isEmptyTopology())return[];let e=this.monitor.getActiveAlerts(),t=[];for(let i of e){let r=this.mapSeverity(i.severity);this.severityValue(r)>=this.severityValue(this.config.minHealthIssueSeverity)&&t.push({severity:r,message:`MinCut: ${i.message}`,timestamp:i.timestamp})}let n=this.monitor.getWeakVertices();for(let i of n.slice(0,3))i.riskScore>.7&&t.push({severity:"high",message:`Weak agent topology: ${i.reason} (risk: ${(i.riskScore*100).toFixed(0)}%)`,timestamp:new Date,domain:i.vertex.domain});return t}extendQueenHealth(e){if(!this.config.includeInQueenHealth)return e;let t=this.getMinCutHealth(),n=this.getHealthIssuesFromMinCut(),i=e.status;return t.status==="critical"&&i==="healthy"&&(i="degraded"),{...e,status:i,issues:[...e.issues,...n],minCut:t}}extendQueenMetrics(e){let t=this.monitor.getHealth(),n=this.graph.getStats();return{...e,minCutValue:t.minCutValue,weakVertexCount:t.weakVertexCount,topologyDensity:n.density}}async saveSnapshot(){if(!this.config.persistData)return;let e=this.graph.snapshot();await this.persistence.saveSnapshot(e)}startSnapshotTimer(){this.snapshotTimer=setInterval(async()=>{await this.saveSnapshot(),await this.persistence.recordHistory({minCutValue:this.monitor.getMinCutValue(),vertexCount:this.graph.vertexCount,edgeCount:this.graph.edgeCount})},this.config.snapshotIntervalMs)}getGraph(){return this.graph}getMonitor(){return this.monitor}getPersistence(){return this.persistence}getMinCutValue(){return this.monitor.getMinCutValue()}getWeakVertices(){return this.monitor.getWeakVertices()}isTopologyCritical(){return this.monitor.isCritical()}addVertex(e){this.graph.addVertex(e)}addEdge(e){this.graph.addEdge(e)}removeVertex(e){return this.graph.removeVertex(e)}async refreshGraph(){await this.buildGraphFromAgents()}async reportHealthIssue(e){await this.eventBus.publish({id:f(),type:"MinCutHealthIssue",source:"mincut-bridge",timestamp:new Date,payload:{issue:e}})}mapSeverity(e){return e}severityValue(e){return{critical:5,high:4,medium:3,low:2,info:1}[e]}};function vt(s,e,t){return new be(s,e,t)}var ke=null,Se=null;function xe(){return ke||(ke=z()),ke}function or(){return Se||(Se=W(xe())),Se}Ae();import{performance as Rt}from"perf_hooks";var En={multiModel:.8,humanReview:.2,security:.85,escalation:.6},wn={trivial:["booster","haiku"],simple:["haiku"],moderate:["sonnet"],complex:["sonnet","opus"],critical:["opus"]},In={enabled:!0,preferCheaperModels:!0,costPerMillionTokens:{haiku:{input:.25,output:1.25},sonnet:{input:3,output:15},opus:{input:15,output:75}},dailyCostLimit:0,costAlertThreshold:.8},Rn={enabled:!0,maxAttempts:2,retryDelayMs:1e3,chain:{booster:"haiku",haiku:"sonnet",sonnet:"opus",opus:null}},x={confidence:En,tierMapping:wn,costOptimization:In,fallback:Rn,verbose:!1,enableEMACalibration:!0,enableAutoEscalation:!0,enableNeuralRouting:!1};function Mt(s=x){let e=structuredClone(s);return process.env.ROUTING_CONFIDENCE_MULTI_MODEL&&(e.confidence.multiModel=parseFloat(process.env.ROUTING_CONFIDENCE_MULTI_MODEL)),process.env.ROUTING_CONFIDENCE_HUMAN_REVIEW&&(e.confidence.humanReview=parseFloat(process.env.ROUTING_CONFIDENCE_HUMAN_REVIEW)),process.env.ROUTING_CONFIDENCE_SECURITY&&(e.confidence.security=parseFloat(process.env.ROUTING_CONFIDENCE_SECURITY)),process.env.ROUTING_CONFIDENCE_ESCALATION&&(e.confidence.escalation=parseFloat(process.env.ROUTING_CONFIDENCE_ESCALATION)),process.env.ROUTING_COST_DAILY_LIMIT&&(e.costOptimization.dailyCostLimit=parseFloat(process.env.ROUTING_COST_DAILY_LIMIT)),process.env.ROUTING_COST_PREFER_CHEAPER&&(e.costOptimization.preferCheaperModels=process.env.ROUTING_COST_PREFER_CHEAPER.toLowerCase()==="true"),process.env.ROUTING_FALLBACK_ENABLED&&(e.fallback.enabled=process.env.ROUTING_FALLBACK_ENABLED.toLowerCase()==="true"),process.env.ROUTING_FALLBACK_MAX_ATTEMPTS&&(e.fallback.maxAttempts=parseInt(process.env.ROUTING_FALLBACK_MAX_ATTEMPTS,10)),process.env.ROUTING_VERBOSE&&(e.verbose=process.env.ROUTING_VERBOSE.toLowerCase()==="true"),e}function Et(s,e,t=x){if(e/100<=.2)return t.tierMapping.trivial;switch(s){case"simple":return t.tierMapping.simple;case"moderate":return t.tierMapping.moderate;case"complex":return t.tierMapping.complex;case"critical":return t.tierMapping.critical}}function wt(s,e=x){return e.fallback.enabled?e.fallback.chain[s]??null:null}function Me(s){switch(s){case"booster":case"haiku":return"haiku";case"sonnet":return"sonnet";case"opus":return"opus"}}function It(s,e,t,n=x){let i=n.costOptimization.costPerMillionTokens[s],r=e/1e6*i.input,a=t/1e6*i.output;return r+a}function Ee(s){let{confidence:e}=s;if(e.multiModel<0||e.multiModel>1)throw new Error("multiModel confidence must be between 0 and 1");if(e.humanReview<0||e.humanReview>1)throw new Error("humanReview confidence must be between 0 and 1");if(e.security<0||e.security>1)throw new Error("security confidence must be between 0 and 1");if(e.escalation<0||e.escalation>1)throw new Error("escalation confidence must be between 0 and 1");if(s.costOptimization.dailyCostLimit<0)throw new Error("dailyCostLimit must be non-negative");if(s.costOptimization.costAlertThreshold<0||s.costOptimization.costAlertThreshold>1)throw new Error("costAlertThreshold must be between 0 and 1");if(s.fallback.maxAttempts<0)throw new Error("maxAttempts must be non-negative");if(s.fallback.retryDelayMs<0)throw new Error("retryDelayMs must be non-negative")}var K=class{tinyDancer;routingConfig;enableCostTracking;avgInputTokens;avgOutputTokens;totalCost=0;costByModel={haiku:0,sonnet:0,opus:0};totalTasks=0;dailyCost=0;lastCostReset=new Date;outcomes=[];maxOutcomes=1e3;constructor(e={}){this.tinyDancer=At(e.tinyDancer);let t=this.mergeRoutingConfig(e.routing);this.routingConfig=Mt(t),Ee(this.routingConfig),this.enableCostTracking=e.enableCostTracking??!0,this.avgInputTokens=e.avgInputTokens??2e3,this.avgOutputTokens=e.avgOutputTokens??500}async route(e){let t=Rt.now();this.checkDailyCostReset();let n=await this.tinyDancer.route(e),r=Et(n.complexity,n.classification.score,this.routingConfig)[0],a=Me(r),o=this.buildFallbackChain(r),l=this.enableCostTracking?It(a,this.avgInputTokens,this.avgOutputTokens,this.routingConfig):0;this.checkCostLimits(l);let c=this.buildQueenReasoning(n,r,o,l),u=Rt.now()-t,d={tier:r,model:a,complexity:n.complexity,confidence:n.confidence,triggerMultiModel:n.triggerMultiModel,triggerHumanReview:n.triggerHumanReview,fallbackTiers:o,estimatedCost:l,reasoning:c,latencyMs:u,tinyDancerResult:n,timestamp:new Date};return this.enableCostTracking&&(this.totalCost+=l,this.costByModel[a]+=l,this.dailyCost+=l),this.totalTasks++,this.routingConfig.verbose&&console.log(`[QueenRouter] Route: ${r} (${a}) complexity=${n.complexity}, confidence=${(n.confidence*100).toFixed(1)}%, cost=$${l.toFixed(4)}`),d}recordOutcome(e,t,n,i,r=i?1:0,a=0,o=0,l){let c={task:e,decision:t,usedTier:n,success:i,qualityScore:r,durationMs:a,fallbackAttempts:o,error:l,timestamp:new Date};this.outcomes.push(c),this.outcomes.length>this.maxOutcomes&&this.outcomes.shift(),this.tinyDancer.recordOutcome?.(e,t.tinyDancerResult,i,r,Me(n),a),this.routingConfig.verbose&&console.log(`[QueenRouter] Recorded outcome: tier=${n}, success=${i}, quality=${(r*100).toFixed(0)}%, fallbacks=${o}`)}getSuccessRateByTier(){let e={booster:{success:0,total:0},haiku:{success:0,total:0},sonnet:{success:0,total:0},opus:{success:0,total:0}};for(let t of this.outcomes){let n=t.usedTier;e[n].total++,t.success&&e[n].success++}return{booster:e.booster.total>0?e.booster.success/e.booster.total:0,haiku:e.haiku.total>0?e.haiku.success/e.haiku.total:0,sonnet:e.sonnet.total>0?e.sonnet.success/e.sonnet.total:0,opus:e.opus.total>0?e.opus.success/e.opus.total:0}}getFallbackStats(){let e=this.outcomes.filter(i=>i.fallbackAttempts>0),t=e.filter(i=>i.success),n=e.reduce((i,r)=>i+r.fallbackAttempts,0);return{totalWithFallback:e.length,avgFallbackAttempts:e.length>0?n/e.length:0,fallbackSuccessRate:e.length>0?t.length/e.length:0}}getCostStats(){return{totalCost:this.totalCost,costByModel:{...this.costByModel},totalTasks:this.totalTasks,avgCostPerTask:this.totalTasks>0?this.totalCost/this.totalTasks:0,dailyCost:this.dailyCost,lastReset:this.lastCostReset}}getOutcomes(){return this.outcomes}getConfig(){return this.routingConfig}updateConfidenceThresholds(e){Object.assign(this.routingConfig.confidence,e),Ee(this.routingConfig),this.routingConfig.verbose&&console.log("[QueenRouter] Updated confidence thresholds:",e)}reset(){this.totalCost=0,this.costByModel={haiku:0,sonnet:0,opus:0},this.totalTasks=0,this.dailyCost=0,this.lastCostReset=new Date,this.outcomes=[],this.tinyDancer.reset?.()}buildFallbackChain(e){let t=[];if(!this.routingConfig.fallback.enabled)return t;let n=e,i=0;for(;n&&i<this.routingConfig.fallback.maxAttempts;){let r=wt(n,this.routingConfig);if(r)t.push(r),n=r;else break;i++}return t}buildQueenReasoning(e,t,n,i){let r=[];return r.push(e.reasoning),r.push(`Assigned to ${t.toUpperCase()} tier.`),n.length>0&&r.push(`Fallback chain: ${n.map(a=>a.toUpperCase()).join(" \u2192 ")}.`),this.enableCostTracking&&i>0&&r.push(`Estimated cost: $${i.toFixed(4)}.`),r.join(" ")}checkDailyCostReset(){let e=new Date,t=this.lastCostReset;(e.getUTCDate()!==t.getUTCDate()||e.getUTCMonth()!==t.getUTCMonth()||e.getUTCFullYear()!==t.getUTCFullYear())&&(this.dailyCost=0,this.lastCostReset=e,this.routingConfig.verbose&&console.log("[QueenRouter] Reset daily cost tracking"))}checkCostLimits(e){if(!this.routingConfig.costOptimization.enabled)return;let{dailyCostLimit:t,costAlertThreshold:n}=this.routingConfig.costOptimization;if(t>0){let i=this.dailyCost+e,r=i/t;i>t?console.warn(`[QueenRouter] COST LIMIT EXCEEDED: Daily cost $${i.toFixed(2)} exceeds limit of $${t.toFixed(2)}`):r>=n&&console.warn(`[QueenRouter] Cost alert: ${(r*100).toFixed(0)}% of daily limit ($${i.toFixed(2)} / $${t.toFixed(2)})`)}}mergeRoutingConfig(e){if(!e)return structuredClone(x);let t=structuredClone(x);return e.confidence&&(t.confidence={...t.confidence,...e.confidence}),e.tierMapping&&(t.tierMapping={...t.tierMapping,...e.tierMapping}),e.costOptimization&&(t.costOptimization={...t.costOptimization,...e.costOptimization,costPerMillionTokens:e.costOptimization.costPerMillionTokens?{...t.costOptimization.costPerMillionTokens,...e.costOptimization.costPerMillionTokens}:t.costOptimization.costPerMillionTokens}),e.fallback&&(t.fallback={...t.fallback,...e.fallback,chain:e.fallback.chain?{...t.fallback.chain,...e.fallback.chain}:t.fallback.chain}),e.verbose!==void 0&&(t.verbose=e.verbose),t}};k();var _t=20,Ie=class{db=null;initialized=!1;initialize(e){if(!this.initialized){this.db=e;try{this.db.exec(`
|
|
122
122
|
CREATE TABLE IF NOT EXISTS qe_agent_co_execution (
|
|
123
123
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
|
124
124
|
agent_a TEXT NOT NULL,
|
|
@@ -145,7 +145,7 @@ import{b as ye}from"./chunk-BULKFVYX.js";import{a as gt,b as pt}from"./chunk-4B6
|
|
|
145
145
|
FROM qe_agent_co_execution
|
|
146
146
|
WHERE agent_a = ? AND agent_b = ?
|
|
147
147
|
GROUP BY agent_a, agent_b
|
|
148
|
-
`).get(n,i);if(!r)return null;let a=r.total_executions>0?r.success_count/r.total_executions:0,o=Math.min(1,r.success_count/
|
|
148
|
+
`).get(n,i);if(!r)return null;let a=r.total_executions>0?r.success_count/r.total_executions:0,o=Math.min(1,r.success_count/_t);return{agentA:r.agent_a,agentB:r.agent_b,totalExecutions:r.total_executions,successCount:r.success_count,successRate:a,behavioralConfidence:o}}catch(r){return console.debug(`[CoExecutionRepository] Stats error: ${p(r)}`),null}}getCoExecutionPartners(e,t=10){if(!this.db)return[];try{return this.db.prepare(`
|
|
149
149
|
SELECT
|
|
150
150
|
agent_a,
|
|
151
151
|
agent_b,
|
|
@@ -156,15 +156,15 @@ import{b as ye}from"./chunk-BULKFVYX.js";import{a as gt,b as pt}from"./chunk-4B6
|
|
|
156
156
|
GROUP BY agent_a, agent_b
|
|
157
157
|
ORDER BY success_count DESC
|
|
158
158
|
LIMIT ?
|
|
159
|
-
`).all(e,e,t).map(i=>{let r=i.total_executions>0?i.success_count/i.total_executions:0;return{agentA:i.agent_a,agentB:i.agent_b,totalExecutions:i.total_executions,successCount:i.success_count,successRate:r,behavioralConfidence:Math.min(1,i.success_count/
|
|
159
|
+
`).all(e,e,t).map(i=>{let r=i.total_executions>0?i.success_count/i.total_executions:0;return{agentA:i.agent_a,agentB:i.agent_b,totalExecutions:i.total_executions,successCount:i.success_count,successRate:r,behavioralConfidence:Math.min(1,i.success_count/_t)}})}catch(n){return console.debug(`[CoExecutionRepository] Partners error: ${p(n)}`),[]}}recordSwarmCoExecution(e,t,n,i){if(!(!this.db||e.length<2))try{let r=this.db.prepare(`
|
|
160
160
|
INSERT INTO qe_agent_co_execution (agent_a, agent_b, domain, success, task_description)
|
|
161
161
|
VALUES (?, ?, ?, ?, ?)
|
|
162
|
-
`);this.db.transaction(()=>{for(let o=0;o<e.length;o++)for(let l=o+1;l<e.length;l++){let[c,u]=[e[o],e[l]].sort();r.run(c,u,t,n?1:0,i?.slice(0,500)||null)}})()}catch(r){console.debug(`[CoExecutionRepository] Swarm record error: ${p(r)}`)}}},we=null;function
|
|
162
|
+
`);this.db.transaction(()=>{for(let o=0;o<e.length;o++)for(let l=o+1;l<e.length;l++){let[c,u]=[e[o],e[l]].sort();r.run(c,u,t,n?1:0,i?.slice(0,500)||null)}})()}catch(r){console.debug(`[CoExecutionRepository] Swarm record error: ${p(r)}`)}}},we=null;function Pt(){return we||(we=new Ie),we}import{readFileSync as _n,existsSync as Pn,readdirSync as Hn}from"fs";import{join as Fn,basename as On}from"path";function Ht(s){let e=s.split(`
|
|
163
163
|
`);if(e.length<2||e[0].trim()!=="---")return null;for(let t=1;t<e.length;t++)if(e[t].trim()==="---")return e.slice(1,t).join(`
|
|
164
|
-
`);return null}function _(s){let e=s.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function
|
|
165
|
-
`),n=-1;for(let c=0;c<t.length;c++)if(/^dependencies:\s*$/.test(t[c])){n=c+1;break}if(n===-1)return null;let i=[];for(let c=n;c<t.length;c++){let u=t[c];if(u.trim()!==""){if(u.length>0&&u[0]!==" "&&u[0]!==" ")break;i.push(u)}}if(i.length===0)return null;let r={},a={section:"none",item:{},inList:!1},o=()=>{a.item.name&&(r.agents||(r.agents=[]),r.agents.push({name:a.item.name,type:a.item.type||"hard",reason:a.item.reason||""}),a.item={})},l=()=>{a.item.name&&(r.mcpServers||(r.mcpServers=[]),r.mcpServers.push({name:a.item.name,required:a.item.required==="true"}),a.item={})};for(let c of i){let u=c.trim();if(u==="")continue;let d=u.match(/^(agents|mcp_servers|models):\s*$/);if(d){a.section==="agents"&&a.inList&&o(),a.section==="mcp_servers"&&a.inList&&l(),a.inList=!1,a.section=d[1];continue}if(a.section==="agents"||a.section==="mcp_servers"){let
|
|
166
|
-
`)){let n=t.match(/^name:\s*(.+)$/);if(n)return _(n[1])}return null}function Pt(s){let e=new Map,t=[];if(!Rn(s))return t.push(`Agents directory not found: ${s}`),{nodes:e,spawnOrder:[],cycles:[],warnings:t};let n=_n(s).filter(a=>a.startsWith("qe-")&&a.endsWith(".md"));for(let a of n){let o;try{o=In(Pn(s,a),"utf-8")}catch{t.push(`Failed to read agent file: ${a}`);continue}let l=On(o)||Hn(a,".md"),c=Fn(o),u=[],d=[],m=[];if(c?.agents)for(let h of c.agents)h.type==="hard"?u.push(h.name):h.type==="soft"?d.push(h.name):h.type==="peer"&&m.push(h.name);e.set(l,{agentName:l,hardDeps:u,softDeps:d,peerDeps:m,dependencies:c||{}})}let i=new Set(e.keys());for(let[a,o]of e)for(let l of o.hardDeps)i.has(l)||t.push(`Agent "${a}" declares hard dependency on "${l}" which is not in the agent directory`);let r=Nn(e);for(let a of r)t.push(`Dependency cycle detected: ${a.join(" -> ")}`);return{nodes:e,spawnOrder:Ln(e,r),cycles:r,warnings:t}}function Nn(s){let e=[],t=new Set,n=new Set,i=[];function r(a){t.add(a),n.add(a),i.push(a);let o=s.get(a);if(o){for(let l of o.hardDeps)if(!t.has(l)&&s.has(l))r(l);else if(n.has(l)){let c=i.indexOf(l);c!==-1&&e.push([...i.slice(c),l])}}i.pop(),n.delete(a)}for(let a of s.keys())t.has(a)||r(a);return e}function Ln(s,e){let t=new Set(e.flat()),n=[],i=new Set,r=new Set;function a(o){if(i.has(o)||t.has(o)||r.has(o))return;r.add(o);let l=s.get(o);if(l)for(let c of l.hardDeps)s.has(c)&&a(c);r.delete(o),i.add(o),n.push(o)}for(let o of s.keys())a(o);for(let o of t)n.includes(o)||n.push(o);return n}function Ht(s,e){let t=new Set(s),n=[],i=[];for(let l of s){let c=e.nodes.get(l);if(!c)continue;let u=c.hardDeps.filter(d=>!t.has(d));u.length>0&&(i.push({agent:l,missing:u}),n.push(`Advisory: "${l}" has unsatisfied hard dependencies: ${u.join(", ")}. Proceeding anyway.`))}let r=[],a=new Set,o=new Set(s);for(;o.size>0;){let l=[];for(let c of o){let u=e.nodes.get(c);if(!u){l.push(c);continue}u.hardDeps.filter(m=>t.has(m)).every(m=>a.has(m))&&l.push(c)}if(l.length===0){n.push(`Could not resolve dependency ordering for: ${[...o].join(", ")}. Placing in final phase.`),r.push([...o]);break}r.push(l);for(let c of l)a.add(c),o.delete(c);o=new Set([...o])}return{phases:r,unsatisfiedHardDeps:i,warnings:n}}var Re={defaultTtlMs:0,cleanupIntervalMs:6e4,maxMailboxSize:1e3};var F=class{mailboxes=new Map;messageHandlers=new Map;broadcastHandlers=new Map;domainAgents=new Map;createMailbox(e,t){let n=this.mailboxes.get(e);if(n)return this.toSnapshot(n);let i={agentId:e,domain:t,messages:[],unreadCount:0,lastRead:Date.now()};this.mailboxes.set(e,i);let r=this.domainAgents.get(t);return r||(r=new Set,this.domainAgents.set(t,r)),r.add(e),this.toSnapshot(i)}getMailbox(e){let t=this.mailboxes.get(e);if(t)return this.toSnapshot(t)}deleteMailbox(e){let t=this.mailboxes.get(e);if(!t)return!1;let n=this.domainAgents.get(t.domain);return n&&(n.delete(e),n.size===0&&this.domainAgents.delete(t.domain)),this.messageHandlers.delete(e),this.mailboxes.delete(e),!0}send(e){if(e.to==="broadcast"){this.broadcast(e.domain,e);return}let t=this.mailboxes.get(e.to);if(!t)throw new Error(`No mailbox found for agent '${e.to}'. Create a mailbox first with createMailbox().`);t.messages.push(e),t.unreadCount++;let n=this.messageHandlers.get(e.to);if(n)for(let i of n)try{i(e)}catch{}}broadcast(e,t){let n=this.domainAgents.get(e);if(!n)return;for(let r of n){if(r===t.from)continue;let a=this.mailboxes.get(r);if(a){a.messages.push(t),a.unreadCount++;let o=this.messageHandlers.get(r);if(o)for(let l of o)try{l(t)}catch{}}}let i=this.broadcastHandlers.get(e);if(i)for(let r of i)try{r(e,t)}catch{}}receive(e,t){let n=this.mailboxes.get(e);if(!n||n.unreadCount===0)return[];let i=Date.now(),r=n.messages.length-n.unreadCount,a=n.messages.slice(r);return a=a.filter(o=>!this.isExpired(o,i)),t?.type&&(a=a.filter(o=>o.type===t.type)),t?.since!==void 0&&(a=a.filter(o=>o.timestamp>=t.since)),t?.limit!==void 0&&t.limit>0&&(a=a.slice(0,t.limit)),n.unreadCount=0,n.lastRead=i,a}peek(e){let t=this.mailboxes.get(e);if(!t)return 0;let n=Date.now(),i=t.messages.length-t.unreadCount,r=0;for(let a=i;a<t.messages.length;a++)this.isExpired(t.messages[a],n)||r++;return r}cleanup(e){let t=Date.now(),n=t-e,i=0;for(let r of this.mailboxes.values()){let a=r.messages.length,o=r.messages.length-r.unreadCount;r.messages=r.messages.filter((c,u)=>!(c.timestamp<n||this.isExpired(c,t)));let l=a-r.messages.length;i+=l,l>0&&(r.unreadCount=r.messages.filter(c=>c.timestamp>r.lastRead).length)}return i}onMessage(e,t){let n=this.messageHandlers.get(e);return n||(n=[],this.messageHandlers.set(e,n)),n.push(t),()=>{let i=this.messageHandlers.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}onBroadcast(e,t){let n=this.broadcastHandlers.get(e);return n||(n=[],this.broadcastHandlers.set(e,n)),n.push(t),()=>{let i=this.broadcastHandlers.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}getAgentsInDomain(e){let t=this.domainAgents.get(e);return t?Array.from(t):[]}getDomains(){return Array.from(this.domainAgents.keys())}get size(){return this.mailboxes.size}clear(){this.mailboxes.clear(),this.messageHandlers.clear(),this.broadcastHandlers.clear(),this.domainAgents.clear()}isExpired(e,t){return!e.ttl||e.ttl<=0?!1:t>e.timestamp+e.ttl}toSnapshot(e){return{agentId:e.agentId,domain:e.domain,messages:[...e.messages],unreadCount:e.unreadCount,lastRead:e.lastRead}}};import{randomUUID as Ft}from"node:crypto";dt();import{randomUUID as Y}from"node:crypto";var Z=class{spans=new Map;traceIndex=new Map;maxSpans;constructor(e=1e4){this.maxSpans=e}startTrace(e){let t=Y(),n=Y(),i={traceId:t,spanId:n},r=this.createSpan(i,e);return{context:i,span:r}}startSpan(e){let t=e.parentContext,n=t?.traceId??Y(),i=Y(),r={traceId:n,spanId:i,parentSpanId:t?.spanId,baggage:t?.baggage},a=this.createSpan(r,e);return{context:r,span:a}}completeSpan(e){let t=this.spans.get(e);t&&(t.endTime=Date.now(),t.status="completed")}failSpan(e,t){let n=this.spans.get(e);n&&(n.endTime=Date.now(),n.status="error",n.errorMessage=t)}getTrace(e){let t=this.traceIndex.get(e);return t?Array.from(t).map(n=>this.spans.get(n)).filter(n=>n!==void 0).sort((n,i)=>n.startTime-i.startTime):[]}getSpan(e){return this.spans.get(e)}getActiveSpans(){return Array.from(this.spans.values()).filter(e=>e.status==="active")}getStats(){let e=new Set,t=new Set;for(let[n,i]of this.traceIndex)Array.from(i).map(a=>this.spans.get(a)).filter(a=>a!==void 0).some(a=>a.status==="active")?e.add(n):t.add(n);return{totalSpans:this.spans.size,activeTraces:e.size,completedTraces:t.size}}purge(e){let t=Date.now()-e,n=0;for(let[i,r]of this.traceIndex){let a=Array.from(r).map(c=>this.spans.get(c)).filter(c=>c!==void 0),o=a.every(c=>c.status!=="active"),l=a.every(c=>(c.endTime??c.startTime)<t);if(o&&l){for(let c of r)this.spans.delete(c),n++;this.traceIndex.delete(i)}}return n}dispose(){this.spans.clear(),this.traceIndex.clear()}createSpan(e,t){this.spans.size>=this.maxSpans&&this.purge(6e4);let n={traceId:e.traceId,spanId:e.spanId,parentSpanId:e.parentSpanId,operationName:t.operationName,agentId:t.agentId,domain:t.domain,startTime:Date.now(),tags:t.tags??{},status:"active"};this.spans.set(e.spanId,n);let i=this.traceIndex.get(e.traceId);return i||(i=new Set,this.traceIndex.set(e.traceId,i)),i.add(e.spanId),n}},Bn="trace:";function X(s){return`${Bn}${JSON.stringify({traceId:s.traceId,spanId:s.spanId,parentSpanId:s.parentSpanId})}`}function _e(s){return new Z(s)}var J=class{mailbox;config;teams=new Map;registeredAgents=new Set;agentDomains=new Map;subscriptions=new Map;cleanupTimer=null;initialized=!1;constructor(e,t){this.mailbox=e??new F,this.config={...Re,...t}}initialize(e){this.initialized||(e&&Object.assign(this.config,e),this.config.cleanupIntervalMs>0&&(this.cleanupTimer=setInterval(()=>{this.performCleanup()},this.config.cleanupIntervalMs)),this.initialized=!0)}shutdown(){this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null),this.mailbox.clear(),this.teams.clear(),this.registeredAgents.clear(),this.agentDomains.clear(),this.subscriptions.clear(),this.initialized=!1}createTeam(e){if(this.teams.has(e.domain))throw new Error(`Team already exists for domain '${e.domain}'. Use getTeamStatus() to inspect the existing team.`);let t={domain:e.domain,leadAgentId:e.leadAgentId,maxTeammates:e.maxTeammates,teammateIds:[...e.teammateIds],autoAssignEnabled:e.autoAssignEnabled};this.teams.set(e.domain,t),this.registerAgent(e.leadAgentId,e.domain);for(let n of e.teammateIds)this.registerAgent(n,e.domain)}getTeamStatus(e){let t=this.teams.get(e);if(!t)return;let n=[t.leadAgentId,...t.teammateIds],i=n.filter(a=>this.mailbox.peek(a)===0),r=0;for(let a of n)r+=this.mailbox.peek(a);return{domain:t.domain,leadAgentId:t.leadAgentId,teammateIds:[...t.teammateIds],activeAgentCount:n.filter(a=>this.registeredAgents.has(a)).length,idleAgentIds:i,totalUnreadMessages:r}}registerAgent(e,t){if(this.registeredAgents.has(e))return;this.registeredAgents.add(e),this.agentDomains.set(e,t),this.mailbox.createMailbox(e,t);let n=this.teams.get(t);n&&n.autoAssignEnabled&&e!==n.leadAgentId&&!n.teammateIds.includes(e)&&n.teammateIds.length<n.maxTeammates&&n.teammateIds.push(e)}unregisterAgent(e){if(!this.registeredAgents.has(e))return!1;let t=this.agentDomains.get(e);if(t){let n=this.teams.get(t);if(n){let i=n.teammateIds.indexOf(e);i>=0&&n.teammateIds.splice(i,1)}}return this.mailbox.deleteMailbox(e),this.subscriptions.delete(e),this.registeredAgents.delete(e),this.agentDomains.delete(e),!0}sendMessage(e,t,n,i,r){this.validateAgent(e,"sender"),this.validateAgent(t,"recipient");let a=this.agentDomains.get(e),o=r?.traceContext?X(r.traceContext):r?.correlationId,l={id:Ft(),from:e,to:t,domain:r?.domain??a,type:n,payload:i,timestamp:Date.now(),correlationId:o,replyTo:r?.replyTo,ttl:r?.ttl??(this.config.defaultTtlMs>0?this.config.defaultTtlMs:void 0)};return this.mailbox.send(l),this.notifySubscribers(t,l),l}broadcast(e,t,n,i){let r=i?.from??"__system__";r!=="__system__"&&this.validateAgent(r,"broadcast sender");let a=i?.traceContext?X(i.traceContext):i?.correlationId,o={id:Ft(),from:r,to:"broadcast",domain:e,type:t,payload:n,timestamp:Date.now(),correlationId:a,ttl:i?.ttl??(this.config.defaultTtlMs>0?this.config.defaultTtlMs:void 0)};this.mailbox.broadcast(e,o);let l=this.mailbox.getAgentsInDomain(e);for(let c of l)c!==r&&this.notifySubscribers(c,o);return o}onMessage(e,t){this.validateAgent(e,"subscription target");let n=this.subscriptions.get(e);return n||(n=[],this.subscriptions.set(e,n)),n.push(t),()=>{let i=this.subscriptions.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}getIdleAgents(e){let t=[],n=e?this.mailbox.getAgentsInDomain(e):Array.from(this.registeredAgents);for(let i of n)this.mailbox.peek(i)===0&&t.push(i);return t}isRegistered(e){return this.registeredAgents.has(e)}getAgentDomain(e){return this.agentDomains.get(e)}getRegisteredAgents(){return Array.from(this.registeredAgents)}getUnreadCount(e){return this.mailbox.peek(e)}receiveMessages(e){return this.mailbox.receive(e)}getMailboxService(){return this.mailbox}validateAgent(e,t){if(!this.registeredAgents.has(e))throw new Error(`Unknown ${t} '${e}'. Register the agent first with registerAgent() or createTeam().`)}notifySubscribers(e,t){let n=this.subscriptions.get(e);if(!(!n||n.length===0))for(let i of n)try{i(t)}catch{}}performCleanup(){let e=this.config.defaultTtlMs>0?this.config.defaultTtlMs*10:this.config.cleanupIntervalMs*60;this.mailbox.cleanup(e)}};function Pe(s){return new J(void 0,s)}var Ot={maxActiveTeams:13,defaultTeamSize:3,autoScaleEnabled:!1,scaleUpThreshold:10,scaleDownIdleMs:6e4},ee=class s{static SYSTEM_AGENT_ID="__dtm_system__";static SYSTEM_DOMAIN="__system__";adapter;config;teams=new Map;systemAgentRegistered=!1;constructor(e,t){this.adapter=e,this.config={...Ot,...t}}createDomainTeam(e,t,n){if(this.teams.has(e))throw new Error(`Domain team already exists for '${e}'. Use getDomainTeam() to inspect the existing team.`);if(this.teams.size>=this.config.maxActiveTeams)throw new Error(`Maximum active teams (${this.config.maxActiveTeams}) reached. Remove an existing team before creating a new one.`);let i=n?[...n]:[],r=this.getMaxTeamSize(e);i.length+1>r&&(i.length=r-1);let a=Date.now(),o={domain:e,leadAgentId:t,teammateIds:i,createdAt:a,taskCount:0,completedCount:0,lastActivity:new Map};o.lastActivity.set(t,a);for(let c of i)o.lastActivity.set(c,a);this.teams.set(e,o);let l={domain:e,leadAgentId:t,maxTeammates:r-1,teammateIds:i,autoAssignEnabled:!1};return this.adapter.createTeam(l),this.toSnapshot(o)}removeDomainTeam(e){let t=this.teams.get(e);if(!t)return!1;for(let n of[t.leadAgentId,...t.teammateIds])this.adapter.unregisterAgent(n);return this.teams.delete(e),!0}getDomainTeam(e){let t=this.teams.get(e);return t?this.toSnapshot(t):void 0}addTeammate(e,t){let n=this.teams.get(e);if(!n||t===n.leadAgentId||n.teammateIds.includes(t))return!1;let i=this.getMaxTeamSize(e);return 1+n.teammateIds.length>=i?!1:(n.teammateIds.push(t),n.lastActivity.set(t,Date.now()),this.adapter.registerAgent(t,e),!0)}listDomainTeams(){return Array.from(this.teams.values(),e=>this.toSnapshot(e))}assignTaskToTeam(e,t,n){let i=this.teams.get(e);return i?(this.ensureSystemAgent(),this.adapter.sendMessage(s.SYSTEM_AGENT_ID,i.leadAgentId,"task-assignment",{taskId:t,payload:n},{domain:e}),i.taskCount++,i.lastActivity.set(i.leadAgentId,Date.now()),!0):!1}broadcastToDomain(e,t,n){let i=this.teams.get(e);if(!i)throw new Error(`No domain team found for '${e}'. Create a team first with createDomainTeam().`);this.adapter.broadcast(e,t,n,{from:"__system__"});let r=Date.now();i.lastActivity.set(i.leadAgentId,r);for(let a of i.teammateIds)i.lastActivity.set(a,r)}getTeamHealth(e){let t=this.teams.get(e);if(!t)return;let n=[t.leadAgentId,...t.teammateIds],i=n.length,r=0,a=0,o=0;for(let c of n)if(this.adapter.isRegistered(c)){r++;let u=this.adapter.getUnreadCount(c);o+=u,u===0&&a++}let l=t.taskCount-t.completedCount;return{domain:e,teamSize:i,activeAgents:r,idleAgents:a,pendingMessages:o,tasksPending:l,tasksCompleted:t.completedCount,healthy:r>0&&r===i&&l<this.config.scaleUpThreshold*2}}scaleTeam(e,t){let n=this.teams.get(e);if(!n)throw new Error(`No domain team found for '${e}'. Create a team first with createDomainTeam().`);let i=Math.max(this.getMaxTeamSize(e),t,this.config.maxActiveTeams),r=Math.max(1,Math.min(t,i)),a=1+n.teammateIds.length,o=[],l=[];if(r>a){let c=r-a;for(let u=0;u<c;u++){let d=`${e}-teammate-${Date.now()}-${u}`;n.teammateIds.push(d),n.lastActivity.set(d,Date.now()),this.adapter.registerAgent(d,e),o.push(d)}}else if(r<a){let c=a-r;for(let u=0;u<c;u++){let d=n.teammateIds.pop();d&&(n.lastActivity.delete(d),this.adapter.unregisterAgent(d),l.push(d))}}return{domain:e,previousSize:a,newSize:1+n.teammateIds.length,addedAgents:o,removedAgents:l}}getIdleTeammates(e){if(e){let n=this.teams.get(e);return n?this.getIdleAgentsForTeam(n):[]}let t=[];for(let n of this.teams.values())t.push(...this.getIdleAgentsForTeam(n));return t}rebalance(){let e=[],t=new Set,n=Array.from(this.teams.values(),a=>{let o=this.getTargetTeamSize(a.domain),l=1+a.teammateIds.length,c=this.getIdleAgentsForTeam(a).filter(u=>u!==a.leadAgentId);return{domain:a.domain,team:a,currentSize:l,targetSize:o,idleTeammates:c}}),i=n.filter(a=>a.currentSize>a.targetSize&&a.idleTeammates.length>0).sort((a,o)=>o.currentSize-o.targetSize-(a.currentSize-a.targetSize)),r=n.filter(a=>a.currentSize<a.targetSize).sort((a,o)=>a.currentSize-a.targetSize-(o.currentSize-o.targetSize));for(let a of i)for(let o of r){if(o.currentSize>=o.targetSize)continue;if(a.idleTeammates.length===0)break;if(o.currentSize>=this.getMaxTeamSize(o.domain))continue;let l=a.idleTeammates.shift(),c=a.team.teammateIds.indexOf(l);c>=0&&a.team.teammateIds.splice(c,1),a.team.lastActivity.delete(l),a.currentSize--,this.adapter.unregisterAgent(l),this.adapter.registerAgent(l,o.domain),o.team.teammateIds.push(l),o.team.lastActivity.set(l,Date.now()),o.currentSize++,e.push({agentId:l,fromDomain:a.domain,toDomain:o.domain}),t.add(a.domain),t.add(o.domain)}return{moves:e,teamsAffected:t.size}}dispose(){for(let e of this.teams.values())for(let t of[e.leadAgentId,...e.teammateIds])this.adapter.unregisterAgent(t);this.teams.clear(),this.systemAgentRegistered&&(this.adapter.unregisterAgent(s.SYSTEM_AGENT_ID),this.systemAgentRegistered=!1)}markTaskCompleted(e){let t=this.teams.get(e);return t?(t.completedCount<t.taskCount&&t.completedCount++,!0):!1}ensureSystemAgent(){this.systemAgentRegistered||(this.adapter.registerAgent(s.SYSTEM_AGENT_ID,s.SYSTEM_DOMAIN),this.systemAgentRegistered=!0)}getMaxTeamSize(e){return this.config.domainTeamSizes&&e in this.config.domainTeamSizes?this.config.domainTeamSizes[e]:this.config.defaultTeamSize}getTargetTeamSize(e){return this.getMaxTeamSize(e)}getIdleAgentsForTeam(e){let t=[];for(let n of[e.leadAgentId,...e.teammateIds])this.adapter.isRegistered(n)&&this.adapter.getUnreadCount(n)===0&&t.push(n);return t}toSnapshot(e){return{domain:e.domain,leadAgentId:e.leadAgentId,teammateIds:[...e.teammateIds],createdAt:e.createdAt,taskCount:e.taskCount,completedCount:e.completedCount}}};function He(s,e){return new ee(s,e)}k();var ne={failureThreshold:3,resetTimeoutMs:6e4,halfOpenSuccessThreshold:2,failureWindowMs:12e4,cascadeEnabled:!1,cascadeTargets:void 0},te=class extends Error{domain;retryAfterMs;constructor(e,t){let n=t!=null?` (retry after ${t}ms)`:"";super(`Circuit breaker is open for domain '${e}'${n}`),this.name="DomainCircuitOpenError",this.domain=e,this.retryAfterMs=t}},D=class{state="closed";failures=[];totalRequests=0;totalSuccesses=0;totalFailures=0;rejectedCount=0;lastFailureTime;lastSuccessTime;openedAt;halfOpenSuccesses=0;config;stateChangeHandlers=new Set;domain;constructor(e,t){this.domain=e,this.config={...ne,...t}}canExecute(){let e=this.getState();return e==="closed"?!0:e!=="open"}async execute(e){if(this.totalRequests++,this.getState()==="open")throw this.rejectedCount++,this.emitEvent({type:"request-rejected",domain:this.domain,timestamp:Date.now(),metadata:{retryAfterMs:this.getTimeUntilTransition()}}),new te(this.domain,this.getTimeUntilTransition());try{let n=await e();return this.recordSuccess(),n}catch(n){throw this.recordFailure(lt(n)),n}}recordSuccess(){this.totalSuccesses++,this.lastSuccessTime=Date.now(),this.getState()==="half-open"&&(this.halfOpenSuccesses++,console.log(`[DomainCircuitBreaker:${this.domain}] Half-open success ${this.halfOpenSuccesses}/${this.config.halfOpenSuccessThreshold}`),this.halfOpenSuccesses>=this.config.halfOpenSuccessThreshold&&this.transitionTo("closed"))}recordFailure(e){this.totalFailures++,this.lastFailureTime=Date.now(),this.failures.push({timestamp:Date.now(),message:e.message}),this.cleanOldFailures();let t=this.getState();if(t==="half-open"){console.log(`[DomainCircuitBreaker:${this.domain}] Failure in half-open state, re-opening`),this.transitionTo("open");return}t==="closed"&&this.failures.length>=this.config.failureThreshold&&(console.log(`[DomainCircuitBreaker:${this.domain}] Failure threshold reached (${this.failures.length}/${this.config.failureThreshold}), opening circuit`),this.transitionTo("open"))}getState(){return this.state==="open"&&this.openedAt!=null&&Date.now()-this.openedAt>=this.config.resetTimeoutMs&&this.transitionTo("half-open"),this.state}getStats(){let e=this.getState();return{domain:this.domain,state:e,totalRequests:this.totalRequests,successCount:this.totalSuccesses,failureCount:this.totalFailures,rejectedCount:this.rejectedCount,lastFailureTime:this.lastFailureTime,lastSuccessTime:this.lastSuccessTime,openedAt:this.openedAt,timeUntilHalfOpen:e==="open"?this.getTimeUntilTransition():void 0,consecutiveSuccesses:this.halfOpenSuccesses}}reset(){let e=this.state;this.state="closed",this.failures=[],this.halfOpenSuccesses=0,this.openedAt=void 0,e!=="closed"&&(console.log(`[DomainCircuitBreaker:${this.domain}] Manually reset from '${e}' to 'closed'`),this.emitEvent({type:"state-change",domain:this.domain,previousState:e,newState:"closed",timestamp:Date.now(),metadata:{trigger:"manual-reset"}}))}forceOpen(){console.log(`[DomainCircuitBreaker:${this.domain}] Force-opening circuit`),this.transitionTo("open")}getRecentFailures(e=5){return this.failures.slice(-e).map(t=>`[${new Date(t.timestamp).toISOString()}] ${t.message}`)}onStateChange(e){return this.stateChangeHandlers.add(e),()=>{this.stateChangeHandlers.delete(e)}}getConfig(){return this.config}transitionTo(e){let t=this.state;if(t!==e){switch(this.state=e,e){case"open":this.openedAt=Date.now(),this.halfOpenSuccesses=0;break;case"half-open":this.halfOpenSuccesses=0,console.log(`[DomainCircuitBreaker:${this.domain}] Transitioning to half-open, allowing probe requests`);break;case"closed":this.failures=[],this.openedAt=void 0,this.halfOpenSuccesses=0,console.log(`[DomainCircuitBreaker:${this.domain}] Circuit closed, domain is healthy`);break}this.emitEvent({type:"state-change",domain:this.domain,previousState:t,newState:e,timestamp:Date.now()})}}cleanOldFailures(){let e=Date.now()-this.config.failureWindowMs;this.failures=this.failures.filter(t=>t.timestamp>e)}getTimeUntilTransition(){if(this.state==="open"&&this.openedAt!=null){let e=Date.now()-this.openedAt,t=this.config.resetTimeoutMs-e;return Math.max(0,t)}}emitEvent(e){for(let t of this.stateChangeHandlers)try{t(e)}catch(n){console.log(`[DomainCircuitBreaker:${this.domain}] State change handler error: ${p(n)}`)}}};k();var Fe={critical:{failureThreshold:2,resetTimeoutMs:3e4,halfOpenSuccessThreshold:2,failureWindowMs:6e4,cascadeEnabled:!1,cascadeTargets:void 0},standard:{failureThreshold:3,resetTimeoutMs:6e4,halfOpenSuccessThreshold:2,failureWindowMs:12e4,cascadeEnabled:!1,cascadeTargets:void 0},lenient:{failureThreshold:5,resetTimeoutMs:12e4,halfOpenSuccessThreshold:3,failureWindowMs:3e5,cascadeEnabled:!1,cascadeTargets:void 0}},Nt={"test-generation":"critical","test-execution":"critical","coverage-analysis":"critical","quality-assessment":"critical","security-compliance":"critical","defect-intelligence":"standard","requirements-validation":"standard","code-intelligence":"standard","contract-testing":"standard","visual-accessibility":"lenient","chaos-resilience":"lenient","learning-optimization":"lenient","enterprise-integration":"standard"},O=class{breakers=new Map;defaultConfig;globalHandlers=new Set;constructor(e){this.defaultConfig={...ne,...e}}getBreaker(e){let t=this.breakers.get(e);if(!t){let n=Nt[e],i=n?{...this.defaultConfig,...Fe[n]}:this.defaultConfig;t=new D(e,i),this.breakers.set(e,t),t.onStateChange(r=>this.handleBreakerEvent(r)),console.log(`[DomainBreakerRegistry] Created breaker for '${e}' (criticality: ${n??"default"})`)}return t}configureBreaker(e,t){let n={...this.defaultConfig,...t},i=new D(e,n);i.onStateChange(r=>this.handleBreakerEvent(r)),this.breakers.set(e,i),console.log(`[DomainBreakerRegistry] Reconfigured breaker for '${e}'`)}configureCriticality(e,t){let n=Fe[t];this.configureBreaker(e,n),console.log(`[DomainBreakerRegistry] Set '${e}' criticality to '${t}'`)}canExecuteInDomain(e){return this.getBreaker(e).canExecute()}async executeInDomain(e,t){return this.getBreaker(e).execute(t)}getAllStats(){let e=new Map;for(let[t,n]of this.breakers)e.set(t,n.getStats());return e}getOpenDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="open"&&e.push(t);return e}getHealthyDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="closed"&&e.push(t);return e}getDegradedDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="half-open"&&e.push(t);return e}getHealthSummary(){let e=0,t=0,n=0;for(let i of this.breakers.values())switch(i.getState()){case"closed":e++;break;case"half-open":t++;break;case"open":n++;break}return{healthy:e,degraded:t,open:n,total:this.breakers.size}}resetAll(){for(let e of this.breakers.values())e.reset();console.log(`[DomainBreakerRegistry] Reset all ${this.breakers.size} breakers`)}reset(e){let t=this.breakers.get(e);t&&t.reset()}onAnyStateChange(e){return this.globalHandlers.add(e),()=>{this.globalHandlers.delete(e)}}handleBreakerEvent(e){for(let t of this.globalHandlers)try{t(e)}catch(n){console.log(`[DomainBreakerRegistry] Global handler error: ${p(n)}`)}e.type==="state-change"&&e.newState==="open"&&this.propagateCascade(e.domain)}propagateCascade(e){let t=this.breakers.get(e);if(!t)return;let n=t.getConfig();if(!(!n.cascadeEnabled||!n.cascadeTargets?.length))for(let i of n.cascadeTargets){if(i===e)continue;let r=this.getBreaker(i);if(r.getState()!=="open"){console.log(`[DomainBreakerRegistry] Cascading open from '${e}' to '${i}'`),r.forceOpen();let o={type:"cascade-triggered",domain:i,timestamp:Date.now(),metadata:{sourceDomain:e,cascadedFrom:e}};for(let l of this.globalHandlers)try{l(o)}catch(c){console.log(`[DomainBreakerRegistry] Cascade event handler error: ${p(c)}`)}}}}};function Lt(s){return new O(s)}var A=["smoke","standard","deep","crisis"];var N=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization","enterprise-integration"],ie=["test-generation","coverage-analysis","quality-assessment"],Oe={"test-generation":["generator","specialist"],"test-execution":["tester","coordinator"],"coverage-analysis":["analyzer","specialist"],"quality-assessment":["analyzer","validator"],"defect-intelligence":["analyzer","specialist"],"requirements-validation":["validator","reviewer"],"code-intelligence":["analyzer","specialist"],"security-compliance":["analyzer","validator"],"contract-testing":["tester","validator"],"visual-accessibility":["tester","validator"],"chaos-resilience":["tester","specialist"],"learning-optimization":["optimizer","specialist"],"enterprise-integration":["coordinator","validator"]},Qn={tier:"smoke",maxAgents:3,agentTeamsEnabled:!1,domains:["test-execution","quality-assessment"],estimatedCost:"minimal",description:"Lightweight smoke test on every commit. Runs core test execution and quality assessment with minimal agent count to catch obvious regressions quickly.",triggers:[{type:"commit"},{type:"schedule",conditions:{interval:"hourly"}}]},$n={tier:"standard",maxAgents:7,agentTeamsEnabled:!1,domains:["test-generation","test-execution","coverage-analysis","quality-assessment","security-compliance"],estimatedCost:"moderate",description:"Standard validation for pull requests. Covers test generation, execution, coverage, quality, and security across up to 7 agents. Agent teams are optional.",triggers:[{type:"pr"},{type:"manual"}]},Un={tier:"deep",maxAgents:15,agentTeamsEnabled:!0,domains:[...N],estimatedCost:"high",description:"Deep validation for pre-release and critical path changes. Activates all 13 domains with up to 15 agents and full agent team collaboration.",triggers:[{type:"release"},{type:"pr",conditions:{criticalPath:!0}},{type:"manual",conditions:{requestedTier:"deep"}}]},Gn={tier:"crisis",maxAgents:15,agentTeamsEnabled:!0,domains:[...N],estimatedCost:"unlimited",description:"Crisis response for production incidents. All domains active with competing hypotheses enabled. Unlimited cost budget to resolve incidents as fast as possible.",triggers:[{type:"incident"},{type:"manual",conditions:{requestedTier:"crisis"}}]},Ne={smoke:Qn,standard:$n,deep:Un,crisis:Gn};var zn=["password","secret","token","crypto","auth","credential","jwt","oauth"],qn=["async","await","Promise","setTimeout","setInterval","Worker","mutex","lock"],jn={securityKeywords:zn,concurrencyKeywords:qn,enableDimensionOverrides:!1};function Wn(s,e){let t=s+e;return t<=8?"trivial":t<=20?"simple":t<=40?"moderate":t<=70?"complex":"critical"}var L=class{config;constructor(e){this.config={...jn,...e}}analyzeExtendedDimensions(e){let t=e.split(`
|
|
167
|
-
`),n=Math.max(t.length,1),i=this.countKeywordLines(t,this.config.securityKeywords),r=re(i/n,0,1),a=this.countKeywordLines(t,this.config.concurrencyKeywords),o=re(a/n,0,1),l=this.countPatternMatches(e,/\.(map|filter|reduce|flatMap|forEach)\s*\(/g),c=re(l/n,0,1),u=this.countPatternMatches(e,/^export\s/gm),d=Math.max(this.countPatternMatches(e,/^(export\s+)?(const|let|var|function|class|interface|type|enum)\s/gm),1),m=re(u/d,0,1);return{securitySurface:r,concurrency:o,dataFlow:c,apiSurface:m}}compose(e,t,n){let i=Wn(e.cyclomatic,e.cognitive),r=this.analyzeExtendedDimensions(n),a=[],o=[],l;switch(i){case"trivial":case"simple":a.push({agentType:"qe-test-generator",priority:1,reason:`${i} complexity \u2014 basic test generation sufficient`}),o.push("unit"),l="haiku";break;case"moderate":a.push({agentType:"qe-test-generator",priority:1,reason:"Moderate complexity requires thorough test generation"},{agentType:"qe-code-intelligence",priority:2,reason:"Moderate complexity benefits from code intelligence analysis"}),o.push("unit","integration"),l="sonnet";break;case"complex":a.push({agentType:"qe-test-generator",priority:1,reason:"Complex code needs comprehensive test generation"},{agentType:"qe-security-scanner",priority:2,reason:"High complexity warrants security analysis"},{agentType:"qe-code-intelligence",priority:2,reason:"Complex code requires deep code intelligence"}),o.push("unit","integration","security"),l="sonnet";break;case"critical":a.push({agentType:"qe-test-generator",priority:1,reason:"Critical complexity demands full test generation"},{agentType:"qe-security-scanner",priority:1,reason:"Critical complexity mandates security scanning"},{agentType:"qe-code-intelligence",priority:1,reason:"Critical complexity requires deep analysis"},{agentType:"qe-chaos-resilience",priority:2,reason:"Critical systems need chaos/resilience testing"},{agentType:"qe-performance",priority:2,reason:"Critical complexity warrants performance analysis"}),o.push("unit","integration","security","chaos","performance"),l="opus";break}return r.securitySurface>.3&&(a.some(c=>c.agentType==="qe-security-scanner")||a.push({agentType:"qe-security-scanner",priority:2,reason:`High security surface (${(r.securitySurface*100).toFixed(0)}%) \u2014 security scanning recommended`}),o.includes("security")||o.push("security")),r.concurrency>.3&&(a.some(c=>c.agentType==="qe-chaos-resilience")||a.push({agentType:"qe-chaos-resilience",priority:2,reason:`High concurrency (${(r.concurrency*100).toFixed(0)}%) \u2014 chaos/resilience testing recommended`}),o.includes("chaos")||o.push("chaos")),r.apiSurface>.5&&(o.includes("integration")||o.push("integration")),a.sort((c,u)=>c.priority-u.priority),{agents:a,testTypes:o,recommendedTier:l,complexityCategory:i}}countKeywordLines(e,t){let n=0;for(let i of e)for(let r of t)if(i.includes(r)){n++;break}return n}countPatternMatches(e,t){let n=e.match(t);return n?n.length:0}};function re(s,e,t){return Math.max(e,Math.min(t,s))}var Bt=200,Qt=10,$t=3,ae=class{configs;history=[];escalationCount=0;deescalationCount=0;constructor(e){this.configs={...Ne,...e}}selectTier(e){let t,n;if(e.manualOverride)return t=e.manualOverride,n=`Manual override to "${t}" tier`,this.buildResult(t,n,e);if(e.trigger==="incident"||e.isHotfix)return t="crisis",n=e.isHotfix?"Hotfix deployment triggers crisis-level validation":"Production incident triggers crisis-level response",this.buildResult(t,n,e);if(e.trigger==="release")return t="deep",n="Pre-release validation requires deep tier across all domains",this.buildResult(t,n,e);if(e.trigger==="pr"){let i=e.changedFiles!==void 0&&e.changedFiles>Qt,r=e.affectedDomains!==void 0&&e.affectedDomains.length>$t;if(i||r){t="deep";let a=[];return i&&a.push(`>${Qt} changed files (${e.changedFiles})`),r&&a.push(`>${$t} affected domains (${e.affectedDomains.length})`),n=`PR escalated to deep tier: ${a.join(" and ")}`,this.buildResult(t,n,e)}return t="standard",n="Pull request triggers standard tier validation",this.buildResult(t,n,e)}return t="smoke",n=e.trigger==="commit"?"Commit triggers lightweight smoke validation":`Trigger "${e.trigger}" defaults to smoke tier`,this.buildResult(t,n,e)}allocateAgents(e,t){let n=this.resolveTargetDomains(e,t);if(n.length===0)return[];let i=e.maxAgents;return n.length>=i?this.allocateWithPriority(n,i):this.allocateWithSurplus(n,i)}escalate(e,t){let n=A.indexOf(e),i=Math.min(n+1,A.length-1),r=A[i],a=e!==r,o=a?`Escalated from "${e}" to "${r}": ${t}`:`Already at maximum tier "${e}", cannot escalate further`;return a&&this.escalationCount++,this.buildResult(r,o,{trigger:"manual"})}deescalate(e){let t=A.indexOf(e),n=Math.max(t-1,0),i=A[n],r=e!==i,a=r?`De-escalated from "${e}" to "${i}"`:`Already at minimum tier "${e}", cannot de-escalate further`;return r&&this.deescalationCount++,this.buildResult(i,a,{trigger:"manual"})}getStats(){let e={smoke:0,standard:0,deep:0,crisis:0};for(let t of this.history)e[t.tier]++;return{totalSelections:this.history.length,selectionsByTier:e,escalationCount:this.escalationCount,deescalationCount:this.deescalationCount,recentSelections:[...this.history].slice(-20)}}_teamComposer;setTeamComposer(e){this._teamComposer=e}selectTierWithComposition(e,t,n){let i=this.selectTier(e);if(!t||!n)return{...i,composition:void 0};let a=(this._teamComposer??new L).compose(t,i.selectedTier,n);return{...i,composition:a}}buildResult(e,t,n){let i=this.configs[e],r=this.allocateAgents(i,n.affectedDomains),a={tier:e,reason:t,timestamp:Date.now(),trigger:n.trigger};return this.history.push(a),this.history.length>Bt&&this.history.splice(0,this.history.length-Bt),{selectedTier:e,config:i,reason:t,agentAllocation:r}}resolveTargetDomains(e,t){let n=e.domains.includes("all")?N:e.domains;if(!t||t.length===0)return[...n];let i=new Set(n),r=t.filter(a=>i.has(a));return r.length>0?r:[...n]}allocateWithPriority(e,t){let n=new Set(ie),i=[],r=t,a=e.filter(l=>n.has(l)),o=e.filter(l=>!n.has(l));for(let l of a){if(r<=0)break;i.push(this.createAllocation(l,1)),r--}for(let l of o){if(r<=0)break;i.push(this.createAllocation(l,1)),r--}return i}allocateWithSurplus(e,t){let n=new Set(ie),i=new Map;for(let u of e)i.set(u,1);let r=t-e.length,a=e.filter(u=>n.has(u)),o=e.filter(u=>!n.has(u)),l=0;for(;r>0&&a.length>0;){let u=a[l%a.length];if(i.set(u,(i.get(u)??0)+1),r--,l++,l>=a.length*2)break}let c=0;for(;r>0&&o.length>0;){let u=o[c%o.length];i.set(u,(i.get(u)??0)+1),r--,c++}for(;r>0&&a.length>0;){let u=a[l%a.length];i.set(u,(i.get(u)??0)+1),r--,l++}return e.map(u=>this.createAllocation(u,i.get(u)??1))}createAllocation(e,t){let n=Oe[e]??["specialist"];return{domain:e,agentCount:t,agentTypes:[...n]}}};function Le(s){return new ae(s)}k();var oe={enabled:!0,minQualityScore:.6,rejectOnFailure:!0,gates:[{name:"test-pass-rate",type:"test-pass-rate",threshold:.8,weight:.35,required:!0},{name:"coverage",type:"coverage",threshold:0,weight:.25,required:!1},{name:"security",type:"security",threshold:0,weight:.25,required:!0},{name:"performance",type:"performance",threshold:3e4,weight:.15,required:!1}]},se=class{config;constructor(e={}){this.config={...oe,...e},e.gates&&(this.config={...this.config,gates:e.gates})}evaluate(e){if(!this.config.enabled)return console.log("[QualityGateEnforcer] Gates disabled, auto-passing"),{passed:!0,score:1,exitCode:0,gates:[],reason:"Quality gates disabled"};if(e.status==="failed")return console.log(`[QualityGateEnforcer] Task ${e.taskId} has failed status`),{passed:!1,score:0,exitCode:this.config.rejectOnFailure?2:0,gates:[],reason:"Task reported failed status"};let t=[],n=[];for(let d of this.config.gates){let m=this.checkGate(d,e);t.push(m),!m.passed&&d.required&&n.push(d.name)}let i=this.config.gates.reduce((d,m)=>d+m.weight,0),r=i>0?t.reduce((d,m)=>{let h=this.config.gates.find(U=>U.name===m.gate);if(!h)return d;let b=m.passed?1:this.computePartialScore(m);return d+b*(h.weight/i)},0):1,a=n.length>0,o=r<this.config.minQualityScore,l=!a&&!o,c;if(!l){let d=[];a&&d.push(`Required gates failed: ${n.join(", ")}`),o&&d.push(`Score ${r.toFixed(3)} below minimum ${this.config.minQualityScore}`),c=d.join("; ")}let u=!l&&this.config.rejectOnFailure?2:0;return console.log(`[QualityGateEnforcer] Task ${e.taskId}: ${l?"PASSED":"FAILED"} (score=${r.toFixed(3)}, gates=${t.filter(d=>d.passed).length}/${t.length})`),{passed:l,score:r,exitCode:u,gates:t,reason:c}}getConfig(){return{...this.config}}checkGate(e,t){let n=this.extractMetricForGate(e,t),i=this.meetsThreshold(e,n);return{gate:e.name,passed:i,actual:n,threshold:e.threshold,weight:e.weight}}extractMetricForGate(e,t){let n=t.metrics;switch(e.type){case"coverage":return n.coverageChange??0;case"test-pass-rate":{let i=n.testsPassed??0,r=n.testsFailed??0,a=i+r;return a>0?i/a:1}case"security":return n.securityIssues??0;case"performance":return n.performanceMs??t.duration;case"custom":{let i=t.output[e.name];return typeof i=="number"?i:0}default:return 0}}meetsThreshold(e,t){switch(e.type){case"security":return t<=e.threshold;case"performance":return t<=e.threshold;default:return t>=e.threshold}}computePartialScore(e){let t=this.config.gates.find(n=>n.name===e.gate);if(!t)return 0;switch(t.type){case"security":case"performance":{if(t.threshold===0)return 0;let n=t.threshold/e.actual;return Math.max(0,Math.min(1,n))}default:{if(t.threshold===0)return 1;let n=e.actual/t.threshold;return Math.max(0,Math.min(1,n))}}}};var Vn={trainPatterns:!0,qualityGate:oe,patternDomains:["test-generation","coverage-analysis","security-compliance","quality-assessment","defect-intelligence","contract-testing"],emitEvents:!0,maxPatternsPerTask:5},Kn={"test-generation":{types:["test-template","assertion-pattern","mock-pattern"],contentKeys:["testCode","template","assertions","mocks"],baseConfidence:.6},"coverage-analysis":{types:["coverage-strategy","mutation-strategy"],contentKeys:["coverageReport","gaps","strategy","recommendations"],baseConfidence:.55},"security-compliance":{types:["security-pattern","vulnerability-fix"],contentKeys:["findings","fixes","recommendations","rules"],baseConfidence:.5},"quality-assessment":{types:["quality-rule","threshold-pattern"],contentKeys:["rules","thresholds","assessments"],baseConfidence:.5},"defect-intelligence":{types:["defect-pattern","root-cause"],contentKeys:["rootCause","pattern","prediction","analysis"],baseConfidence:.45},"contract-testing":{types:["api-contract","schema-pattern"],contentKeys:["contract","schema","endpoints","violations"],baseConfidence:.55},"test-execution":{types:["flaky-fix","retry-strategy"],contentKeys:["flakyTests","retryPolicy","stabilization"],baseConfidence:.5},"visual-accessibility":{types:["visual-baseline","a11y-check"],contentKeys:["baseline","violations","wcagResults"],baseConfidence:.5},"chaos-resilience":{types:["perf-benchmark","resilience-pattern"],contentKeys:["benchmark","faultInjection","recoveryTime"],baseConfidence:.45}},le=class{config;gateEnforcer;patternStore;completionHandlers=new Set;stats={totalProcessed:0,accepted:0,rejected:0,patternsExtracted:0};constructor(e={},t){this.config={...Vn,...e},e.qualityGate&&(this.config={...this.config,qualityGate:{...oe,...e.qualityGate}}),this.gateEnforcer=new se(this.config.qualityGate),this.patternStore=t??null}async onTaskCompleted(e){this.stats.totalProcessed++,console.log(`[TaskCompletedHook] Processing task ${e.taskId} (agent=${e.agentId}, domain=${e.domain}, status=${e.status})`);let t=this.gateEnforcer.evaluate(e);if(!t.passed&&this.config.qualityGate.rejectOnFailure){this.stats.rejected++;let r={action:"reject",exitCode:2,reason:t.reason||"Quality gate check failed",gateResult:t};return console.log(`[TaskCompletedHook] Task ${e.taskId} REJECTED: ${r.reason}`),this.emitCompletion(e.taskId,r),r}let n=0;if(this.config.trainPatterns&&this.patternStore){let r=this.extractPatterns(e);n=await this.storePatterns(r,e),this.stats.patternsExtracted+=n}this.stats.accepted++;let i={action:"accept",patternsExtracted:n};return console.log(`[TaskCompletedHook] Task ${e.taskId} ACCEPTED (score=${t.score.toFixed(3)}, patterns=${n})`),this.emitCompletion(e.taskId,i),i}extractPatterns(e){let t=[],n=e.domain;if(!this.config.patternDomains.includes(n))return t;let i=Kn[n];if(!i)return this.extractGenericPatterns(e);let r=this.computeConfidenceBoost(e.metrics);for(let a of i.types){if(t.length>=this.config.maxPatternsPerTask)break;for(let o of i.contentKeys){if(t.length>=this.config.maxPatternsPerTask)break;let l=e.output[o];if(l==null)continue;let c=typeof l=="string"?l:JSON.stringify(l);if(c.length<10)continue;let u=Math.min(1,i.baseConfidence+r);t.push({domain:n,type:a,content:c,confidence:u,metadata:{sourceTaskId:e.taskId,sourceAgent:e.agentId,taskType:e.type,duration:e.duration,extractedFrom:o,timestamp:e.timestamp}})}}return t}onCompletion(e){this.completionHandlers.add(e)}offCompletion(e){this.completionHandlers.delete(e)}getStats(){return{...this.stats}}resetStats(){this.stats={totalProcessed:0,accepted:0,rejected:0,patternsExtracted:0}}async storePatterns(e,t){if(!this.patternStore||e.length===0)return 0;let n=0;for(let i of e)try{let r=await this.patternStore.store(i),a=t.status==="completed";await this.patternStore.recordOutcome(r,a),n++}catch(r){console.error(`[TaskCompletedHook] Failed to store pattern: ${p(r)}`)}return n>0&&console.log(`[TaskCompletedHook] Stored ${n}/${e.length} patterns from task ${t.taskId}`),n}extractGenericPatterns(e){let t=[];for(let[n,i]of Object.entries(e.output)){if(t.length>=this.config.maxPatternsPerTask)break;if(i==null)continue;let r=typeof i=="string"?i:JSON.stringify(i);r.length<10||t.push({domain:e.domain,type:"generic",content:r,confidence:.3+this.computeConfidenceBoost(e.metrics),metadata:{sourceTaskId:e.taskId,sourceAgent:e.agentId,taskType:e.type,extractedFrom:n,timestamp:e.timestamp}})}return t}computeConfidenceBoost(e){let t=0,n=e.testsPassed??0,i=e.testsFailed??0,r=n+i;return r>0&&(t+=n/r*.15),e.coverageChange!==void 0&&e.coverageChange>0&&(t+=Math.min(.1,e.coverageChange*.5)),e.securityIssues!==void 0&&e.securityIssues===0&&(t+=.1),e.performanceMs!==void 0&&e.performanceMs<5e3&&(t+=.05),Math.min(.4,t)}emitCompletion(e,t){if(this.config.emitEvents)for(let n of this.completionHandlers)try{n(e,t)}catch(i){console.error(`[TaskCompletedHook] Completion handler error: ${p(i)}`)}}};k();var Yn={"test-template":"test-template","assertion-pattern":"assertion-pattern","mock-pattern":"mock-pattern","coverage-strategy":"coverage-strategy","mutation-strategy":"mutation-strategy","security-pattern":"error-handling","vulnerability-fix":"error-handling","quality-rule":"test-template","threshold-pattern":"test-template","defect-pattern":"error-handling","root-cause":"error-handling","api-contract":"api-contract","schema-pattern":"api-contract","flaky-fix":"flaky-fix","retry-strategy":"flaky-fix","visual-baseline":"visual-baseline","a11y-check":"a11y-check","perf-benchmark":"perf-benchmark","resilience-pattern":"perf-benchmark",generic:"test-template"};function Zn(s){return Yn[s]??"test-template"}function Xn(s){let e=fe(s.domain);if(e)return e;let t=fe(s.content);return t||"test-generation"}function Jn(s){let e=0;for(let t=0;t<s.length;t++){let n=s.charCodeAt(t);e=(e<<5)-e+n,e=e&e}return Math.abs(e).toString(36).slice(0,8)}var ce=class{constructor(e){this.reasoningBank=e}async store(e){let t=Xn(e),n=Zn(e.type),i=Jn(e.content),r=`${t}-${e.type}-${i}`,a=[t,e.type,...e.metadata.sourceTaskId?[`task:${e.metadata.sourceTaskId}`]:[]],o={patternType:n,name:r,description:`Auto-extracted ${e.type} pattern from ${e.domain} domain`,template:{type:"prompt",content:e.content,variables:[]},context:{tags:a},confidence:e.confidence};try{let l=await this.reasoningBank.storePattern(o);if(l.success)return l.value.id;throw console.error(`[ReasoningBankPatternStore] Failed to store pattern: ${l.error.message}`),l.error}catch(l){throw console.error(`[ReasoningBankPatternStore] Store error: ${p(l)}`),l}}async recordOutcome(e,t){let n={patternId:e,success:t};try{let i=await this.reasoningBank.recordOutcome(n);i.success||console.error(`[ReasoningBankPatternStore] Failed to record outcome: ${i.error.message}`)}catch(i){console.error(`[ReasoningBankPatternStore] recordOutcome error: ${p(i)}`)}}};ln();var Be={maxHypothesesPerInvestigation:5,convergenceThreshold:.2,investigationTimeoutMs:3e5,minEvidenceForConvergence:3,autoRejectThreshold:.15};import{randomUUID as Qe}from"node:crypto";var ue=class{investigations=new Map;config;constructor(e){this.config={...Be,...e}}createInvestigation(e,t,n){let i=`inv-${Qe().slice(0,8)}`,r=Date.now(),a={id:i,taskId:e,domain:t,description:n,hypotheses:[],status:"open",maxHypotheses:this.config.maxHypothesesPerInvestigation,convergenceThreshold:this.config.convergenceThreshold,createdAt:r,updatedAt:r};return this.investigations.set(i,a),this.toSnapshot(a)}addHypothesis(e,t,n,i){let r=this.getInvestigationMutable(e);if(r.hypotheses.length>=r.maxHypotheses)throw new Error(`Investigation ${e} already has ${r.maxHypotheses} hypotheses (max)`);let a={id:`hyp-${Qe().slice(0,8)}`,description:t,investigatorAgentId:i,strategy:n,status:"pending",evidence:[],confidenceScore:.5,createdAt:Date.now(),updatedAt:Date.now()};return r.hypotheses.push(a),r.updatedAt=Date.now(),r.status==="open"&&(r.status="investigating"),a}startHypothesis(e,t){let n=this.getInvestigationMutable(e),i=this.findHypothesis(n,t);if(i.status!=="pending")throw new Error(`Hypothesis ${t} cannot be started (current status: ${i.status})`);i.status="investigating",i.updatedAt=Date.now(),n.updatedAt=Date.now()}completeHypothesis(e,t){let n=this.getInvestigationMutable(e),i=this.findHypothesis(n,t);i.status="completed",i.updatedAt=Date.now(),n.updatedAt=Date.now()}submitEvidence(e,t,n){let i=this.getInvestigationMutable(e),r=this.findHypothesis(i,t),a={...n,id:`evi-${Qe().slice(0,8)}`,hypothesisId:t,timestamp:Date.now()};return r.evidence.push(a),r.confidenceScore=this.calculateConfidence(r),r.updatedAt=Date.now(),i.updatedAt=Date.now(),r.confidenceScore<this.config.autoRejectThreshold&&r.evidence.length>=2&&(r.status="rejected"),a}converge(e){let t=this.getInvestigationMutable(e),n=t.hypotheses.reduce((c,u)=>c+u.evidence.length,0);if(n<this.config.minEvidenceForConvergence){t.status="inconclusive";let c={winningHypothesisId:null,confidence:0,evidenceSummary:`Insufficient evidence (${n}/${this.config.minEvidenceForConvergence} required)`,rejectedHypotheses:t.hypotheses.filter(u=>u.status==="rejected").map(u=>u.id),method:"evidence-scoring"};return t.convergenceResult=c,t.updatedAt=Date.now(),c}let i=[...t.hypotheses].filter(c=>c.status!=="rejected").sort((c,u)=>u.confidenceScore-c.confidenceScore),r="evidence-scoring",a=null,o=0;i.length===0?t.status="inconclusive":i.length===1?(a=i[0].id,o=i[0].confidenceScore,r="unanimous",t.status="converged"):i[0].confidenceScore-i[1].confidenceScore>=t.convergenceThreshold?(a=i[0].id,o=i[0].confidenceScore,t.status="converged"):t.status="inconclusive";let l={winningHypothesisId:a,confidence:o,evidenceSummary:this.buildEvidenceSummary(t),rejectedHypotheses:t.hypotheses.filter(c=>c.status==="rejected").map(c=>c.id),method:r};return t.convergenceResult=l,t.updatedAt=Date.now(),l}getInvestigation(e){let t=this.investigations.get(e);return t?this.toSnapshot(t):void 0}listInvestigations(){return Array.from(this.investigations.values()).map(e=>this.toSnapshot(e))}getConfig(){return this.config}dispose(){this.investigations.clear()}getInvestigationMutable(e){let t=this.investigations.get(e);if(!t)throw new Error(`Investigation ${e} not found`);return t}findHypothesis(e,t){let n=e.hypotheses.find(i=>i.id===t);if(!n)throw new Error(`Hypothesis ${t} not found in investigation ${e.id}`);return n}calculateConfidence(e){if(e.evidence.length===0)return .5;let t=0,n=0;for(let r of e.evidence)r.supports?t+=r.weight:n+=r.weight;let i=t+n;return i===0?.5:Math.min(1,Math.max(0,t/i))}buildEvidenceSummary(e){let t=[];for(let n of e.hypotheses){let i=n.evidence.filter(a=>a.supports).length,r=n.evidence.filter(a=>!a.supports).length;t.push(`${n.id}: ${i} supporting, ${r} refuting (confidence: ${n.confidenceScore.toFixed(2)})`)}return t.join("; ")}toSnapshot(e){return{...e,hypotheses:e.hypotheses.map(t=>({...t,evidence:[...t.evidence]}))}}};function $e(s){return new ue(s)}import{randomUUID as ei}from"node:crypto";var Ue={localFleetId:"local",heartbeatIntervalMs:3e4,serviceTimeoutMs:9e4,maxPendingMessages:5e3,maxRoutes:100};var me=class{config;services=new Map;routes=[];outbox=[];inbox=[];handlers=[];messagesSent=0;messagesReceived=0;constructor(e){this.config={...Ue,...e}}registerService(e,t,n,i){if(this.services.has(e))throw new Error(`Service '${e}' already registered`);let r=Date.now(),a={fleetId:e,name:t,domains:[...n],status:"active",registeredAt:r,lastHeartbeat:r,metadata:i};return this.services.set(e,a),de(a)}deregisterService(e){let t=this.services.get(e);if(!t)return!1;t.status="deregistered";for(let n=this.routes.length-1;n>=0;n--)this.routes[n].targetFleetId===e&&this.routes.splice(n,1);return this.services.delete(e),!0}heartbeat(e){let t=this.services.get(e);return t?(t.lastHeartbeat=Date.now(),(t.status==="degraded"||t.status==="unreachable")&&(t.status="active"),!0):!1}addRoute(e,t,n,i=0){if(this.routes.length>=this.config.maxRoutes)throw new Error(`Maximum routes (${this.config.maxRoutes}) reached`);let r={sourceDomain:e,targetDomain:t,targetFleetId:n,priority:i,active:!0};return this.routes.push(r),this.routes.sort((a,o)=>o.priority-a.priority),Ut(r)}removeRoute(e,t){let n=this.routes.findIndex(i=>i.sourceDomain===e&&i.targetFleetId===t);return n<0?!1:(this.routes.splice(n,1),!0)}send(e,t,n,i,r,a){let o=e==="any"?this.resolveRoute(t,n):e;if(!o)throw new Error(`No route found for ${t} -> ${n}`);let l={id:ei(),sourceFleetId:this.config.localFleetId,targetFleetId:o,sourceDomain:t,targetDomain:n,type:i,payload:r,timestamp:Date.now(),ttl:a?.ttl,correlationId:a?.correlationId};return this.outbox.length>=this.config.maxPendingMessages&&this.outbox.shift(),this.outbox.push(l),this.messagesSent++,l}receive(e){this.inbox.length>=this.config.maxPendingMessages&&this.inbox.shift(),this.inbox.push(e),this.messagesReceived++;for(let t of this.handlers)try{t(e)}catch{}}onMessage(e){return this.handlers.push(e),()=>{let t=this.handlers.indexOf(e);t>=0&&this.handlers.splice(t,1)}}drainOutbox(){let e=[...this.outbox];return this.outbox.length=0,e}drainInbox(){let e=[...this.inbox];return this.inbox.length=0,e}findServicesByDomain(e){return Array.from(this.services.values()).filter(t=>t.status==="active"&&t.domains.includes(e)).map(de)}getService(e){let t=this.services.get(e);return t?de(t):void 0}listServices(){return Array.from(this.services.values()).map(de)}listRoutes(){return this.routes.map(Ut)}checkHealth(){let e=Date.now();for(let t of this.services.values()){if(t.status==="deregistered")continue;let n=e-t.lastHeartbeat;n>this.config.serviceTimeoutMs?t.status="unreachable":n>this.config.serviceTimeoutMs*.6&&(t.status="degraded")}}getHealth(){return{localFleetId:this.config.localFleetId,connectedServices:Array.from(this.services.values()).filter(e=>e.status==="active").length,activeRoutes:this.routes.filter(e=>e.active).length,pendingMessages:this.outbox.length+this.inbox.length,messagesSent:this.messagesSent,messagesReceived:this.messagesReceived}}dispose(){this.services.clear(),this.routes.length=0,this.outbox.length=0,this.inbox.length=0,this.handlers.length=0}resolveRoute(e,t){for(let i of this.routes)if(i.active&&i.sourceDomain===e&&i.targetDomain===t){let r=this.services.get(i.targetFleetId);if(r&&r.status==="active")return i.targetFleetId}let n=this.findServicesByDomain(t);return n.length>0?n[0].fleetId:void 0}};function de(s){return{fleetId:s.fleetId,name:s.name,domains:[...s.domains],status:s.status,registeredAt:s.registeredAt,lastHeartbeat:s.lastHeartbeat,metadata:s.metadata,endpoint:void 0}}function Ut(s){return{sourceDomain:s.sourceDomain,targetDomain:s.targetDomain,targetFleetId:s.targetFleetId,priority:s.priority,active:s.active}}function Ge(s){return new me(s)}var Gt={name:"default",scaleUpQueueRatio:3,scaleDownIdleRatio:.5,errorRateScaleUpThreshold:.3,minAgents:2,maxAgents:15,cooldownMs:3e4,sampleWindowSize:5},ze={defaultPolicy:Gt,metricsHistorySize:100,decisionHistorySize:50};import{randomUUID as ti}from"node:crypto";he();k();var ge=class s{config;policy;metricsHistory=[];events=[];lastScaleTime=0;scaleUpCount=0;scaleDownCount=0;totalDecisions=0;currentAgents;lastDecision;db=null;persistCount=0;static KV_NAMESPACE="scaling-metrics";static KV_KEY="dynamic-scaler-snapshot";static PERSIST_INTERVAL=10;static KV_TTL=7200;constructor(e=2,t){this.config={...ze,...t},this.policy=this.config.defaultPolicy,this.currentAgents=e}recordMetrics(e){this.metricsHistory.push(e),this.metricsHistory.length>this.config.metricsHistorySize&&this.metricsHistory.shift(),this.persistCount++,this.persistCount%s.PERSIST_INTERVAL===0&&this.persistSnapshot().catch(()=>{})}evaluate(){let e=this.getAverageMetrics(),t=Date.now();if(this.totalDecisions++,t-this.lastScaleTime<this.policy.cooldownMs){let o={action:"maintain",currentAgents:this.currentAgents,targetAgents:this.currentAgents,reason:"Cooldown period active",metrics:e,timestamp:t};return this.lastDecision=o,o}let n="maintain",i=this.currentAgents,r="Workload within acceptable range";if(e.errorRate>this.policy.errorRateScaleUpThreshold)n="scale-up",i=Math.min(this.currentAgents+2,this.policy.maxAgents),r=`High error rate (${(e.errorRate*100).toFixed(1)}% > ${(this.policy.errorRateScaleUpThreshold*100).toFixed(1)}% threshold)`;else if(this.currentAgents>0&&e.queueDepth/Math.max(1,this.currentAgents)>this.policy.scaleUpQueueRatio){n="scale-up";let o=Math.ceil(e.queueDepth/this.policy.scaleUpQueueRatio);i=Math.min(o,this.policy.maxAgents),r=`Queue depth ratio ${(e.queueDepth/Math.max(1,this.currentAgents)).toFixed(1)} > ${this.policy.scaleUpQueueRatio} threshold`}if(n==="maintain"&&this.currentAgents>this.policy.minAgents){let o=this.currentAgents>0?e.idleAgents/this.currentAgents:0;if(o>this.policy.scaleDownIdleRatio){n="scale-down";let l=Math.floor(e.idleAgents*.5);i=Math.max(this.currentAgents-l,this.policy.minAgents),r=`Idle ratio ${(o*100).toFixed(1)}% > ${(this.policy.scaleDownIdleRatio*100).toFixed(1)}% threshold`}}i=Math.max(this.policy.minAgents,Math.min(this.policy.maxAgents,i)),i===this.currentAgents&&(n="maintain");let a={action:n,currentAgents:this.currentAgents,targetAgents:i,reason:r,metrics:e,timestamp:t};return this.lastDecision=a,a}async execute(e,t){let n={id:`scale-${ti().slice(0,8)}`,decision:e,executedAt:Date.now(),success:!0};if(e.action==="maintain")return this.recordEvent(n),n;try{if(t&&!await t(e.currentAgents,e.targetAgents)){let r={...n,success:!1,error:"Executor returned false"};return this.recordEvent(r),r}return this.currentAgents=e.targetAgents,this.lastScaleTime=Date.now(),e.action==="scale-up"&&this.scaleUpCount++,e.action==="scale-down"&&this.scaleDownCount++,this.recordEvent(n),n}catch(i){let r={...n,success:!1,error:p(i)};return this.recordEvent(r),r}}setPolicy(e){this.policy=e}getPolicy(){return{...this.policy}}getCurrentAgents(){return this.currentAgents}getStats(){return{scaleUpCount:this.scaleUpCount,scaleDownCount:this.scaleDownCount,totalDecisions:this.totalDecisions,currentAgents:this.currentAgents,policyName:this.policy.name,lastDecision:this.lastDecision,recentEvents:[...this.events].slice(-10)}}getMetricsHistory(){return[...this.metricsHistory]}async initialize(){try{this.db=w(),this.db.isInitialized()||await this.db.initialize(),await this.loadFromKv()}catch(e){console.warn("[DynamicScaler] DB init failed, using memory-only:",p(e)),this.db=null}}dispose(){this.metricsHistory.length=0,this.events.length=0}getAverageMetrics(){let e=this.metricsHistory.slice(-this.policy.sampleWindowSize);if(e.length===0)return{queueDepth:0,activeAgents:this.currentAgents,idleAgents:0,avgTaskDurationMs:0,errorRate:0,throughput:0,timestamp:Date.now()};let t=n=>e.reduce((i,r)=>i+n(r),0)/e.length;return{queueDepth:Math.round(t(n=>n.queueDepth)),activeAgents:Math.round(t(n=>n.activeAgents)),idleAgents:Math.round(t(n=>n.idleAgents)),avgTaskDurationMs:Math.round(t(n=>n.avgTaskDurationMs)),errorRate:t(n=>n.errorRate),throughput:t(n=>n.throughput),timestamp:Date.now()}}recordEvent(e){this.events.push(e),this.events.length>this.config.decisionHistorySize&&this.events.shift(),this.persistCount++,this.persistCount%s.PERSIST_INTERVAL===0&&this.persistSnapshot().catch(()=>{})}async loadFromKv(){if(this.db)try{let e=await this.db.kvGet(s.KV_KEY,s.KV_NAMESPACE);if(e){if(Array.isArray(e.metricsHistory))for(let t of e.metricsHistory)this.metricsHistory.push(t);if(Array.isArray(e.events))for(let t of e.events)this.events.push(t)}}catch(e){console.warn("[DynamicScaler] Failed to load KV snapshot:",p(e))}}async persistSnapshot(){if(this.db)try{let e={metricsHistory:this.metricsHistory.slice(-50),events:this.events.slice(-50)};await this.db.kvSet(s.KV_KEY,e,s.KV_NAMESPACE,s.KV_TTL)}catch(e){console.warn("[DynamicScaler] Failed to persist KV snapshot:",p(e))}}};function qe(s,e){return new ge(s,e)}var ni=[{name:"Core Testing",domains:["test-generation","test-execution","coverage-analysis","quality-assessment"],priority:"p0",description:"Core testing workflow domains"},{name:"Intelligence",domains:["defect-intelligence","code-intelligence","requirements-validation","security-compliance"],priority:"p0",description:"Intelligence and analysis domains"},{name:"Specialized",domains:["contract-testing","visual-accessibility","chaos-resilience","learning-optimization"],priority:"p1",description:"Specialized testing domains"}],P={"generate-tests":["test-generation"],"execute-tests":["test-execution"],"analyze-coverage":["coverage-analysis"],"assess-quality":["quality-assessment"],"predict-defects":["defect-intelligence"],"validate-requirements":["requirements-validation"],"index-code":["code-intelligence"],"scan-security":["security-compliance"],"validate-contracts":["contract-testing"],"test-accessibility":["visual-accessibility"],"run-chaos":["chaos-resilience"],"optimize-learning":["learning-optimization"],"cross-domain-workflow":[],"protocol-execution":[],"ideation-assessment":["requirements-validation","coverage-analysis","security-compliance"]},zt={maxConcurrentTasks:50,defaultTaskTimeout:3e5,taskRetryLimit:3,workStealing:{enabled:!0,idleThreshold:5e3,loadThreshold:10,stealBatchSize:3,checkInterval:1e4},enableMetrics:!0,metricsInterval:6e4,priorityWeights:{p0:100,p1:50,p2:25,p3:10},enableRouting:!0};function qt(s){P["cross-domain-workflow"]=s,P["protocol-execution"]=s}import{readFileSync as ri,existsSync as ai}from"fs";import{join as si}from"path";import{parse as oi}from"yaml";he();import{randomUUID as ii}from"crypto";var B={RISK_WEIGHTS:2160*60*60*1e3,SFDIPOT_WEIGHTS:2160*60*60*1e3,FLAKY_PATTERNS:720*60*60*1e3,AC_QUALITY:1440*60*60*1e3};function Q(s,e){let t=Date.now(),n=ii().split("-")[0];return`${e||s}-signal-${t}-${n}`}function $(s){return new Date(Date.now()+s).toISOString()}function M(s){return new Date(s.expiresAt)<new Date}var v={STRATEGIC:"qcsd/strategic",TACTICAL:"qcsd/tactical",OPERATIONAL:"qcsd/operational",QUALITY_CRITERIA:"qcsd/quality-criteria"},We=class{memory;initialized=!1;constructor(e={}){this.memory=e.memoryManager||w()}async initialize(){this.initialized||(await this.memory.initialize(),this.initialized=!0,console.log("[CrossPhaseMemory] Initialized with UnifiedMemoryManager"))}async storeRiskSignal(e,t){await this.ensureInitialized();let n={id:Q("strategic","risk"),timestamp:new Date().toISOString(),source:"production",target:"ideation",loopType:"strategic",version:"1.0.0",expiresAt:$(B.RISK_WEIGHTS),riskWeights:e,recommendations:t};return await this.store(v.STRATEGIC,n),n}async queryRiskSignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.STRATEGIC)).filter(t=>!M(t))}async storeSFDIPOTSignal(e,t,n){await this.ensureInitialized();let i={id:Q("tactical","sfdipot"),timestamp:new Date().toISOString(),source:"production",target:"refinement",loopType:"tactical",version:"1.0.0",expiresAt:$(B.SFDIPOT_WEIGHTS),factorWeights:e,featureContext:t,recommendations:n};return await this.store(v.TACTICAL,i),i}async querySFDIPOTSignals(e){await this.ensureInitialized();let t=await this.queryByNamespace(v.TACTICAL);return t=t.filter(n=>!M(n)),e&&(t=t.filter(n=>n.featureContext.toLowerCase().includes(e.toLowerCase()))),t}async storeTestHealthSignal(e,t,n){await this.ensureInitialized();let i={id:Q("operational","test-health"),timestamp:new Date().toISOString(),source:"cicd",target:"development",loopType:"operational",version:"1.0.0",expiresAt:$(B.FLAKY_PATTERNS),flakyPatterns:e,gateFailures:t,recommendations:n};return await this.store(v.OPERATIONAL,i),i}async queryTestHealthSignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.OPERATIONAL)).filter(t=>!M(t))}async storeACQualitySignal(e,t,n){await this.ensureInitialized();let i={id:Q("quality-criteria","ac-quality"),timestamp:new Date().toISOString(),source:"development",target:"refinement",loopType:"quality-criteria",version:"1.0.0",expiresAt:$(B.AC_QUALITY),untestablePatterns:e,coverageGaps:t,recommendations:n};return await this.store(v.QUALITY_CRITERIA,i),i}async queryACQualitySignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.QUALITY_CRITERIA)).filter(t=>!M(t))}async store(e,t){let n=new Date(t.expiresAt).getTime(),i=Math.max(0,Math.floor((n-Date.now())/1e3));await this.memory.kvSet(t.id,t,e,i>0?i:void 0),console.log(`[CrossPhaseMemory] Stored signal: ${t.id} in ${e}`)}async queryByNamespace(e){let t=await this.memory.kvSearch("*",e,1e3),n=[];for(let i of t){let r=await this.memory.kvGet(i,e);r&&n.push(r)}return n.sort((i,r)=>new Date(r.timestamp).getTime()-new Date(i.timestamp).getTime())}async delete(e,t){let n=await this.memory.kvDelete(t,e);return n&&console.log(`[CrossPhaseMemory] Deleted signal: ${t}`),n}async cleanupExpired(){let e={deleted:0,namespaces:{}};for(let t of Object.values(v)){let n=await this.queryByNamespace(t),i=0;for(let r of n)M(r)&&(await this.delete(t,r.id),i++,e.deleted++);i>0&&(e.namespaces[t]=i)}return e.deleted>0&&console.log(`[CrossPhaseMemory] Cleanup: deleted ${e.deleted} expired signals`),e}async getStats(){await this.ensureInitialized();let e={totalSignals:0,byLoop:{strategic:0,tactical:0,operational:0,"quality-criteria":0},byNamespace:{},oldestSignal:null,newestSignal:null},t=null,n=null;for(let i of Object.values(v)){let a=(await this.queryByNamespace(i)).filter(o=>!M(o));e.byNamespace[i]=a.length,e.totalSignals+=a.length;for(let o of a){e.byLoop[o.loopType]++;let l=new Date(o.timestamp);(!t||l<t)&&(t=l,e.oldestSignal=o.timestamp),(!n||l>n)&&(n=l,e.newestSignal=o.timestamp)}}return e}async ensureInitialized(){this.initialized||await this.initialize()}},je=null;function jt(s){return je||(je=new We(s)),je}function Ve(s){let e=Object.getOwnPropertyNames(s);for(let t of e){let n=s[t];n&&typeof n=="object"&&!Object.isFrozen(n)&&Ve(n)}return Object.freeze(s)}function Ke(s){let e=structuredClone(s);return Ve(e)}function Ye(s){return s===0?"success":s===2?"model_blocking":"user_error"}var Xe=class{config=null;memory;configPath;listeners=new Map;constructor(e){this.configPath=e||si(process.cwd(),".claude/hooks/cross-phase-memory.yaml"),this.memory=jt()}async initialize(){if(process.env.AQE_HOOKS_DISABLED==="true")return console.log("[CrossPhaseHooks] All hooks disabled via AQE_HOOKS_DISABLED"),!1;if(!ai(this.configPath))return console.warn(`[CrossPhaseHooks] Config not found: ${this.configPath}`),!1;try{let e=ri(this.configPath,"utf-8"),t=oi(e);return t.enabled?(this.config=Ke(t),await this.memory.initialize(),console.log(`[CrossPhaseHooks] Initialized with ${Object.keys(this.config.hooks).length} hooks`),!0):(console.log("[CrossPhaseHooks] Hooks disabled in config"),!1)}catch(e){return console.error("[CrossPhaseHooks] Failed to load config:",e),!1}}async onAgentComplete(e,t){if(!this.config||process.env.AQE_HOOKS_DISABLED==="true")return;let n=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([i,r])=>r.trigger.event==="agent-complete"&&r.trigger.agent===e));for(let[i,r]of n)this.checkConditions(r.trigger.conditions,t)&&(console.log(`[CrossPhaseHooks] Executing hook: ${i}`),await this.executeActions(r.actions,t))}async onPhaseStart(e,t={}){if(!this.config)return{};if(process.env.AQE_HOOKS_DISABLED==="true")return{};let n={},i=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([r,a])=>a.trigger.event==="phase-start"&&a.trigger.phase===e));for(let[r,a]of i){console.log(`[CrossPhaseHooks] Executing phase-start hook: ${r}`);for(let o of a.actions)if(o.type==="query-signals"&&o.injectInto){let l=await this.querySignalsForInjection(o.namespace,o.maxAge,o.filterBy?t[o.filterBy]:void 0);for(let c of o.injectInto)n[c]||(n[c]=[]),n[c].push(...l)}}return n}async onPhaseEnd(e,t){if(!this.config||process.env.AQE_HOOKS_DISABLED==="true")return;let n=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([i,r])=>r.trigger.event==="phase-end"&&r.trigger.phase===e));for(let[i,r]of n)console.log(`[CrossPhaseHooks] Executing phase-end hook: ${i}`),await this.executeActions(r.actions,t)}async executeActions(e,t){for(let n of e)try{await this.executeAction(n,t)}catch(i){let r=i?.exitCode;if(typeof r=="number"){let a=Ye(r);if(a==="model_blocking")throw console.error(`[CrossPhaseHooks] Model-blocking hook failure (exit ${r}):`,i),i;console.warn(`[CrossPhaseHooks] Hook ${a} (exit ${r}):`,i)}else console.error("[CrossPhaseHooks] Action failed:",i)}}async executeAction(e,t){switch(e.type){case"store-signal":await this.executeStoreSignal(e,t);break;case"query-signals":break;case"notify-agent":await this.executeNotifyAgent(e,t);break;case"invoke-agent":await this.executeInvokeAgent(e,t);break;case"conditional":e.condition&&e.action&&this.evaluateCondition(e.condition,t)&&await this.executeAction(e.action,t);break;case"delete-expired":await this.memory.cleanupExpired();break;default:console.warn(`[CrossPhaseHooks] Unknown action type: ${e.type}`)}}async executeStoreSignal(e,t){if(!e.loop||!e.namespace||!e.extract)return;let n=this.extractFromContext(e.extract,t);switch(e.loop){case"strategic":await this.memory.storeRiskSignal(n.riskWeights||[],n.recommendations||{forRiskAssessor:[],forQualityCriteria:[]});break;case"tactical":await this.memory.storeSFDIPOTSignal(n.factorWeights||[],n.featureContext||"unknown",n.recommendations||{forProductFactorsAssessor:[]});break;case"operational":await this.memory.storeTestHealthSignal(n.flakyPatterns||[],n.gateFailures||[],n.recommendations||{forTestArchitect:[],antiPatterns:[]});break;case"quality-criteria":await this.memory.storeACQualitySignal(n.untestablePatterns||[],n.coverageGaps||[],n.recommendations||{forRequirementsValidator:[],acTemplates:{}});break}this.emit("signal-stored",{loop:e.loop,namespace:e.namespace})}async executeNotifyAgent(e,t){!e.target||!e.message||await this.isBlockedUrl(e.target)||(console.log(`[CrossPhaseHooks] Notify ${e.target}: ${e.message}`),this.emit("agent-notification",{target:e.target,message:e.message,priority:e.priority||"normal",context:t}))}async executeInvokeAgent(e,t){e.target&&(await this.isBlockedUrl(e.target)||(console.log(`[CrossPhaseHooks] Invoke agent: ${e.target}`),this.emit("agent-invocation",{agent:e.target,input:{...t,...e.input||{}}})))}async querySignalsForInjection(e,t,n){let r=await this.memory.queryByNamespace(e);if(t){let a=this.parseMaxAge(t),o=Date.now()-a;r=r.filter(l=>new Date(l.timestamp).getTime()>o)}return r}formatSignalsForInjection(e){if(e.length===0)return"";let t=`## CROSS-PHASE LEARNING SIGNALS
|
|
164
|
+
`);return null}function _(s){let e=s.trim();return e.startsWith('"')&&e.endsWith('"')||e.startsWith("'")&&e.endsWith("'")?e.slice(1,-1):e}function Nn(s){let e=Ht(s);if(!e)return null;let t=e.split(`
|
|
165
|
+
`),n=-1;for(let c=0;c<t.length;c++)if(/^dependencies:\s*$/.test(t[c])){n=c+1;break}if(n===-1)return null;let i=[];for(let c=n;c<t.length;c++){let u=t[c];if(u.trim()!==""){if(u.length>0&&u[0]!==" "&&u[0]!==" ")break;i.push(u)}}if(i.length===0)return null;let r={},a={section:"none",item:{},inList:!1},o=()=>{a.item.name&&(r.agents||(r.agents=[]),r.agents.push({name:a.item.name,type:a.item.type||"hard",reason:a.item.reason||""}),a.item={})},l=()=>{a.item.name&&(r.mcpServers||(r.mcpServers=[]),r.mcpServers.push({name:a.item.name,required:a.item.required==="true"}),a.item={})};for(let c of i){let u=c.trim();if(u==="")continue;let d=u.match(/^(agents|mcp_servers|models):\s*$/);if(d){a.section==="agents"&&a.inList&&o(),a.section==="mcp_servers"&&a.inList&&l(),a.inList=!1,a.section=d[1];continue}if(a.section==="agents"||a.section==="mcp_servers"){let g=u.match(/^-\s+(\w+):\s*(.*)$/);if(g){a.inList&&(a.section==="agents"?o():l()),a.inList=!0,a.item={[g[1]]:_(g[2])};continue}if(a.inList){let h=u.match(/^(\w+):\s*(.*)$/);if(h){a.item[h[1]]=_(h[2]);continue}}}if(a.section==="models"){r.models||(r.models={});let g=u.match(/^(\w+):\s*(.*)$/);if(g){let b=_(g[2]);if(g[1]==="minimum")r.models={...r.models,minimum:b};else if(g[1]==="capabilities"){let U=b.match(/^\[(.+)]$/);U&&(r.models={...r.models,capabilities:U[1].split(",").map(ln=>_(ln.trim()))})}}let h=u.match(/^-\s+(.+)$/);if(h&&r.models){let b=r.models.capabilities||[];r.models={...r.models,capabilities:[...b,_(h[1])]}}}}return a.section==="agents"&&a.inList&&o(),a.section==="mcp_servers"&&a.inList&&l(),!r.agents&&!r.mcpServers&&!r.models?null:r}function Ln(s){let e=Ht(s);if(!e)return null;for(let t of e.split(`
|
|
166
|
+
`)){let n=t.match(/^name:\s*(.+)$/);if(n)return _(n[1])}return null}function Ft(s){let e=new Map,t=[];if(!Pn(s))return t.push(`Agents directory not found: ${s}`),{nodes:e,spawnOrder:[],cycles:[],warnings:t};let n=Hn(s).filter(a=>a.startsWith("qe-")&&a.endsWith(".md"));for(let a of n){let o;try{o=_n(Fn(s,a),"utf-8")}catch{t.push(`Failed to read agent file: ${a}`);continue}let l=Ln(o)||On(a,".md"),c=Nn(o),u=[],d=[],g=[];if(c?.agents)for(let h of c.agents)h.type==="hard"?u.push(h.name):h.type==="soft"?d.push(h.name):h.type==="peer"&&g.push(h.name);e.set(l,{agentName:l,hardDeps:u,softDeps:d,peerDeps:g,dependencies:c||{}})}let i=new Set(e.keys());for(let[a,o]of e)for(let l of o.hardDeps)i.has(l)||t.push(`Agent "${a}" declares hard dependency on "${l}" which is not in the agent directory`);let r=Bn(e);for(let a of r)t.push(`Dependency cycle detected: ${a.join(" -> ")}`);return{nodes:e,spawnOrder:Qn(e,r),cycles:r,warnings:t}}function Bn(s){let e=[],t=new Set,n=new Set,i=[];function r(a){t.add(a),n.add(a),i.push(a);let o=s.get(a);if(o){for(let l of o.hardDeps)if(!t.has(l)&&s.has(l))r(l);else if(n.has(l)){let c=i.indexOf(l);c!==-1&&e.push([...i.slice(c),l])}}i.pop(),n.delete(a)}for(let a of s.keys())t.has(a)||r(a);return e}function Qn(s,e){let t=new Set(e.flat()),n=[],i=new Set,r=new Set;function a(o){if(i.has(o)||t.has(o)||r.has(o))return;r.add(o);let l=s.get(o);if(l)for(let c of l.hardDeps)s.has(c)&&a(c);r.delete(o),i.add(o),n.push(o)}for(let o of s.keys())a(o);for(let o of t)n.includes(o)||n.push(o);return n}function Ot(s,e){let t=new Set(s),n=[],i=[];for(let l of s){let c=e.nodes.get(l);if(!c)continue;let u=c.hardDeps.filter(d=>!t.has(d));u.length>0&&(i.push({agent:l,missing:u}),n.push(`Advisory: "${l}" has unsatisfied hard dependencies: ${u.join(", ")}. Proceeding anyway.`))}let r=[],a=new Set,o=new Set(s);for(;o.size>0;){let l=[];for(let c of o){let u=e.nodes.get(c);if(!u){l.push(c);continue}u.hardDeps.filter(g=>t.has(g)).every(g=>a.has(g))&&l.push(c)}if(l.length===0){n.push(`Could not resolve dependency ordering for: ${[...o].join(", ")}. Placing in final phase.`),r.push([...o]);break}r.push(l);for(let c of l)a.add(c),o.delete(c);o=new Set([...o])}return{phases:r,unsatisfiedHardDeps:i,warnings:n}}var Re={defaultTtlMs:0,cleanupIntervalMs:6e4,maxMailboxSize:1e3};var F=class{mailboxes=new Map;messageHandlers=new Map;broadcastHandlers=new Map;domainAgents=new Map;cognitiveRouter=null;cognitiveRouterInitialized=!1;compressedMessages=new Map;createMailbox(e,t){let n=this.mailboxes.get(e);if(n)return this.toSnapshot(n);let i={agentId:e,domain:t,messages:[],unreadCount:0,lastRead:Date.now()};this.mailboxes.set(e,i);let r=this.domainAgents.get(t);return r||(r=new Set,this.domainAgents.set(t,r)),r.add(e),this.toSnapshot(i)}getMailbox(e){let t=this.mailboxes.get(e);if(t)return this.toSnapshot(t)}deleteMailbox(e){let t=this.mailboxes.get(e);if(!t)return!1;let n=this.domainAgents.get(t.domain);n&&(n.delete(e),n.size===0&&this.domainAgents.delete(t.domain));for(let i of t.messages)this.compressedMessages.delete(i.id);return this.messageHandlers.delete(e),this.mailboxes.delete(e),!0}send(e){if(e.to==="broadcast"){this.broadcast(e.domain,e);return}let t=this.mailboxes.get(e.to);if(!t)throw new Error(`No mailbox found for agent '${e.to}'. Create a mailbox first with createMailbox().`);let n=this.compressViaCognitive(e);t.messages.push(n),t.unreadCount++;let i=this.messageHandlers.get(e.to);if(i)for(let r of i)try{r(e)}catch{}}broadcast(e,t){let n=this.domainAgents.get(e);if(!n)return;for(let r of n){if(r===t.from)continue;let a=this.mailboxes.get(r);if(a){a.messages.push(t),a.unreadCount++;let o=this.messageHandlers.get(r);if(o)for(let l of o)try{l(t)}catch{}}}let i=this.broadcastHandlers.get(e);if(i)for(let r of i)try{r(e,t)}catch{}}receive(e,t){let n=this.mailboxes.get(e);if(!n||n.unreadCount===0)return[];let i=Date.now(),r=n.messages.length-n.unreadCount,a=n.messages.slice(r);return a=a.filter(o=>!this.isExpired(o,i)),t?.type&&(a=a.filter(o=>o.type===t.type)),t?.since!==void 0&&(a=a.filter(o=>o.timestamp>=t.since)),t?.limit!==void 0&&t.limit>0&&(a=a.slice(0,t.limit)),n.unreadCount=0,n.lastRead=i,this.decompressMessages(a)}peek(e){let t=this.mailboxes.get(e);if(!t)return 0;let n=Date.now(),i=t.messages.length-t.unreadCount,r=0;for(let a=i;a<t.messages.length;a++)this.isExpired(t.messages[a],n)||r++;return r}cleanup(e){let t=Date.now(),n=t-e,i=0;for(let r of this.mailboxes.values()){let a=r.messages.length,o=r.messages.length-r.unreadCount;r.messages=r.messages.filter((c,u)=>c.timestamp<n?(this.compressedMessages.delete(c.id),!1):this.isExpired(c,t)?(this.compressedMessages.delete(c.id),!1):!0);let l=a-r.messages.length;i+=l,l>0&&(r.unreadCount=r.messages.filter(c=>c.timestamp>r.lastRead).length)}return i}onMessage(e,t){let n=this.messageHandlers.get(e);return n||(n=[],this.messageHandlers.set(e,n)),n.push(t),()=>{let i=this.messageHandlers.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}onBroadcast(e,t){let n=this.broadcastHandlers.get(e);return n||(n=[],this.broadcastHandlers.set(e,n)),n.push(t),()=>{let i=this.broadcastHandlers.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}getAgentsInDomain(e){let t=this.domainAgents.get(e);return t?Array.from(t):[]}getDomains(){return Array.from(this.domainAgents.keys())}get size(){return this.mailboxes.size}clear(){this.mailboxes.clear(),this.messageHandlers.clear(),this.broadcastHandlers.clear(),this.domainAgents.clear(),this.compressedMessages.clear(),this.cognitiveRouter=null,this.cognitiveRouterInitialized=!1}isExpired(e,t){return!e.ttl||e.ttl<=0?!1:t>e.timestamp+e.ttl}toSnapshot(e){return{agentId:e.agentId,domain:e.domain,messages:[...e.messages],unreadCount:e.unreadCount,lastRead:e.lastRead}}ensureCognitiveRouter(){if(this.cognitiveRouterInitialized)return this.cognitiveRouter;if(this.cognitiveRouterInitialized=!0,!pt())return null;try{this.cognitiveRouter=mt()??null}catch{this.cognitiveRouter=null}return this.cognitiveRouter}compressViaCognitive(e){try{let t=this.ensureCognitiveRouter();if(!t)return e;let n=`${e.from}->${e.to}`,i=t.send(n,e.from,e.to,e.payload);return i.compressed&&i.compressedSize<i.originalSize?(this.compressedMessages.set(e.id,i),{...e,payload:i.payload}):e}catch{return e}}decompressMessages(e){let t=this.cognitiveRouter;return!t||this.compressedMessages.size===0?e:e.map(n=>{try{let i=this.compressedMessages.get(n.id);if(!i)return n;let r=t.receive(i);return this.compressedMessages.delete(n.id),{...n,payload:r}}catch{return n}})}getCognitiveRoutingStats(){return this.cognitiveRouter?this.cognitiveRouter.getStats():null}};import{randomUUID as Nt}from"node:crypto";dt();import{randomUUID as Y}from"node:crypto";var Z=class{spans=new Map;traceIndex=new Map;maxSpans;constructor(e=1e4){this.maxSpans=e}startTrace(e){let t=Y(),n=Y(),i={traceId:t,spanId:n},r=this.createSpan(i,e);return{context:i,span:r}}startSpan(e){let t=e.parentContext,n=t?.traceId??Y(),i=Y(),r={traceId:n,spanId:i,parentSpanId:t?.spanId,baggage:t?.baggage},a=this.createSpan(r,e);return{context:r,span:a}}completeSpan(e){let t=this.spans.get(e);t&&(t.endTime=Date.now(),t.status="completed")}failSpan(e,t){let n=this.spans.get(e);n&&(n.endTime=Date.now(),n.status="error",n.errorMessage=t)}getTrace(e){let t=this.traceIndex.get(e);return t?Array.from(t).map(n=>this.spans.get(n)).filter(n=>n!==void 0).sort((n,i)=>n.startTime-i.startTime):[]}getSpan(e){return this.spans.get(e)}getActiveSpans(){return Array.from(this.spans.values()).filter(e=>e.status==="active")}getStats(){let e=new Set,t=new Set;for(let[n,i]of this.traceIndex)Array.from(i).map(a=>this.spans.get(a)).filter(a=>a!==void 0).some(a=>a.status==="active")?e.add(n):t.add(n);return{totalSpans:this.spans.size,activeTraces:e.size,completedTraces:t.size}}purge(e){let t=Date.now()-e,n=0;for(let[i,r]of this.traceIndex){let a=Array.from(r).map(c=>this.spans.get(c)).filter(c=>c!==void 0),o=a.every(c=>c.status!=="active"),l=a.every(c=>(c.endTime??c.startTime)<t);if(o&&l){for(let c of r)this.spans.delete(c),n++;this.traceIndex.delete(i)}}return n}dispose(){this.spans.clear(),this.traceIndex.clear()}createSpan(e,t){this.spans.size>=this.maxSpans&&this.purge(6e4);let n={traceId:e.traceId,spanId:e.spanId,parentSpanId:e.parentSpanId,operationName:t.operationName,agentId:t.agentId,domain:t.domain,startTime:Date.now(),tags:t.tags??{},status:"active"};this.spans.set(e.spanId,n);let i=this.traceIndex.get(e.traceId);return i||(i=new Set,this.traceIndex.set(e.traceId,i)),i.add(e.spanId),n}},$n="trace:";function X(s){return`${$n}${JSON.stringify({traceId:s.traceId,spanId:s.spanId,parentSpanId:s.parentSpanId})}`}function _e(s){return new Z(s)}var J=class{mailbox;config;teams=new Map;registeredAgents=new Set;agentDomains=new Map;subscriptions=new Map;cleanupTimer=null;initialized=!1;constructor(e,t){this.mailbox=e??new F,this.config={...Re,...t}}initialize(e){this.initialized||(e&&Object.assign(this.config,e),this.config.cleanupIntervalMs>0&&(this.cleanupTimer=setInterval(()=>{this.performCleanup()},this.config.cleanupIntervalMs)),this.initialized=!0)}shutdown(){this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null),this.mailbox.clear(),this.teams.clear(),this.registeredAgents.clear(),this.agentDomains.clear(),this.subscriptions.clear(),this.initialized=!1}createTeam(e){if(this.teams.has(e.domain))throw new Error(`Team already exists for domain '${e.domain}'. Use getTeamStatus() to inspect the existing team.`);let t={domain:e.domain,leadAgentId:e.leadAgentId,maxTeammates:e.maxTeammates,teammateIds:[...e.teammateIds],autoAssignEnabled:e.autoAssignEnabled};this.teams.set(e.domain,t),this.registerAgent(e.leadAgentId,e.domain);for(let n of e.teammateIds)this.registerAgent(n,e.domain)}getTeamStatus(e){let t=this.teams.get(e);if(!t)return;let n=[t.leadAgentId,...t.teammateIds],i=n.filter(a=>this.mailbox.peek(a)===0),r=0;for(let a of n)r+=this.mailbox.peek(a);return{domain:t.domain,leadAgentId:t.leadAgentId,teammateIds:[...t.teammateIds],activeAgentCount:n.filter(a=>this.registeredAgents.has(a)).length,idleAgentIds:i,totalUnreadMessages:r}}registerAgent(e,t){if(this.registeredAgents.has(e))return;this.registeredAgents.add(e),this.agentDomains.set(e,t),this.mailbox.createMailbox(e,t);let n=this.teams.get(t);n&&n.autoAssignEnabled&&e!==n.leadAgentId&&!n.teammateIds.includes(e)&&n.teammateIds.length<n.maxTeammates&&n.teammateIds.push(e)}unregisterAgent(e){if(!this.registeredAgents.has(e))return!1;let t=this.agentDomains.get(e);if(t){let n=this.teams.get(t);if(n){let i=n.teammateIds.indexOf(e);i>=0&&n.teammateIds.splice(i,1)}}return this.mailbox.deleteMailbox(e),this.subscriptions.delete(e),this.registeredAgents.delete(e),this.agentDomains.delete(e),!0}sendMessage(e,t,n,i,r){this.validateAgent(e,"sender"),this.validateAgent(t,"recipient");let a=this.agentDomains.get(e),o=r?.traceContext?X(r.traceContext):r?.correlationId,l={id:Nt(),from:e,to:t,domain:r?.domain??a,type:n,payload:i,timestamp:Date.now(),correlationId:o,replyTo:r?.replyTo,ttl:r?.ttl??(this.config.defaultTtlMs>0?this.config.defaultTtlMs:void 0)};return this.mailbox.send(l),this.notifySubscribers(t,l),l}broadcast(e,t,n,i){let r=i?.from??"__system__";r!=="__system__"&&this.validateAgent(r,"broadcast sender");let a=i?.traceContext?X(i.traceContext):i?.correlationId,o={id:Nt(),from:r,to:"broadcast",domain:e,type:t,payload:n,timestamp:Date.now(),correlationId:a,ttl:i?.ttl??(this.config.defaultTtlMs>0?this.config.defaultTtlMs:void 0)};this.mailbox.broadcast(e,o);let l=this.mailbox.getAgentsInDomain(e);for(let c of l)c!==r&&this.notifySubscribers(c,o);return o}onMessage(e,t){this.validateAgent(e,"subscription target");let n=this.subscriptions.get(e);return n||(n=[],this.subscriptions.set(e,n)),n.push(t),()=>{let i=this.subscriptions.get(e);if(i){let r=i.indexOf(t);r>=0&&i.splice(r,1)}}}getIdleAgents(e){let t=[],n=e?this.mailbox.getAgentsInDomain(e):Array.from(this.registeredAgents);for(let i of n)this.mailbox.peek(i)===0&&t.push(i);return t}isRegistered(e){return this.registeredAgents.has(e)}getAgentDomain(e){return this.agentDomains.get(e)}getRegisteredAgents(){return Array.from(this.registeredAgents)}getUnreadCount(e){return this.mailbox.peek(e)}receiveMessages(e){return this.mailbox.receive(e)}getMailboxService(){return this.mailbox}validateAgent(e,t){if(!this.registeredAgents.has(e))throw new Error(`Unknown ${t} '${e}'. Register the agent first with registerAgent() or createTeam().`)}notifySubscribers(e,t){let n=this.subscriptions.get(e);if(!(!n||n.length===0))for(let i of n)try{i(t)}catch{}}performCleanup(){let e=this.config.defaultTtlMs>0?this.config.defaultTtlMs*10:this.config.cleanupIntervalMs*60;this.mailbox.cleanup(e)}};function Pe(s){return new J(void 0,s)}var Lt={maxActiveTeams:13,defaultTeamSize:3,autoScaleEnabled:!1,scaleUpThreshold:10,scaleDownIdleMs:6e4},ee=class s{static SYSTEM_AGENT_ID="__dtm_system__";static SYSTEM_DOMAIN="__system__";adapter;config;teams=new Map;systemAgentRegistered=!1;constructor(e,t){this.adapter=e,this.config={...Lt,...t}}createDomainTeam(e,t,n){if(this.teams.has(e))throw new Error(`Domain team already exists for '${e}'. Use getDomainTeam() to inspect the existing team.`);if(this.teams.size>=this.config.maxActiveTeams)throw new Error(`Maximum active teams (${this.config.maxActiveTeams}) reached. Remove an existing team before creating a new one.`);let i=n?[...n]:[],r=this.getMaxTeamSize(e);i.length+1>r&&(i.length=r-1);let a=Date.now(),o={domain:e,leadAgentId:t,teammateIds:i,createdAt:a,taskCount:0,completedCount:0,lastActivity:new Map};o.lastActivity.set(t,a);for(let c of i)o.lastActivity.set(c,a);this.teams.set(e,o);let l={domain:e,leadAgentId:t,maxTeammates:r-1,teammateIds:i,autoAssignEnabled:!1};return this.adapter.createTeam(l),this.toSnapshot(o)}removeDomainTeam(e){let t=this.teams.get(e);if(!t)return!1;for(let n of[t.leadAgentId,...t.teammateIds])this.adapter.unregisterAgent(n);return this.teams.delete(e),!0}getDomainTeam(e){let t=this.teams.get(e);return t?this.toSnapshot(t):void 0}addTeammate(e,t){let n=this.teams.get(e);if(!n||t===n.leadAgentId||n.teammateIds.includes(t))return!1;let i=this.getMaxTeamSize(e);return 1+n.teammateIds.length>=i?!1:(n.teammateIds.push(t),n.lastActivity.set(t,Date.now()),this.adapter.registerAgent(t,e),!0)}listDomainTeams(){return Array.from(this.teams.values(),e=>this.toSnapshot(e))}assignTaskToTeam(e,t,n){let i=this.teams.get(e);return i?(this.ensureSystemAgent(),this.adapter.sendMessage(s.SYSTEM_AGENT_ID,i.leadAgentId,"task-assignment",{taskId:t,payload:n},{domain:e}),i.taskCount++,i.lastActivity.set(i.leadAgentId,Date.now()),!0):!1}broadcastToDomain(e,t,n){let i=this.teams.get(e);if(!i)throw new Error(`No domain team found for '${e}'. Create a team first with createDomainTeam().`);this.adapter.broadcast(e,t,n,{from:"__system__"});let r=Date.now();i.lastActivity.set(i.leadAgentId,r);for(let a of i.teammateIds)i.lastActivity.set(a,r)}getTeamHealth(e){let t=this.teams.get(e);if(!t)return;let n=[t.leadAgentId,...t.teammateIds],i=n.length,r=0,a=0,o=0;for(let c of n)if(this.adapter.isRegistered(c)){r++;let u=this.adapter.getUnreadCount(c);o+=u,u===0&&a++}let l=t.taskCount-t.completedCount;return{domain:e,teamSize:i,activeAgents:r,idleAgents:a,pendingMessages:o,tasksPending:l,tasksCompleted:t.completedCount,healthy:r>0&&r===i&&l<this.config.scaleUpThreshold*2}}scaleTeam(e,t){let n=this.teams.get(e);if(!n)throw new Error(`No domain team found for '${e}'. Create a team first with createDomainTeam().`);let i=Math.max(this.getMaxTeamSize(e),t,this.config.maxActiveTeams),r=Math.max(1,Math.min(t,i)),a=1+n.teammateIds.length,o=[],l=[];if(r>a){let c=r-a;for(let u=0;u<c;u++){let d=`${e}-teammate-${Date.now()}-${u}`;n.teammateIds.push(d),n.lastActivity.set(d,Date.now()),this.adapter.registerAgent(d,e),o.push(d)}}else if(r<a){let c=a-r;for(let u=0;u<c;u++){let d=n.teammateIds.pop();d&&(n.lastActivity.delete(d),this.adapter.unregisterAgent(d),l.push(d))}}return{domain:e,previousSize:a,newSize:1+n.teammateIds.length,addedAgents:o,removedAgents:l}}getIdleTeammates(e){if(e){let n=this.teams.get(e);return n?this.getIdleAgentsForTeam(n):[]}let t=[];for(let n of this.teams.values())t.push(...this.getIdleAgentsForTeam(n));return t}rebalance(){let e=[],t=new Set,n=Array.from(this.teams.values(),a=>{let o=this.getTargetTeamSize(a.domain),l=1+a.teammateIds.length,c=this.getIdleAgentsForTeam(a).filter(u=>u!==a.leadAgentId);return{domain:a.domain,team:a,currentSize:l,targetSize:o,idleTeammates:c}}),i=n.filter(a=>a.currentSize>a.targetSize&&a.idleTeammates.length>0).sort((a,o)=>o.currentSize-o.targetSize-(a.currentSize-a.targetSize)),r=n.filter(a=>a.currentSize<a.targetSize).sort((a,o)=>a.currentSize-a.targetSize-(o.currentSize-o.targetSize));for(let a of i)for(let o of r){if(o.currentSize>=o.targetSize)continue;if(a.idleTeammates.length===0)break;if(o.currentSize>=this.getMaxTeamSize(o.domain))continue;let l=a.idleTeammates.shift(),c=a.team.teammateIds.indexOf(l);c>=0&&a.team.teammateIds.splice(c,1),a.team.lastActivity.delete(l),a.currentSize--,this.adapter.unregisterAgent(l),this.adapter.registerAgent(l,o.domain),o.team.teammateIds.push(l),o.team.lastActivity.set(l,Date.now()),o.currentSize++,e.push({agentId:l,fromDomain:a.domain,toDomain:o.domain}),t.add(a.domain),t.add(o.domain)}return{moves:e,teamsAffected:t.size}}dispose(){for(let e of this.teams.values())for(let t of[e.leadAgentId,...e.teammateIds])this.adapter.unregisterAgent(t);this.teams.clear(),this.systemAgentRegistered&&(this.adapter.unregisterAgent(s.SYSTEM_AGENT_ID),this.systemAgentRegistered=!1)}markTaskCompleted(e){let t=this.teams.get(e);return t?(t.completedCount<t.taskCount&&t.completedCount++,!0):!1}ensureSystemAgent(){this.systemAgentRegistered||(this.adapter.registerAgent(s.SYSTEM_AGENT_ID,s.SYSTEM_DOMAIN),this.systemAgentRegistered=!0)}getMaxTeamSize(e){return this.config.domainTeamSizes&&e in this.config.domainTeamSizes?this.config.domainTeamSizes[e]:this.config.defaultTeamSize}getTargetTeamSize(e){return this.getMaxTeamSize(e)}getIdleAgentsForTeam(e){let t=[];for(let n of[e.leadAgentId,...e.teammateIds])this.adapter.isRegistered(n)&&this.adapter.getUnreadCount(n)===0&&t.push(n);return t}toSnapshot(e){return{domain:e.domain,leadAgentId:e.leadAgentId,teammateIds:[...e.teammateIds],createdAt:e.createdAt,taskCount:e.taskCount,completedCount:e.completedCount}}};function He(s,e){return new ee(s,e)}k();var ne={failureThreshold:3,resetTimeoutMs:6e4,halfOpenSuccessThreshold:2,failureWindowMs:12e4,cascadeEnabled:!1,cascadeTargets:void 0},te=class extends Error{domain;retryAfterMs;constructor(e,t){let n=t!=null?` (retry after ${t}ms)`:"";super(`Circuit breaker is open for domain '${e}'${n}`),this.name="DomainCircuitOpenError",this.domain=e,this.retryAfterMs=t}},D=class{state="closed";failures=[];totalRequests=0;totalSuccesses=0;totalFailures=0;rejectedCount=0;lastFailureTime;lastSuccessTime;openedAt;halfOpenSuccesses=0;config;stateChangeHandlers=new Set;domain;constructor(e,t){this.domain=e,this.config={...ne,...t}}canExecute(){let e=this.getState();return e==="closed"?!0:e!=="open"}async execute(e){if(this.totalRequests++,this.getState()==="open")throw this.rejectedCount++,this.emitEvent({type:"request-rejected",domain:this.domain,timestamp:Date.now(),metadata:{retryAfterMs:this.getTimeUntilTransition()}}),new te(this.domain,this.getTimeUntilTransition());try{let n=await e();return this.recordSuccess(),n}catch(n){throw this.recordFailure(lt(n)),n}}recordSuccess(){this.totalSuccesses++,this.lastSuccessTime=Date.now(),this.getState()==="half-open"&&(this.halfOpenSuccesses++,console.log(`[DomainCircuitBreaker:${this.domain}] Half-open success ${this.halfOpenSuccesses}/${this.config.halfOpenSuccessThreshold}`),this.halfOpenSuccesses>=this.config.halfOpenSuccessThreshold&&this.transitionTo("closed"))}recordFailure(e){this.totalFailures++,this.lastFailureTime=Date.now(),this.failures.push({timestamp:Date.now(),message:e.message}),this.cleanOldFailures();let t=this.getState();if(t==="half-open"){console.log(`[DomainCircuitBreaker:${this.domain}] Failure in half-open state, re-opening`),this.transitionTo("open");return}t==="closed"&&this.failures.length>=this.config.failureThreshold&&(console.log(`[DomainCircuitBreaker:${this.domain}] Failure threshold reached (${this.failures.length}/${this.config.failureThreshold}), opening circuit`),this.transitionTo("open"))}getState(){return this.state==="open"&&this.openedAt!=null&&Date.now()-this.openedAt>=this.config.resetTimeoutMs&&this.transitionTo("half-open"),this.state}getStats(){let e=this.getState();return{domain:this.domain,state:e,totalRequests:this.totalRequests,successCount:this.totalSuccesses,failureCount:this.totalFailures,rejectedCount:this.rejectedCount,lastFailureTime:this.lastFailureTime,lastSuccessTime:this.lastSuccessTime,openedAt:this.openedAt,timeUntilHalfOpen:e==="open"?this.getTimeUntilTransition():void 0,consecutiveSuccesses:this.halfOpenSuccesses}}reset(){let e=this.state;this.state="closed",this.failures=[],this.halfOpenSuccesses=0,this.openedAt=void 0,e!=="closed"&&(console.log(`[DomainCircuitBreaker:${this.domain}] Manually reset from '${e}' to 'closed'`),this.emitEvent({type:"state-change",domain:this.domain,previousState:e,newState:"closed",timestamp:Date.now(),metadata:{trigger:"manual-reset"}}))}forceOpen(){console.log(`[DomainCircuitBreaker:${this.domain}] Force-opening circuit`),this.transitionTo("open")}getRecentFailures(e=5){return this.failures.slice(-e).map(t=>`[${new Date(t.timestamp).toISOString()}] ${t.message}`)}onStateChange(e){return this.stateChangeHandlers.add(e),()=>{this.stateChangeHandlers.delete(e)}}getConfig(){return this.config}transitionTo(e){let t=this.state;if(t!==e){switch(this.state=e,e){case"open":this.openedAt=Date.now(),this.halfOpenSuccesses=0;break;case"half-open":this.halfOpenSuccesses=0,console.log(`[DomainCircuitBreaker:${this.domain}] Transitioning to half-open, allowing probe requests`);break;case"closed":this.failures=[],this.openedAt=void 0,this.halfOpenSuccesses=0,console.log(`[DomainCircuitBreaker:${this.domain}] Circuit closed, domain is healthy`);break}this.emitEvent({type:"state-change",domain:this.domain,previousState:t,newState:e,timestamp:Date.now()})}}cleanOldFailures(){let e=Date.now()-this.config.failureWindowMs;this.failures=this.failures.filter(t=>t.timestamp>e)}getTimeUntilTransition(){if(this.state==="open"&&this.openedAt!=null){let e=Date.now()-this.openedAt,t=this.config.resetTimeoutMs-e;return Math.max(0,t)}}emitEvent(e){for(let t of this.stateChangeHandlers)try{t(e)}catch(n){console.log(`[DomainCircuitBreaker:${this.domain}] State change handler error: ${p(n)}`)}}};k();var Fe={critical:{failureThreshold:2,resetTimeoutMs:3e4,halfOpenSuccessThreshold:2,failureWindowMs:6e4,cascadeEnabled:!1,cascadeTargets:void 0},standard:{failureThreshold:3,resetTimeoutMs:6e4,halfOpenSuccessThreshold:2,failureWindowMs:12e4,cascadeEnabled:!1,cascadeTargets:void 0},lenient:{failureThreshold:5,resetTimeoutMs:12e4,halfOpenSuccessThreshold:3,failureWindowMs:3e5,cascadeEnabled:!1,cascadeTargets:void 0}},Bt={"test-generation":"critical","test-execution":"critical","coverage-analysis":"critical","quality-assessment":"critical","security-compliance":"critical","defect-intelligence":"standard","requirements-validation":"standard","code-intelligence":"standard","contract-testing":"standard","visual-accessibility":"lenient","chaos-resilience":"lenient","learning-optimization":"lenient","enterprise-integration":"standard"},O=class{breakers=new Map;defaultConfig;globalHandlers=new Set;constructor(e){this.defaultConfig={...ne,...e}}getBreaker(e){let t=this.breakers.get(e);if(!t){let n=Bt[e],i=n?{...this.defaultConfig,...Fe[n]}:this.defaultConfig;t=new D(e,i),this.breakers.set(e,t),t.onStateChange(r=>this.handleBreakerEvent(r)),console.log(`[DomainBreakerRegistry] Created breaker for '${e}' (criticality: ${n??"default"})`)}return t}configureBreaker(e,t){let n={...this.defaultConfig,...t},i=new D(e,n);i.onStateChange(r=>this.handleBreakerEvent(r)),this.breakers.set(e,i),console.log(`[DomainBreakerRegistry] Reconfigured breaker for '${e}'`)}configureCriticality(e,t){let n=Fe[t];this.configureBreaker(e,n),console.log(`[DomainBreakerRegistry] Set '${e}' criticality to '${t}'`)}canExecuteInDomain(e){return this.getBreaker(e).canExecute()}async executeInDomain(e,t){return this.getBreaker(e).execute(t)}getAllStats(){let e=new Map;for(let[t,n]of this.breakers)e.set(t,n.getStats());return e}getOpenDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="open"&&e.push(t);return e}getHealthyDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="closed"&&e.push(t);return e}getDegradedDomains(){let e=[];for(let[t,n]of this.breakers)n.getState()==="half-open"&&e.push(t);return e}getHealthSummary(){let e=0,t=0,n=0;for(let i of this.breakers.values())switch(i.getState()){case"closed":e++;break;case"half-open":t++;break;case"open":n++;break}return{healthy:e,degraded:t,open:n,total:this.breakers.size}}resetAll(){for(let e of this.breakers.values())e.reset();console.log(`[DomainBreakerRegistry] Reset all ${this.breakers.size} breakers`)}reset(e){let t=this.breakers.get(e);t&&t.reset()}onAnyStateChange(e){return this.globalHandlers.add(e),()=>{this.globalHandlers.delete(e)}}handleBreakerEvent(e){for(let t of this.globalHandlers)try{t(e)}catch(n){console.log(`[DomainBreakerRegistry] Global handler error: ${p(n)}`)}e.type==="state-change"&&e.newState==="open"&&this.propagateCascade(e.domain)}propagateCascade(e){let t=this.breakers.get(e);if(!t)return;let n=t.getConfig();if(!(!n.cascadeEnabled||!n.cascadeTargets?.length))for(let i of n.cascadeTargets){if(i===e)continue;let r=this.getBreaker(i);if(r.getState()!=="open"){console.log(`[DomainBreakerRegistry] Cascading open from '${e}' to '${i}'`),r.forceOpen();let o={type:"cascade-triggered",domain:i,timestamp:Date.now(),metadata:{sourceDomain:e,cascadedFrom:e}};for(let l of this.globalHandlers)try{l(o)}catch(c){console.log(`[DomainBreakerRegistry] Cascade event handler error: ${p(c)}`)}}}}};function Qt(s){return new O(s)}var A=["smoke","standard","deep","crisis"];var N=["test-generation","test-execution","coverage-analysis","quality-assessment","defect-intelligence","requirements-validation","code-intelligence","security-compliance","contract-testing","visual-accessibility","chaos-resilience","learning-optimization","enterprise-integration"],ie=["test-generation","coverage-analysis","quality-assessment"],Oe={"test-generation":["generator","specialist"],"test-execution":["tester","coordinator"],"coverage-analysis":["analyzer","specialist"],"quality-assessment":["analyzer","validator"],"defect-intelligence":["analyzer","specialist"],"requirements-validation":["validator","reviewer"],"code-intelligence":["analyzer","specialist"],"security-compliance":["analyzer","validator"],"contract-testing":["tester","validator"],"visual-accessibility":["tester","validator"],"chaos-resilience":["tester","specialist"],"learning-optimization":["optimizer","specialist"],"enterprise-integration":["coordinator","validator"]},Un={tier:"smoke",maxAgents:3,agentTeamsEnabled:!1,domains:["test-execution","quality-assessment"],estimatedCost:"minimal",description:"Lightweight smoke test on every commit. Runs core test execution and quality assessment with minimal agent count to catch obvious regressions quickly.",triggers:[{type:"commit"},{type:"schedule",conditions:{interval:"hourly"}}]},Gn={tier:"standard",maxAgents:7,agentTeamsEnabled:!1,domains:["test-generation","test-execution","coverage-analysis","quality-assessment","security-compliance"],estimatedCost:"moderate",description:"Standard validation for pull requests. Covers test generation, execution, coverage, quality, and security across up to 7 agents. Agent teams are optional.",triggers:[{type:"pr"},{type:"manual"}]},zn={tier:"deep",maxAgents:15,agentTeamsEnabled:!0,domains:[...N],estimatedCost:"high",description:"Deep validation for pre-release and critical path changes. Activates all 13 domains with up to 15 agents and full agent team collaboration.",triggers:[{type:"release"},{type:"pr",conditions:{criticalPath:!0}},{type:"manual",conditions:{requestedTier:"deep"}}]},qn={tier:"crisis",maxAgents:15,agentTeamsEnabled:!0,domains:[...N],estimatedCost:"unlimited",description:"Crisis response for production incidents. All domains active with competing hypotheses enabled. Unlimited cost budget to resolve incidents as fast as possible.",triggers:[{type:"incident"},{type:"manual",conditions:{requestedTier:"crisis"}}]},Ne={smoke:Un,standard:Gn,deep:zn,crisis:qn};var jn=["password","secret","token","crypto","auth","credential","jwt","oauth"],Wn=["async","await","Promise","setTimeout","setInterval","Worker","mutex","lock"],Vn={securityKeywords:jn,concurrencyKeywords:Wn,enableDimensionOverrides:!1};function Kn(s,e){let t=s+e;return t<=8?"trivial":t<=20?"simple":t<=40?"moderate":t<=70?"complex":"critical"}var L=class{config;constructor(e){this.config={...Vn,...e}}analyzeExtendedDimensions(e){let t=e.split(`
|
|
167
|
+
`),n=Math.max(t.length,1),i=this.countKeywordLines(t,this.config.securityKeywords),r=re(i/n,0,1),a=this.countKeywordLines(t,this.config.concurrencyKeywords),o=re(a/n,0,1),l=this.countPatternMatches(e,/\.(map|filter|reduce|flatMap|forEach)\s*\(/g),c=re(l/n,0,1),u=this.countPatternMatches(e,/^export\s/gm),d=Math.max(this.countPatternMatches(e,/^(export\s+)?(const|let|var|function|class|interface|type|enum)\s/gm),1),g=re(u/d,0,1);return{securitySurface:r,concurrency:o,dataFlow:c,apiSurface:g}}compose(e,t,n){let i=Kn(e.cyclomatic,e.cognitive),r=this.analyzeExtendedDimensions(n),a=[],o=[],l;switch(i){case"trivial":case"simple":a.push({agentType:"qe-test-generator",priority:1,reason:`${i} complexity \u2014 basic test generation sufficient`}),o.push("unit"),l="haiku";break;case"moderate":a.push({agentType:"qe-test-generator",priority:1,reason:"Moderate complexity requires thorough test generation"},{agentType:"qe-code-intelligence",priority:2,reason:"Moderate complexity benefits from code intelligence analysis"}),o.push("unit","integration"),l="sonnet";break;case"complex":a.push({agentType:"qe-test-generator",priority:1,reason:"Complex code needs comprehensive test generation"},{agentType:"qe-security-scanner",priority:2,reason:"High complexity warrants security analysis"},{agentType:"qe-code-intelligence",priority:2,reason:"Complex code requires deep code intelligence"}),o.push("unit","integration","security"),l="sonnet";break;case"critical":a.push({agentType:"qe-test-generator",priority:1,reason:"Critical complexity demands full test generation"},{agentType:"qe-security-scanner",priority:1,reason:"Critical complexity mandates security scanning"},{agentType:"qe-code-intelligence",priority:1,reason:"Critical complexity requires deep analysis"},{agentType:"qe-chaos-resilience",priority:2,reason:"Critical systems need chaos/resilience testing"},{agentType:"qe-performance",priority:2,reason:"Critical complexity warrants performance analysis"}),o.push("unit","integration","security","chaos","performance"),l="opus";break}return r.securitySurface>.3&&(a.some(c=>c.agentType==="qe-security-scanner")||a.push({agentType:"qe-security-scanner",priority:2,reason:`High security surface (${(r.securitySurface*100).toFixed(0)}%) \u2014 security scanning recommended`}),o.includes("security")||o.push("security")),r.concurrency>.3&&(a.some(c=>c.agentType==="qe-chaos-resilience")||a.push({agentType:"qe-chaos-resilience",priority:2,reason:`High concurrency (${(r.concurrency*100).toFixed(0)}%) \u2014 chaos/resilience testing recommended`}),o.includes("chaos")||o.push("chaos")),r.apiSurface>.5&&(o.includes("integration")||o.push("integration")),a.sort((c,u)=>c.priority-u.priority),{agents:a,testTypes:o,recommendedTier:l,complexityCategory:i}}countKeywordLines(e,t){let n=0;for(let i of e)for(let r of t)if(i.includes(r)){n++;break}return n}countPatternMatches(e,t){let n=e.match(t);return n?n.length:0}};function re(s,e,t){return Math.max(e,Math.min(t,s))}var $t=200,Ut=10,Gt=3,ae=class{configs;history=[];escalationCount=0;deescalationCount=0;constructor(e){this.configs={...Ne,...e}}selectTier(e){let t,n;if(e.manualOverride)return t=e.manualOverride,n=`Manual override to "${t}" tier`,this.buildResult(t,n,e);if(e.trigger==="incident"||e.isHotfix)return t="crisis",n=e.isHotfix?"Hotfix deployment triggers crisis-level validation":"Production incident triggers crisis-level response",this.buildResult(t,n,e);if(e.trigger==="release")return t="deep",n="Pre-release validation requires deep tier across all domains",this.buildResult(t,n,e);if(e.trigger==="pr"){let i=e.changedFiles!==void 0&&e.changedFiles>Ut,r=e.affectedDomains!==void 0&&e.affectedDomains.length>Gt;if(i||r){t="deep";let a=[];return i&&a.push(`>${Ut} changed files (${e.changedFiles})`),r&&a.push(`>${Gt} affected domains (${e.affectedDomains.length})`),n=`PR escalated to deep tier: ${a.join(" and ")}`,this.buildResult(t,n,e)}return t="standard",n="Pull request triggers standard tier validation",this.buildResult(t,n,e)}return t="smoke",n=e.trigger==="commit"?"Commit triggers lightweight smoke validation":`Trigger "${e.trigger}" defaults to smoke tier`,this.buildResult(t,n,e)}allocateAgents(e,t){let n=this.resolveTargetDomains(e,t);if(n.length===0)return[];let i=e.maxAgents;return n.length>=i?this.allocateWithPriority(n,i):this.allocateWithSurplus(n,i)}escalate(e,t){let n=A.indexOf(e),i=Math.min(n+1,A.length-1),r=A[i],a=e!==r,o=a?`Escalated from "${e}" to "${r}": ${t}`:`Already at maximum tier "${e}", cannot escalate further`;return a&&this.escalationCount++,this.buildResult(r,o,{trigger:"manual"})}deescalate(e){let t=A.indexOf(e),n=Math.max(t-1,0),i=A[n],r=e!==i,a=r?`De-escalated from "${e}" to "${i}"`:`Already at minimum tier "${e}", cannot de-escalate further`;return r&&this.deescalationCount++,this.buildResult(i,a,{trigger:"manual"})}getStats(){let e={smoke:0,standard:0,deep:0,crisis:0};for(let t of this.history)e[t.tier]++;return{totalSelections:this.history.length,selectionsByTier:e,escalationCount:this.escalationCount,deescalationCount:this.deescalationCount,recentSelections:[...this.history].slice(-20)}}_teamComposer;setTeamComposer(e){this._teamComposer=e}selectTierWithComposition(e,t,n){let i=this.selectTier(e);if(!t||!n)return{...i,composition:void 0};let a=(this._teamComposer??new L).compose(t,i.selectedTier,n);return{...i,composition:a}}buildResult(e,t,n){let i=this.configs[e],r=this.allocateAgents(i,n.affectedDomains),a={tier:e,reason:t,timestamp:Date.now(),trigger:n.trigger};return this.history.push(a),this.history.length>$t&&this.history.splice(0,this.history.length-$t),{selectedTier:e,config:i,reason:t,agentAllocation:r}}resolveTargetDomains(e,t){let n=e.domains.includes("all")?N:e.domains;if(!t||t.length===0)return[...n];let i=new Set(n),r=t.filter(a=>i.has(a));return r.length>0?r:[...n]}allocateWithPriority(e,t){let n=new Set(ie),i=[],r=t,a=e.filter(l=>n.has(l)),o=e.filter(l=>!n.has(l));for(let l of a){if(r<=0)break;i.push(this.createAllocation(l,1)),r--}for(let l of o){if(r<=0)break;i.push(this.createAllocation(l,1)),r--}return i}allocateWithSurplus(e,t){let n=new Set(ie),i=new Map;for(let u of e)i.set(u,1);let r=t-e.length,a=e.filter(u=>n.has(u)),o=e.filter(u=>!n.has(u)),l=0;for(;r>0&&a.length>0;){let u=a[l%a.length];if(i.set(u,(i.get(u)??0)+1),r--,l++,l>=a.length*2)break}let c=0;for(;r>0&&o.length>0;){let u=o[c%o.length];i.set(u,(i.get(u)??0)+1),r--,c++}for(;r>0&&a.length>0;){let u=a[l%a.length];i.set(u,(i.get(u)??0)+1),r--,l++}return e.map(u=>this.createAllocation(u,i.get(u)??1))}createAllocation(e,t){let n=Oe[e]??["specialist"];return{domain:e,agentCount:t,agentTypes:[...n]}}};function Le(s){return new ae(s)}k();var oe={enabled:!0,minQualityScore:.6,rejectOnFailure:!0,gates:[{name:"test-pass-rate",type:"test-pass-rate",threshold:.8,weight:.35,required:!0},{name:"coverage",type:"coverage",threshold:0,weight:.25,required:!1},{name:"security",type:"security",threshold:0,weight:.25,required:!0},{name:"performance",type:"performance",threshold:3e4,weight:.15,required:!1}]},se=class{config;constructor(e={}){this.config={...oe,...e},e.gates&&(this.config={...this.config,gates:e.gates})}evaluate(e){if(!this.config.enabled)return console.log("[QualityGateEnforcer] Gates disabled, auto-passing"),{passed:!0,score:1,exitCode:0,gates:[],reason:"Quality gates disabled"};if(e.status==="failed")return console.log(`[QualityGateEnforcer] Task ${e.taskId} has failed status`),{passed:!1,score:0,exitCode:this.config.rejectOnFailure?2:0,gates:[],reason:"Task reported failed status"};let t=[],n=[];for(let d of this.config.gates){let g=this.checkGate(d,e);t.push(g),!g.passed&&d.required&&n.push(d.name)}let i=this.config.gates.reduce((d,g)=>d+g.weight,0),r=i>0?t.reduce((d,g)=>{let h=this.config.gates.find(U=>U.name===g.gate);if(!h)return d;let b=g.passed?1:this.computePartialScore(g);return d+b*(h.weight/i)},0):1,a=n.length>0,o=r<this.config.minQualityScore,l=!a&&!o,c;if(!l){let d=[];a&&d.push(`Required gates failed: ${n.join(", ")}`),o&&d.push(`Score ${r.toFixed(3)} below minimum ${this.config.minQualityScore}`),c=d.join("; ")}let u=!l&&this.config.rejectOnFailure?2:0;return console.log(`[QualityGateEnforcer] Task ${e.taskId}: ${l?"PASSED":"FAILED"} (score=${r.toFixed(3)}, gates=${t.filter(d=>d.passed).length}/${t.length})`),{passed:l,score:r,exitCode:u,gates:t,reason:c}}getConfig(){return{...this.config}}checkGate(e,t){let n=this.extractMetricForGate(e,t),i=this.meetsThreshold(e,n);return{gate:e.name,passed:i,actual:n,threshold:e.threshold,weight:e.weight}}extractMetricForGate(e,t){let n=t.metrics;switch(e.type){case"coverage":return n.coverageChange??0;case"test-pass-rate":{let i=n.testsPassed??0,r=n.testsFailed??0,a=i+r;return a>0?i/a:1}case"security":return n.securityIssues??0;case"performance":return n.performanceMs??t.duration;case"custom":{let i=t.output[e.name];return typeof i=="number"?i:0}default:return 0}}meetsThreshold(e,t){switch(e.type){case"security":return t<=e.threshold;case"performance":return t<=e.threshold;default:return t>=e.threshold}}computePartialScore(e){let t=this.config.gates.find(n=>n.name===e.gate);if(!t)return 0;switch(t.type){case"security":case"performance":{if(t.threshold===0)return 0;let n=t.threshold/e.actual;return Math.max(0,Math.min(1,n))}default:{if(t.threshold===0)return 1;let n=e.actual/t.threshold;return Math.max(0,Math.min(1,n))}}}};var Yn={trainPatterns:!0,qualityGate:oe,patternDomains:["test-generation","coverage-analysis","security-compliance","quality-assessment","defect-intelligence","contract-testing"],emitEvents:!0,maxPatternsPerTask:5},Zn={"test-generation":{types:["test-template","assertion-pattern","mock-pattern"],contentKeys:["testCode","template","assertions","mocks"],baseConfidence:.6},"coverage-analysis":{types:["coverage-strategy","mutation-strategy"],contentKeys:["coverageReport","gaps","strategy","recommendations"],baseConfidence:.55},"security-compliance":{types:["security-pattern","vulnerability-fix"],contentKeys:["findings","fixes","recommendations","rules"],baseConfidence:.5},"quality-assessment":{types:["quality-rule","threshold-pattern"],contentKeys:["rules","thresholds","assessments"],baseConfidence:.5},"defect-intelligence":{types:["defect-pattern","root-cause"],contentKeys:["rootCause","pattern","prediction","analysis"],baseConfidence:.45},"contract-testing":{types:["api-contract","schema-pattern"],contentKeys:["contract","schema","endpoints","violations"],baseConfidence:.55},"test-execution":{types:["flaky-fix","retry-strategy"],contentKeys:["flakyTests","retryPolicy","stabilization"],baseConfidence:.5},"visual-accessibility":{types:["visual-baseline","a11y-check"],contentKeys:["baseline","violations","wcagResults"],baseConfidence:.5},"chaos-resilience":{types:["perf-benchmark","resilience-pattern"],contentKeys:["benchmark","faultInjection","recoveryTime"],baseConfidence:.45}},le=class{config;gateEnforcer;patternStore;completionHandlers=new Set;stats={totalProcessed:0,accepted:0,rejected:0,patternsExtracted:0};constructor(e={},t){this.config={...Yn,...e},e.qualityGate&&(this.config={...this.config,qualityGate:{...oe,...e.qualityGate}}),this.gateEnforcer=new se(this.config.qualityGate),this.patternStore=t??null}async onTaskCompleted(e){this.stats.totalProcessed++,console.log(`[TaskCompletedHook] Processing task ${e.taskId} (agent=${e.agentId}, domain=${e.domain}, status=${e.status})`);let t=this.gateEnforcer.evaluate(e);if(!t.passed&&this.config.qualityGate.rejectOnFailure){this.stats.rejected++;let r={action:"reject",exitCode:2,reason:t.reason||"Quality gate check failed",gateResult:t};return console.log(`[TaskCompletedHook] Task ${e.taskId} REJECTED: ${r.reason}`),this.emitCompletion(e.taskId,r),r}let n=0;if(this.config.trainPatterns&&this.patternStore){let r=this.extractPatterns(e);n=await this.storePatterns(r,e),this.stats.patternsExtracted+=n}this.stats.accepted++;let i={action:"accept",patternsExtracted:n};return console.log(`[TaskCompletedHook] Task ${e.taskId} ACCEPTED (score=${t.score.toFixed(3)}, patterns=${n})`),this.emitCompletion(e.taskId,i),i}extractPatterns(e){let t=[],n=e.domain;if(!this.config.patternDomains.includes(n))return t;let i=Zn[n];if(!i)return this.extractGenericPatterns(e);let r=this.computeConfidenceBoost(e.metrics);for(let a of i.types){if(t.length>=this.config.maxPatternsPerTask)break;for(let o of i.contentKeys){if(t.length>=this.config.maxPatternsPerTask)break;let l=e.output[o];if(l==null)continue;let c=typeof l=="string"?l:JSON.stringify(l);if(c.length<10)continue;let u=Math.min(1,i.baseConfidence+r);t.push({domain:n,type:a,content:c,confidence:u,metadata:{sourceTaskId:e.taskId,sourceAgent:e.agentId,taskType:e.type,duration:e.duration,extractedFrom:o,timestamp:e.timestamp}})}}return t}onCompletion(e){this.completionHandlers.add(e)}offCompletion(e){this.completionHandlers.delete(e)}getStats(){return{...this.stats}}resetStats(){this.stats={totalProcessed:0,accepted:0,rejected:0,patternsExtracted:0}}async storePatterns(e,t){if(!this.patternStore||e.length===0)return 0;let n=0;for(let i of e)try{let r=await this.patternStore.store(i),a=t.status==="completed";await this.patternStore.recordOutcome(r,a),n++}catch(r){console.error(`[TaskCompletedHook] Failed to store pattern: ${p(r)}`)}return n>0&&console.log(`[TaskCompletedHook] Stored ${n}/${e.length} patterns from task ${t.taskId}`),n}extractGenericPatterns(e){let t=[];for(let[n,i]of Object.entries(e.output)){if(t.length>=this.config.maxPatternsPerTask)break;if(i==null)continue;let r=typeof i=="string"?i:JSON.stringify(i);r.length<10||t.push({domain:e.domain,type:"generic",content:r,confidence:.3+this.computeConfidenceBoost(e.metrics),metadata:{sourceTaskId:e.taskId,sourceAgent:e.agentId,taskType:e.type,extractedFrom:n,timestamp:e.timestamp}})}return t}computeConfidenceBoost(e){let t=0,n=e.testsPassed??0,i=e.testsFailed??0,r=n+i;return r>0&&(t+=n/r*.15),e.coverageChange!==void 0&&e.coverageChange>0&&(t+=Math.min(.1,e.coverageChange*.5)),e.securityIssues!==void 0&&e.securityIssues===0&&(t+=.1),e.performanceMs!==void 0&&e.performanceMs<5e3&&(t+=.05),Math.min(.4,t)}emitCompletion(e,t){if(this.config.emitEvents)for(let n of this.completionHandlers)try{n(e,t)}catch(i){console.error(`[TaskCompletedHook] Completion handler error: ${p(i)}`)}}};k();var Xn={"test-template":"test-template","assertion-pattern":"assertion-pattern","mock-pattern":"mock-pattern","coverage-strategy":"coverage-strategy","mutation-strategy":"mutation-strategy","security-pattern":"error-handling","vulnerability-fix":"error-handling","quality-rule":"test-template","threshold-pattern":"test-template","defect-pattern":"error-handling","root-cause":"error-handling","api-contract":"api-contract","schema-pattern":"api-contract","flaky-fix":"flaky-fix","retry-strategy":"flaky-fix","visual-baseline":"visual-baseline","a11y-check":"a11y-check","perf-benchmark":"perf-benchmark","resilience-pattern":"perf-benchmark",generic:"test-template"};function Jn(s){return Xn[s]??"test-template"}function ei(s){let e=fe(s.domain);if(e)return e;let t=fe(s.content);return t||"test-generation"}function ti(s){let e=0;for(let t=0;t<s.length;t++){let n=s.charCodeAt(t);e=(e<<5)-e+n,e=e&e}return Math.abs(e).toString(36).slice(0,8)}var ce=class{constructor(e){this.reasoningBank=e}async store(e){let t=ei(e),n=Jn(e.type),i=ti(e.content),r=`${t}-${e.type}-${i}`,a=[t,e.type,...e.metadata.sourceTaskId?[`task:${e.metadata.sourceTaskId}`]:[]],o={patternType:n,name:r,description:`Auto-extracted ${e.type} pattern from ${e.domain} domain`,template:{type:"prompt",content:e.content,variables:[]},context:{tags:a},confidence:e.confidence};try{let l=await this.reasoningBank.storePattern(o);if(l.success)return l.value.id;throw console.error(`[ReasoningBankPatternStore] Failed to store pattern: ${l.error.message}`),l.error}catch(l){throw console.error(`[ReasoningBankPatternStore] Store error: ${p(l)}`),l}}async recordOutcome(e,t){let n={patternId:e,success:t};try{let i=await this.reasoningBank.recordOutcome(n);i.success||console.error(`[ReasoningBankPatternStore] Failed to record outcome: ${i.error.message}`)}catch(i){console.error(`[ReasoningBankPatternStore] recordOutcome error: ${p(i)}`)}}};un();var Be={maxHypothesesPerInvestigation:5,convergenceThreshold:.2,investigationTimeoutMs:3e5,minEvidenceForConvergence:3,autoRejectThreshold:.15};import{randomUUID as Qe}from"node:crypto";var ue=class{investigations=new Map;config;constructor(e){this.config={...Be,...e}}createInvestigation(e,t,n){let i=`inv-${Qe().slice(0,8)}`,r=Date.now(),a={id:i,taskId:e,domain:t,description:n,hypotheses:[],status:"open",maxHypotheses:this.config.maxHypothesesPerInvestigation,convergenceThreshold:this.config.convergenceThreshold,createdAt:r,updatedAt:r};return this.investigations.set(i,a),this.toSnapshot(a)}addHypothesis(e,t,n,i){let r=this.getInvestigationMutable(e);if(r.hypotheses.length>=r.maxHypotheses)throw new Error(`Investigation ${e} already has ${r.maxHypotheses} hypotheses (max)`);let a={id:`hyp-${Qe().slice(0,8)}`,description:t,investigatorAgentId:i,strategy:n,status:"pending",evidence:[],confidenceScore:.5,createdAt:Date.now(),updatedAt:Date.now()};return r.hypotheses.push(a),r.updatedAt=Date.now(),r.status==="open"&&(r.status="investigating"),a}startHypothesis(e,t){let n=this.getInvestigationMutable(e),i=this.findHypothesis(n,t);if(i.status!=="pending")throw new Error(`Hypothesis ${t} cannot be started (current status: ${i.status})`);i.status="investigating",i.updatedAt=Date.now(),n.updatedAt=Date.now()}completeHypothesis(e,t){let n=this.getInvestigationMutable(e),i=this.findHypothesis(n,t);i.status="completed",i.updatedAt=Date.now(),n.updatedAt=Date.now()}submitEvidence(e,t,n){let i=this.getInvestigationMutable(e),r=this.findHypothesis(i,t),a={...n,id:`evi-${Qe().slice(0,8)}`,hypothesisId:t,timestamp:Date.now()};return r.evidence.push(a),r.confidenceScore=this.calculateConfidence(r),r.updatedAt=Date.now(),i.updatedAt=Date.now(),r.confidenceScore<this.config.autoRejectThreshold&&r.evidence.length>=2&&(r.status="rejected"),a}converge(e){let t=this.getInvestigationMutable(e),n=t.hypotheses.reduce((c,u)=>c+u.evidence.length,0);if(n<this.config.minEvidenceForConvergence){t.status="inconclusive";let c={winningHypothesisId:null,confidence:0,evidenceSummary:`Insufficient evidence (${n}/${this.config.minEvidenceForConvergence} required)`,rejectedHypotheses:t.hypotheses.filter(u=>u.status==="rejected").map(u=>u.id),method:"evidence-scoring"};return t.convergenceResult=c,t.updatedAt=Date.now(),c}let i=[...t.hypotheses].filter(c=>c.status!=="rejected").sort((c,u)=>u.confidenceScore-c.confidenceScore),r="evidence-scoring",a=null,o=0;i.length===0?t.status="inconclusive":i.length===1?(a=i[0].id,o=i[0].confidenceScore,r="unanimous",t.status="converged"):i[0].confidenceScore-i[1].confidenceScore>=t.convergenceThreshold?(a=i[0].id,o=i[0].confidenceScore,t.status="converged"):t.status="inconclusive";let l={winningHypothesisId:a,confidence:o,evidenceSummary:this.buildEvidenceSummary(t),rejectedHypotheses:t.hypotheses.filter(c=>c.status==="rejected").map(c=>c.id),method:r};return t.convergenceResult=l,t.updatedAt=Date.now(),l}getInvestigation(e){let t=this.investigations.get(e);return t?this.toSnapshot(t):void 0}listInvestigations(){return Array.from(this.investigations.values()).map(e=>this.toSnapshot(e))}getConfig(){return this.config}dispose(){this.investigations.clear()}getInvestigationMutable(e){let t=this.investigations.get(e);if(!t)throw new Error(`Investigation ${e} not found`);return t}findHypothesis(e,t){let n=e.hypotheses.find(i=>i.id===t);if(!n)throw new Error(`Hypothesis ${t} not found in investigation ${e.id}`);return n}calculateConfidence(e){if(e.evidence.length===0)return .5;let t=0,n=0;for(let r of e.evidence)r.supports?t+=r.weight:n+=r.weight;let i=t+n;return i===0?.5:Math.min(1,Math.max(0,t/i))}buildEvidenceSummary(e){let t=[];for(let n of e.hypotheses){let i=n.evidence.filter(a=>a.supports).length,r=n.evidence.filter(a=>!a.supports).length;t.push(`${n.id}: ${i} supporting, ${r} refuting (confidence: ${n.confidenceScore.toFixed(2)})`)}return t.join("; ")}toSnapshot(e){return{...e,hypotheses:e.hypotheses.map(t=>({...t,evidence:[...t.evidence]}))}}};function $e(s){return new ue(s)}import{randomUUID as ni}from"node:crypto";var Ue={localFleetId:"local",heartbeatIntervalMs:3e4,serviceTimeoutMs:9e4,maxPendingMessages:5e3,maxRoutes:100};var ge=class{config;services=new Map;routes=[];outbox=[];inbox=[];handlers=[];messagesSent=0;messagesReceived=0;constructor(e){this.config={...Ue,...e}}registerService(e,t,n,i){if(this.services.has(e))throw new Error(`Service '${e}' already registered`);let r=Date.now(),a={fleetId:e,name:t,domains:[...n],status:"active",registeredAt:r,lastHeartbeat:r,metadata:i};return this.services.set(e,a),de(a)}deregisterService(e){let t=this.services.get(e);if(!t)return!1;t.status="deregistered";for(let n=this.routes.length-1;n>=0;n--)this.routes[n].targetFleetId===e&&this.routes.splice(n,1);return this.services.delete(e),!0}heartbeat(e){let t=this.services.get(e);return t?(t.lastHeartbeat=Date.now(),(t.status==="degraded"||t.status==="unreachable")&&(t.status="active"),!0):!1}addRoute(e,t,n,i=0){if(this.routes.length>=this.config.maxRoutes)throw new Error(`Maximum routes (${this.config.maxRoutes}) reached`);let r={sourceDomain:e,targetDomain:t,targetFleetId:n,priority:i,active:!0};return this.routes.push(r),this.routes.sort((a,o)=>o.priority-a.priority),zt(r)}removeRoute(e,t){let n=this.routes.findIndex(i=>i.sourceDomain===e&&i.targetFleetId===t);return n<0?!1:(this.routes.splice(n,1),!0)}send(e,t,n,i,r,a){let o=e==="any"?this.resolveRoute(t,n):e;if(!o)throw new Error(`No route found for ${t} -> ${n}`);let l={id:ni(),sourceFleetId:this.config.localFleetId,targetFleetId:o,sourceDomain:t,targetDomain:n,type:i,payload:r,timestamp:Date.now(),ttl:a?.ttl,correlationId:a?.correlationId};return this.outbox.length>=this.config.maxPendingMessages&&this.outbox.shift(),this.outbox.push(l),this.messagesSent++,l}receive(e){this.inbox.length>=this.config.maxPendingMessages&&this.inbox.shift(),this.inbox.push(e),this.messagesReceived++;for(let t of this.handlers)try{t(e)}catch{}}onMessage(e){return this.handlers.push(e),()=>{let t=this.handlers.indexOf(e);t>=0&&this.handlers.splice(t,1)}}drainOutbox(){let e=[...this.outbox];return this.outbox.length=0,e}drainInbox(){let e=[...this.inbox];return this.inbox.length=0,e}findServicesByDomain(e){return Array.from(this.services.values()).filter(t=>t.status==="active"&&t.domains.includes(e)).map(de)}getService(e){let t=this.services.get(e);return t?de(t):void 0}listServices(){return Array.from(this.services.values()).map(de)}listRoutes(){return this.routes.map(zt)}checkHealth(){let e=Date.now();for(let t of this.services.values()){if(t.status==="deregistered")continue;let n=e-t.lastHeartbeat;n>this.config.serviceTimeoutMs?t.status="unreachable":n>this.config.serviceTimeoutMs*.6&&(t.status="degraded")}}getHealth(){return{localFleetId:this.config.localFleetId,connectedServices:Array.from(this.services.values()).filter(e=>e.status==="active").length,activeRoutes:this.routes.filter(e=>e.active).length,pendingMessages:this.outbox.length+this.inbox.length,messagesSent:this.messagesSent,messagesReceived:this.messagesReceived}}dispose(){this.services.clear(),this.routes.length=0,this.outbox.length=0,this.inbox.length=0,this.handlers.length=0}resolveRoute(e,t){for(let i of this.routes)if(i.active&&i.sourceDomain===e&&i.targetDomain===t){let r=this.services.get(i.targetFleetId);if(r&&r.status==="active")return i.targetFleetId}let n=this.findServicesByDomain(t);return n.length>0?n[0].fleetId:void 0}};function de(s){return{fleetId:s.fleetId,name:s.name,domains:[...s.domains],status:s.status,registeredAt:s.registeredAt,lastHeartbeat:s.lastHeartbeat,metadata:s.metadata,endpoint:void 0}}function zt(s){return{sourceDomain:s.sourceDomain,targetDomain:s.targetDomain,targetFleetId:s.targetFleetId,priority:s.priority,active:s.active}}function Ge(s){return new ge(s)}var qt={name:"default",scaleUpQueueRatio:3,scaleDownIdleRatio:.5,errorRateScaleUpThreshold:.3,minAgents:2,maxAgents:15,cooldownMs:3e4,sampleWindowSize:5},ze={defaultPolicy:qt,metricsHistorySize:100,decisionHistorySize:50};import{randomUUID as ii}from"node:crypto";he();k();var me=class s{config;policy;metricsHistory=[];events=[];lastScaleTime=0;scaleUpCount=0;scaleDownCount=0;totalDecisions=0;currentAgents;lastDecision;db=null;persistCount=0;static KV_NAMESPACE="scaling-metrics";static KV_KEY="dynamic-scaler-snapshot";static PERSIST_INTERVAL=10;static KV_TTL=7200;constructor(e=2,t){this.config={...ze,...t},this.policy=this.config.defaultPolicy,this.currentAgents=e}recordMetrics(e){this.metricsHistory.push(e),this.metricsHistory.length>this.config.metricsHistorySize&&this.metricsHistory.shift(),this.persistCount++,this.persistCount%s.PERSIST_INTERVAL===0&&this.persistSnapshot().catch(()=>{})}evaluate(){let e=this.getAverageMetrics(),t=Date.now();if(this.totalDecisions++,t-this.lastScaleTime<this.policy.cooldownMs){let o={action:"maintain",currentAgents:this.currentAgents,targetAgents:this.currentAgents,reason:"Cooldown period active",metrics:e,timestamp:t};return this.lastDecision=o,o}let n="maintain",i=this.currentAgents,r="Workload within acceptable range";if(e.errorRate>this.policy.errorRateScaleUpThreshold)n="scale-up",i=Math.min(this.currentAgents+2,this.policy.maxAgents),r=`High error rate (${(e.errorRate*100).toFixed(1)}% > ${(this.policy.errorRateScaleUpThreshold*100).toFixed(1)}% threshold)`;else if(this.currentAgents>0&&e.queueDepth/Math.max(1,this.currentAgents)>this.policy.scaleUpQueueRatio){n="scale-up";let o=Math.ceil(e.queueDepth/this.policy.scaleUpQueueRatio);i=Math.min(o,this.policy.maxAgents),r=`Queue depth ratio ${(e.queueDepth/Math.max(1,this.currentAgents)).toFixed(1)} > ${this.policy.scaleUpQueueRatio} threshold`}if(n==="maintain"&&this.currentAgents>this.policy.minAgents){let o=this.currentAgents>0?e.idleAgents/this.currentAgents:0;if(o>this.policy.scaleDownIdleRatio){n="scale-down";let l=Math.floor(e.idleAgents*.5);i=Math.max(this.currentAgents-l,this.policy.minAgents),r=`Idle ratio ${(o*100).toFixed(1)}% > ${(this.policy.scaleDownIdleRatio*100).toFixed(1)}% threshold`}}i=Math.max(this.policy.minAgents,Math.min(this.policy.maxAgents,i)),i===this.currentAgents&&(n="maintain");let a={action:n,currentAgents:this.currentAgents,targetAgents:i,reason:r,metrics:e,timestamp:t};return this.lastDecision=a,a}async execute(e,t){let n={id:`scale-${ii().slice(0,8)}`,decision:e,executedAt:Date.now(),success:!0};if(e.action==="maintain")return this.recordEvent(n),n;try{if(t&&!await t(e.currentAgents,e.targetAgents)){let r={...n,success:!1,error:"Executor returned false"};return this.recordEvent(r),r}return this.currentAgents=e.targetAgents,this.lastScaleTime=Date.now(),e.action==="scale-up"&&this.scaleUpCount++,e.action==="scale-down"&&this.scaleDownCount++,this.recordEvent(n),n}catch(i){let r={...n,success:!1,error:p(i)};return this.recordEvent(r),r}}setPolicy(e){this.policy=e}getPolicy(){return{...this.policy}}getCurrentAgents(){return this.currentAgents}getStats(){return{scaleUpCount:this.scaleUpCount,scaleDownCount:this.scaleDownCount,totalDecisions:this.totalDecisions,currentAgents:this.currentAgents,policyName:this.policy.name,lastDecision:this.lastDecision,recentEvents:[...this.events].slice(-10)}}getMetricsHistory(){return[...this.metricsHistory]}async initialize(){try{this.db=w(),this.db.isInitialized()||await this.db.initialize(),await this.loadFromKv()}catch(e){console.warn("[DynamicScaler] DB init failed, using memory-only:",p(e)),this.db=null}}dispose(){this.metricsHistory.length=0,this.events.length=0}getAverageMetrics(){let e=this.metricsHistory.slice(-this.policy.sampleWindowSize);if(e.length===0)return{queueDepth:0,activeAgents:this.currentAgents,idleAgents:0,avgTaskDurationMs:0,errorRate:0,throughput:0,timestamp:Date.now()};let t=n=>e.reduce((i,r)=>i+n(r),0)/e.length;return{queueDepth:Math.round(t(n=>n.queueDepth)),activeAgents:Math.round(t(n=>n.activeAgents)),idleAgents:Math.round(t(n=>n.idleAgents)),avgTaskDurationMs:Math.round(t(n=>n.avgTaskDurationMs)),errorRate:t(n=>n.errorRate),throughput:t(n=>n.throughput),timestamp:Date.now()}}recordEvent(e){this.events.push(e),this.events.length>this.config.decisionHistorySize&&this.events.shift(),this.persistCount++,this.persistCount%s.PERSIST_INTERVAL===0&&this.persistSnapshot().catch(()=>{})}async loadFromKv(){if(this.db)try{let e=await this.db.kvGet(s.KV_KEY,s.KV_NAMESPACE);if(e){if(Array.isArray(e.metricsHistory))for(let t of e.metricsHistory)this.metricsHistory.push(t);if(Array.isArray(e.events))for(let t of e.events)this.events.push(t)}}catch(e){console.warn("[DynamicScaler] Failed to load KV snapshot:",p(e))}}async persistSnapshot(){if(this.db)try{let e={metricsHistory:this.metricsHistory.slice(-50),events:this.events.slice(-50)};await this.db.kvSet(s.KV_KEY,e,s.KV_NAMESPACE,s.KV_TTL)}catch(e){console.warn("[DynamicScaler] Failed to persist KV snapshot:",p(e))}}};function qe(s,e){return new me(s,e)}var ri=[{name:"Core Testing",domains:["test-generation","test-execution","coverage-analysis","quality-assessment"],priority:"p0",description:"Core testing workflow domains"},{name:"Intelligence",domains:["defect-intelligence","code-intelligence","requirements-validation","security-compliance"],priority:"p0",description:"Intelligence and analysis domains"},{name:"Specialized",domains:["contract-testing","visual-accessibility","chaos-resilience","learning-optimization"],priority:"p1",description:"Specialized testing domains"}],P={"generate-tests":["test-generation"],"execute-tests":["test-execution"],"analyze-coverage":["coverage-analysis"],"assess-quality":["quality-assessment"],"predict-defects":["defect-intelligence"],"validate-requirements":["requirements-validation"],"index-code":["code-intelligence"],"scan-security":["security-compliance"],"validate-contracts":["contract-testing"],"test-accessibility":["visual-accessibility"],"run-chaos":["chaos-resilience"],"optimize-learning":["learning-optimization"],"cross-domain-workflow":[],"protocol-execution":[],"ideation-assessment":["requirements-validation","coverage-analysis","security-compliance"]},jt={maxConcurrentTasks:50,defaultTaskTimeout:3e5,taskRetryLimit:3,workStealing:{enabled:!0,idleThreshold:5e3,loadThreshold:10,stealBatchSize:3,checkInterval:1e4},enableMetrics:!0,metricsInterval:6e4,priorityWeights:{p0:100,p1:50,p2:25,p3:10},enableRouting:!0};function Wt(s){P["cross-domain-workflow"]=s,P["protocol-execution"]=s}import{readFileSync as si,existsSync as oi}from"fs";import{join as li}from"path";import{parse as ci}from"yaml";he();import{randomUUID as ai}from"crypto";var B={RISK_WEIGHTS:2160*60*60*1e3,SFDIPOT_WEIGHTS:2160*60*60*1e3,FLAKY_PATTERNS:720*60*60*1e3,AC_QUALITY:1440*60*60*1e3};function Q(s,e){let t=Date.now(),n=ai().split("-")[0];return`${e||s}-signal-${t}-${n}`}function $(s){return new Date(Date.now()+s).toISOString()}function M(s){return new Date(s.expiresAt)<new Date}var v={STRATEGIC:"qcsd/strategic",TACTICAL:"qcsd/tactical",OPERATIONAL:"qcsd/operational",QUALITY_CRITERIA:"qcsd/quality-criteria"},We=class{memory;initialized=!1;constructor(e={}){this.memory=e.memoryManager||w()}async initialize(){this.initialized||(await this.memory.initialize(),this.initialized=!0,console.log("[CrossPhaseMemory] Initialized with UnifiedMemoryManager"))}async storeRiskSignal(e,t){await this.ensureInitialized();let n={id:Q("strategic","risk"),timestamp:new Date().toISOString(),source:"production",target:"ideation",loopType:"strategic",version:"1.0.0",expiresAt:$(B.RISK_WEIGHTS),riskWeights:e,recommendations:t};return await this.store(v.STRATEGIC,n),n}async queryRiskSignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.STRATEGIC)).filter(t=>!M(t))}async storeSFDIPOTSignal(e,t,n){await this.ensureInitialized();let i={id:Q("tactical","sfdipot"),timestamp:new Date().toISOString(),source:"production",target:"refinement",loopType:"tactical",version:"1.0.0",expiresAt:$(B.SFDIPOT_WEIGHTS),factorWeights:e,featureContext:t,recommendations:n};return await this.store(v.TACTICAL,i),i}async querySFDIPOTSignals(e){await this.ensureInitialized();let t=await this.queryByNamespace(v.TACTICAL);return t=t.filter(n=>!M(n)),e&&(t=t.filter(n=>n.featureContext.toLowerCase().includes(e.toLowerCase()))),t}async storeTestHealthSignal(e,t,n){await this.ensureInitialized();let i={id:Q("operational","test-health"),timestamp:new Date().toISOString(),source:"cicd",target:"development",loopType:"operational",version:"1.0.0",expiresAt:$(B.FLAKY_PATTERNS),flakyPatterns:e,gateFailures:t,recommendations:n};return await this.store(v.OPERATIONAL,i),i}async queryTestHealthSignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.OPERATIONAL)).filter(t=>!M(t))}async storeACQualitySignal(e,t,n){await this.ensureInitialized();let i={id:Q("quality-criteria","ac-quality"),timestamp:new Date().toISOString(),source:"development",target:"refinement",loopType:"quality-criteria",version:"1.0.0",expiresAt:$(B.AC_QUALITY),untestablePatterns:e,coverageGaps:t,recommendations:n};return await this.store(v.QUALITY_CRITERIA,i),i}async queryACQualitySignals(){return await this.ensureInitialized(),(await this.queryByNamespace(v.QUALITY_CRITERIA)).filter(t=>!M(t))}async store(e,t){let n=new Date(t.expiresAt).getTime(),i=Math.max(0,Math.floor((n-Date.now())/1e3));await this.memory.kvSet(t.id,t,e,i>0?i:void 0),console.log(`[CrossPhaseMemory] Stored signal: ${t.id} in ${e}`)}async queryByNamespace(e){let t=await this.memory.kvSearch("*",e,1e3),n=[];for(let i of t){let r=await this.memory.kvGet(i,e);r&&n.push(r)}return n.sort((i,r)=>new Date(r.timestamp).getTime()-new Date(i.timestamp).getTime())}async delete(e,t){let n=await this.memory.kvDelete(t,e);return n&&console.log(`[CrossPhaseMemory] Deleted signal: ${t}`),n}async cleanupExpired(){let e={deleted:0,namespaces:{}};for(let t of Object.values(v)){let n=await this.queryByNamespace(t),i=0;for(let r of n)M(r)&&(await this.delete(t,r.id),i++,e.deleted++);i>0&&(e.namespaces[t]=i)}return e.deleted>0&&console.log(`[CrossPhaseMemory] Cleanup: deleted ${e.deleted} expired signals`),e}async getStats(){await this.ensureInitialized();let e={totalSignals:0,byLoop:{strategic:0,tactical:0,operational:0,"quality-criteria":0},byNamespace:{},oldestSignal:null,newestSignal:null},t=null,n=null;for(let i of Object.values(v)){let a=(await this.queryByNamespace(i)).filter(o=>!M(o));e.byNamespace[i]=a.length,e.totalSignals+=a.length;for(let o of a){e.byLoop[o.loopType]++;let l=new Date(o.timestamp);(!t||l<t)&&(t=l,e.oldestSignal=o.timestamp),(!n||l>n)&&(n=l,e.newestSignal=o.timestamp)}}return e}async ensureInitialized(){this.initialized||await this.initialize()}},je=null;function Vt(s){return je||(je=new We(s)),je}function Ve(s){let e=Object.getOwnPropertyNames(s);for(let t of e){let n=s[t];n&&typeof n=="object"&&!Object.isFrozen(n)&&Ve(n)}return Object.freeze(s)}function Ke(s){let e=structuredClone(s);return Ve(e)}function Ye(s){return s===0?"success":s===2?"model_blocking":"user_error"}var Xe=class{config=null;memory;configPath;listeners=new Map;constructor(e){this.configPath=e||li(process.cwd(),".claude/hooks/cross-phase-memory.yaml"),this.memory=Vt()}async initialize(){if(process.env.AQE_HOOKS_DISABLED==="true")return console.log("[CrossPhaseHooks] All hooks disabled via AQE_HOOKS_DISABLED"),!1;if(!oi(this.configPath))return console.warn(`[CrossPhaseHooks] Config not found: ${this.configPath}`),!1;try{let e=si(this.configPath,"utf-8"),t=ci(e);return t.enabled?(this.config=Ke(t),await this.memory.initialize(),console.log(`[CrossPhaseHooks] Initialized with ${Object.keys(this.config.hooks).length} hooks`),!0):(console.log("[CrossPhaseHooks] Hooks disabled in config"),!1)}catch(e){return console.error("[CrossPhaseHooks] Failed to load config:",e),!1}}async onAgentComplete(e,t){if(!this.config||process.env.AQE_HOOKS_DISABLED==="true")return;let n=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([i,r])=>r.trigger.event==="agent-complete"&&r.trigger.agent===e));for(let[i,r]of n)this.checkConditions(r.trigger.conditions,t)&&(console.log(`[CrossPhaseHooks] Executing hook: ${i}`),await this.executeActions(r.actions,t))}async onPhaseStart(e,t={}){if(!this.config)return{};if(process.env.AQE_HOOKS_DISABLED==="true")return{};let n={},i=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([r,a])=>a.trigger.event==="phase-start"&&a.trigger.phase===e));for(let[r,a]of i){console.log(`[CrossPhaseHooks] Executing phase-start hook: ${r}`);for(let o of a.actions)if(o.type==="query-signals"&&o.injectInto){let l=await this.querySignalsForInjection(o.namespace,o.maxAge,o.filterBy?t[o.filterBy]:void 0);for(let c of o.injectInto)n[c]||(n[c]=[]),n[c].push(...l)}}return n}async onPhaseEnd(e,t){if(!this.config||process.env.AQE_HOOKS_DISABLED==="true")return;let n=this.filterManagedHooks(Object.entries(this.config.hooks).filter(([i,r])=>r.trigger.event==="phase-end"&&r.trigger.phase===e));for(let[i,r]of n)console.log(`[CrossPhaseHooks] Executing phase-end hook: ${i}`),await this.executeActions(r.actions,t)}async executeActions(e,t){for(let n of e)try{await this.executeAction(n,t)}catch(i){let r=i?.exitCode;if(typeof r=="number"){let a=Ye(r);if(a==="model_blocking")throw console.error(`[CrossPhaseHooks] Model-blocking hook failure (exit ${r}):`,i),i;console.warn(`[CrossPhaseHooks] Hook ${a} (exit ${r}):`,i)}else console.error("[CrossPhaseHooks] Action failed:",i)}}async executeAction(e,t){switch(e.type){case"store-signal":await this.executeStoreSignal(e,t);break;case"query-signals":break;case"notify-agent":await this.executeNotifyAgent(e,t);break;case"invoke-agent":await this.executeInvokeAgent(e,t);break;case"conditional":e.condition&&e.action&&this.evaluateCondition(e.condition,t)&&await this.executeAction(e.action,t);break;case"delete-expired":await this.memory.cleanupExpired();break;default:console.warn(`[CrossPhaseHooks] Unknown action type: ${e.type}`)}}async executeStoreSignal(e,t){if(!e.loop||!e.namespace||!e.extract)return;let n=this.extractFromContext(e.extract,t);switch(e.loop){case"strategic":await this.memory.storeRiskSignal(n.riskWeights||[],n.recommendations||{forRiskAssessor:[],forQualityCriteria:[]});break;case"tactical":await this.memory.storeSFDIPOTSignal(n.factorWeights||[],n.featureContext||"unknown",n.recommendations||{forProductFactorsAssessor:[]});break;case"operational":await this.memory.storeTestHealthSignal(n.flakyPatterns||[],n.gateFailures||[],n.recommendations||{forTestArchitect:[],antiPatterns:[]});break;case"quality-criteria":await this.memory.storeACQualitySignal(n.untestablePatterns||[],n.coverageGaps||[],n.recommendations||{forRequirementsValidator:[],acTemplates:{}});break}this.emit("signal-stored",{loop:e.loop,namespace:e.namespace})}async executeNotifyAgent(e,t){!e.target||!e.message||await this.isBlockedUrl(e.target)||(console.log(`[CrossPhaseHooks] Notify ${e.target}: ${e.message}`),this.emit("agent-notification",{target:e.target,message:e.message,priority:e.priority||"normal",context:t}))}async executeInvokeAgent(e,t){e.target&&(await this.isBlockedUrl(e.target)||(console.log(`[CrossPhaseHooks] Invoke agent: ${e.target}`),this.emit("agent-invocation",{agent:e.target,input:{...t,...e.input||{}}})))}async querySignalsForInjection(e,t,n){let r=await this.memory.queryByNamespace(e);if(t){let a=this.parseMaxAge(t),o=Date.now()-a;r=r.filter(l=>new Date(l.timestamp).getTime()>o)}return r}formatSignalsForInjection(e){if(e.length===0)return"";let t=`## CROSS-PHASE LEARNING SIGNALS
|
|
168
168
|
|
|
169
169
|
`;t+=`The following signals have been automatically injected from previous phases.
|
|
170
170
|
`,t+=`Apply these learnings to your analysis.
|
|
@@ -177,4 +177,4 @@ import{b as ye}from"./chunk-BULKFVYX.js";import{a as gt,b as pt}from"./chunk-4B6
|
|
|
177
177
|
`;let i=this.getRecommendations(n);if(i.length>0){t+=`**Recommendations:**
|
|
178
178
|
`;for(let r of i)t+=`- ${r}
|
|
179
179
|
`;t+=`
|
|
180
|
-
`}}return t}getRecommendations(e){switch(e.loopType){case"strategic":return[...e.recommendations.forRiskAssessor,...e.recommendations.forQualityCriteria];case"tactical":return e.recommendations.forProductFactorsAssessor;case"operational":return[...e.recommendations.forTestArchitect,...e.recommendations.antiPatterns];case"quality-criteria":return e.recommendations.forRequirementsValidator;default:return[]}}filterManagedHooks(e){if(process.env.AQE_HOOKS_MANAGED_ONLY!=="true")return e;let t=e.filter(([n])=>n.startsWith("managed:"));return t.length<e.length&&console.log(`[CrossPhaseHooks] AQE_HOOKS_MANAGED_ONLY: filtered ${e.length-t.length} non-managed hooks`),t}async isBlockedUrl(e){if(!e.includes("://"))return!1;let t=await ye(e);return t.safe?!1:(console.warn(`[CrossPhaseHooks] SSRF blocked: ${t.reason}`),!0)}checkConditions(e,t){return!e||e.length===0?!0:e.every(n=>this.evaluateCondition(n,t))}evaluateCondition(e,t){try{let n=e.split(/\s*(>|<|>=|<=|==|!=)\s*/);if(n.length!==3)return!1;let[i,r,a]=n,o=this.getValueFromPath(t,i),l=isNaN(Number(a))?a:Number(a),c=typeof o=="number"?o:Number(o),u=typeof l=="number"?l:Number(l);switch(r){case">":return c>u;case"<":return c<u;case">=":return c>=u;case"<=":return c<=u;case"==":return o==l;case"!=":return o!=l;default:return!1}}catch{return!1}}getValueFromPath(e,t){return t.split(".").reduce((n,i)=>{if(n&&typeof n=="object"&&i in n)return n[i]},e)}extractFromContext(e,t){let n={};for(let[i,r]of Object.entries(e))n[i]=this.getValueFromPath(t,r);return n}parseMaxAge(e){let t=e.match(/^(\d+)(d|h|m|s)$/);if(!t)return 0;let[,n,i]=t,r=parseInt(n,10);switch(i){case"d":return r*24*60*60*1e3;case"h":return r*60*60*1e3;case"m":return r*60*1e3;case"s":return r*1e3;default:return 0}}on(e,t){this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t)}off(e,t){this.listeners.get(e)?.delete(t)}emit(e,t){this.listeners.get(e)?.forEach(n=>n(t))}async runCleanup(){if(!this.config?.cleanup.enabled)return;console.log("[CrossPhaseHooks] Running cleanup...");let e=await this.memory.cleanupExpired();console.log(`[CrossPhaseHooks] Cleanup complete: ${e.deleted} signals deleted`)}},Ze=null;function Wt(s){return Ze||(Ze=new Xe(s)),Ze}function Vt(s,e){let t=[];for(let a of e){let o=s.router.subscribeToDoamin(a,async l=>{await li(s,l)});t.push(o)}let n=s.router.subscribeToEventType("TaskCompleted",async a=>{await ci(s,a)});t.push(n);let i=s.router.subscribeToEventType("TaskFailed",async a=>{await ui(s,a)});t.push(i);let r=s.router.subscribeToEventType("AgentStatusChanged",async a=>{await di(s,a)});return t.push(r),t}async function li(s,e){s.domainLastActivity.set(e.source,new Date),await s.processQueue()}async function ci(s,e){let{taskId:t,result:n}=e.payload,i=s.tasks.get(t);if(i){(i.status==="running"||i.status==="assigned")&&(s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1));let r=i.startedAt?Date.now()-i.startedAt.getTime():0;s.tasks.set(t,{...i,status:"completed",completedAt:new Date,result:n}),s.tasksCompleted++,s.taskDurations.push(r),s.auditLogger.logComplete(t,i.assignedAgents[0]);try{let a=Wt(),o=i.assignedAgents[0];o&&await a.onAgentComplete(o,{taskId:t,taskType:i.task.type,domain:i.assignedDomain,result:n,duration:r})}catch(a){console.warn("[QueenCoordinator] Cross-phase hook error:",a)}try{await I.afterTaskExecution({taskId:t,taskType:i.task.type,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",priority:i.task.priority},!0,0,0)}catch(a){console.warn("[QueenCoordinator] Governance tracking error:",a)}if(s.domainBreakerRegistry&&i.assignedDomain&&s.domainBreakerRegistry.getBreaker(i.assignedDomain).recordSuccess(),s.traceCollector){let a=s.taskTraceContexts.get(t);a&&(s.traceCollector.completeSpan(a.spanId),s.taskTraceContexts.delete(t))}if(s.taskCompletedHook)try{let a=typeof n=="object"&&n!==null?n:null;if(a===null)console.error(`[QueenCoordinator] Pattern training skipped for task ${t}: result is not an object (got ${typeof n})`);else{let o=mi(a,t);if(o){let l={taskId:t,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",type:i.task.type,status:"completed",output:a,metrics:o,duration:r,timestamp:Date.now()};s.taskCompletedHook.onTaskCompleted(l).catch(c=>{console.warn("[QueenCoordinator] Pattern training error:",c)})}}}catch(a){console.warn("[QueenCoordinator] Pattern training setup error:",a)}}await s.processQueue()}async function ui(s,e){let{taskId:t,error:n}=e.payload,i=s.tasks.get(t);if(i){if((i.status==="running"||i.status==="assigned")&&(s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1)),s.domainBreakerRegistry&&i.assignedDomain&&s.domainBreakerRegistry.getBreaker(i.assignedDomain).recordFailure(new Error(n||"Task failed")),s.traceCollector){let r=s.taskTraceContexts.get(t);r&&(s.traceCollector.failSpan(r.spanId,n||"Task failed"),s.taskTraceContexts.delete(t))}if(i.retryCount<s.config.taskRetryLimit){s.auditLogger.logFail(t,i.assignedAgents[0],n);let r={...i,status:"queued",retryCount:i.retryCount+1,error:n};s.tasks.set(t,r),s.enqueueTask(i.task)}else{s.tasks.set(t,{...i,status:"failed",completedAt:new Date,error:n}),s.tasksFailed++,s.auditLogger.logFail(t,i.assignedAgents[0],n);try{await I.afterTaskExecution({taskId:t,taskType:i.task.type,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",priority:i.task.priority},!1,0,0)}catch(r){console.warn("[QueenCoordinator] Governance tracking error:",r)}if(s.hypothesisManager&&(i.task.priority==="p0"||i.task.priority==="p1"))try{let r=i.assignedDomain||"test-generation",a=s.hypothesisManager.createInvestigation(t,r,`Root cause analysis for ${i.task.type} failure: ${n}`);s.hypothesisManager.addHypothesis(a.id,`Infrastructure failure in domain '${r}' caused task ${t} to fail`,"log-analysis",`${r}-lead`),s.hypothesisManager.addHypothesis(a.id,`Logic/configuration error in task payload caused ${i.task.type} to fail: ${n}`,"code-analysis",i.assignedAgents[0]||"unknown"),console.log(`[QueenCoordinator] Competing hypotheses investigation created: ${a.id}`)}catch(r){console.warn("[QueenCoordinator] Hypothesis creation error:",r)}}}await s.processQueue()}async function di(s,e){let{agentId:t,status:n,domain:i}=e.payload;s.domainLastActivity.set(i,new Date),(n==="completed"||n==="failed")&&await s.processQueue()}function mi(s,e){if("metrics"in s&&typeof s.metrics=="object"&&s.metrics!==null){let t=s.metrics;return{testsPassed:typeof t.testsPassed=="number"?t.testsPassed:void 0,testsFailed:typeof t.testsFailed=="number"?t.testsFailed:void 0,coverageChange:typeof t.coverageChange=="number"?t.coverageChange:void 0,securityIssues:typeof t.securityIssues=="number"?t.securityIssues:void 0,performanceMs:typeof t.performanceMs=="number"?t.performanceMs:void 0,linesChanged:typeof t.linesChanged=="number"?t.linesChanged:void 0}}return"testsPassed"in s||"testsFailed"in s?{testsPassed:typeof s.testsPassed=="number"?s.testsPassed:void 0,testsFailed:typeof s.testsFailed=="number"?s.testsFailed:void 0,coverageChange:typeof s.coverageChange=="number"?s.coverageChange:void 0,securityIssues:typeof s.securityIssues=="number"?s.securityIssues:void 0,performanceMs:typeof s.performanceMs=="number"?s.performanceMs:void 0,linesChanged:typeof s.linesChanged=="number"?s.linesChanged:void 0}:(console.error(`[QueenCoordinator] Pattern training skipped for task ${e}: result object has no recognizable metrics shape (keys: ${Object.keys(s).join(", ")})`),null)}function Kt(s,e,t){let n=s.listAgents({domain:e}),i=n.filter(l=>l.status==="running").length,r=n.filter(l=>l.status==="idle").length,a=n.filter(l=>l.status==="failed").length,o;return a>0&&a>=n.length/2?o="unhealthy":a>0?o="degraded":i>0?o="healthy":o="idle",{status:o,agents:{total:n.length,active:i,idle:r,failed:a},lastActivity:t,errors:[]}}var gi=pt();function Yt(s,e,t){let n=s.get(t.priority);n&>(n,t,gi);for(let i of t.targetDomains){let r=e.get(i);r&&r.push(t)}}function pe(s,e,t){let n=s.get(t.priority);if(n){let i=n.findIndex(r=>r.id===t.id);i!==-1&&n.splice(i,1)}for(let i of t.targetDomains){let r=e.get(i);if(r){let a=r.findIndex(o=>o.id===t.id);a!==-1&&r.splice(a,1)}}}function Je(s,e){let t=0;for(let n of["p0","p1","p2","p3"]){let i=s.get(n);if(i){if(n===e.priority){t+=i.findIndex(r=>r.id===e.id);break}t+=i.length}}return t}async function et(s){if(!(s.runningTaskCounter>=s.config.maxConcurrentTasks))for(let e of["p0","p1","p2","p3"]){let t=s.taskQueue.get(e);if(!t||t.length===0)continue;let n=t.shift();if(n){pe(s.taskQueue,s.domainQueues,n),s.runningTaskCounter++;try{await tt(s,n)}catch(i){throw s.runningTaskCounter--,i}if(s.runningTaskCounter>=s.config.maxConcurrentTasks)return}}}function Zt(s,e){let t=Array.from(s.values());return e&&(e.status&&(t=t.filter(n=>n.status===e.status)),e.domain&&(t=t.filter(n=>n.assignedDomain===e.domain)),e.priority&&(t=t.filter(n=>n.task.priority===e.priority)),e.type&&(t=t.filter(n=>n.task.type===e.type)),e.fromDate&&(t=t.filter(n=>n.task.createdAt>=e.fromDate)),e.toDate&&(t=t.filter(n=>n.task.createdAt<=e.toDate))),t}async function tt(s,e){let t=e.targetDomains.length>0?e.targetDomains:P[e.type]||[];if(t.length===0)return y(new Error(`No domains configured for task type: ${e.type}`));let n,i=1/0;for(let r of t){let a=s.getDomainLoad(r);s.getDomainHealth(r)?.status!=="unhealthy"&&a<i&&(i=a,n=r)}return n?nt(s,e,n):y(new Error("No healthy domain available for task"))}async function nt(s,e,t){let n;if(s.tinyDancerRouter){let l={p0:"critical",p1:"high",p2:"normal",p3:"low"},c={description:`${e.type}: ${JSON.stringify(e.payload).slice(0,200)}`,type:e.type,domain:t,priority:l[e.priority]};n=await s.tinyDancerRouter.route(c),s.config.enableMetrics&&console.log(`[Queen] TinyDancer routing: ${e.type} \u2192 tier=${n.tier}, model=${n.model}, cost=$${n.estimatedCost.toFixed(4)}`)}if(s.domainBreakerRegistry&&!s.domainBreakerRegistry.canExecuteInDomain(t))return y(new Error(`Domain '${t}' circuit breaker is open \u2014 too many recent failures`));if(s.domainTeamManager)try{if(!s.domainTeamManager.getDomainTeam(t)){let c=`${t}-lead`;s.domainTeamManager.createDomainTeam(t,c)}}catch(l){console.warn(`[Queen] Domain team setup for '${t}' failed (continuing):`,l)}let i=n?.tier||"task-worker",r=await s.requestAgentSpawn(t,i,["task-execution",e.type,...n?[`model:${n.model}`]:[]]),a=[];r.success&&a.push(r.value);let o={taskId:e.id,task:e,status:"running",assignedDomain:t,assignedAgents:a,startedAt:new Date,retryCount:0};s.tasks.set(e.id,o),s.domainLastActivity.set(t,new Date);for(let l of a)s.auditLogger.logAssign(e.id,l,t);if(await s.publishEvent("TaskAssigned",{taskId:e.id,domain:t,agentIds:a}),s.domainPlugins){let l=s.domainPlugins.get(t);if(l?.executeTask&&l.canHandleTask?.(e.type)){let c={taskId:e.id,taskType:e.type,payload:e.payload,priority:e.priority,timeout:e.timeout,correlationId:e.correlationId},u=await l.executeTask(c,d=>pi(s,d));return u.success?C(e.id):(s.tasks.set(e.id,{...o,status:"failed",error:u.error.message,completedAt:new Date}),s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1),s.tasksFailed++,s.auditLogger.logFail(e.id,a[0],u.error.message),y(u.error))}if(l)try{await l.handleEvent({id:f(),type:"TaskAssigned",timestamp:new Date,source:"queen-coordinator",correlationId:e.correlationId,payload:{task:e}}),console.warn(`[Queen] Domain ${t} has no executeTask handler, using event fallback`)}catch(c){console.warn(`[Queen] Failed to invoke domain ${t} event handler:`,c)}}return C(e.id)}async function pi(s,e){let t=s.tasks.get(e.taskId);if(!t){console.warn(`[Queen] Received completion for unknown task: ${e.taskId}`);return}let n={...t,status:e.success?"completed":"failed",completedAt:new Date,result:e.data,error:e.error};if(s.tasks.set(e.taskId,n),e.success?(s.tasksCompleted++,s.taskDurations.push(e.duration),s.auditLogger.logComplete(e.taskId,t.assignedAgents[0])):(s.tasksFailed++,s.auditLogger.logFail(e.taskId,t.assignedAgents[0],e.error||"Unknown error")),s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1),s.coExecutionRepo&&t.assignedAgents.length>=2)try{s.coExecutionRepo.recordSwarmCoExecution(t.assignedAgents,t.assignedDomain||"unknown",e.success,t.task.type)}catch{}for(let i of t.assignedAgents)await s.agentCoordinator.stop(i);await s.publishEvent(e.success?"TaskCompleted":"TaskFailed",{taskId:e.taskId,domain:t.assignedDomain,result:e.data,error:e.error,duration:e.duration}),await et(s)}function Xt(s,e){return(P[e.type]||[]).includes(s)}k();async function Jt(s){let e=0,t=s.getIdleDomains(),n=s.getBusyDomains();if(t.length===0||n.length===0)return 0;n.sort((i,r)=>s.getDomainLoad(r)-s.getDomainLoad(i));for(let i of n){if(t.length===0)break;let r=s.domainQueues.get(i)||[],a=Math.min(r.length,s.config.workStealing.stealBatchSize);for(let o=0;o<a&&t.length>0;o++){let l=r.find(c=>Xt(t[0],c));if(l){let c=t.shift();s.removeFromQueues(l),s.auditLogger.logSteal(l.id,i,c),await s.assignTaskToDomain(l,c),e++,s.tasksStolen++,await s.publishEvent("TaskStolen",{taskId:l.id,fromDomain:i,toDomain:c})}}}return e}function it(s,e){let t=0,n=10,i;return i=setInterval(async()=>{try{await e(),t=0}catch(r){t++;let a=Math.min(1e3*Math.pow(2,t),3e4);if(console.warn(`[QueenCoordinator] Work-stealing failed (attempt ${t}), backing off ${a}ms`,p(r)),t>n){console.error(`[QueenCoordinator] Work-stealing exceeded ${n} consecutive failures, stopping interval`),clearInterval(i);return}await new Promise(o=>setTimeout(o,a))}},s.workStealing.checkInterval),i}function rt(s){return typeof s.setMinCutBridge=="function"}function en(s,e){for(let[t,n]of s)rt(n)&&(n.setMinCutBridge(e),console.log(`[QueenCoordinator] MinCut bridge injected into ${t}`))}async function tn(s,e,t){try{let n=await s.get("queen:state");if(n)for(let[i,r]of n.tasks)r.status==="queued"&&(e.set(i,r),t(r.task))}catch(n){console.debug("[QueenCoordinator] State loading failed:",n instanceof Error?n.message:n)}}async function nn(s,e){let t=Array.from(e.entries()).filter(([,n])=>n.status==="queued");await s.set("queen:state",{tasks:t},{namespace:"queen-coordinator",persist:!0})}function rn(s){return setInterval(async()=>{let e=s.getMetrics();if(await s.publishEvent("MetricsCollected",{metrics:e}),await s.memory.set(`queen:metrics:${Date.now()}`,e,{ttl:864e5,namespace:"queen-coordinator"}),s.dynamicScaler)try{let t=s.getAverageTaskDuration(),n={queueDepth:s.getQueuedTaskCount(),activeAgents:s.getActiveAgentCount(),idleAgents:s.getIdleAgentCount(),avgTaskDurationMs:t,errorRate:s.getTasksReceived()>0?s.getTasksFailed()/s.getTasksReceived():0,throughput:e.uptime>0?s.getTasksCompleted()/(e.uptime/1e3):0,timestamp:Date.now()};s.dynamicScaler.recordMetrics(n);let i=s.dynamicScaler.evaluate();i&&i.action!=="maintain"&&(console.log(`[QueenCoordinator] Dynamic scaler: ${i.action} to ${i.targetAgents} agents \u2014 ${i.reason}`),s.dynamicScaler.execute(i).catch(r=>{console.warn("[QueenCoordinator] Dynamic scaling execution error:",r)}))}catch(t){console.warn("[QueenCoordinator] Dynamic scaler metrics error:",t)}},s.config.metricsInterval)}function at(s,e,t=36e5){let n=Date.now(),i=0;for(let[a,o]of s)if(o.status==="completed"||o.status==="failed"||o.status==="cancelled"){let l=o.completedAt?.getTime()||o.startedAt?.getTime()||0;l>0&&n-l>t&&(s.delete(a),e.delete(a),i++)}let r=1e4;if(e.size>r){let a=e.size-r,o=e.keys();for(let l=0;l<a;l++){let c=o.next().value;c!==void 0&&e.delete(c)}console.log(`[QueenCoordinator] Evicted ${a} oldest trace contexts (max: ${r})`)}return i>0&&console.log(`[QueenCoordinator] Cleaned up ${i} old tasks (retention: ${t}ms)`),i}function an(s,e){return s&&s.size>0?Array.from(s.keys()):[...e]}var g=ut.create("QueenCoordinator");qt(T);var st=class{constructor(e,t,n,i,r,a,o,l={}){this.eventBus=e;this.agentCoordinator=t;this.memory=n;this.router=i;this.protocolExecutor=r;this.workflowExecutor=a;this.domainPlugins=o;this.config={...zt,...l},this.auditLogger=Te({enableConsoleLog:this.config.enableMetrics,maxEntries:1e3,logPrefix:"[QUEEN]"}),["p0","p1","p2","p3"].forEach(c=>{this.taskQueue.set(c,[])}),this.config.enableRouting!==!1&&(this.tinyDancerRouter=new K(this.config.routing)),T.forEach(c=>{this.domainQueues.set(c,[]),this.domainLastActivity.set(c,new Date)})}config;tasks=new Map;taskQueue=new Map;domainQueues=new Map;domainLastActivity=new Map;initialized=!1;workStealingTimer=null;metricsTimer=null;cleanupTimer=null;startTime=new Date;eventSubscriptionIds=[];runningTaskCounter=0;tasksReceived=0;tasksCompleted=0;tasksFailed=0;tasksStolen=0;taskDurations=new ct(1e3);protocolsExecuted=0;workflowsExecuted=0;auditLogger;minCutBridge=null;tinyDancerRouter=null;domainBreakerRegistry=null;domainTeamManager=null;agentTeamsAdapter=null;tierSelector=null;taskCompletedHook=null;traceCollector=null;taskTraceContexts=new Map;hypothesisManager=null;federationMailbox=null;dynamicScaler=null;coExecutionRepo=null;dependencyGraph=null;availableMcpServers=[];async initialize(){if(!this.initialized){this.startTime=new Date,await this.router.initialize(),this.subscribeToEvents(),this.config.workStealing.enabled&&(this.workStealingTimer=it(this.config,()=>this.triggerWorkStealing().then(()=>{}))),this.config.enableMetrics&&(this.metricsTimer=rn(this.createMetricsContext())),this.cleanupTimer=setInterval(()=>{at(this.tasks,this.taskTraceContexts,36e5)},3e5),this.cleanupTimer.unref(),await tn(this.memory,this.tasks,e=>this.enqueueTaskInternal(e)),this.minCutBridge=yt(this.eventBus,this.agentCoordinator,{autoUpdateFromEvents:!0,persistData:!0,includeInQueenHealth:!0,sharedGraph:xe()}),await this.minCutBridge.initialize(),this.domainPlugins&&en(this.domainPlugins,this.minCutBridge);try{await I.initialize(),g.info("Governance adapter initialized")}catch(e){g.warn("Governance initialization failed (continuing)",{error:e})}this.initializeSubsystems();try{let{join:e}=await import("path"),t=e(process.cwd(),".claude","agents","v3");this.dependencyGraph=Pt(t),this.availableMcpServers=ht(process.cwd());let{getUnifiedMemory:n}=await import("./unified-memory-XYGENQUT.js"),i=n();await i.initialize(),this.coExecutionRepo=Rt(),this.coExecutionRepo.initialize(i.getDatabase()),this.dependencyGraph.warnings.length>0&&g.warn(`Dependency graph: ${this.dependencyGraph.warnings.length} warning(s)`,{warnings:this.dependencyGraph.warnings.slice(0,5)}),g.info("Dependency intelligence initialized",{agents:this.dependencyGraph.nodes.size,mcpServers:this.availableMcpServers.length})}catch(e){g.warn("Dependency intelligence initialization failed (continuing)",{error:e})}await this.publishEvent("QueenInitialized",{timestamp:new Date,config:this.config,domains:T}),this.initialized=!0}}async dispose(){this.workStealingTimer&&(clearInterval(this.workStealingTimer),this.workStealingTimer=null),this.metricsTimer&&(clearInterval(this.metricsTimer),this.metricsTimer=null),this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null),this.minCutBridge&&(await this.minCutBridge.dispose(),this.minCutBridge=null),this.domainTeamManager&&(this.domainTeamManager.dispose(),this.domainTeamManager=null),this.agentTeamsAdapter&&(this.agentTeamsAdapter.shutdown(),this.agentTeamsAdapter=null),this.domainBreakerRegistry=null,this.tierSelector=null,this.traceCollector&&(this.traceCollector.dispose(),this.traceCollector=null),this.hypothesisManager&&(this.hypothesisManager.dispose(),this.hypothesisManager=null),this.federationMailbox&&(this.federationMailbox.dispose(),this.federationMailbox=null),this.dynamicScaler&&(this.dynamicScaler.dispose(),this.dynamicScaler=null),await nn(this.memory,this.tasks);for(let[e,t]of this.tasks)(t.status==="queued"||t.status==="running")&&await this.cancelTask(e);await this.publishEvent("QueenShutdown",{timestamp:new Date,metrics:this.getMetrics()});for(let e of this.eventSubscriptionIds)this.router.unsubscribe(e);this.eventSubscriptionIds=[],await this.router.dispose(),this.initialized=!1}async submitTask(e){if(!this.initialized)return y(new Error("Queen Coordinator not initialized"));let t=`task_${f()}`,n={...e,id:t,createdAt:new Date,timeout:e.timeout||this.config.defaultTaskTimeout},i={taskId:n.id,taskType:n.type,agentId:n.requester||"unknown",domain:n.targetDomains[0]||"test-generation",priority:n.priority,payload:n.payload};try{let r=await I.beforeTaskExecution(i);if(!r.allowed)return this.auditLogger.logFail(t,"governance",r.reason||"Governance check failed"),await this.publishEvent("TaskRejected",{taskId:t,reason:r.reason,escalate:r.escalate}),y(new Error(`Task blocked by governance: ${r.reason}`))}catch(r){g.warn("Governance check error (continuing)",{error:r})}this.runningTaskCounter++;try{if(this.runningTaskCounter>this.config.maxConcurrentTasks)return this.runningTaskCounter--,this.queueTask(n);this.auditLogger.logSubmit(t,{type:n.type,priority:n.priority}),this.selectFleetTier(n),this.startTaskTrace(n,t);let r=await tt(this.createTaskContext(),n);return r.success?(this.tasksReceived++,await this.publishEvent("TaskSubmitted",{taskId:t,task:n}),C(t)):(this.runningTaskCounter--,r)}catch(r){throw this.runningTaskCounter--,r}}async cancelTask(e){let t=this.tasks.get(e);if(!t)return y(new Error(`Task not found: ${e}`));if(t.status==="completed"||t.status==="failed")return y(new Error(`Task already finished: ${e}`));(t.status==="running"||t.status==="assigned")&&(this.runningTaskCounter=Math.max(0,this.runningTaskCounter-1)),this.tasks.set(e,{...t,status:"cancelled",completedAt:new Date}),pe(this.taskQueue,this.domainQueues,t.task);for(let n of t.assignedAgents)await this.agentCoordinator.stop(n);return this.auditLogger.logCancel(e),await this.publishEvent("TaskCancelled",{taskId:e}),C(void 0)}getTaskStatus(e){return this.tasks.get(e)}listTasks(e){return Zt(this.tasks,e)}getDomainHealth(e){if(this.domainPlugins){let t=this.domainPlugins.get(e);if(t)return t.getHealth()}return Kt(this.agentCoordinator,e,this.domainLastActivity.get(e))}getDomainLoad(e){let t=this.domainQueues.get(e)||[],n=Array.from(this.tasks.values()).filter(i=>i.assignedDomain===e&&i.status==="running");return t.length+n.length}getIdleDomains(){let e=Date.now(),t=this.config.workStealing.idleThreshold;return T.filter(n=>{let i=this.domainLastActivity.get(n);return this.getDomainLoad(n)===0&&i&&e-i.getTime()>t})}getBusyDomains(){return T.filter(e=>this.getDomainLoad(e)>this.config.workStealing.loadThreshold)}getSpawnPlan(e){return this.dependencyGraph?Ht(e,this.dependencyGraph):{phases:[e],warnings:[],unsatisfiedHardDeps:[]}}getDependencyGraph(){return this.dependencyGraph}enableWorkStealing(){this.workStealingTimer||(this.workStealingTimer=it(this.config,()=>this.triggerWorkStealing().then(()=>{})))}disableWorkStealing(){this.workStealingTimer&&(clearInterval(this.workStealingTimer),this.workStealingTimer=null)}async triggerWorkStealing(){return Jt(this.createWorkStealingContext())}listAllAgents(){return this.agentCoordinator.listAgents()}getAgentsByDomain(e){return this.agentCoordinator.listAgents({domain:e})}async requestAgentSpawn(e,t,n){if(!this.agentCoordinator.canSpawn())return y(new Error("Maximum concurrent agents reached (15)"));if(this.dependencyGraph&&this.availableMcpServers.length>0)try{for(let[,r]of this.dependencyGraph.nodes){let a=r.dependencies.mcpServers;if(!a||a.length===0)continue;let o=a.filter(l=>l.required&&!this.availableMcpServers.includes(l.name));if(o.length>0){g.warn(`Pre-spawn MCP advisory: ${r.agentName} needs ${o.map(l=>l.name).join(", ")}`,{agent:r.agentName,domain:e,missing:o.map(l=>l.name)});break}}}catch{}let i=await this.agentCoordinator.spawn({name:`${e}-${t}-${Date.now()}`,domain:e,type:t,capabilities:n});if(i.success){if(this.domainLastActivity.set(e,new Date),this.domainTeamManager&&typeof this.domainTeamManager.getDomainTeam=="function")try{if(this.domainTeamManager.getDomainTeam(e))this.domainTeamManager.addTeammate(e,i.value)||g.warn(`Agent ${i.value} could not join ${e} team (full)`);else try{this.domainTeamManager.createDomainTeam(e,i.value)}catch{this.domainTeamManager.addTeammate(e,i.value)||g.warn(`Agent ${i.value} could not join ${e} team (full or max teams reached)`)}}catch(r){g.warn(`Auto-team-wiring failed for ${i.value}`,{error:r})}await this.publishEvent("AgentSpawned",{agentId:i.value,domain:e,type:t,capabilities:n})}return i}getHealth(){let e=new Map,t=[],n=0,i=0,r=an(this.domainPlugins,T);for(let u of r){let d=this.getDomainHealth(u);d&&(e.set(u,d),d.status==="unhealthy"?(n++,t.push({domain:u,severity:"high",message:`Domain ${u} is unhealthy`,timestamp:new Date})):d.status==="degraded"&&(i++,t.push({domain:u,severity:"medium",message:`Domain ${u} is degraded`,timestamp:new Date})))}let a=this.agentCoordinator.listAgents(),o=a.filter(u=>u.status==="running").length,l="healthy";n>0?l="unhealthy":i>r.length/2&&(l="degraded");let c={status:l,domainHealth:e,totalAgents:a.length,activeAgents:o,pendingTasks:this.getQueuedTaskCount(),runningTasks:this.getRunningTaskCount(),workStealingActive:this.workStealingTimer!==null,lastHealthCheck:new Date,issues:t};return this.minCutBridge?this.minCutBridge.extendQueenHealth(c):c}getMetrics(){let e=new Map,t=0;for(let l of T){let c=this.getDomainLoad(l);e.set(l,c),t+=c}let n=this.agentCoordinator.listAgents(),i=n.filter(l=>l.status==="running").length,r=n.length>0?i/n.length:0,a=this.taskDurations.average(),o={tasksReceived:this.tasksReceived,tasksCompleted:this.tasksCompleted,tasksFailed:this.tasksFailed,tasksStolen:this.tasksStolen,averageTaskDuration:a,domainUtilization:e,agentUtilization:r,protocolsExecuted:this.protocolsExecuted,workflowsExecuted:this.workflowsExecuted,uptime:Date.now()-this.startTime.getTime()};return this.minCutBridge?this.minCutBridge.extendQueenMetrics(o):o}getMinCutBridge(){return this.minCutBridge}injectMinCutBridgeIntoDomain(e){if(!this.minCutBridge)return g.warn("Cannot inject MinCut bridge: bridge not initialized"),!1;if(!this.domainPlugins)return g.warn("Cannot inject MinCut bridge: no domain plugins registered"),!1;let t=this.domainPlugins.get(e);return t?rt(t)?(t.setMinCutBridge(this.minCutBridge),g.info(`MinCut bridge injected into ${e} (late binding)`),!0):(g.warn(`Domain ${e} does not support MinCut integration`),!1):(g.warn(`Cannot inject MinCut bridge: domain ${e} not found`),!1)}getTinyDancerRouter(){return this.tinyDancerRouter}getDomainBreakerRegistry(){return this.domainBreakerRegistry}getDomainTeamManager(){return this.domainTeamManager}getAgentTeamsAdapter(){return this.agentTeamsAdapter}getTierSelector(){return this.tierSelector}getTraceCollector(){return this.traceCollector}getHypothesisManager(){return this.hypothesisManager}getFederationMailbox(){return this.federationMailbox}getDynamicScaler(){return this.dynamicScaler}connectReasoningBank(e){let t=new ce(e);this.taskCompletedHook=new le({},t),g.info("ReasoningBank connected for pattern training")}async executeProtocol(e,t){if(!this.protocolExecutor)return y(new Error("Protocol executor not configured"));let n=await this.protocolExecutor.execute(e,t);return n.success?(this.protocolsExecuted++,await this.publishEvent("ProtocolExecuted",{protocolId:e,executionId:n.value.executionId}),C(n.value.executionId)):n}async executeWorkflow(e,t){if(!this.workflowExecutor)return y(new Error("Workflow executor not configured"));let n=await this.workflowExecutor.execute(e,t);return n.success?(this.workflowsExecuted++,await this.publishEvent("WorkflowExecuted",{workflowId:e,executionId:n.value.executionId}),C(n.value.executionId)):n}cleanupCompletedTasks(e=36e5){return at(this.tasks,this.taskTraceContexts,e)}subscribeToEvents(){this.eventSubscriptionIds=Vt(this.createEventHandlerContext(),T)}enqueueTaskInternal(e){Yt(this.taskQueue,this.domainQueues,e)}async publishEvent(e,t){await this.eventBus.publish({id:f(),type:`Queen${e}`,timestamp:new Date,source:"queen-coordinator",payload:t})}queueTask(e){this.enqueueTaskInternal(e);let t={taskId:e.id,task:e,status:"queued",assignedAgents:[],retryCount:0};return this.tasks.set(e.id,t),this.tasksReceived++,this.auditLogger.logSubmit(e.id,{type:e.type,priority:e.priority}),this.auditLogger.logQueue(e.id,Je(this.taskQueue,e)),this.publishEvent("TaskQueued",{taskId:e.id,task:e,position:Je(this.taskQueue,e)}),C(e.id)}selectFleetTier(e){if(this.tierSelector)try{let t={trigger:e.payload?.trigger??"manual",changedFiles:e.payload?.changedFiles,affectedDomains:e.targetDomains,severity:e.priority==="p0"?"critical":e.priority==="p1"?"high":void 0,isHotfix:e.payload?.isHotfix},n=this.tierSelector.selectTier(t);return g.info(`Fleet tier: ${n.selectedTier} (${n.reason})`),n.selectedTier}catch(t){g.warn("Tier selection error (continuing)",{error:t});return}}startTaskTrace(e,t){if(this.traceCollector)try{let{context:n}=this.traceCollector.startTrace({operationName:e.type,agentId:e.requester||"queen",domain:e.targetDomains[0]||"test-generation",tags:{taskId:t,priority:e.priority}});if(this.taskTraceContexts.size>=1e4){let r=this.taskTraceContexts.keys().next().value;r!==void 0&&this.taskTraceContexts.delete(r)}this.taskTraceContexts.set(t,n)}catch(n){g.warn("Trace start error (continuing)",{error:n})}}getRunningTaskCount(){return Array.from(this.tasks.values()).filter(e=>e.status==="running"||e.status==="assigned").length}getQueuedTaskCount(){return Array.from(this.tasks.values()).filter(e=>e.status==="queued").length}initializeSubsystems(){if(this.config.enableCircuitBreakers!==!1)try{this.domainBreakerRegistry=Lt(),g.info("Domain circuit breaker registry initialized")}catch(e){g.warn("Circuit breaker initialization failed (continuing)",{error:e})}if(this.config.enableDomainTeams!==!1)try{this.agentTeamsAdapter=Pe(),this.agentTeamsAdapter.initialize(),this.domainTeamManager=He(this.agentTeamsAdapter),g.info("Domain team manager initialized")}catch(e){g.warn("Domain team manager initialization failed (continuing)",{error:e})}if(this.config.enableFleetTiers!==!1)try{this.tierSelector=Le(),g.info("Fleet tier selector initialized")}catch(e){g.warn("Tier selector initialization failed (continuing)",{error:e})}try{this.traceCollector=_e(),g.info("Trace collector initialized")}catch(e){g.warn("Trace collector initialization failed (continuing)",{error:e})}try{this.hypothesisManager=$e(),this.federationMailbox=Ge(),this.dynamicScaler=qe(),g.info("Phase 4 modules initialized (hypotheses, federation, scaling)")}catch(e){g.warn("Phase 4 initialization failed (continuing)",{error:e})}}createEventHandlerContext(){let e=this;return{config:e.config,tasks:e.tasks,domainLastActivity:e.domainLastActivity,auditLogger:e.auditLogger,router:e.router,agentCoordinator:e.agentCoordinator,get runningTaskCounter(){return e.runningTaskCounter},set runningTaskCounter(t){e.runningTaskCounter=t},get tasksCompleted(){return e.tasksCompleted},set tasksCompleted(t){e.tasksCompleted=t},get tasksFailed(){return e.tasksFailed},set tasksFailed(t){e.tasksFailed=t},taskDurations:e.taskDurations,get domainBreakerRegistry(){return e.domainBreakerRegistry},get traceCollector(){return e.traceCollector},taskTraceContexts:e.taskTraceContexts,get taskCompletedHook(){return e.taskCompletedHook},get hypothesisManager(){return e.hypothesisManager},processQueue:()=>et(e.createTaskContext()),enqueueTask:t=>e.enqueueTaskInternal(t)}}createTaskContext(){let e=this;return{config:e.config,tasks:e.tasks,taskQueue:e.taskQueue,domainQueues:e.domainQueues,domainLastActivity:e.domainLastActivity,auditLogger:e.auditLogger,agentCoordinator:e.agentCoordinator,domainPlugins:e.domainPlugins,get runningTaskCounter(){return e.runningTaskCounter},set runningTaskCounter(t){e.runningTaskCounter=t},get tasksReceived(){return e.tasksReceived},set tasksReceived(t){e.tasksReceived=t},get tasksCompleted(){return e.tasksCompleted},set tasksCompleted(t){e.tasksCompleted=t},get tasksFailed(){return e.tasksFailed},set tasksFailed(t){e.tasksFailed=t},taskDurations:e.taskDurations,get tinyDancerRouter(){return e.tinyDancerRouter},get domainBreakerRegistry(){return e.domainBreakerRegistry},get domainTeamManager(){return e.domainTeamManager},get tierSelector(){return e.tierSelector},get traceCollector(){return e.traceCollector},taskTraceContexts:e.taskTraceContexts,get coExecutionRepo(){return e.coExecutionRepo},requestAgentSpawn:(t,n,i)=>e.requestAgentSpawn(t,n,i),publishEvent:(t,n)=>e.publishEvent(t,n),getDomainLoad:t=>e.getDomainLoad(t),getDomainHealth:t=>e.getDomainHealth(t)}}createWorkStealingContext(){let e=this;return{config:e.config,domainQueues:e.domainQueues,auditLogger:e.auditLogger,get tasksStolen(){return e.tasksStolen},set tasksStolen(t){e.tasksStolen=t},getIdleDomains:()=>e.getIdleDomains(),getBusyDomains:()=>e.getBusyDomains(),getDomainLoad:t=>e.getDomainLoad(t),removeFromQueues:t=>pe(e.taskQueue,e.domainQueues,t),assignTaskToDomain:(t,n)=>nt(e.createTaskContext(),t,n).then(()=>{}),publishEvent:(t,n)=>e.publishEvent(t,n)}}createMetricsContext(){let e=this;return{config:e.config,memory:e.memory,get dynamicScaler(){return e.dynamicScaler},getMetrics:()=>e.getMetrics(),publishEvent:(t,n)=>e.publishEvent(t,n),getQueuedTaskCount:()=>e.getQueuedTaskCount(),getActiveAgentCount:()=>e.agentCoordinator.listAgents().filter(t=>t.status==="running").length,getIdleAgentCount:()=>e.agentCoordinator.listAgents().filter(t=>t.status==="idle").length,getAverageTaskDuration:()=>e.taskDurations.average(),getTasksReceived:()=>e.tasksReceived,getTasksFailed:()=>e.tasksFailed,getTasksCompleted:()=>e.tasksCompleted}}};function Fo(s,e,t,n,i,r){return new st(s.eventBus,s.coordinator,s.memory,e,t,n,i,r)}export{xe as a,ar as b,ni as c,P as d,st as e,Fo as f};
|
|
180
|
+
`}}return t}getRecommendations(e){switch(e.loopType){case"strategic":return[...e.recommendations.forRiskAssessor,...e.recommendations.forQualityCriteria];case"tactical":return e.recommendations.forProductFactorsAssessor;case"operational":return[...e.recommendations.forTestArchitect,...e.recommendations.antiPatterns];case"quality-criteria":return e.recommendations.forRequirementsValidator;default:return[]}}filterManagedHooks(e){if(process.env.AQE_HOOKS_MANAGED_ONLY!=="true")return e;let t=e.filter(([n])=>n.startsWith("managed:"));return t.length<e.length&&console.log(`[CrossPhaseHooks] AQE_HOOKS_MANAGED_ONLY: filtered ${e.length-t.length} non-managed hooks`),t}async isBlockedUrl(e){if(!e.includes("://"))return!1;let t=await ye(e);return t.safe?!1:(console.warn(`[CrossPhaseHooks] SSRF blocked: ${t.reason}`),!0)}checkConditions(e,t){return!e||e.length===0?!0:e.every(n=>this.evaluateCondition(n,t))}evaluateCondition(e,t){try{let n=e.split(/\s*(>|<|>=|<=|==|!=)\s*/);if(n.length!==3)return!1;let[i,r,a]=n,o=this.getValueFromPath(t,i),l=isNaN(Number(a))?a:Number(a),c=typeof o=="number"?o:Number(o),u=typeof l=="number"?l:Number(l);switch(r){case">":return c>u;case"<":return c<u;case">=":return c>=u;case"<=":return c<=u;case"==":return o==l;case"!=":return o!=l;default:return!1}}catch{return!1}}getValueFromPath(e,t){return t.split(".").reduce((n,i)=>{if(n&&typeof n=="object"&&i in n)return n[i]},e)}extractFromContext(e,t){let n={};for(let[i,r]of Object.entries(e))n[i]=this.getValueFromPath(t,r);return n}parseMaxAge(e){let t=e.match(/^(\d+)(d|h|m|s)$/);if(!t)return 0;let[,n,i]=t,r=parseInt(n,10);switch(i){case"d":return r*24*60*60*1e3;case"h":return r*60*60*1e3;case"m":return r*60*1e3;case"s":return r*1e3;default:return 0}}on(e,t){this.listeners.has(e)||this.listeners.set(e,new Set),this.listeners.get(e).add(t)}off(e,t){this.listeners.get(e)?.delete(t)}emit(e,t){this.listeners.get(e)?.forEach(n=>n(t))}async runCleanup(){if(!this.config?.cleanup.enabled)return;console.log("[CrossPhaseHooks] Running cleanup...");let e=await this.memory.cleanupExpired();console.log(`[CrossPhaseHooks] Cleanup complete: ${e.deleted} signals deleted`)}},Ze=null;function Kt(s){return Ze||(Ze=new Xe(s)),Ze}function Yt(s,e){let t=[];for(let a of e){let o=s.router.subscribeToDoamin(a,async l=>{await ui(s,l)});t.push(o)}let n=s.router.subscribeToEventType("TaskCompleted",async a=>{await di(s,a)});t.push(n);let i=s.router.subscribeToEventType("TaskFailed",async a=>{await gi(s,a)});t.push(i);let r=s.router.subscribeToEventType("AgentStatusChanged",async a=>{await mi(s,a)});return t.push(r),t}async function ui(s,e){s.domainLastActivity.set(e.source,new Date),await s.processQueue()}async function di(s,e){let{taskId:t,result:n}=e.payload,i=s.tasks.get(t);if(i){(i.status==="running"||i.status==="assigned")&&(s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1));let r=i.startedAt?Date.now()-i.startedAt.getTime():0;s.tasks.set(t,{...i,status:"completed",completedAt:new Date,result:n}),s.tasksCompleted++,s.taskDurations.push(r),s.auditLogger.logComplete(t,i.assignedAgents[0]);try{let a=Kt(),o=i.assignedAgents[0];o&&await a.onAgentComplete(o,{taskId:t,taskType:i.task.type,domain:i.assignedDomain,result:n,duration:r})}catch(a){console.warn("[QueenCoordinator] Cross-phase hook error:",a)}try{await I.afterTaskExecution({taskId:t,taskType:i.task.type,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",priority:i.task.priority},!0,0,0)}catch(a){console.warn("[QueenCoordinator] Governance tracking error:",a)}if(s.domainBreakerRegistry&&i.assignedDomain&&s.domainBreakerRegistry.getBreaker(i.assignedDomain).recordSuccess(),s.traceCollector){let a=s.taskTraceContexts.get(t);a&&(s.traceCollector.completeSpan(a.spanId),s.taskTraceContexts.delete(t))}if(s.taskCompletedHook)try{let a=typeof n=="object"&&n!==null?n:null;if(a===null)console.error(`[QueenCoordinator] Pattern training skipped for task ${t}: result is not an object (got ${typeof n})`);else{let o=pi(a,t);if(o){let l={taskId:t,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",type:i.task.type,status:"completed",output:a,metrics:o,duration:r,timestamp:Date.now()};s.taskCompletedHook.onTaskCompleted(l).catch(c=>{console.warn("[QueenCoordinator] Pattern training error:",c)})}}}catch(a){console.warn("[QueenCoordinator] Pattern training setup error:",a)}}await s.processQueue()}async function gi(s,e){let{taskId:t,error:n}=e.payload,i=s.tasks.get(t);if(i){if((i.status==="running"||i.status==="assigned")&&(s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1)),s.domainBreakerRegistry&&i.assignedDomain&&s.domainBreakerRegistry.getBreaker(i.assignedDomain).recordFailure(new Error(n||"Task failed")),s.traceCollector){let r=s.taskTraceContexts.get(t);r&&(s.traceCollector.failSpan(r.spanId,n||"Task failed"),s.taskTraceContexts.delete(t))}if(i.retryCount<s.config.taskRetryLimit){s.auditLogger.logFail(t,i.assignedAgents[0],n);let r={...i,status:"queued",retryCount:i.retryCount+1,error:n};s.tasks.set(t,r),s.enqueueTask(i.task)}else{s.tasks.set(t,{...i,status:"failed",completedAt:new Date,error:n}),s.tasksFailed++,s.auditLogger.logFail(t,i.assignedAgents[0],n);try{await I.afterTaskExecution({taskId:t,taskType:i.task.type,agentId:i.assignedAgents[0]||"unknown",domain:i.assignedDomain||"test-generation",priority:i.task.priority},!1,0,0)}catch(r){console.warn("[QueenCoordinator] Governance tracking error:",r)}if(s.hypothesisManager&&(i.task.priority==="p0"||i.task.priority==="p1"))try{let r=i.assignedDomain||"test-generation",a=s.hypothesisManager.createInvestigation(t,r,`Root cause analysis for ${i.task.type} failure: ${n}`);s.hypothesisManager.addHypothesis(a.id,`Infrastructure failure in domain '${r}' caused task ${t} to fail`,"log-analysis",`${r}-lead`),s.hypothesisManager.addHypothesis(a.id,`Logic/configuration error in task payload caused ${i.task.type} to fail: ${n}`,"code-analysis",i.assignedAgents[0]||"unknown"),console.log(`[QueenCoordinator] Competing hypotheses investigation created: ${a.id}`)}catch(r){console.warn("[QueenCoordinator] Hypothesis creation error:",r)}}}await s.processQueue()}async function mi(s,e){let{agentId:t,status:n,domain:i}=e.payload;s.domainLastActivity.set(i,new Date),(n==="completed"||n==="failed")&&await s.processQueue()}function pi(s,e){if("metrics"in s&&typeof s.metrics=="object"&&s.metrics!==null){let t=s.metrics;return{testsPassed:typeof t.testsPassed=="number"?t.testsPassed:void 0,testsFailed:typeof t.testsFailed=="number"?t.testsFailed:void 0,coverageChange:typeof t.coverageChange=="number"?t.coverageChange:void 0,securityIssues:typeof t.securityIssues=="number"?t.securityIssues:void 0,performanceMs:typeof t.performanceMs=="number"?t.performanceMs:void 0,linesChanged:typeof t.linesChanged=="number"?t.linesChanged:void 0}}return"testsPassed"in s||"testsFailed"in s?{testsPassed:typeof s.testsPassed=="number"?s.testsPassed:void 0,testsFailed:typeof s.testsFailed=="number"?s.testsFailed:void 0,coverageChange:typeof s.coverageChange=="number"?s.coverageChange:void 0,securityIssues:typeof s.securityIssues=="number"?s.securityIssues:void 0,performanceMs:typeof s.performanceMs=="number"?s.performanceMs:void 0,linesChanged:typeof s.linesChanged=="number"?s.linesChanged:void 0}:(console.error(`[QueenCoordinator] Pattern training skipped for task ${e}: result object has no recognizable metrics shape (keys: ${Object.keys(s).join(", ")})`),null)}function Zt(s,e,t){let n=s.listAgents({domain:e}),i=n.filter(l=>l.status==="running").length,r=n.filter(l=>l.status==="idle").length,a=n.filter(l=>l.status==="failed").length,o;return a>0&&a>=n.length/2?o="unhealthy":a>0?o="degraded":i>0?o="healthy":o="idle",{status:o,agents:{total:n.length,active:i,idle:r,failed:a},lastActivity:t,errors:[]}}var hi=ft();function Xt(s,e,t){let n=s.get(t.priority);n&&ht(n,t,hi);for(let i of t.targetDomains){let r=e.get(i);r&&r.push(t)}}function pe(s,e,t){let n=s.get(t.priority);if(n){let i=n.findIndex(r=>r.id===t.id);i!==-1&&n.splice(i,1)}for(let i of t.targetDomains){let r=e.get(i);if(r){let a=r.findIndex(o=>o.id===t.id);a!==-1&&r.splice(a,1)}}}function Je(s,e){let t=0;for(let n of["p0","p1","p2","p3"]){let i=s.get(n);if(i){if(n===e.priority){t+=i.findIndex(r=>r.id===e.id);break}t+=i.length}}return t}async function et(s){if(!(s.runningTaskCounter>=s.config.maxConcurrentTasks))for(let e of["p0","p1","p2","p3"]){let t=s.taskQueue.get(e);if(!t||t.length===0)continue;let n=t.shift();if(n){pe(s.taskQueue,s.domainQueues,n),s.runningTaskCounter++;try{await tt(s,n)}catch(i){throw s.runningTaskCounter--,i}if(s.runningTaskCounter>=s.config.maxConcurrentTasks)return}}}function Jt(s,e){let t=Array.from(s.values());return e&&(e.status&&(t=t.filter(n=>n.status===e.status)),e.domain&&(t=t.filter(n=>n.assignedDomain===e.domain)),e.priority&&(t=t.filter(n=>n.task.priority===e.priority)),e.type&&(t=t.filter(n=>n.task.type===e.type)),e.fromDate&&(t=t.filter(n=>n.task.createdAt>=e.fromDate)),e.toDate&&(t=t.filter(n=>n.task.createdAt<=e.toDate))),t}async function tt(s,e){let t=e.targetDomains.length>0?e.targetDomains:P[e.type]||[];if(t.length===0)return y(new Error(`No domains configured for task type: ${e.type}`));let n,i=1/0;for(let r of t){let a=s.getDomainLoad(r);s.getDomainHealth(r)?.status!=="unhealthy"&&a<i&&(i=a,n=r)}return n?nt(s,e,n):y(new Error("No healthy domain available for task"))}async function nt(s,e,t){let n;if(s.tinyDancerRouter){let l={p0:"critical",p1:"high",p2:"normal",p3:"low"},c={description:`${e.type}: ${JSON.stringify(e.payload).slice(0,200)}`,type:e.type,domain:t,priority:l[e.priority]};n=await s.tinyDancerRouter.route(c),s.config.enableMetrics&&console.log(`[Queen] TinyDancer routing: ${e.type} \u2192 tier=${n.tier}, model=${n.model}, cost=$${n.estimatedCost.toFixed(4)}`)}if(s.domainBreakerRegistry&&!s.domainBreakerRegistry.canExecuteInDomain(t))return y(new Error(`Domain '${t}' circuit breaker is open \u2014 too many recent failures`));if(s.domainTeamManager)try{if(!s.domainTeamManager.getDomainTeam(t)){let c=`${t}-lead`;s.domainTeamManager.createDomainTeam(t,c)}}catch(l){console.warn(`[Queen] Domain team setup for '${t}' failed (continuing):`,l)}let i=n?.tier||"task-worker",r=await s.requestAgentSpawn(t,i,["task-execution",e.type,...n?[`model:${n.model}`]:[]]),a=[];r.success&&a.push(r.value);let o={taskId:e.id,task:e,status:"running",assignedDomain:t,assignedAgents:a,startedAt:new Date,retryCount:0};s.tasks.set(e.id,o),s.domainLastActivity.set(t,new Date);for(let l of a)s.auditLogger.logAssign(e.id,l,t);if(await s.publishEvent("TaskAssigned",{taskId:e.id,domain:t,agentIds:a}),s.domainPlugins){let l=s.domainPlugins.get(t);if(l?.executeTask&&l.canHandleTask?.(e.type)){let c={taskId:e.id,taskType:e.type,payload:e.payload,priority:e.priority,timeout:e.timeout,correlationId:e.correlationId},u=await l.executeTask(c,d=>fi(s,d));return u.success?C(e.id):(s.tasks.set(e.id,{...o,status:"failed",error:u.error.message,completedAt:new Date}),s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1),s.tasksFailed++,s.auditLogger.logFail(e.id,a[0],u.error.message),y(u.error))}if(l)try{await l.handleEvent({id:f(),type:"TaskAssigned",timestamp:new Date,source:"queen-coordinator",correlationId:e.correlationId,payload:{task:e}}),console.warn(`[Queen] Domain ${t} has no executeTask handler, using event fallback`)}catch(c){console.warn(`[Queen] Failed to invoke domain ${t} event handler:`,c)}}return C(e.id)}async function fi(s,e){let t=s.tasks.get(e.taskId);if(!t){console.warn(`[Queen] Received completion for unknown task: ${e.taskId}`);return}let n={...t,status:e.success?"completed":"failed",completedAt:new Date,result:e.data,error:e.error};if(s.tasks.set(e.taskId,n),e.success?(s.tasksCompleted++,s.taskDurations.push(e.duration),s.auditLogger.logComplete(e.taskId,t.assignedAgents[0])):(s.tasksFailed++,s.auditLogger.logFail(e.taskId,t.assignedAgents[0],e.error||"Unknown error")),s.runningTaskCounter=Math.max(0,s.runningTaskCounter-1),s.coExecutionRepo&&t.assignedAgents.length>=2)try{s.coExecutionRepo.recordSwarmCoExecution(t.assignedAgents,t.assignedDomain||"unknown",e.success,t.task.type)}catch{}for(let i of t.assignedAgents)await s.agentCoordinator.stop(i);await s.publishEvent(e.success?"TaskCompleted":"TaskFailed",{taskId:e.taskId,domain:t.assignedDomain,result:e.data,error:e.error,duration:e.duration}),await et(s)}function en(s,e){return(P[e.type]||[]).includes(s)}k();async function tn(s){let e=0,t=s.getIdleDomains(),n=s.getBusyDomains();if(t.length===0||n.length===0)return 0;n.sort((i,r)=>s.getDomainLoad(r)-s.getDomainLoad(i));for(let i of n){if(t.length===0)break;let r=s.domainQueues.get(i)||[],a=Math.min(r.length,s.config.workStealing.stealBatchSize);for(let o=0;o<a&&t.length>0;o++){let l=r.find(c=>en(t[0],c));if(l){let c=t.shift();s.removeFromQueues(l),s.auditLogger.logSteal(l.id,i,c),await s.assignTaskToDomain(l,c),e++,s.tasksStolen++,await s.publishEvent("TaskStolen",{taskId:l.id,fromDomain:i,toDomain:c})}}}return e}function it(s,e){let t=0,n=10,i;return i=setInterval(async()=>{try{await e(),t=0}catch(r){t++;let a=Math.min(1e3*Math.pow(2,t),3e4);if(console.warn(`[QueenCoordinator] Work-stealing failed (attempt ${t}), backing off ${a}ms`,p(r)),t>n){console.error(`[QueenCoordinator] Work-stealing exceeded ${n} consecutive failures, stopping interval`),clearInterval(i);return}await new Promise(o=>setTimeout(o,a))}},s.workStealing.checkInterval),i}function rt(s){return typeof s.setMinCutBridge=="function"}function nn(s,e){for(let[t,n]of s)rt(n)&&(n.setMinCutBridge(e),console.log(`[QueenCoordinator] MinCut bridge injected into ${t}`))}async function rn(s,e,t){try{let n=await s.get("queen:state");if(n)for(let[i,r]of n.tasks)r.status==="queued"&&(e.set(i,r),t(r.task))}catch(n){console.debug("[QueenCoordinator] State loading failed:",n instanceof Error?n.message:n)}}async function an(s,e){let t=Array.from(e.entries()).filter(([,n])=>n.status==="queued");await s.set("queen:state",{tasks:t},{namespace:"queen-coordinator",persist:!0})}function sn(s){return setInterval(async()=>{let e=s.getMetrics();if(await s.publishEvent("MetricsCollected",{metrics:e}),await s.memory.set(`queen:metrics:${Date.now()}`,e,{ttl:864e5,namespace:"queen-coordinator"}),s.dynamicScaler)try{let t=s.getAverageTaskDuration(),n={queueDepth:s.getQueuedTaskCount(),activeAgents:s.getActiveAgentCount(),idleAgents:s.getIdleAgentCount(),avgTaskDurationMs:t,errorRate:s.getTasksReceived()>0?s.getTasksFailed()/s.getTasksReceived():0,throughput:e.uptime>0?s.getTasksCompleted()/(e.uptime/1e3):0,timestamp:Date.now()};s.dynamicScaler.recordMetrics(n);let i=s.dynamicScaler.evaluate();i&&i.action!=="maintain"&&(console.log(`[QueenCoordinator] Dynamic scaler: ${i.action} to ${i.targetAgents} agents \u2014 ${i.reason}`),s.dynamicScaler.execute(i).catch(r=>{console.warn("[QueenCoordinator] Dynamic scaling execution error:",r)}))}catch(t){console.warn("[QueenCoordinator] Dynamic scaler metrics error:",t)}},s.config.metricsInterval)}function at(s,e,t=36e5){let n=Date.now(),i=0;for(let[a,o]of s)if(o.status==="completed"||o.status==="failed"||o.status==="cancelled"){let l=o.completedAt?.getTime()||o.startedAt?.getTime()||0;l>0&&n-l>t&&(s.delete(a),e.delete(a),i++)}let r=1e4;if(e.size>r){let a=e.size-r,o=e.keys();for(let l=0;l<a;l++){let c=o.next().value;c!==void 0&&e.delete(c)}console.log(`[QueenCoordinator] Evicted ${a} oldest trace contexts (max: ${r})`)}return i>0&&console.log(`[QueenCoordinator] Cleaned up ${i} old tasks (retention: ${t}ms)`),i}function on(s,e){return s&&s.size>0?Array.from(s.keys()):[...e]}var m=ut.create("QueenCoordinator");Wt(T);var st=class{constructor(e,t,n,i,r,a,o,l={}){this.eventBus=e;this.agentCoordinator=t;this.memory=n;this.router=i;this.protocolExecutor=r;this.workflowExecutor=a;this.domainPlugins=o;this.config={...jt,...l},this.auditLogger=Te({enableConsoleLog:this.config.enableMetrics,maxEntries:1e3,logPrefix:"[QUEEN]"}),["p0","p1","p2","p3"].forEach(c=>{this.taskQueue.set(c,[])}),this.config.enableRouting!==!1&&(this.tinyDancerRouter=new K(this.config.routing)),T.forEach(c=>{this.domainQueues.set(c,[]),this.domainLastActivity.set(c,new Date)})}config;tasks=new Map;taskQueue=new Map;domainQueues=new Map;domainLastActivity=new Map;initialized=!1;workStealingTimer=null;metricsTimer=null;cleanupTimer=null;startTime=new Date;eventSubscriptionIds=[];runningTaskCounter=0;tasksReceived=0;tasksCompleted=0;tasksFailed=0;tasksStolen=0;taskDurations=new ct(1e3);protocolsExecuted=0;workflowsExecuted=0;auditLogger;minCutBridge=null;tinyDancerRouter=null;domainBreakerRegistry=null;domainTeamManager=null;agentTeamsAdapter=null;tierSelector=null;taskCompletedHook=null;traceCollector=null;taskTraceContexts=new Map;hypothesisManager=null;federationMailbox=null;dynamicScaler=null;coExecutionRepo=null;dependencyGraph=null;availableMcpServers=[];async initialize(){if(!this.initialized){this.startTime=new Date,await this.router.initialize(),this.subscribeToEvents(),this.config.workStealing.enabled&&(this.workStealingTimer=it(this.config,()=>this.triggerWorkStealing().then(()=>{}))),this.config.enableMetrics&&(this.metricsTimer=sn(this.createMetricsContext())),this.cleanupTimer=setInterval(()=>{at(this.tasks,this.taskTraceContexts,36e5)},3e5),this.cleanupTimer.unref(),await rn(this.memory,this.tasks,e=>this.enqueueTaskInternal(e)),this.minCutBridge=vt(this.eventBus,this.agentCoordinator,{autoUpdateFromEvents:!0,persistData:!0,includeInQueenHealth:!0,sharedGraph:xe()}),await this.minCutBridge.initialize(),this.domainPlugins&&nn(this.domainPlugins,this.minCutBridge);try{await I.initialize(),m.info("Governance adapter initialized")}catch(e){m.warn("Governance initialization failed (continuing)",{error:e})}this.initializeSubsystems();try{let{join:e}=await import("path"),t=e(process.cwd(),".claude","agents","v3");this.dependencyGraph=Ft(t),this.availableMcpServers=yt(process.cwd());let{getUnifiedMemory:n}=await import("./unified-memory-72SKVZ7Y.js"),i=n();await i.initialize(),this.coExecutionRepo=Pt(),this.coExecutionRepo.initialize(i.getDatabase()),this.dependencyGraph.warnings.length>0&&m.warn(`Dependency graph: ${this.dependencyGraph.warnings.length} warning(s)`,{warnings:this.dependencyGraph.warnings.slice(0,5)}),m.info("Dependency intelligence initialized",{agents:this.dependencyGraph.nodes.size,mcpServers:this.availableMcpServers.length})}catch(e){m.warn("Dependency intelligence initialization failed (continuing)",{error:e})}await this.publishEvent("QueenInitialized",{timestamp:new Date,config:this.config,domains:T}),this.initialized=!0}}async dispose(){this.workStealingTimer&&(clearInterval(this.workStealingTimer),this.workStealingTimer=null),this.metricsTimer&&(clearInterval(this.metricsTimer),this.metricsTimer=null),this.cleanupTimer&&(clearInterval(this.cleanupTimer),this.cleanupTimer=null),this.minCutBridge&&(await this.minCutBridge.dispose(),this.minCutBridge=null),this.domainTeamManager&&(this.domainTeamManager.dispose(),this.domainTeamManager=null),this.agentTeamsAdapter&&(this.agentTeamsAdapter.shutdown(),this.agentTeamsAdapter=null),this.domainBreakerRegistry=null,this.tierSelector=null,this.traceCollector&&(this.traceCollector.dispose(),this.traceCollector=null),this.hypothesisManager&&(this.hypothesisManager.dispose(),this.hypothesisManager=null),this.federationMailbox&&(this.federationMailbox.dispose(),this.federationMailbox=null),this.dynamicScaler&&(this.dynamicScaler.dispose(),this.dynamicScaler=null),await an(this.memory,this.tasks);for(let[e,t]of this.tasks)(t.status==="queued"||t.status==="running")&&await this.cancelTask(e);await this.publishEvent("QueenShutdown",{timestamp:new Date,metrics:this.getMetrics()});for(let e of this.eventSubscriptionIds)this.router.unsubscribe(e);this.eventSubscriptionIds=[],await this.router.dispose(),this.initialized=!1}async submitTask(e){if(!this.initialized)return y(new Error("Queen Coordinator not initialized"));let t=`task_${f()}`,n={...e,id:t,createdAt:new Date,timeout:e.timeout||this.config.defaultTaskTimeout},i={taskId:n.id,taskType:n.type,agentId:n.requester||"unknown",domain:n.targetDomains[0]||"test-generation",priority:n.priority,payload:n.payload};try{let r=await I.beforeTaskExecution(i);if(!r.allowed)return this.auditLogger.logFail(t,"governance",r.reason||"Governance check failed"),await this.publishEvent("TaskRejected",{taskId:t,reason:r.reason,escalate:r.escalate}),y(new Error(`Task blocked by governance: ${r.reason}`))}catch(r){m.warn("Governance check error (continuing)",{error:r})}this.runningTaskCounter++;try{if(this.runningTaskCounter>this.config.maxConcurrentTasks)return this.runningTaskCounter--,this.queueTask(n);this.auditLogger.logSubmit(t,{type:n.type,priority:n.priority}),this.selectFleetTier(n),this.startTaskTrace(n,t);let r=await tt(this.createTaskContext(),n);return r.success?(this.tasksReceived++,await this.publishEvent("TaskSubmitted",{taskId:t,task:n}),C(t)):(this.runningTaskCounter--,r)}catch(r){throw this.runningTaskCounter--,r}}async cancelTask(e){let t=this.tasks.get(e);if(!t)return y(new Error(`Task not found: ${e}`));if(t.status==="completed"||t.status==="failed")return y(new Error(`Task already finished: ${e}`));(t.status==="running"||t.status==="assigned")&&(this.runningTaskCounter=Math.max(0,this.runningTaskCounter-1)),this.tasks.set(e,{...t,status:"cancelled",completedAt:new Date}),pe(this.taskQueue,this.domainQueues,t.task);for(let n of t.assignedAgents)await this.agentCoordinator.stop(n);return this.auditLogger.logCancel(e),await this.publishEvent("TaskCancelled",{taskId:e}),C(void 0)}getTaskStatus(e){return this.tasks.get(e)}listTasks(e){return Jt(this.tasks,e)}getDomainHealth(e){if(this.domainPlugins){let t=this.domainPlugins.get(e);if(t)return t.getHealth()}return Zt(this.agentCoordinator,e,this.domainLastActivity.get(e))}getDomainLoad(e){let t=this.domainQueues.get(e)||[],n=Array.from(this.tasks.values()).filter(i=>i.assignedDomain===e&&i.status==="running");return t.length+n.length}getIdleDomains(){let e=Date.now(),t=this.config.workStealing.idleThreshold;return T.filter(n=>{let i=this.domainLastActivity.get(n);return this.getDomainLoad(n)===0&&i&&e-i.getTime()>t})}getBusyDomains(){return T.filter(e=>this.getDomainLoad(e)>this.config.workStealing.loadThreshold)}getSpawnPlan(e){return this.dependencyGraph?Ot(e,this.dependencyGraph):{phases:[e],warnings:[],unsatisfiedHardDeps:[]}}getDependencyGraph(){return this.dependencyGraph}enableWorkStealing(){this.workStealingTimer||(this.workStealingTimer=it(this.config,()=>this.triggerWorkStealing().then(()=>{})))}disableWorkStealing(){this.workStealingTimer&&(clearInterval(this.workStealingTimer),this.workStealingTimer=null)}async triggerWorkStealing(){return tn(this.createWorkStealingContext())}listAllAgents(){return this.agentCoordinator.listAgents()}getAgentsByDomain(e){return this.agentCoordinator.listAgents({domain:e})}async requestAgentSpawn(e,t,n){if(!this.agentCoordinator.canSpawn())return y(new Error("Maximum concurrent agents reached (15)"));if(this.dependencyGraph&&this.availableMcpServers.length>0)try{for(let[,r]of this.dependencyGraph.nodes){let a=r.dependencies.mcpServers;if(!a||a.length===0)continue;let o=a.filter(l=>l.required&&!this.availableMcpServers.includes(l.name));if(o.length>0){m.warn(`Pre-spawn MCP advisory: ${r.agentName} needs ${o.map(l=>l.name).join(", ")}`,{agent:r.agentName,domain:e,missing:o.map(l=>l.name)});break}}}catch{}let i=await this.agentCoordinator.spawn({name:`${e}-${t}-${Date.now()}`,domain:e,type:t,capabilities:n});if(i.success){if(this.domainLastActivity.set(e,new Date),this.domainTeamManager&&typeof this.domainTeamManager.getDomainTeam=="function")try{if(this.domainTeamManager.getDomainTeam(e))this.domainTeamManager.addTeammate(e,i.value)||m.warn(`Agent ${i.value} could not join ${e} team (full)`);else try{this.domainTeamManager.createDomainTeam(e,i.value)}catch{this.domainTeamManager.addTeammate(e,i.value)||m.warn(`Agent ${i.value} could not join ${e} team (full or max teams reached)`)}}catch(r){m.warn(`Auto-team-wiring failed for ${i.value}`,{error:r})}await this.publishEvent("AgentSpawned",{agentId:i.value,domain:e,type:t,capabilities:n})}return i}getHealth(){let e=new Map,t=[],n=0,i=0,r=on(this.domainPlugins,T);for(let u of r){let d=this.getDomainHealth(u);d&&(e.set(u,d),d.status==="unhealthy"?(n++,t.push({domain:u,severity:"high",message:`Domain ${u} is unhealthy`,timestamp:new Date})):d.status==="degraded"&&(i++,t.push({domain:u,severity:"medium",message:`Domain ${u} is degraded`,timestamp:new Date})))}let a=this.agentCoordinator.listAgents(),o=a.filter(u=>u.status==="running").length,l="healthy";n>0?l="unhealthy":i>r.length/2&&(l="degraded");let c={status:l,domainHealth:e,totalAgents:a.length,activeAgents:o,pendingTasks:this.getQueuedTaskCount(),runningTasks:this.getRunningTaskCount(),workStealingActive:this.workStealingTimer!==null,lastHealthCheck:new Date,issues:t};return this.minCutBridge?this.minCutBridge.extendQueenHealth(c):c}getMetrics(){let e=new Map,t=0;for(let l of T){let c=this.getDomainLoad(l);e.set(l,c),t+=c}let n=this.agentCoordinator.listAgents(),i=n.filter(l=>l.status==="running").length,r=n.length>0?i/n.length:0,a=this.taskDurations.average(),o={tasksReceived:this.tasksReceived,tasksCompleted:this.tasksCompleted,tasksFailed:this.tasksFailed,tasksStolen:this.tasksStolen,averageTaskDuration:a,domainUtilization:e,agentUtilization:r,protocolsExecuted:this.protocolsExecuted,workflowsExecuted:this.workflowsExecuted,uptime:Date.now()-this.startTime.getTime()};return this.minCutBridge?this.minCutBridge.extendQueenMetrics(o):o}getMinCutBridge(){return this.minCutBridge}injectMinCutBridgeIntoDomain(e){if(!this.minCutBridge)return m.warn("Cannot inject MinCut bridge: bridge not initialized"),!1;if(!this.domainPlugins)return m.warn("Cannot inject MinCut bridge: no domain plugins registered"),!1;let t=this.domainPlugins.get(e);return t?rt(t)?(t.setMinCutBridge(this.minCutBridge),m.info(`MinCut bridge injected into ${e} (late binding)`),!0):(m.warn(`Domain ${e} does not support MinCut integration`),!1):(m.warn(`Cannot inject MinCut bridge: domain ${e} not found`),!1)}getTinyDancerRouter(){return this.tinyDancerRouter}getDomainBreakerRegistry(){return this.domainBreakerRegistry}getDomainTeamManager(){return this.domainTeamManager}getAgentTeamsAdapter(){return this.agentTeamsAdapter}getTierSelector(){return this.tierSelector}getTraceCollector(){return this.traceCollector}getHypothesisManager(){return this.hypothesisManager}getFederationMailbox(){return this.federationMailbox}getDynamicScaler(){return this.dynamicScaler}connectReasoningBank(e){let t=new ce(e);this.taskCompletedHook=new le({},t),m.info("ReasoningBank connected for pattern training")}async executeProtocol(e,t){if(!this.protocolExecutor)return y(new Error("Protocol executor not configured"));let n=await this.protocolExecutor.execute(e,t);return n.success?(this.protocolsExecuted++,await this.publishEvent("ProtocolExecuted",{protocolId:e,executionId:n.value.executionId}),C(n.value.executionId)):n}async executeWorkflow(e,t){if(!this.workflowExecutor)return y(new Error("Workflow executor not configured"));let n=await this.workflowExecutor.execute(e,t);return n.success?(this.workflowsExecuted++,await this.publishEvent("WorkflowExecuted",{workflowId:e,executionId:n.value.executionId}),C(n.value.executionId)):n}cleanupCompletedTasks(e=36e5){return at(this.tasks,this.taskTraceContexts,e)}subscribeToEvents(){this.eventSubscriptionIds=Yt(this.createEventHandlerContext(),T)}enqueueTaskInternal(e){Xt(this.taskQueue,this.domainQueues,e)}async publishEvent(e,t){await this.eventBus.publish({id:f(),type:`Queen${e}`,timestamp:new Date,source:"queen-coordinator",payload:t})}queueTask(e){this.enqueueTaskInternal(e);let t={taskId:e.id,task:e,status:"queued",assignedAgents:[],retryCount:0};return this.tasks.set(e.id,t),this.tasksReceived++,this.auditLogger.logSubmit(e.id,{type:e.type,priority:e.priority}),this.auditLogger.logQueue(e.id,Je(this.taskQueue,e)),this.publishEvent("TaskQueued",{taskId:e.id,task:e,position:Je(this.taskQueue,e)}),C(e.id)}selectFleetTier(e){if(this.tierSelector)try{let t={trigger:e.payload?.trigger??"manual",changedFiles:e.payload?.changedFiles,affectedDomains:e.targetDomains,severity:e.priority==="p0"?"critical":e.priority==="p1"?"high":void 0,isHotfix:e.payload?.isHotfix},n=this.tierSelector.selectTier(t);return m.info(`Fleet tier: ${n.selectedTier} (${n.reason})`),n.selectedTier}catch(t){m.warn("Tier selection error (continuing)",{error:t});return}}startTaskTrace(e,t){if(this.traceCollector)try{let{context:n}=this.traceCollector.startTrace({operationName:e.type,agentId:e.requester||"queen",domain:e.targetDomains[0]||"test-generation",tags:{taskId:t,priority:e.priority}});if(this.taskTraceContexts.size>=1e4){let r=this.taskTraceContexts.keys().next().value;r!==void 0&&this.taskTraceContexts.delete(r)}this.taskTraceContexts.set(t,n)}catch(n){m.warn("Trace start error (continuing)",{error:n})}}getRunningTaskCount(){return Array.from(this.tasks.values()).filter(e=>e.status==="running"||e.status==="assigned").length}getQueuedTaskCount(){return Array.from(this.tasks.values()).filter(e=>e.status==="queued").length}initializeSubsystems(){if(this.config.enableCircuitBreakers!==!1)try{this.domainBreakerRegistry=Qt(),m.info("Domain circuit breaker registry initialized")}catch(e){m.warn("Circuit breaker initialization failed (continuing)",{error:e})}if(this.config.enableDomainTeams!==!1)try{this.agentTeamsAdapter=Pe(),this.agentTeamsAdapter.initialize(),this.domainTeamManager=He(this.agentTeamsAdapter),m.info("Domain team manager initialized")}catch(e){m.warn("Domain team manager initialization failed (continuing)",{error:e})}if(this.config.enableFleetTiers!==!1)try{this.tierSelector=Le(),m.info("Fleet tier selector initialized")}catch(e){m.warn("Tier selector initialization failed (continuing)",{error:e})}try{this.traceCollector=_e(),m.info("Trace collector initialized")}catch(e){m.warn("Trace collector initialization failed (continuing)",{error:e})}try{this.hypothesisManager=$e(),this.federationMailbox=Ge(),this.dynamicScaler=qe(),m.info("Phase 4 modules initialized (hypotheses, federation, scaling)")}catch(e){m.warn("Phase 4 initialization failed (continuing)",{error:e})}}createEventHandlerContext(){let e=this;return{config:e.config,tasks:e.tasks,domainLastActivity:e.domainLastActivity,auditLogger:e.auditLogger,router:e.router,agentCoordinator:e.agentCoordinator,get runningTaskCounter(){return e.runningTaskCounter},set runningTaskCounter(t){e.runningTaskCounter=t},get tasksCompleted(){return e.tasksCompleted},set tasksCompleted(t){e.tasksCompleted=t},get tasksFailed(){return e.tasksFailed},set tasksFailed(t){e.tasksFailed=t},taskDurations:e.taskDurations,get domainBreakerRegistry(){return e.domainBreakerRegistry},get traceCollector(){return e.traceCollector},taskTraceContexts:e.taskTraceContexts,get taskCompletedHook(){return e.taskCompletedHook},get hypothesisManager(){return e.hypothesisManager},processQueue:()=>et(e.createTaskContext()),enqueueTask:t=>e.enqueueTaskInternal(t)}}createTaskContext(){let e=this;return{config:e.config,tasks:e.tasks,taskQueue:e.taskQueue,domainQueues:e.domainQueues,domainLastActivity:e.domainLastActivity,auditLogger:e.auditLogger,agentCoordinator:e.agentCoordinator,domainPlugins:e.domainPlugins,get runningTaskCounter(){return e.runningTaskCounter},set runningTaskCounter(t){e.runningTaskCounter=t},get tasksReceived(){return e.tasksReceived},set tasksReceived(t){e.tasksReceived=t},get tasksCompleted(){return e.tasksCompleted},set tasksCompleted(t){e.tasksCompleted=t},get tasksFailed(){return e.tasksFailed},set tasksFailed(t){e.tasksFailed=t},taskDurations:e.taskDurations,get tinyDancerRouter(){return e.tinyDancerRouter},get domainBreakerRegistry(){return e.domainBreakerRegistry},get domainTeamManager(){return e.domainTeamManager},get tierSelector(){return e.tierSelector},get traceCollector(){return e.traceCollector},taskTraceContexts:e.taskTraceContexts,get coExecutionRepo(){return e.coExecutionRepo},requestAgentSpawn:(t,n,i)=>e.requestAgentSpawn(t,n,i),publishEvent:(t,n)=>e.publishEvent(t,n),getDomainLoad:t=>e.getDomainLoad(t),getDomainHealth:t=>e.getDomainHealth(t)}}createWorkStealingContext(){let e=this;return{config:e.config,domainQueues:e.domainQueues,auditLogger:e.auditLogger,get tasksStolen(){return e.tasksStolen},set tasksStolen(t){e.tasksStolen=t},getIdleDomains:()=>e.getIdleDomains(),getBusyDomains:()=>e.getBusyDomains(),getDomainLoad:t=>e.getDomainLoad(t),removeFromQueues:t=>pe(e.taskQueue,e.domainQueues,t),assignTaskToDomain:(t,n)=>nt(e.createTaskContext(),t,n).then(()=>{}),publishEvent:(t,n)=>e.publishEvent(t,n)}}createMetricsContext(){let e=this;return{config:e.config,memory:e.memory,get dynamicScaler(){return e.dynamicScaler},getMetrics:()=>e.getMetrics(),publishEvent:(t,n)=>e.publishEvent(t,n),getQueuedTaskCount:()=>e.getQueuedTaskCount(),getActiveAgentCount:()=>e.agentCoordinator.listAgents().filter(t=>t.status==="running").length,getIdleAgentCount:()=>e.agentCoordinator.listAgents().filter(t=>t.status==="idle").length,getAverageTaskDuration:()=>e.taskDurations.average(),getTasksReceived:()=>e.tasksReceived,getTasksFailed:()=>e.tasksFailed,getTasksCompleted:()=>e.tasksCompleted}}};function Lo(s,e,t,n,i,r){return new st(s.eventBus,s.coordinator,s.memory,e,t,n,i,r)}export{xe as a,or as b,ri as c,P as d,st as e,Lo as f};
|