@askexenow/exe-os 0.9.280 → 0.9.281
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/deploy/compose/.env.customer.example +1 -1
- package/deploy/compose/.env.default +2 -1
- package/deploy/compose/.env.example +1 -1
- package/deploy/compose/docker-compose.yml +74 -13
- package/deploy/compose/erp-nginx/nginx.conf +52 -0
- package/deploy/compose/generate-env.ts +1 -1
- package/deploy/compose/init-db.sql +13 -2
- package/deploy/stack-manifests/v0.9.json +11 -31
- package/dist/active-agent-6ZBHGHXF.js +26 -0
- package/dist/active-agent-E23SCYER.js +27 -0
- package/dist/active-agent-KMZT44S4.js +26 -0
- package/dist/active-agent-LFFTVROM.js +27 -0
- package/dist/agentic-ontology-PCZB5HV5.js +25 -0
- package/dist/agentic-ontology-PGGJN2ES.js +25 -0
- package/dist/assets/tmux.conf +2 -0
- package/dist/backfill-metadata-KQ4FEVUR.js +599 -0
- package/dist/backfill-metadata-Y3YWCHKJ.js +599 -0
- package/dist/behaviors-H4DZECKL.js +39 -0
- package/dist/behaviors-WIUTIJF6.js +39 -0
- package/dist/bin/agentic-ontology-backfill.js +5 -5
- package/dist/bin/agentic-reflection-backfill.js +6 -6
- package/dist/bin/agentic-semantic-label.js +5 -5
- package/dist/bin/backfill-conversations.js +4 -4
- package/dist/bin/backfill-responses.js +4 -4
- package/dist/bin/backfill-vectors.js +5 -5
- package/dist/bin/bulk-sync-postgres.js +7 -7
- package/dist/bin/cc-doctor.js +4 -4
- package/dist/bin/cleanup-stale-review-tasks.js +10 -10
- package/dist/bin/cli.js +15 -15
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +4 -4
- package/dist/bin/exe-assign.js +5 -5
- package/dist/bin/exe-boot.js +17 -17
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +5 -5
- package/dist/bin/exe-dispatch.js +10 -10
- package/dist/bin/exe-doctor.js +1 -1
- package/dist/bin/exe-export-behaviors.js +7 -7
- package/dist/bin/exe-forget.js +6 -6
- package/dist/bin/exe-gateway.js +7 -7
- package/dist/bin/exe-healthcheck.js +4 -4
- package/dist/bin/exe-heartbeat.js +10 -10
- package/dist/bin/exe-kill.js +13 -13
- package/dist/bin/exe-launch-agent.js +17 -17
- package/dist/bin/exe-new-employee.js +7 -7
- package/dist/bin/exe-pending-messages.js +11 -11
- package/dist/bin/exe-pending-notifications.js +10 -10
- package/dist/bin/exe-pending-reviews.js +10 -10
- package/dist/bin/exe-rename.js +4 -4
- package/dist/bin/exe-review.js +12 -12
- package/dist/bin/exe-search.js +5 -5
- package/dist/bin/exe-session-cleanup.js +15 -15
- package/dist/bin/exe-settings.js +5 -5
- package/dist/bin/exe-start-codex.js +11 -11
- package/dist/bin/exe-start-opencode.js +8 -8
- package/dist/bin/exe-status.js +11 -11
- package/dist/bin/exe-support.js +2 -2
- package/dist/bin/exe-team.js +3 -3
- package/dist/bin/exe-watchdog.js +17 -2
- package/dist/bin/git-sweep.js +11 -11
- package/dist/bin/graph-backfill.js +4 -4
- package/dist/bin/graph-export.js +5 -5
- package/dist/bin/import-history.js +7 -7
- package/dist/bin/install.js +8 -7
- package/dist/bin/intercom-check.js +4 -4
- package/dist/bin/mcp-sessions.js +2 -2
- package/dist/bin/orchestration-metrics.js +4 -4
- package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
- package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
- package/dist/bin/scan-tasks.js +10 -10
- package/dist/bin/setup.js +1 -1
- package/dist/bin/shard-migrate.js +4 -4
- package/dist/bin/stack-update.js +3 -3
- package/dist/bin/vps-health-gate.js +1 -1
- package/dist/capability-cards-F22XWGLB.js +88 -0
- package/dist/capability-cards-KCKITXXZ.js +88 -0
- package/dist/capacity-monitor-CHXGKVEO.js +50 -0
- package/dist/capacity-monitor-L3M5KB6T.js +50 -0
- package/dist/catchup-brief-BVZANLRZ.js +154 -0
- package/dist/catchup-brief-LDUGMC7S.js +154 -0
- package/dist/catchup-brief-NZDLL7SA.js +154 -0
- package/dist/catchup-brief-OOIXVGBA.js +154 -0
- package/dist/catchup-brief-UPXHDYTB.js +154 -0
- package/dist/chunk-2BI3FQKL.js +1876 -0
- package/dist/chunk-2CJUQGHH.js +362 -0
- package/dist/chunk-2EVYBMBJ.js +128 -0
- package/dist/chunk-2NQOZOXG.js +2113 -0
- package/dist/chunk-2QK5E3LB.js +128 -0
- package/dist/chunk-2VTCG4ZU.js +1352 -0
- package/dist/chunk-2YGI36DV.js +1119 -0
- package/dist/chunk-32BQN2QN.js +185 -0
- package/dist/chunk-33JMO4UV.js +157 -0
- package/dist/chunk-3DZAYLXY.js +377 -0
- package/dist/chunk-3MGBE7GR.js +76 -0
- package/dist/chunk-3MTV4FJL.js +271 -0
- package/dist/chunk-3NN7VQ27.js +1352 -0
- package/dist/chunk-4533HNOG.js +70 -0
- package/dist/chunk-456UW3MT.js +731 -0
- package/dist/chunk-4AU56XV2.js +58 -0
- package/dist/chunk-4MRP6EBR.js +280 -0
- package/dist/chunk-4MRWW52U.js +14219 -0
- package/dist/chunk-4WWECNAY.js +50 -0
- package/dist/chunk-4ZJDDR6L.js +171 -0
- package/dist/chunk-522EOPM6.js +382 -0
- package/dist/chunk-52UDAVZE.js +3208 -0
- package/dist/chunk-5FAMUB4X.js +204 -0
- package/dist/chunk-5PGZJQUI.js +58 -0
- package/dist/chunk-67TZJXNZ.js +262 -0
- package/dist/chunk-6FEZ7GN2.js +123 -0
- package/dist/chunk-6MOGND7S.js +14219 -0
- package/dist/chunk-6TRSVY7L.js +181 -0
- package/dist/chunk-6WCS7ZNK.js +85 -0
- package/dist/chunk-6WRYDREW.js +539 -0
- package/dist/chunk-72UA2FB3.js +181 -0
- package/dist/chunk-77DMFEOL.js +30 -0
- package/dist/chunk-7COXVQ5W.js +214 -0
- package/dist/chunk-7HLWBYH7.js +60 -0
- package/dist/chunk-ALSTZCWT.js +204 -0
- package/dist/chunk-ARUTDXZX.js +280 -0
- package/dist/chunk-AU47B4QY.js +129 -0
- package/dist/chunk-AXOREWVL.js +836 -0
- package/dist/chunk-B5MNC54V.js +127 -0
- package/dist/chunk-B74VSMKX.js +1350 -0
- package/dist/chunk-BHWLH44J.js +362 -0
- package/dist/chunk-BUPZ3HD2.js +85 -0
- package/dist/chunk-BWVLMA53.js +2113 -0
- package/dist/chunk-C5WLBKMJ.js +50 -0
- package/dist/chunk-C62T6R2A.js +97 -0
- package/dist/chunk-CV5KBAIK.js +33 -0
- package/dist/chunk-DAYSDWXA.js +1068 -0
- package/dist/chunk-DI4URIUB.js +227 -0
- package/dist/chunk-DNTCYFJ6.js +76 -0
- package/dist/chunk-DPDRRS7T.js +103 -0
- package/dist/chunk-DT3EV6CW.js +103 -0
- package/dist/chunk-DX45HDWY.js +1076 -0
- package/dist/chunk-E72BD6MG.js +284 -0
- package/dist/chunk-EAPUSVKS.js +375 -0
- package/dist/chunk-EFUANRRT.js +85 -0
- package/dist/chunk-EG2SCT5R.js +1352 -0
- package/dist/chunk-EJD2JU77.js +58 -0
- package/dist/chunk-EMXYUAVP.js +81 -0
- package/dist/chunk-ENM2TAAM.js +14219 -0
- package/dist/chunk-EPDRTPVP.js +1876 -0
- package/dist/chunk-EW6XDHID.js +221 -0
- package/dist/chunk-EYEGSAWZ.js +1094 -0
- package/dist/chunk-F6L33PAQ.js +231 -0
- package/dist/chunk-FC2SCTVE.js +38 -0
- package/dist/chunk-FSRKIZGZ.js +630 -0
- package/dist/chunk-FTG7I5CB.js +81 -0
- package/dist/chunk-GVFRLWX7.js +30 -0
- package/dist/chunk-H3XMZOWW.js +1119 -0
- package/dist/chunk-HAKXE6LN.js +123 -0
- package/dist/chunk-HLP3ZDTW.js +448 -0
- package/dist/chunk-HOYWKQAA.js +510 -0
- package/dist/chunk-HWDD64IW.js +712 -0
- package/dist/chunk-HWMCULHY.js +127 -0
- package/dist/chunk-HZZHRZPK.js +210 -0
- package/dist/chunk-ICRWTYNW.js +103 -0
- package/dist/chunk-J5MWPC33.js +167 -0
- package/dist/chunk-JBXANNNB.js +70 -0
- package/dist/chunk-JPBMIYWF.js +1352 -0
- package/dist/chunk-JY6EXBFI.js +373 -0
- package/dist/chunk-JZLIBXI7.js +14219 -0
- package/dist/chunk-JZPTKXJ6.js +668 -0
- package/dist/chunk-KEYMA4ZP.js +510 -0
- package/dist/chunk-KHGNN6GL.js +2078 -0
- package/dist/chunk-KVLB2PD6.js +97 -0
- package/dist/chunk-L3YBRBKL.js +1076 -0
- package/dist/chunk-L7VZ32NA.js +89 -0
- package/dist/chunk-LEHLADW4.js +221 -0
- package/dist/chunk-LPD4HILQ.js +262 -0
- package/dist/chunk-LSJ3ADDI.js +51 -0
- package/dist/chunk-LUMS2MAS.js +58 -0
- package/dist/chunk-LV4SEC6C.js +394 -0
- package/dist/chunk-LXXBEI4A.js +284 -0
- package/dist/chunk-M4NPCAIH.js +456 -0
- package/dist/chunk-MFJ62LQ5.js +157 -0
- package/dist/chunk-MGEZNKOD.js +836 -0
- package/dist/chunk-MJ7X5IBW.js +227 -0
- package/dist/chunk-MLGRWCY4.js +54 -0
- package/dist/chunk-MQZX57IY.js +348 -0
- package/dist/chunk-MY7MFF6J.js +103 -0
- package/dist/chunk-MYA2X5OY.js +185 -0
- package/dist/chunk-MYEABW5Z.js +630 -0
- package/dist/chunk-MZ2TDCAL.js +402 -0
- package/dist/chunk-NF3FRB7Z.js +271 -0
- package/dist/chunk-NXYIFEPV.js +539 -0
- package/dist/chunk-O2GVE5B5.js +58 -0
- package/dist/chunk-O5GUCDR2.js +456 -0
- package/dist/chunk-OBZNRECA.js +128 -0
- package/dist/chunk-OMZ2RLJG.js +214 -0
- package/dist/chunk-ORDHJRWN.js +299 -0
- package/dist/chunk-OSPIJMCD.js +210 -0
- package/dist/chunk-OUGWEH4J.js +240 -0
- package/dist/chunk-OV5MJQGC.js +1876 -0
- package/dist/chunk-PC635OAG.js +4318 -0
- package/dist/chunk-PH46R4J6.js +348 -0
- package/dist/chunk-PJP2EP7P.js +394 -0
- package/dist/chunk-PODFWH3V.js +333 -0
- package/dist/chunk-PPWH3SHR.js +1068 -0
- package/dist/chunk-PWPJK7KB.js +4318 -0
- package/dist/chunk-PXONZVG4.js +377 -0
- package/dist/chunk-QAOGJRZD.js +369 -0
- package/dist/chunk-QC3LAEI7.js +197 -0
- package/dist/chunk-QDWQDUWI.js +668 -0
- package/dist/chunk-QKJFD6BH.js +1350 -0
- package/dist/chunk-QNYVJGFM.js +345 -0
- package/dist/chunk-QQF3XGQ5.js +14219 -0
- package/dist/chunk-QRPFQNI3.js +150 -0
- package/dist/chunk-QSSU5XWD.js +731 -0
- package/dist/chunk-QXZAGVAV.js +2078 -0
- package/dist/chunk-RA54MW64.js +244 -0
- package/dist/chunk-RF7PUWXI.js +197 -0
- package/dist/chunk-S3INDYSO.js +244 -0
- package/dist/chunk-SLQVTHH5.js +369 -0
- package/dist/chunk-SY2B74KL.js +345 -0
- package/dist/chunk-T6QPXXXW.js +712 -0
- package/dist/chunk-TO5M5YCT.js +41 -0
- package/dist/chunk-TQ4VXUAF.js +129 -0
- package/dist/chunk-UAB7RQC4.js +41 -0
- package/dist/chunk-UMEIBDYW.js +97 -0
- package/dist/chunk-UXW5TB7Y.js +240 -0
- package/dist/chunk-VB2N5WOX.js +150 -0
- package/dist/chunk-VLZEMRG3.js +167 -0
- package/dist/chunk-VM3V6VK7.js +230 -0
- package/dist/chunk-VMCGKBHB.js +1352 -0
- package/dist/chunk-VNIYZAR5.js +128 -0
- package/dist/chunk-VYV4KOD2.js +85 -0
- package/dist/chunk-W4SRJBAT.js +171 -0
- package/dist/chunk-W5W3LZ3Q.js +54 -0
- package/dist/chunk-WDNZEOM3.js +38 -0
- package/dist/chunk-WUKEXVOR.js +3208 -0
- package/dist/chunk-X3Z35Q6L.js +373 -0
- package/dist/chunk-X4VOU6BQ.js +382 -0
- package/dist/chunk-X6EEVSVG.js +290 -0
- package/dist/chunk-XFHGWGNB.js +1094 -0
- package/dist/chunk-XKOLRWYA.js +33 -0
- package/dist/chunk-XMMIL3UD.js +402 -0
- package/dist/chunk-XWILC6VA.js +290 -0
- package/dist/chunk-Y4OQCX4C.js +97 -0
- package/dist/chunk-Y67VYYOA.js +231 -0
- package/dist/chunk-YGQCQTQH.js +230 -0
- package/dist/chunk-YGWFBN5A.js +299 -0
- package/dist/chunk-YMKUXZIG.js +379 -0
- package/dist/chunk-YOMLMT7E.js +230 -0
- package/dist/chunk-YPESIZOB.js +14219 -0
- package/dist/chunk-Z2CGCIU2.js +89 -0
- package/dist/chunk-ZLAWNHQR.js +448 -0
- package/dist/chunk-ZME5UQSN.js +333 -0
- package/dist/co-activation-NUEQYXE5.js +73 -0
- package/dist/co-activation-ZG5HLBCZ.js +73 -0
- package/dist/co-occurrence-7S5KWQB2.js +94 -0
- package/dist/co-occurrence-X5SWDXT2.js +94 -0
- package/dist/core-memory-GOPBRGGZ.js +110 -0
- package/dist/core-memory-XLCU6L5M.js +110 -0
- package/dist/crdt-sync-EPKHPGRZ.js +33 -0
- package/dist/crdt-sync-UIQJ5U7T.js +33 -0
- package/dist/crm-webhook-MKN23JNU.js +10 -0
- package/dist/crm-webhook-SM63BPXO.js +10 -0
- package/dist/cto-delegation-gate-PQY5TOVZ.js +279 -0
- package/dist/cto-delegation-gate-V5VVUR3G.js +279 -0
- package/dist/daemon-orchestration-C7AAS67Q.js +138 -0
- package/dist/daemon-orchestration-OBCAJB2H.js +138 -0
- package/dist/db-backup-F7VP4QRH.js +33 -0
- package/dist/db-backup-KVYC57W7.js +33 -0
- package/dist/doc-graph-extractor-H2ETEINP.js +132 -0
- package/dist/doc-graph-extractor-PCUZEYCH.js +132 -0
- package/dist/dreaming-4OZXSLE3.js +33 -0
- package/dist/dreaming-Z2RYEYNT.js +33 -0
- package/dist/exe-drift-GEWNIK7A.js +69 -0
- package/dist/exe-drift-XCGH7AFO.js +69 -0
- package/dist/exe-export-7DKAU5IP.js +75 -0
- package/dist/exe-export-BCHH6OE6.js +75 -0
- package/dist/exe-import-PDRIZVYF.js +78 -0
- package/dist/exe-import-ZCKUDFKL.js +78 -0
- package/dist/exe-key-FUWLLI3U.js +580 -0
- package/dist/exe-key-RKKNVUMP.js +580 -0
- package/dist/exe-snapshot-G4I5FQMK.js +337 -0
- package/dist/exe-snapshot-GWU7QTZK.js +337 -0
- package/dist/fast-db-init-6QG6YQNT.js +7 -0
- package/dist/fast-db-init-X2QDQUA4.js +7 -0
- package/dist/founder-context-TOMNUBGJ.js +96 -0
- package/dist/founder-context-UU3V6MAS.js +96 -0
- package/dist/gateway/index.js +8 -8
- package/dist/git-staleness-FEPFMZKF.js +111 -0
- package/dist/git-staleness-HYVYLCW3.js +111 -0
- package/dist/git-task-sweep-IRV52JIM.js +41 -0
- package/dist/git-task-sweep-T6BSM3GS.js +41 -0
- package/dist/global-procedures-3AURRMKO.js +21 -0
- package/dist/global-procedures-JPCYBZYC.js +21 -0
- package/dist/graph-auto-extract-OC3AOSMW.js +182 -0
- package/dist/graph-auto-extract-PVDYEJBY.js +182 -0
- package/dist/hooks/bug-report-worker.js +12 -12
- package/dist/hooks/codex-stop-task-finalizer.js +12 -12
- package/dist/hooks/commit-complete.js +12 -12
- package/dist/hooks/error-recall.js +6 -6
- package/dist/hooks/exe-heartbeat-hook.js +3 -3
- package/dist/hooks/ingest.js +6 -6
- package/dist/hooks/instructions-loaded.js +4 -4
- package/dist/hooks/manifest.json +19 -19
- package/dist/hooks/notification.js +4 -4
- package/dist/hooks/post-compact.js +11 -11
- package/dist/hooks/post-tool-combined.js +5 -5
- package/dist/hooks/pre-compact.js +12 -12
- package/dist/hooks/pre-tool-use.js +15 -15
- package/dist/hooks/prompt-submit.js +22 -22
- package/dist/hooks/session-end.js +16 -16
- package/dist/hooks/session-start.js +10 -10
- package/dist/hooks/stop.js +15 -15
- package/dist/hooks/subagent-stop.js +11 -11
- package/dist/hooks/summary-worker.js +15 -15
- package/dist/index.js +18 -18
- package/dist/installer-72XXLBRP.js +39 -0
- package/dist/installer-HDXG2BZN.js +343 -0
- package/dist/installer-JALMKPCS.js +297 -0
- package/dist/installer-Q46SNNLU.js +39 -0
- package/dist/installer-W7PIPRCX.js +343 -0
- package/dist/installer-Z7WQEOS7.js +297 -0
- package/dist/lib/cloud-sync.js +5 -5
- package/dist/lib/consolidation.js +5 -5
- package/dist/lib/database.js +2 -2
- package/dist/lib/db.js +2 -2
- package/dist/lib/employee-templates.js +4 -4
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon.js +45 -41
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/license.js +1 -1
- package/dist/lib/messaging.js +10 -10
- package/dist/lib/reminders.js +3 -3
- package/dist/lib/schedules.js +5 -5
- package/dist/lib/session-registry.js +4 -4
- package/dist/lib/skill-learning.js +6 -6
- package/dist/lib/store.js +4 -4
- package/dist/lib/task-router.js +3 -3
- package/dist/lib/tasks.js +11 -11
- package/dist/lib/tmux-routing.js +9 -9
- package/dist/lib/token-spend.js +3 -3
- package/dist/license-gate-7JZCHOAG.js +14 -0
- package/dist/license-gate-OP4SKL4P.js +14 -0
- package/dist/mcp/register-tools.js +58 -58
- package/dist/mcp/server.js +59 -59
- package/dist/mcp/tools/complete-reminder.js +4 -4
- package/dist/mcp/tools/create-reminder.js +4 -4
- package/dist/mcp/tools/create-task.js +13 -13
- package/dist/mcp/tools/deactivate-behavior.js +7 -7
- package/dist/mcp/tools/list-reminders.js +4 -4
- package/dist/mcp/tools/list-tasks.js +13 -13
- package/dist/mcp/tools/send-message.js +12 -12
- package/dist/mcp/tools/update-task.js +12 -12
- package/dist/mcp-health-VULNT722.js +17 -0
- package/dist/mcp-health-WDOB6XUB.js +19 -0
- package/dist/mcp-http-config-2OZ7N74D.js +28 -0
- package/dist/mcp-http-config-4VXA5K73.js +28 -0
- package/dist/memory-cards-2K6QRZU6.js +179 -0
- package/dist/memory-cards-KSJF5OH2.js +179 -0
- package/dist/memory-graph-extractor-IJD5HWYT.js +21 -0
- package/dist/memory-graph-extractor-O4GAXOK5.js +21 -0
- package/dist/memory-poisoning-defense-2JRPWT5V.js +223 -0
- package/dist/memory-poisoning-defense-DH4A25NU.js +223 -0
- package/dist/memory-reflection-ISY2BBDB.js +243 -0
- package/dist/memory-reflection-Z5AQRR6H.js +243 -0
- package/dist/notifications-2VSWK2UJ.js +46 -0
- package/dist/notifications-4S253VQM.js +46 -0
- package/dist/oauth-server-D7D4574D.js +437 -0
- package/dist/oauth-server-MACN54SJ.js +437 -0
- package/dist/orchestration-events-BGP5RYQI.js +26 -0
- package/dist/orchestration-events-MDXUEVRZ.js +26 -0
- package/dist/orchestrator-DHK7RSSH.js +34 -0
- package/dist/orchestrator-R75WHQVA.js +34 -0
- package/dist/pipeline-router-4WUKQQEC.js +14 -0
- package/dist/pipeline-router-GWB2XK2Q.js +14 -0
- package/dist/plan-limits-NNJRAESF.js +27 -0
- package/dist/plan-limits-YTQW4UR4.js +27 -0
- package/dist/project-boot-46GZJTEX.js +299 -0
- package/dist/project-boot-PPHBBGIF.js +299 -0
- package/dist/projection-worker-UPAWXI7P.js +1034 -0
- package/dist/projection-worker-ZIKDYBW5.js +1034 -0
- package/dist/reranker-5ZBP2RRN.js +19 -0
- package/dist/reranker-E2MQIMJL.js +19 -0
- package/dist/reranker-GLSDJT3V.js +19 -0
- package/dist/reranker-LBBXWNOD.js +19 -0
- package/dist/reranker-XZ2EF4OH.js +19 -0
- package/dist/retrieval-health-JYRKPSII.js +7 -0
- package/dist/retrieval-health-OUV25J6S.js +7 -0
- package/dist/retrieval-health-U73JUAZL.js +7 -0
- package/dist/retrieval-health-WSZ7TYFF.js +7 -0
- package/dist/review-polling-62JV55ZT.js +125 -0
- package/dist/review-polling-CJXLWFWK.js +125 -0
- package/dist/runtime/index.js +12 -12
- package/dist/session-events-2ADD54VI.js +37 -0
- package/dist/session-events-QIJVBSKS.js +37 -0
- package/dist/session-kill-telemetry-HS6HD2YE.js +30 -0
- package/dist/session-kill-telemetry-MRT5FVSM.js +30 -0
- package/dist/session-scope-7ICYPC33.js +87 -0
- package/dist/session-scope-KMXD6EE6.js +87 -0
- package/dist/setup-wizard-B6GIT7YC.js +12 -0
- package/dist/setup-wizard-JUIJ4UZO.js +12 -0
- package/dist/skill-refinement-HIOX4VMC.js +158 -0
- package/dist/skill-refinement-T7JXRYUW.js +158 -0
- package/dist/stack-update-5KE6BZKQ.js +74 -0
- package/dist/stack-update-OP2RHP7N.js +74 -0
- package/dist/stack-update-VGCWDJEE.js +74 -0
- package/dist/steward-gate-L22WE3SY.js +14 -0
- package/dist/steward-gate-YKD2LUWN.js +14 -0
- package/dist/task-enforcement-5AOKXTY4.js +439 -0
- package/dist/task-enforcement-VO3YEGIO.js +439 -0
- package/dist/task-scope-YV2WPKRD.js +36 -0
- package/dist/task-scope-ZSXDZBRE.js +36 -0
- package/dist/tasks-crud-C6KADACT.js +78 -0
- package/dist/tasks-crud-NV6JEWGL.js +78 -0
- package/dist/tasks-notify-E22HSN6O.js +39 -0
- package/dist/tasks-notify-RPSEQ4WV.js +39 -0
- package/dist/tasks-review-V4ZLXOAZ.js +48 -0
- package/dist/tasks-review-ZVRI73JE.js +48 -0
- package/dist/telemetry-upload-LXUH7SKI.js +740 -0
- package/dist/telemetry-upload-TCDAZTUQ.js +740 -0
- package/dist/token-budget-OFBEZJTA.js +85 -0
- package/dist/token-budget-WAN57V6S.js +85 -0
- package/dist/tool-telemetry-UA3N32PK.js +17 -0
- package/dist/tool-telemetry-XXZJ35RR.js +17 -0
- package/dist/tui/App.js +17 -17
- package/dist/tui-data-46QLCJUE.js +259 -0
- package/dist/tui-data-ZDB7BLP2.js +259 -0
- package/dist/wiki-acl-HHSIBPF3.js +111 -0
- package/dist/wiki-acl-O65GZ2ZF.js +111 -0
- package/dist/worker-gate-27I4GAEZ.js +21 -0
- package/dist/worker-gate-DXU4HEPY.js +21 -0
- package/dist/workflow-engine-63EOEJ5Q.js +28 -0
- package/dist/workflow-engine-C6F2RMPN.js +28 -0
- package/dist/worktree-SFKKOMFD.js +27 -0
- package/dist/worktree-SVCE3S7X.js +27 -0
- package/dist/worktree-sweep-S3JHJTVP.js +20 -0
- package/dist/worktree-sweep-U3TIQ7WL.js +20 -0
- package/package.json +1 -1
- package/release-notes.json +88 -26
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
import {
|
|
2
|
+
redactSecrets
|
|
3
|
+
} from "./chunk-Y25OJWOQ.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/memory-write-governor.ts
|
|
6
|
+
import { createHash } from "crypto";
|
|
7
|
+
var HIGH_VALUE_SUPERSESSION_TYPES = /* @__PURE__ */ new Set([
|
|
8
|
+
"decision",
|
|
9
|
+
"adr",
|
|
10
|
+
"behavior",
|
|
11
|
+
"procedure"
|
|
12
|
+
]);
|
|
13
|
+
var NOISE_DROP_PATTERNS = [
|
|
14
|
+
/^\s*\[📋\s+\d+\s+reviews?\s+pending\b/im,
|
|
15
|
+
/^\s*<system-reminder>[\s\S]*?<\/system-reminder>\s*$/im,
|
|
16
|
+
/^\s*The UserPromptSubmit hook checks the DB for new tasks/im,
|
|
17
|
+
/^\s*Intercom is a speedup, not delivery/im,
|
|
18
|
+
/^\s*Context bar reads as USAGE not remaining/im,
|
|
19
|
+
// Intercom noise — these repeat on every prompt and cause 18K+ duplicates
|
|
20
|
+
/^\/exe-intercom\b/i,
|
|
21
|
+
/^You have pending notifications\.\s*Run list_tasks/i,
|
|
22
|
+
/^You have open tasks\.\s*Run list_tasks/i,
|
|
23
|
+
/^You have a new P\d+ task/i,
|
|
24
|
+
/^You have more open tasks to dispatch/i,
|
|
25
|
+
/^No new tasks\.\s*(Standing by|Idle|Dashboard)/i
|
|
26
|
+
];
|
|
27
|
+
var SKIP_EMBED_PATTERNS = [
|
|
28
|
+
/tmux capture-pane\b/i,
|
|
29
|
+
/docker ps\b/i,
|
|
30
|
+
/docker images\b/i,
|
|
31
|
+
/git status\b/i,
|
|
32
|
+
/grep .*node_modules/i,
|
|
33
|
+
/npm (install|ci)\b[\s\S]*(added \d+ packages|audited \d+ packages)/i
|
|
34
|
+
];
|
|
35
|
+
function normalizeMemoryText(text) {
|
|
36
|
+
return text.replace(/\r\n/g, "\n").replace(/[ \t]+$/gm, "").replace(/\n{4,}/g, "\n\n\n").trim();
|
|
37
|
+
}
|
|
38
|
+
function classifyMemoryType(input) {
|
|
39
|
+
if (input.memory_type && input.memory_type.trim()) return input.memory_type.trim();
|
|
40
|
+
const tool = input.tool_name.toLowerCase();
|
|
41
|
+
const text = input.raw_text.toLowerCase();
|
|
42
|
+
if (tool.includes("store_decision") || tool.includes("decision")) return "decision";
|
|
43
|
+
if (tool.includes("commit") || text.includes("adr-") || text.includes("architectural decision")) return "adr";
|
|
44
|
+
if (tool.includes("store_behavior") || tool.includes("behavior")) return "behavior";
|
|
45
|
+
if (tool.includes("global_procedure") || text.includes("organization-wide procedures")) return "procedure";
|
|
46
|
+
if (tool.includes("checkpoint") || text.startsWith("context checkpoint")) return "checkpoint";
|
|
47
|
+
if (tool.includes("sessionsummary") || tool.includes("session-summary")) return "summary";
|
|
48
|
+
if (tool.includes("sessionend") || text.startsWith("session ended")) return "summary";
|
|
49
|
+
if (tool.includes("send_whatsapp") || tool.includes("conversation")) return "conversation";
|
|
50
|
+
if (tool === "store_memory" || tool === "manual") return "observation";
|
|
51
|
+
if (tool === "userprompt" || tool === "slashcommand") return "conversation";
|
|
52
|
+
return "raw";
|
|
53
|
+
}
|
|
54
|
+
function shouldDropMemory(text) {
|
|
55
|
+
const normalized = normalizeMemoryText(text);
|
|
56
|
+
if (normalized.length < 10) return { drop: true, reason: "too_short" };
|
|
57
|
+
if (NOISE_DROP_PATTERNS.some((pattern) => pattern.test(normalized))) {
|
|
58
|
+
return { drop: true, reason: "known_boilerplate_noise" };
|
|
59
|
+
}
|
|
60
|
+
return { drop: false };
|
|
61
|
+
}
|
|
62
|
+
function shouldSkipEmbedding(input) {
|
|
63
|
+
const type = classifyMemoryType(input);
|
|
64
|
+
if (HIGH_VALUE_SUPERSESSION_TYPES.has(type)) return false;
|
|
65
|
+
if (type === "raw" && input.raw_text.length > 2e4) return true;
|
|
66
|
+
if (SKIP_EMBED_PATTERNS.some((pattern) => pattern.test(input.raw_text))) return true;
|
|
67
|
+
return false;
|
|
68
|
+
}
|
|
69
|
+
function hashMemoryContent(text) {
|
|
70
|
+
return createHash("sha256").update(normalizeMemoryText(text)).digest("hex");
|
|
71
|
+
}
|
|
72
|
+
function scopedDedupArgs(input) {
|
|
73
|
+
return [input.contentHash, input.agentId, input.projectName, input.memoryType];
|
|
74
|
+
}
|
|
75
|
+
function governMemoryRecord(record) {
|
|
76
|
+
const redacted = redactSecrets(record.raw_text);
|
|
77
|
+
const normalized = normalizeMemoryText(redacted.text);
|
|
78
|
+
const memoryType = classifyMemoryType({
|
|
79
|
+
raw_text: normalized,
|
|
80
|
+
agent_id: record.agent_id,
|
|
81
|
+
project_name: record.project_name,
|
|
82
|
+
tool_name: record.tool_name,
|
|
83
|
+
memory_type: record.memory_type
|
|
84
|
+
});
|
|
85
|
+
const drop = shouldDropMemory(normalized);
|
|
86
|
+
const skipEmbedding = shouldSkipEmbedding({
|
|
87
|
+
raw_text: normalized,
|
|
88
|
+
agent_id: record.agent_id,
|
|
89
|
+
project_name: record.project_name,
|
|
90
|
+
tool_name: record.tool_name,
|
|
91
|
+
memory_type: memoryType
|
|
92
|
+
});
|
|
93
|
+
const trajectoryValue = record.trajectory;
|
|
94
|
+
const redactedTrajectory = typeof trajectoryValue === "string" ? redactSecrets(trajectoryValue).text : record.trajectory;
|
|
95
|
+
return {
|
|
96
|
+
record: {
|
|
97
|
+
...record,
|
|
98
|
+
raw_text: normalized,
|
|
99
|
+
memory_type: memoryType,
|
|
100
|
+
vector: skipEmbedding ? null : record.vector,
|
|
101
|
+
keywords: record.keywords ? redactSecrets(record.keywords).text : record.keywords,
|
|
102
|
+
trajectory: redactedTrajectory
|
|
103
|
+
},
|
|
104
|
+
contentHash: hashMemoryContent(normalized),
|
|
105
|
+
shouldDrop: drop.drop,
|
|
106
|
+
dropReason: drop.reason,
|
|
107
|
+
skipEmbedding,
|
|
108
|
+
hygiene: {
|
|
109
|
+
dedup: true,
|
|
110
|
+
supersession: HIGH_VALUE_SUPERSESSION_TYPES.has(memoryType)
|
|
111
|
+
}
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
async function findScopedDuplicate(input) {
|
|
115
|
+
const { getClient } = await import("./lib/database.js");
|
|
116
|
+
const client = getClient();
|
|
117
|
+
const args = scopedDedupArgs(input);
|
|
118
|
+
let sql = `SELECT id FROM memories
|
|
119
|
+
WHERE content_hash = ?
|
|
120
|
+
AND agent_id = ?
|
|
121
|
+
AND project_name = ?
|
|
122
|
+
AND COALESCE(memory_type, 'raw') = ?
|
|
123
|
+
AND COALESCE(status, 'active') != 'deleted'`;
|
|
124
|
+
if (input.excludeId) {
|
|
125
|
+
sql += " AND id != ?";
|
|
126
|
+
args.push(input.excludeId);
|
|
127
|
+
}
|
|
128
|
+
sql += " ORDER BY timestamp DESC LIMIT 1";
|
|
129
|
+
const result = await client.execute({ sql, args });
|
|
130
|
+
return result.rows[0]?.id ? String(result.rows[0].id) : null;
|
|
131
|
+
}
|
|
132
|
+
async function runPostWriteMemoryHygiene(memoryId) {
|
|
133
|
+
try {
|
|
134
|
+
const { getClient } = await import("./lib/database.js");
|
|
135
|
+
const client = getClient();
|
|
136
|
+
const current = await client.execute({
|
|
137
|
+
sql: `SELECT id, agent_id, project_name, memory_type, content_hash, supersedes_id,
|
|
138
|
+
importance, timestamp
|
|
139
|
+
FROM memories
|
|
140
|
+
WHERE id = ?
|
|
141
|
+
LIMIT 1`,
|
|
142
|
+
args: [memoryId]
|
|
143
|
+
});
|
|
144
|
+
const row = current.rows[0];
|
|
145
|
+
if (!row) return;
|
|
146
|
+
const memoryType = String(row.memory_type ?? "raw");
|
|
147
|
+
const contentHash = row.content_hash ? String(row.content_hash) : null;
|
|
148
|
+
const agentId = String(row.agent_id);
|
|
149
|
+
const projectName = String(row.project_name);
|
|
150
|
+
if (contentHash) {
|
|
151
|
+
await client.execute({
|
|
152
|
+
sql: `UPDATE memories
|
|
153
|
+
SET status = 'deleted',
|
|
154
|
+
outcome = COALESCE(outcome, 'superseded')
|
|
155
|
+
WHERE id != ?
|
|
156
|
+
AND content_hash = ?
|
|
157
|
+
AND agent_id = ?
|
|
158
|
+
AND project_name = ?
|
|
159
|
+
AND COALESCE(memory_type, 'raw') = ?
|
|
160
|
+
AND COALESCE(status, 'active') = 'active'`,
|
|
161
|
+
args: [memoryId, contentHash, agentId, projectName, memoryType]
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
const supersedesId = row.supersedes_id ? String(row.supersedes_id) : null;
|
|
165
|
+
if (supersedesId && HIGH_VALUE_SUPERSESSION_TYPES.has(memoryType)) {
|
|
166
|
+
const old = await client.execute({
|
|
167
|
+
sql: `SELECT importance FROM memories WHERE id = ? LIMIT 1`,
|
|
168
|
+
args: [supersedesId]
|
|
169
|
+
});
|
|
170
|
+
const oldImportance = Number(old.rows[0]?.importance ?? 0);
|
|
171
|
+
const newImportance = Number(row.importance ?? 0);
|
|
172
|
+
await client.batch([
|
|
173
|
+
{
|
|
174
|
+
sql: `UPDATE memories
|
|
175
|
+
SET status = 'archived',
|
|
176
|
+
outcome = COALESCE(outcome, 'superseded')
|
|
177
|
+
WHERE id = ?`,
|
|
178
|
+
args: [supersedesId]
|
|
179
|
+
},
|
|
180
|
+
{
|
|
181
|
+
sql: `UPDATE memories
|
|
182
|
+
SET importance = MAX(COALESCE(importance, 5), ?),
|
|
183
|
+
parent_memory_id = COALESCE(parent_memory_id, ?)
|
|
184
|
+
WHERE id = ?`,
|
|
185
|
+
args: [Math.max(oldImportance, newImportance), supersedesId, memoryId]
|
|
186
|
+
}
|
|
187
|
+
], "write");
|
|
188
|
+
}
|
|
189
|
+
} catch (err) {
|
|
190
|
+
process.stderr.write(
|
|
191
|
+
`[memory-governor] post-write hygiene failed for ${memoryId}: ${err instanceof Error ? err.message : String(err)}
|
|
192
|
+
`
|
|
193
|
+
);
|
|
194
|
+
}
|
|
195
|
+
}
|
|
196
|
+
function schedulePostWriteMemoryHygiene(memoryIds) {
|
|
197
|
+
if (process.env.EXE_SKIP_MEMORY_HYGIENE === "1") return;
|
|
198
|
+
if (memoryIds.length === 0) return;
|
|
199
|
+
const run = () => {
|
|
200
|
+
void Promise.all(memoryIds.map((id) => runPostWriteMemoryHygiene(id)));
|
|
201
|
+
};
|
|
202
|
+
if (typeof setImmediate === "function") setImmediate(run);
|
|
203
|
+
else setTimeout(run, 0);
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export {
|
|
207
|
+
governMemoryRecord,
|
|
208
|
+
findScopedDuplicate,
|
|
209
|
+
schedulePostWriteMemoryHygiene
|
|
210
|
+
};
|
|
@@ -0,0 +1,240 @@
|
|
|
1
|
+
import {
|
|
2
|
+
getClient,
|
|
3
|
+
isCoordinatorName,
|
|
4
|
+
loadEmployeesSync
|
|
5
|
+
} from "./chunk-52UDAVZE.js";
|
|
6
|
+
|
|
7
|
+
// src/lib/steward-gate.ts
|
|
8
|
+
import crypto from "crypto";
|
|
9
|
+
var ROLE_PERMISSIONS = {
|
|
10
|
+
coordinator: /* @__PURE__ */ new Set([
|
|
11
|
+
"close_task",
|
|
12
|
+
"cancel_task",
|
|
13
|
+
"merge_entities",
|
|
14
|
+
"purge_document",
|
|
15
|
+
"deactivate_behavior",
|
|
16
|
+
"override"
|
|
17
|
+
]),
|
|
18
|
+
manager: /* @__PURE__ */ new Set([
|
|
19
|
+
"close_task",
|
|
20
|
+
// their team only — enforced contextually
|
|
21
|
+
"deactivate_behavior"
|
|
22
|
+
// their team's behaviors
|
|
23
|
+
]),
|
|
24
|
+
specialist: /* @__PURE__ */ new Set([
|
|
25
|
+
"deactivate_behavior_own",
|
|
26
|
+
// own behaviors only
|
|
27
|
+
"delete_own_memory"
|
|
28
|
+
])
|
|
29
|
+
};
|
|
30
|
+
var UNIVERSAL_OPS = /* @__PURE__ */ new Set([
|
|
31
|
+
"update_own_task",
|
|
32
|
+
"store_memory",
|
|
33
|
+
"store_behavior"
|
|
34
|
+
]);
|
|
35
|
+
var MANAGER_ROLES = /* @__PURE__ */ new Set(["CTO", "CMO"]);
|
|
36
|
+
var StewardGate = class {
|
|
37
|
+
/**
|
|
38
|
+
* Check whether an agent has authority for a destructive operation.
|
|
39
|
+
*/
|
|
40
|
+
async checkAuthority(agent, operation, target) {
|
|
41
|
+
const role = await this.resolveRole(agent);
|
|
42
|
+
if (UNIVERSAL_OPS.has(operation)) {
|
|
43
|
+
const decision2 = {
|
|
44
|
+
allowed: true,
|
|
45
|
+
reason: `Operation "${operation}" is universally permitted.`,
|
|
46
|
+
confidence: 1,
|
|
47
|
+
requires_override: false
|
|
48
|
+
};
|
|
49
|
+
await this.logDecision(agent, operation, target, decision2);
|
|
50
|
+
return decision2;
|
|
51
|
+
}
|
|
52
|
+
const permissions = ROLE_PERMISSIONS[role];
|
|
53
|
+
let allowed = permissions.has(operation);
|
|
54
|
+
let reason;
|
|
55
|
+
if (!allowed && role === "specialist" && operation === "deactivate_behavior") {
|
|
56
|
+
const isOwn = await this.isOwnBehavior(agent, target);
|
|
57
|
+
if (isOwn) {
|
|
58
|
+
allowed = true;
|
|
59
|
+
reason = `Specialist "${agent}" can deactivate their own behavior.`;
|
|
60
|
+
} else {
|
|
61
|
+
reason = `Specialist "${agent}" cannot deactivate behaviors belonging to other agents.`;
|
|
62
|
+
}
|
|
63
|
+
} else if (allowed) {
|
|
64
|
+
reason = `Role "${role}" has authority for "${operation}".`;
|
|
65
|
+
} else {
|
|
66
|
+
reason = `Role "${role}" does not have authority for "${operation}". Requires coordinator override.`;
|
|
67
|
+
}
|
|
68
|
+
let requiresOverride = !allowed;
|
|
69
|
+
let confidence = allowed ? 0.95 : 0.9;
|
|
70
|
+
try {
|
|
71
|
+
const dreamingPath = "./dreaming.js";
|
|
72
|
+
const dreaming = await import(
|
|
73
|
+
/* @vite-ignore */
|
|
74
|
+
dreamingPath
|
|
75
|
+
);
|
|
76
|
+
if (typeof dreaming.calculateDrift === "function") {
|
|
77
|
+
const driftScore = await dreaming.calculateDrift(agent);
|
|
78
|
+
if (typeof driftScore === "number" && driftScore > 0.8) {
|
|
79
|
+
requiresOverride = true;
|
|
80
|
+
confidence = Math.max(0.5, confidence - 0.3);
|
|
81
|
+
reason += ` (\u26A0\uFE0F High drift score: ${driftScore.toFixed(2)} \u2014 requires override.)`;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
} catch {
|
|
85
|
+
}
|
|
86
|
+
const decision = {
|
|
87
|
+
allowed: allowed && !requiresOverride,
|
|
88
|
+
reason,
|
|
89
|
+
confidence,
|
|
90
|
+
requires_override: requiresOverride
|
|
91
|
+
};
|
|
92
|
+
await this.logDecision(agent, operation, target, decision);
|
|
93
|
+
return decision;
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Record an explicit coordinator override that bypasses the gate.
|
|
97
|
+
*/
|
|
98
|
+
async override(agent, operation, target, reason) {
|
|
99
|
+
const role = await this.resolveRole(agent);
|
|
100
|
+
if (role !== "coordinator") {
|
|
101
|
+
const decision2 = {
|
|
102
|
+
allowed: false,
|
|
103
|
+
reason: `Only coordinators can issue overrides. "${agent}" is a ${role}.`,
|
|
104
|
+
confidence: 1,
|
|
105
|
+
requires_override: false
|
|
106
|
+
};
|
|
107
|
+
await this.logDecision(agent, `override:${operation}`, target, decision2);
|
|
108
|
+
return decision2;
|
|
109
|
+
}
|
|
110
|
+
const decision = {
|
|
111
|
+
allowed: true,
|
|
112
|
+
reason: `Coordinator override: ${reason}`,
|
|
113
|
+
confidence: 1,
|
|
114
|
+
requires_override: false
|
|
115
|
+
};
|
|
116
|
+
await this.logDecision(agent, `override:${operation}`, target, decision);
|
|
117
|
+
return decision;
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Query the audit trail.
|
|
121
|
+
*/
|
|
122
|
+
async getAuditLog(opts) {
|
|
123
|
+
await this.ensureAuditTable();
|
|
124
|
+
const client = getClient();
|
|
125
|
+
const conditions = [];
|
|
126
|
+
const args = [];
|
|
127
|
+
if (opts?.agent) {
|
|
128
|
+
conditions.push("agent = ?");
|
|
129
|
+
args.push(opts.agent);
|
|
130
|
+
}
|
|
131
|
+
if (opts?.operation) {
|
|
132
|
+
conditions.push("operation = ?");
|
|
133
|
+
args.push(opts.operation);
|
|
134
|
+
}
|
|
135
|
+
const where = conditions.length > 0 ? `WHERE ${conditions.join(" AND ")}` : "";
|
|
136
|
+
const limit = opts?.limit ?? 50;
|
|
137
|
+
const result = await client.execute({
|
|
138
|
+
sql: `SELECT * FROM steward_audit ${where} ORDER BY created_at DESC LIMIT ?`,
|
|
139
|
+
args: [...args, limit]
|
|
140
|
+
});
|
|
141
|
+
return result.rows.map((row) => ({
|
|
142
|
+
id: String(row.id),
|
|
143
|
+
agent: String(row.agent),
|
|
144
|
+
operation: String(row.operation),
|
|
145
|
+
target: String(row.target),
|
|
146
|
+
decision: {
|
|
147
|
+
allowed: Number(row.allowed) === 1,
|
|
148
|
+
reason: String(row.reason),
|
|
149
|
+
confidence: Number(row.confidence),
|
|
150
|
+
requires_override: Number(row.requires_override) === 1
|
|
151
|
+
},
|
|
152
|
+
timestamp: String(row.created_at)
|
|
153
|
+
}));
|
|
154
|
+
}
|
|
155
|
+
// -------------------------------------------------------------------------
|
|
156
|
+
// Internal methods
|
|
157
|
+
// -------------------------------------------------------------------------
|
|
158
|
+
/**
|
|
159
|
+
* Resolve an agent name to a role category.
|
|
160
|
+
*/
|
|
161
|
+
async resolveRole(agent) {
|
|
162
|
+
if (isCoordinatorName(agent)) return "coordinator";
|
|
163
|
+
try {
|
|
164
|
+
const employees = loadEmployeesSync();
|
|
165
|
+
const employee = employees.find((e) => e.name === agent);
|
|
166
|
+
if (employee && MANAGER_ROLES.has(employee.role)) return "manager";
|
|
167
|
+
} catch {
|
|
168
|
+
}
|
|
169
|
+
return "specialist";
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Check if a behavior belongs to the given agent.
|
|
173
|
+
*/
|
|
174
|
+
async isOwnBehavior(agent, behaviorId) {
|
|
175
|
+
try {
|
|
176
|
+
const client = getClient();
|
|
177
|
+
const result = await client.execute({
|
|
178
|
+
sql: "SELECT agent_id FROM behaviors WHERE id = ? LIMIT 1",
|
|
179
|
+
args: [behaviorId]
|
|
180
|
+
});
|
|
181
|
+
if (result.rows.length === 0) return false;
|
|
182
|
+
return String(result.rows[0].agent_id) === agent;
|
|
183
|
+
} catch {
|
|
184
|
+
return false;
|
|
185
|
+
}
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Ensure the steward_audit table exists.
|
|
189
|
+
*/
|
|
190
|
+
async ensureAuditTable() {
|
|
191
|
+
const client = getClient();
|
|
192
|
+
await client.execute({
|
|
193
|
+
sql: `CREATE TABLE IF NOT EXISTS steward_audit (
|
|
194
|
+
id TEXT PRIMARY KEY,
|
|
195
|
+
agent TEXT NOT NULL,
|
|
196
|
+
operation TEXT NOT NULL,
|
|
197
|
+
target TEXT NOT NULL,
|
|
198
|
+
allowed INTEGER NOT NULL,
|
|
199
|
+
reason TEXT NOT NULL,
|
|
200
|
+
confidence REAL NOT NULL,
|
|
201
|
+
requires_override INTEGER NOT NULL DEFAULT 0,
|
|
202
|
+
created_at TEXT NOT NULL
|
|
203
|
+
)`,
|
|
204
|
+
args: []
|
|
205
|
+
});
|
|
206
|
+
}
|
|
207
|
+
/**
|
|
208
|
+
* Log a gate decision to the audit trail.
|
|
209
|
+
*/
|
|
210
|
+
async logDecision(agent, operation, target, decision) {
|
|
211
|
+
try {
|
|
212
|
+
await this.ensureAuditTable();
|
|
213
|
+
const client = getClient();
|
|
214
|
+
await client.execute({
|
|
215
|
+
sql: `INSERT INTO steward_audit (id, agent, operation, target, allowed, reason, confidence, requires_override, created_at)
|
|
216
|
+
VALUES (?, ?, ?, ?, ?, ?, ?, ?, ?)`,
|
|
217
|
+
args: [
|
|
218
|
+
crypto.randomUUID(),
|
|
219
|
+
agent,
|
|
220
|
+
operation,
|
|
221
|
+
target,
|
|
222
|
+
decision.allowed ? 1 : 0,
|
|
223
|
+
decision.reason,
|
|
224
|
+
decision.confidence,
|
|
225
|
+
decision.requires_override ? 1 : 0,
|
|
226
|
+
(/* @__PURE__ */ new Date()).toISOString()
|
|
227
|
+
]
|
|
228
|
+
});
|
|
229
|
+
} catch {
|
|
230
|
+
process.stderr.write(
|
|
231
|
+
`[steward-gate] Audit log write failed for ${agent}:${operation}
|
|
232
|
+
`
|
|
233
|
+
);
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
};
|
|
237
|
+
|
|
238
|
+
export {
|
|
239
|
+
StewardGate
|
|
240
|
+
};
|