@synergenius/flow-weaver-pack-weaver 0.8.1
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/LICENSE +204 -0
- package/README.md +167 -0
- package/dist/bot/agent-provider.d.ts +34 -0
- package/dist/bot/agent-provider.d.ts.map +1 -0
- package/dist/bot/agent-provider.js +218 -0
- package/dist/bot/agent-provider.js.map +1 -0
- package/dist/bot/ai-client.d.ts +15 -0
- package/dist/bot/ai-client.d.ts.map +1 -0
- package/dist/bot/ai-client.js +128 -0
- package/dist/bot/ai-client.js.map +1 -0
- package/dist/bot/approvals.d.ts +22 -0
- package/dist/bot/approvals.d.ts.map +1 -0
- package/dist/bot/approvals.js +187 -0
- package/dist/bot/approvals.js.map +1 -0
- package/dist/bot/audit-logger.d.ts +5 -0
- package/dist/bot/audit-logger.d.ts.map +1 -0
- package/dist/bot/audit-logger.js +42 -0
- package/dist/bot/audit-logger.js.map +1 -0
- package/dist/bot/audit-store.d.ts +13 -0
- package/dist/bot/audit-store.d.ts.map +1 -0
- package/dist/bot/audit-store.js +59 -0
- package/dist/bot/audit-store.js.map +1 -0
- package/dist/bot/bot-agent-channel.d.ts +46 -0
- package/dist/bot/bot-agent-channel.d.ts.map +1 -0
- package/dist/bot/bot-agent-channel.js +58 -0
- package/dist/bot/bot-agent-channel.js.map +1 -0
- package/dist/bot/cli-provider.d.ts +29 -0
- package/dist/bot/cli-provider.d.ts.map +1 -0
- package/dist/bot/cli-provider.js +132 -0
- package/dist/bot/cli-provider.js.map +1 -0
- package/dist/bot/cli-stream-parser.d.ts +11 -0
- package/dist/bot/cli-stream-parser.d.ts.map +1 -0
- package/dist/bot/cli-stream-parser.js +53 -0
- package/dist/bot/cli-stream-parser.js.map +1 -0
- package/dist/bot/cost-store.d.ts +18 -0
- package/dist/bot/cost-store.d.ts.map +1 -0
- package/dist/bot/cost-store.js +81 -0
- package/dist/bot/cost-store.js.map +1 -0
- package/dist/bot/cost-tracker.d.ts +18 -0
- package/dist/bot/cost-tracker.d.ts.map +1 -0
- package/dist/bot/cost-tracker.js +60 -0
- package/dist/bot/cost-tracker.js.map +1 -0
- package/dist/bot/cron-parser.d.ts +5 -0
- package/dist/bot/cron-parser.d.ts.map +1 -0
- package/dist/bot/cron-parser.js +141 -0
- package/dist/bot/cron-parser.js.map +1 -0
- package/dist/bot/cron-scheduler.d.ts +12 -0
- package/dist/bot/cron-scheduler.d.ts.map +1 -0
- package/dist/bot/cron-scheduler.js +43 -0
- package/dist/bot/cron-scheduler.js.map +1 -0
- package/dist/bot/dashboard.d.ts +34 -0
- package/dist/bot/dashboard.d.ts.map +1 -0
- package/dist/bot/dashboard.js +602 -0
- package/dist/bot/dashboard.js.map +1 -0
- package/dist/bot/design-checker.d.ts +24 -0
- package/dist/bot/design-checker.d.ts.map +1 -0
- package/dist/bot/design-checker.js +269 -0
- package/dist/bot/design-checker.js.map +1 -0
- package/dist/bot/file-lock.d.ts +7 -0
- package/dist/bot/file-lock.d.ts.map +1 -0
- package/dist/bot/file-lock.js +64 -0
- package/dist/bot/file-lock.js.map +1 -0
- package/dist/bot/file-validator.d.ts +10 -0
- package/dist/bot/file-validator.d.ts.map +1 -0
- package/dist/bot/file-validator.js +27 -0
- package/dist/bot/file-validator.js.map +1 -0
- package/dist/bot/file-watcher.d.ts +24 -0
- package/dist/bot/file-watcher.d.ts.map +1 -0
- package/dist/bot/file-watcher.js +98 -0
- package/dist/bot/file-watcher.js.map +1 -0
- package/dist/bot/fw-api.d.ts +8 -0
- package/dist/bot/fw-api.d.ts.map +1 -0
- package/dist/bot/fw-api.js +12 -0
- package/dist/bot/fw-api.js.map +1 -0
- package/dist/bot/genesis-prompt-context.d.ts +31 -0
- package/dist/bot/genesis-prompt-context.d.ts.map +1 -0
- package/dist/bot/genesis-prompt-context.js +121 -0
- package/dist/bot/genesis-prompt-context.js.map +1 -0
- package/dist/bot/genesis-store.d.ts +28 -0
- package/dist/bot/genesis-store.d.ts.map +1 -0
- package/dist/bot/genesis-store.js +154 -0
- package/dist/bot/genesis-store.js.map +1 -0
- package/dist/bot/index.d.ts +38 -0
- package/dist/bot/index.d.ts.map +1 -0
- package/dist/bot/index.js +37 -0
- package/dist/bot/index.js.map +1 -0
- package/dist/bot/notifications.d.ts +20 -0
- package/dist/bot/notifications.d.ts.map +1 -0
- package/dist/bot/notifications.js +215 -0
- package/dist/bot/notifications.js.map +1 -0
- package/dist/bot/pipeline-runner.d.ts +22 -0
- package/dist/bot/pipeline-runner.d.ts.map +1 -0
- package/dist/bot/pipeline-runner.js +263 -0
- package/dist/bot/pipeline-runner.js.map +1 -0
- package/dist/bot/provider-registry.d.ts +26 -0
- package/dist/bot/provider-registry.d.ts.map +1 -0
- package/dist/bot/provider-registry.js +175 -0
- package/dist/bot/provider-registry.js.map +1 -0
- package/dist/bot/run-store.d.ts +25 -0
- package/dist/bot/run-store.d.ts.map +1 -0
- package/dist/bot/run-store.js +156 -0
- package/dist/bot/run-store.js.map +1 -0
- package/dist/bot/runner.d.ts +13 -0
- package/dist/bot/runner.d.ts.map +1 -0
- package/dist/bot/runner.js +244 -0
- package/dist/bot/runner.js.map +1 -0
- package/dist/bot/session-state.d.ts +19 -0
- package/dist/bot/session-state.d.ts.map +1 -0
- package/dist/bot/session-state.js +65 -0
- package/dist/bot/session-state.js.map +1 -0
- package/dist/bot/steering.d.ts +13 -0
- package/dist/bot/steering.d.ts.map +1 -0
- package/dist/bot/steering.js +40 -0
- package/dist/bot/steering.js.map +1 -0
- package/dist/bot/step-executor.d.ts +10 -0
- package/dist/bot/step-executor.d.ts.map +1 -0
- package/dist/bot/step-executor.js +30 -0
- package/dist/bot/step-executor.js.map +1 -0
- package/dist/bot/system-prompt.d.ts +19 -0
- package/dist/bot/system-prompt.d.ts.map +1 -0
- package/dist/bot/system-prompt.js +222 -0
- package/dist/bot/system-prompt.js.map +1 -0
- package/dist/bot/task-queue.d.ts +26 -0
- package/dist/bot/task-queue.d.ts.map +1 -0
- package/dist/bot/task-queue.js +98 -0
- package/dist/bot/task-queue.js.map +1 -0
- package/dist/bot/types.d.ts +478 -0
- package/dist/bot/types.d.ts.map +1 -0
- package/dist/bot/types.js +2 -0
- package/dist/bot/types.js.map +1 -0
- package/dist/bot/utils.d.ts +2 -0
- package/dist/bot/utils.d.ts.map +1 -0
- package/dist/bot/utils.js +20 -0
- package/dist/bot/utils.js.map +1 -0
- package/dist/bot/watch-daemon.d.ts +19 -0
- package/dist/bot/watch-daemon.d.ts.map +1 -0
- package/dist/bot/watch-daemon.js +178 -0
- package/dist/bot/watch-daemon.js.map +1 -0
- package/dist/bot/web-approval.d.ts +19 -0
- package/dist/bot/web-approval.d.ts.map +1 -0
- package/dist/bot/web-approval.js +207 -0
- package/dist/bot/web-approval.js.map +1 -0
- package/dist/cli-bridge.d.ts +2 -0
- package/dist/cli-bridge.d.ts.map +1 -0
- package/dist/cli-bridge.js +30 -0
- package/dist/cli-bridge.js.map +1 -0
- package/dist/cli-handlers.d.ts +79 -0
- package/dist/cli-handlers.d.ts.map +1 -0
- package/dist/cli-handlers.js +1335 -0
- package/dist/cli-handlers.js.map +1 -0
- package/dist/cli.d.ts +3 -0
- package/dist/cli.d.ts.map +1 -0
- package/dist/cli.js +749 -0
- package/dist/cli.js.map +1 -0
- package/dist/docs/docs/weaver-config.md +135 -0
- package/dist/docs/weaver-config.md +141 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +37 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp-tools.d.ts +13 -0
- package/dist/mcp-tools.d.ts.map +1 -0
- package/dist/mcp-tools.js +197 -0
- package/dist/mcp-tools.js.map +1 -0
- package/dist/node-types/abort-task.d.ts +15 -0
- package/dist/node-types/abort-task.d.ts.map +1 -0
- package/dist/node-types/abort-task.js +28 -0
- package/dist/node-types/abort-task.js.map +1 -0
- package/dist/node-types/approval-gate.d.ts +18 -0
- package/dist/node-types/approval-gate.d.ts.map +1 -0
- package/dist/node-types/approval-gate.js +80 -0
- package/dist/node-types/approval-gate.js.map +1 -0
- package/dist/node-types/bot-report.d.ts +20 -0
- package/dist/node-types/bot-report.d.ts.map +1 -0
- package/dist/node-types/bot-report.js +67 -0
- package/dist/node-types/bot-report.js.map +1 -0
- package/dist/node-types/build-context.d.ts +16 -0
- package/dist/node-types/build-context.d.ts.map +1 -0
- package/dist/node-types/build-context.js +64 -0
- package/dist/node-types/build-context.js.map +1 -0
- package/dist/node-types/detect-provider.d.ts +17 -0
- package/dist/node-types/detect-provider.d.ts.map +1 -0
- package/dist/node-types/detect-provider.js +71 -0
- package/dist/node-types/detect-provider.js.map +1 -0
- package/dist/node-types/exec-validate-retry.d.ts +17 -0
- package/dist/node-types/exec-validate-retry.d.ts.map +1 -0
- package/dist/node-types/exec-validate-retry.js +147 -0
- package/dist/node-types/exec-validate-retry.js.map +1 -0
- package/dist/node-types/execute-plan.d.ts +26 -0
- package/dist/node-types/execute-plan.d.ts.map +1 -0
- package/dist/node-types/execute-plan.js +120 -0
- package/dist/node-types/execute-plan.js.map +1 -0
- package/dist/node-types/execute-target.d.ts +16 -0
- package/dist/node-types/execute-target.d.ts.map +1 -0
- package/dist/node-types/execute-target.js +238 -0
- package/dist/node-types/execute-target.js.map +1 -0
- package/dist/node-types/fix-errors.d.ts +24 -0
- package/dist/node-types/fix-errors.d.ts.map +1 -0
- package/dist/node-types/fix-errors.js +49 -0
- package/dist/node-types/fix-errors.js.map +1 -0
- package/dist/node-types/genesis-apply-retry.d.ts +27 -0
- package/dist/node-types/genesis-apply-retry.d.ts.map +1 -0
- package/dist/node-types/genesis-apply-retry.js +97 -0
- package/dist/node-types/genesis-apply-retry.js.map +1 -0
- package/dist/node-types/genesis-apply.d.ts +29 -0
- package/dist/node-types/genesis-apply.d.ts.map +1 -0
- package/dist/node-types/genesis-apply.js +76 -0
- package/dist/node-types/genesis-apply.js.map +1 -0
- package/dist/node-types/genesis-approve.d.ts +19 -0
- package/dist/node-types/genesis-approve.d.ts.map +1 -0
- package/dist/node-types/genesis-approve.js +59 -0
- package/dist/node-types/genesis-approve.js.map +1 -0
- package/dist/node-types/genesis-check-stabilize.d.ts +16 -0
- package/dist/node-types/genesis-check-stabilize.d.ts.map +1 -0
- package/dist/node-types/genesis-check-stabilize.js +32 -0
- package/dist/node-types/genesis-check-stabilize.js.map +1 -0
- package/dist/node-types/genesis-check-threshold.d.ts +15 -0
- package/dist/node-types/genesis-check-threshold.d.ts.map +1 -0
- package/dist/node-types/genesis-check-threshold.js +29 -0
- package/dist/node-types/genesis-check-threshold.js.map +1 -0
- package/dist/node-types/genesis-commit.d.ts +17 -0
- package/dist/node-types/genesis-commit.d.ts.map +1 -0
- package/dist/node-types/genesis-commit.js +59 -0
- package/dist/node-types/genesis-commit.js.map +1 -0
- package/dist/node-types/genesis-compile-validate.d.ts +26 -0
- package/dist/node-types/genesis-compile-validate.d.ts.map +1 -0
- package/dist/node-types/genesis-compile-validate.js +60 -0
- package/dist/node-types/genesis-compile-validate.js.map +1 -0
- package/dist/node-types/genesis-diff-fingerprint.d.ts +15 -0
- package/dist/node-types/genesis-diff-fingerprint.d.ts.map +1 -0
- package/dist/node-types/genesis-diff-fingerprint.js +59 -0
- package/dist/node-types/genesis-diff-fingerprint.js.map +1 -0
- package/dist/node-types/genesis-diff-workflow.d.ts +15 -0
- package/dist/node-types/genesis-diff-workflow.d.ts.map +1 -0
- package/dist/node-types/genesis-diff-workflow.js +67 -0
- package/dist/node-types/genesis-diff-workflow.js.map +1 -0
- package/dist/node-types/genesis-escrow-grace.d.ts +15 -0
- package/dist/node-types/genesis-escrow-grace.d.ts.map +1 -0
- package/dist/node-types/genesis-escrow-grace.js +52 -0
- package/dist/node-types/genesis-escrow-grace.js.map +1 -0
- package/dist/node-types/genesis-escrow-migrate.d.ts +21 -0
- package/dist/node-types/genesis-escrow-migrate.d.ts.map +1 -0
- package/dist/node-types/genesis-escrow-migrate.js +116 -0
- package/dist/node-types/genesis-escrow-migrate.js.map +1 -0
- package/dist/node-types/genesis-escrow-recover.d.ts +15 -0
- package/dist/node-types/genesis-escrow-recover.d.ts.map +1 -0
- package/dist/node-types/genesis-escrow-recover.js +90 -0
- package/dist/node-types/genesis-escrow-recover.js.map +1 -0
- package/dist/node-types/genesis-escrow-stage.d.ts +17 -0
- package/dist/node-types/genesis-escrow-stage.d.ts.map +1 -0
- package/dist/node-types/genesis-escrow-stage.js +86 -0
- package/dist/node-types/genesis-escrow-stage.js.map +1 -0
- package/dist/node-types/genesis-escrow-validate.d.ts +17 -0
- package/dist/node-types/genesis-escrow-validate.d.ts.map +1 -0
- package/dist/node-types/genesis-escrow-validate.js +110 -0
- package/dist/node-types/genesis-escrow-validate.js.map +1 -0
- package/dist/node-types/genesis-load-config.d.ts +17 -0
- package/dist/node-types/genesis-load-config.d.ts.map +1 -0
- package/dist/node-types/genesis-load-config.js +36 -0
- package/dist/node-types/genesis-load-config.js.map +1 -0
- package/dist/node-types/genesis-observe.d.ts +18 -0
- package/dist/node-types/genesis-observe.d.ts.map +1 -0
- package/dist/node-types/genesis-observe.js +103 -0
- package/dist/node-types/genesis-observe.js.map +1 -0
- package/dist/node-types/genesis-propose.d.ts +17 -0
- package/dist/node-types/genesis-propose.d.ts.map +1 -0
- package/dist/node-types/genesis-propose.js +69 -0
- package/dist/node-types/genesis-propose.js.map +1 -0
- package/dist/node-types/genesis-report.d.ts +20 -0
- package/dist/node-types/genesis-report.d.ts.map +1 -0
- package/dist/node-types/genesis-report.js +87 -0
- package/dist/node-types/genesis-report.js.map +1 -0
- package/dist/node-types/genesis-snapshot.d.ts +15 -0
- package/dist/node-types/genesis-snapshot.d.ts.map +1 -0
- package/dist/node-types/genesis-snapshot.js +26 -0
- package/dist/node-types/genesis-snapshot.js.map +1 -0
- package/dist/node-types/genesis-try-apply.d.ts +18 -0
- package/dist/node-types/genesis-try-apply.d.ts.map +1 -0
- package/dist/node-types/genesis-try-apply.js +142 -0
- package/dist/node-types/genesis-try-apply.js.map +1 -0
- package/dist/node-types/genesis-update-history.d.ts +15 -0
- package/dist/node-types/genesis-update-history.d.ts.map +1 -0
- package/dist/node-types/genesis-update-history.js +70 -0
- package/dist/node-types/genesis-update-history.js.map +1 -0
- package/dist/node-types/genesis-validate-proposal.d.ts +16 -0
- package/dist/node-types/genesis-validate-proposal.d.ts.map +1 -0
- package/dist/node-types/genesis-validate-proposal.js +109 -0
- package/dist/node-types/genesis-validate-proposal.js.map +1 -0
- package/dist/node-types/git-ops.d.ts +15 -0
- package/dist/node-types/git-ops.d.ts.map +1 -0
- package/dist/node-types/git-ops.js +69 -0
- package/dist/node-types/git-ops.js.map +1 -0
- package/dist/node-types/index.d.ts +37 -0
- package/dist/node-types/index.d.ts.map +1 -0
- package/dist/node-types/index.js +37 -0
- package/dist/node-types/index.js.map +1 -0
- package/dist/node-types/load-config.d.ts +17 -0
- package/dist/node-types/load-config.d.ts.map +1 -0
- package/dist/node-types/load-config.js +27 -0
- package/dist/node-types/load-config.js.map +1 -0
- package/dist/node-types/plan-task.d.ts +17 -0
- package/dist/node-types/plan-task.d.ts.map +1 -0
- package/dist/node-types/plan-task.js +55 -0
- package/dist/node-types/plan-task.js.map +1 -0
- package/dist/node-types/read-workflow.d.ts +15 -0
- package/dist/node-types/read-workflow.d.ts.map +1 -0
- package/dist/node-types/read-workflow.js +60 -0
- package/dist/node-types/read-workflow.js.map +1 -0
- package/dist/node-types/receive-task.d.ts +20 -0
- package/dist/node-types/receive-task.d.ts.map +1 -0
- package/dist/node-types/receive-task.js +69 -0
- package/dist/node-types/receive-task.js.map +1 -0
- package/dist/node-types/report.d.ts +14 -0
- package/dist/node-types/report.d.ts.map +1 -0
- package/dist/node-types/report.js +25 -0
- package/dist/node-types/report.js.map +1 -0
- package/dist/node-types/resolve-target.d.ts +16 -0
- package/dist/node-types/resolve-target.d.ts.map +1 -0
- package/dist/node-types/resolve-target.js +67 -0
- package/dist/node-types/resolve-target.js.map +1 -0
- package/dist/node-types/route-task.d.ts +14 -0
- package/dist/node-types/route-task.d.ts.map +1 -0
- package/dist/node-types/route-task.js +22 -0
- package/dist/node-types/route-task.js.map +1 -0
- package/dist/node-types/send-notify.d.ts +14 -0
- package/dist/node-types/send-notify.d.ts.map +1 -0
- package/dist/node-types/send-notify.js +71 -0
- package/dist/node-types/send-notify.js.map +1 -0
- package/dist/node-types/validate-result.d.ts +24 -0
- package/dist/node-types/validate-result.d.ts.map +1 -0
- package/dist/node-types/validate-result.js +38 -0
- package/dist/node-types/validate-result.js.map +1 -0
- package/dist/templates/index.d.ts +5 -0
- package/dist/templates/index.d.ts.map +1 -0
- package/dist/templates/index.js +4 -0
- package/dist/templates/index.js.map +1 -0
- package/dist/templates/weaver-bot-template.d.ts +11 -0
- package/dist/templates/weaver-bot-template.d.ts.map +1 -0
- package/dist/templates/weaver-bot-template.js +99 -0
- package/dist/templates/weaver-bot-template.js.map +1 -0
- package/dist/templates/weaver-template.d.ts +11 -0
- package/dist/templates/weaver-template.d.ts.map +1 -0
- package/dist/templates/weaver-template.js +53 -0
- package/dist/templates/weaver-template.js.map +1 -0
- package/dist/workflows/genesis-task.d.ts +62 -0
- package/dist/workflows/genesis-task.d.ts.map +1 -0
- package/dist/workflows/genesis-task.js +64 -0
- package/dist/workflows/genesis-task.js.map +1 -0
- package/dist/workflows/index.d.ts +4 -0
- package/dist/workflows/index.d.ts.map +1 -0
- package/dist/workflows/index.js +4 -0
- package/dist/workflows/index.js.map +1 -0
- package/dist/workflows/weaver-bot-batch.d.ts +49 -0
- package/dist/workflows/weaver-bot-batch.d.ts.map +1 -0
- package/dist/workflows/weaver-bot-batch.js +49 -0
- package/dist/workflows/weaver-bot-batch.js.map +1 -0
- package/dist/workflows/weaver-bot-session.d.ts +65 -0
- package/dist/workflows/weaver-bot-session.d.ts.map +1 -0
- package/dist/workflows/weaver-bot-session.js +68 -0
- package/dist/workflows/weaver-bot-session.js.map +1 -0
- package/dist/workflows/weaver-bot.d.ts +61 -0
- package/dist/workflows/weaver-bot.d.ts.map +1 -0
- package/dist/workflows/weaver-bot.js +61 -0
- package/dist/workflows/weaver-bot.js.map +1 -0
- package/dist/workflows/weaver.d.ts +24 -0
- package/dist/workflows/weaver.d.ts.map +1 -0
- package/dist/workflows/weaver.js +28 -0
- package/dist/workflows/weaver.js.map +1 -0
- package/flowweaver.manifest.json +1001 -0
- package/package.json +78 -0
- package/src/bot/agent-provider.ts +273 -0
- package/src/bot/ai-client.ts +153 -0
- package/src/bot/approvals.ts +273 -0
- package/src/bot/audit-logger.ts +45 -0
- package/src/bot/audit-store.ts +69 -0
- package/src/bot/bot-agent-channel.ts +99 -0
- package/src/bot/cli-provider.ts +169 -0
- package/src/bot/cli-stream-parser.ts +59 -0
- package/src/bot/cost-store.ts +92 -0
- package/src/bot/cost-tracker.ts +72 -0
- package/src/bot/cron-parser.ts +153 -0
- package/src/bot/cron-scheduler.ts +48 -0
- package/src/bot/dashboard.ts +658 -0
- package/src/bot/design-checker.ts +327 -0
- package/src/bot/file-lock.ts +73 -0
- package/src/bot/file-validator.ts +41 -0
- package/src/bot/file-watcher.ts +103 -0
- package/src/bot/fw-api.ts +18 -0
- package/src/bot/genesis-prompt-context.ts +135 -0
- package/src/bot/genesis-store.ts +180 -0
- package/src/bot/index.ts +127 -0
- package/src/bot/notifications.ts +263 -0
- package/src/bot/pipeline-runner.ts +324 -0
- package/src/bot/provider-registry.ts +236 -0
- package/src/bot/run-store.ts +169 -0
- package/src/bot/runner.ts +311 -0
- package/src/bot/session-state.ts +73 -0
- package/src/bot/steering.ts +44 -0
- package/src/bot/step-executor.ts +34 -0
- package/src/bot/system-prompt.ts +280 -0
- package/src/bot/task-queue.ts +111 -0
- package/src/bot/types.ts +571 -0
- package/src/bot/utils.ts +17 -0
- package/src/bot/watch-daemon.ts +203 -0
- package/src/bot/web-approval.ts +240 -0
- package/src/cli-bridge.ts +41 -0
- package/src/cli-handlers.ts +1445 -0
- package/src/docs/weaver-config.md +135 -0
- package/src/index.ts +177 -0
- package/src/mcp-tools.ts +274 -0
- package/src/node-types/abort-task.ts +31 -0
- package/src/node-types/approval-gate.ts +95 -0
- package/src/node-types/bot-report.ts +82 -0
- package/src/node-types/build-context.ts +65 -0
- package/src/node-types/detect-provider.ts +77 -0
- package/src/node-types/exec-validate-retry.ts +170 -0
- package/src/node-types/execute-plan.ts +130 -0
- package/src/node-types/execute-target.ts +256 -0
- package/src/node-types/fix-errors.ts +63 -0
- package/src/node-types/genesis-apply-retry.ts +133 -0
- package/src/node-types/genesis-apply.ts +96 -0
- package/src/node-types/genesis-approve.ts +73 -0
- package/src/node-types/genesis-check-stabilize.ts +37 -0
- package/src/node-types/genesis-check-threshold.ts +34 -0
- package/src/node-types/genesis-commit.ts +71 -0
- package/src/node-types/genesis-compile-validate.ts +77 -0
- package/src/node-types/genesis-diff-fingerprint.ts +67 -0
- package/src/node-types/genesis-diff-workflow.ts +71 -0
- package/src/node-types/genesis-escrow-grace.ts +62 -0
- package/src/node-types/genesis-escrow-migrate.ts +138 -0
- package/src/node-types/genesis-escrow-recover.ts +99 -0
- package/src/node-types/genesis-escrow-stage.ts +104 -0
- package/src/node-types/genesis-escrow-validate.ts +120 -0
- package/src/node-types/genesis-load-config.ts +44 -0
- package/src/node-types/genesis-observe.ts +119 -0
- package/src/node-types/genesis-propose.ts +86 -0
- package/src/node-types/genesis-report.ts +95 -0
- package/src/node-types/genesis-snapshot.ts +30 -0
- package/src/node-types/genesis-try-apply.ts +165 -0
- package/src/node-types/genesis-update-history.ts +72 -0
- package/src/node-types/genesis-validate-proposal.ts +124 -0
- package/src/node-types/git-ops.ts +72 -0
- package/src/node-types/index.ts +36 -0
- package/src/node-types/load-config.ts +27 -0
- package/src/node-types/plan-task.ts +66 -0
- package/src/node-types/read-workflow.ts +68 -0
- package/src/node-types/receive-task.ts +92 -0
- package/src/node-types/report.ts +25 -0
- package/src/node-types/resolve-target.ts +64 -0
- package/src/node-types/route-task.ts +25 -0
- package/src/node-types/send-notify.ts +75 -0
- package/src/node-types/validate-result.ts +49 -0
- package/src/templates/index.ts +5 -0
- package/src/templates/weaver-bot-template.ts +106 -0
- package/src/workflows/genesis-task.ts +91 -0
- package/src/workflows/index.ts +3 -0
- package/src/workflows/weaver-bot-batch.ts +65 -0
- package/src/workflows/weaver-bot.ts +79 -0
- package/templates.js +1 -0
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import * as fs from 'node:fs';
|
|
2
|
+
import * as path from 'node:path';
|
|
3
|
+
import * as crypto from 'node:crypto';
|
|
4
|
+
import type { GenesisConfig, GenesisHistory, GenesisCycleRecord, GenesisFingerprint, EscrowToken, GenesisSelfMigrationRecord } from './types.js';
|
|
5
|
+
|
|
6
|
+
const DEFAULT_CONFIG: GenesisConfig = {
|
|
7
|
+
intent: 'Improve workflow reliability and efficiency',
|
|
8
|
+
focus: [],
|
|
9
|
+
constraints: [],
|
|
10
|
+
approvalThreshold: 'MINOR',
|
|
11
|
+
budgetPerCycle: 3,
|
|
12
|
+
stabilize: false,
|
|
13
|
+
targetWorkflow: '',
|
|
14
|
+
maxCyclesPerRun: 10,
|
|
15
|
+
};
|
|
16
|
+
|
|
17
|
+
export class GenesisStore {
|
|
18
|
+
private genesisDir: string;
|
|
19
|
+
|
|
20
|
+
constructor(projectDir: string) {
|
|
21
|
+
this.genesisDir = path.join(projectDir, '.genesis');
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
ensureDirs(): void {
|
|
25
|
+
fs.mkdirSync(path.join(this.genesisDir, 'snapshots'), { recursive: true });
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
loadConfig(): GenesisConfig {
|
|
29
|
+
const configPath = path.join(this.genesisDir, 'config.json');
|
|
30
|
+
if (!fs.existsSync(configPath)) {
|
|
31
|
+
this.ensureDirs();
|
|
32
|
+
fs.writeFileSync(configPath, JSON.stringify(DEFAULT_CONFIG, null, 2), 'utf-8');
|
|
33
|
+
return { ...DEFAULT_CONFIG };
|
|
34
|
+
}
|
|
35
|
+
const raw = JSON.parse(fs.readFileSync(configPath, 'utf-8'));
|
|
36
|
+
return { ...DEFAULT_CONFIG, ...raw };
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
saveConfig(config: GenesisConfig): void {
|
|
40
|
+
this.ensureDirs();
|
|
41
|
+
fs.writeFileSync(path.join(this.genesisDir, 'config.json'), JSON.stringify(config, null, 2), 'utf-8');
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
loadHistory(): GenesisHistory {
|
|
45
|
+
const historyPath = path.join(this.genesisDir, 'history.json');
|
|
46
|
+
if (!fs.existsSync(historyPath)) {
|
|
47
|
+
return { configHash: '', cycles: [] };
|
|
48
|
+
}
|
|
49
|
+
return JSON.parse(fs.readFileSync(historyPath, 'utf-8'));
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
appendCycle(cycle: GenesisCycleRecord): void {
|
|
53
|
+
const history = this.loadHistory();
|
|
54
|
+
history.cycles.push(cycle);
|
|
55
|
+
this.ensureDirs();
|
|
56
|
+
fs.writeFileSync(path.join(this.genesisDir, 'history.json'), JSON.stringify(history, null, 2), 'utf-8');
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
saveSnapshot(cycleId: string, content: string): string {
|
|
60
|
+
this.ensureDirs();
|
|
61
|
+
const snapshotPath = path.join(this.genesisDir, 'snapshots', `${cycleId}.ts`);
|
|
62
|
+
fs.writeFileSync(snapshotPath, content, 'utf-8');
|
|
63
|
+
return snapshotPath;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
loadSnapshot(snapshotPath: string): string | null {
|
|
67
|
+
try {
|
|
68
|
+
return fs.readFileSync(snapshotPath, 'utf-8');
|
|
69
|
+
} catch {
|
|
70
|
+
return null;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
saveFingerprint(fingerprint: GenesisFingerprint): void {
|
|
75
|
+
this.ensureDirs();
|
|
76
|
+
fs.writeFileSync(path.join(this.genesisDir, 'fingerprint.json'), JSON.stringify(fingerprint, null, 2), 'utf-8');
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
getLastFingerprint(): GenesisFingerprint | null {
|
|
80
|
+
const fpPath = path.join(this.genesisDir, 'fingerprint.json');
|
|
81
|
+
if (!fs.existsSync(fpPath)) return null;
|
|
82
|
+
try {
|
|
83
|
+
return JSON.parse(fs.readFileSync(fpPath, 'utf-8'));
|
|
84
|
+
} catch {
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
getRecentOutcomes(count: number): string[] {
|
|
90
|
+
const history = this.loadHistory();
|
|
91
|
+
return history.cycles.slice(-count).map(c => c.outcome);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
static newCycleId(): string {
|
|
95
|
+
return crypto.randomUUID().slice(0, 8);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
static hashConfig(config: GenesisConfig): string {
|
|
99
|
+
return crypto.createHash('sha256').update(JSON.stringify(config)).digest('hex').slice(0, 12);
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
// --- Escrow ---
|
|
103
|
+
|
|
104
|
+
ensureEscrowDirs(): void {
|
|
105
|
+
fs.mkdirSync(path.join(this.genesisDir, 'escrow', 'staged'), { recursive: true });
|
|
106
|
+
fs.mkdirSync(path.join(this.genesisDir, 'escrow', 'backup'), { recursive: true });
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
loadEscrowToken(): EscrowToken | null {
|
|
110
|
+
const tokenPath = path.join(this.genesisDir, 'escrow', 'token.json');
|
|
111
|
+
if (!fs.existsSync(tokenPath)) return null;
|
|
112
|
+
try {
|
|
113
|
+
return JSON.parse(fs.readFileSync(tokenPath, 'utf-8'));
|
|
114
|
+
} catch {
|
|
115
|
+
return null;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
saveEscrowToken(token: EscrowToken): void {
|
|
120
|
+
this.ensureEscrowDirs();
|
|
121
|
+
fs.writeFileSync(
|
|
122
|
+
path.join(this.genesisDir, 'escrow', 'token.json'),
|
|
123
|
+
JSON.stringify(token, null, 2),
|
|
124
|
+
'utf-8',
|
|
125
|
+
);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
clearEscrow(): void {
|
|
129
|
+
const escrowDir = path.join(this.genesisDir, 'escrow');
|
|
130
|
+
if (fs.existsSync(escrowDir)) {
|
|
131
|
+
fs.rmSync(escrowDir, { recursive: true, force: true });
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
getEscrowStagedPath(relativePath: string): string {
|
|
136
|
+
return path.join(this.genesisDir, 'escrow', 'staged', relativePath);
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
getEscrowBackupPath(relativePath: string): string {
|
|
140
|
+
return path.join(this.genesisDir, 'escrow', 'backup', relativePath);
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// --- Self-evolution history ---
|
|
144
|
+
|
|
145
|
+
loadSelfHistory(): GenesisSelfMigrationRecord[] {
|
|
146
|
+
const histPath = path.join(this.genesisDir, 'self-history.json');
|
|
147
|
+
if (!fs.existsSync(histPath)) return [];
|
|
148
|
+
try {
|
|
149
|
+
return JSON.parse(fs.readFileSync(histPath, 'utf-8'));
|
|
150
|
+
} catch {
|
|
151
|
+
return [];
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
appendSelfMigration(record: GenesisSelfMigrationRecord): void {
|
|
156
|
+
const records = this.loadSelfHistory();
|
|
157
|
+
records.push(record);
|
|
158
|
+
this.ensureDirs();
|
|
159
|
+
fs.writeFileSync(
|
|
160
|
+
path.join(this.genesisDir, 'self-history.json'),
|
|
161
|
+
JSON.stringify(records, null, 2),
|
|
162
|
+
'utf-8',
|
|
163
|
+
);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
getSelfFailureCount(): number {
|
|
167
|
+
const records = this.loadSelfHistory();
|
|
168
|
+
let count = 0;
|
|
169
|
+
for (let i = records.length - 1; i >= 0; i--) {
|
|
170
|
+
if (records[i]!.outcome === 'rolled-back') count++;
|
|
171
|
+
else break;
|
|
172
|
+
}
|
|
173
|
+
return count;
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
static hashFile(filePath: string): string {
|
|
177
|
+
const content = fs.readFileSync(filePath);
|
|
178
|
+
return crypto.createHash('sha256').update(content).digest('hex');
|
|
179
|
+
}
|
|
180
|
+
}
|
package/src/bot/index.ts
ADDED
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
export type {
|
|
2
|
+
BotConfig,
|
|
3
|
+
BotProviderConfig,
|
|
4
|
+
BotApprovalConfig,
|
|
5
|
+
BotNotifyConfig,
|
|
6
|
+
NotificationEvent,
|
|
7
|
+
NotificationEventType,
|
|
8
|
+
ExecutionEvent,
|
|
9
|
+
ExecutionEventType,
|
|
10
|
+
ApprovalMode,
|
|
11
|
+
WeaverConfig,
|
|
12
|
+
WeaverEnv,
|
|
13
|
+
ProviderInfo,
|
|
14
|
+
WorkflowResult,
|
|
15
|
+
ProviderName,
|
|
16
|
+
RunRecord,
|
|
17
|
+
RunFilter,
|
|
18
|
+
RetentionPolicy,
|
|
19
|
+
RunOutcome,
|
|
20
|
+
TokenUsage,
|
|
21
|
+
OnUsageCallback,
|
|
22
|
+
RunCostEntry,
|
|
23
|
+
RunCostSummary,
|
|
24
|
+
CostRecord,
|
|
25
|
+
CostSummary,
|
|
26
|
+
BotAgentProvider,
|
|
27
|
+
ProviderMetadata,
|
|
28
|
+
ProviderFactory,
|
|
29
|
+
ProviderFactoryConfig,
|
|
30
|
+
ProviderModule,
|
|
31
|
+
CronExpression,
|
|
32
|
+
ParsedCron,
|
|
33
|
+
CronField,
|
|
34
|
+
TriggerSource,
|
|
35
|
+
WatchDaemonOptions,
|
|
36
|
+
WatchDaemonState,
|
|
37
|
+
StageCondition,
|
|
38
|
+
StageStatus,
|
|
39
|
+
PipelineStage,
|
|
40
|
+
PipelineConfig,
|
|
41
|
+
StageResult,
|
|
42
|
+
PipelineResult,
|
|
43
|
+
DashboardEventType,
|
|
44
|
+
DashboardNodeStatus,
|
|
45
|
+
DashboardEvent,
|
|
46
|
+
DashboardNodeState,
|
|
47
|
+
DashboardServerOptions,
|
|
48
|
+
BotTask,
|
|
49
|
+
BotPlan,
|
|
50
|
+
BotPlanStep,
|
|
51
|
+
BotValidationResult,
|
|
52
|
+
BotExecutionResult,
|
|
53
|
+
BotNotificationEventType,
|
|
54
|
+
ToolDefinition,
|
|
55
|
+
ToolUseResult,
|
|
56
|
+
StreamChunk,
|
|
57
|
+
GenesisImpactLevel,
|
|
58
|
+
GenesisOperationType,
|
|
59
|
+
GenesisConfig,
|
|
60
|
+
GenesisOperation,
|
|
61
|
+
GenesisProposal,
|
|
62
|
+
GenesisFingerprint,
|
|
63
|
+
GenesisCycleRecord,
|
|
64
|
+
GenesisHistory,
|
|
65
|
+
} from './types.js';
|
|
66
|
+
|
|
67
|
+
export {
|
|
68
|
+
AnthropicAgentProvider,
|
|
69
|
+
resolveProviderConfig,
|
|
70
|
+
createProvider,
|
|
71
|
+
detectProvider,
|
|
72
|
+
} from './agent-provider.js';
|
|
73
|
+
export { CliAgentProvider } from './cli-provider.js';
|
|
74
|
+
export { ProviderRegistry, defaultRegistry, loadExternalProvider, discoverProviders } from './provider-registry.js';
|
|
75
|
+
export { BotAgentChannel } from './bot-agent-channel.js';
|
|
76
|
+
export type { BotChannelContext } from './bot-agent-channel.js';
|
|
77
|
+
export {
|
|
78
|
+
WebhookNotificationChannel,
|
|
79
|
+
createNotifier,
|
|
80
|
+
} from './notifications.js';
|
|
81
|
+
export type { NotificationChannel, NotificationErrorHandler } from './notifications.js';
|
|
82
|
+
export { buildSystemPrompt } from './system-prompt.js';
|
|
83
|
+
export { runWorkflow } from './runner.js';
|
|
84
|
+
export { createApprovalHandler } from './approvals.js';
|
|
85
|
+
export type { ApprovalHandler, ApprovalResult } from './approvals.js';
|
|
86
|
+
|
|
87
|
+
export { RunStore } from './run-store.js';
|
|
88
|
+
export { CostTracker, MODEL_PRICING } from './cost-tracker.js';
|
|
89
|
+
export { CostStore } from './cost-store.js';
|
|
90
|
+
|
|
91
|
+
// Watch/Cron (F4)
|
|
92
|
+
export { parseCron, matches as cronMatches, nextMatch as cronNextMatch } from './cron-parser.js';
|
|
93
|
+
export { FileWatcher } from './file-watcher.js';
|
|
94
|
+
export { CronScheduler } from './cron-scheduler.js';
|
|
95
|
+
export { WatchDaemon } from './watch-daemon.js';
|
|
96
|
+
|
|
97
|
+
// Pipelines (F1)
|
|
98
|
+
export { PipelineRunner } from './pipeline-runner.js';
|
|
99
|
+
export type { PipelineRunOptions } from './pipeline-runner.js';
|
|
100
|
+
|
|
101
|
+
// Dashboard (F3)
|
|
102
|
+
export { DashboardServer } from './dashboard.js';
|
|
103
|
+
export { openBrowser } from './utils.js';
|
|
104
|
+
|
|
105
|
+
// Web Approval (F6)
|
|
106
|
+
export { WebApprovalHandler } from './web-approval.js';
|
|
107
|
+
|
|
108
|
+
// Genesis
|
|
109
|
+
export { GenesisStore } from './genesis-store.js';
|
|
110
|
+
|
|
111
|
+
// File locking
|
|
112
|
+
export { withFileLock } from './file-lock.js';
|
|
113
|
+
export type { FileLockOptions } from './file-lock.js';
|
|
114
|
+
|
|
115
|
+
// Shared modules
|
|
116
|
+
export { callCli, callApi, parseJsonResponse } from './ai-client.js';
|
|
117
|
+
export { executeStep } from './step-executor.js';
|
|
118
|
+
export { validateFiles } from './file-validator.js';
|
|
119
|
+
|
|
120
|
+
// Bot infrastructure
|
|
121
|
+
export { SteeringController } from './steering.js';
|
|
122
|
+
export type { SteeringCommand } from './steering.js';
|
|
123
|
+
export { TaskQueue } from './task-queue.js';
|
|
124
|
+
export type { QueuedTask } from './task-queue.js';
|
|
125
|
+
export { SessionStore } from './session-state.js';
|
|
126
|
+
export type { SessionState } from './session-state.js';
|
|
127
|
+
export { buildBotSystemPrompt } from './system-prompt.js';
|
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
BotNotifyConfig,
|
|
3
|
+
NotificationEvent,
|
|
4
|
+
NotificationEventType,
|
|
5
|
+
} from './types.js';
|
|
6
|
+
|
|
7
|
+
export interface NotificationChannel {
|
|
8
|
+
name: string;
|
|
9
|
+
shouldSend(eventType: NotificationEventType): boolean;
|
|
10
|
+
send(event: NotificationEvent): Promise<void>;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export type NotificationErrorHandler = (
|
|
14
|
+
channel: string,
|
|
15
|
+
event: NotificationEvent,
|
|
16
|
+
error: string,
|
|
17
|
+
) => void;
|
|
18
|
+
|
|
19
|
+
const EVENT_COLORS: Record<NotificationEventType, number> = {
|
|
20
|
+
'workflow-start': 0x3498db,
|
|
21
|
+
'workflow-complete': 0x2ecc71,
|
|
22
|
+
'cycle-start': 0x3498db,
|
|
23
|
+
'cycle-complete': 0x2ecc71,
|
|
24
|
+
'approval-needed': 0xf1c40f,
|
|
25
|
+
error: 0xe74c3c,
|
|
26
|
+
'pipeline-start': 0x9b59b6,
|
|
27
|
+
'pipeline-complete': 0x2ecc71,
|
|
28
|
+
'stage-start': 0x3498db,
|
|
29
|
+
'stage-complete': 0x2ecc71,
|
|
30
|
+
'bot-task-start': 0x3498db,
|
|
31
|
+
'bot-task-complete': 0x2ecc71,
|
|
32
|
+
'bot-plan-ready': 0x9b59b6,
|
|
33
|
+
'bot-step-complete': 0x1abc9c,
|
|
34
|
+
'bot-validation-failed': 0xe67e22,
|
|
35
|
+
'bot-fix-attempt': 0xf39c12,
|
|
36
|
+
'bot-session-start': 0x3498db,
|
|
37
|
+
'bot-session-end': 0x2ecc71,
|
|
38
|
+
'bot-steering-received': 0x95a5a6,
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
const EVENT_LABELS: Record<NotificationEventType, string> = {
|
|
42
|
+
'workflow-start': 'Workflow Started',
|
|
43
|
+
'workflow-complete': 'Workflow Complete',
|
|
44
|
+
'cycle-start': 'Cycle Started',
|
|
45
|
+
'cycle-complete': 'Cycle Complete',
|
|
46
|
+
'approval-needed': 'Approval Needed',
|
|
47
|
+
error: 'Error',
|
|
48
|
+
'pipeline-start': 'Pipeline Started',
|
|
49
|
+
'pipeline-complete': 'Pipeline Complete',
|
|
50
|
+
'stage-start': 'Stage Started',
|
|
51
|
+
'stage-complete': 'Stage Complete',
|
|
52
|
+
'bot-task-start': 'Bot Task Started',
|
|
53
|
+
'bot-task-complete': 'Bot Task Complete',
|
|
54
|
+
'bot-plan-ready': 'Bot Plan Ready',
|
|
55
|
+
'bot-step-complete': 'Bot Step Complete',
|
|
56
|
+
'bot-validation-failed': 'Bot Validation Failed',
|
|
57
|
+
'bot-fix-attempt': 'Bot Fix Attempt',
|
|
58
|
+
'bot-session-start': 'Bot Session Started',
|
|
59
|
+
'bot-session-end': 'Bot Session Ended',
|
|
60
|
+
'bot-steering-received': 'Bot Steering Received',
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
function formatDiscordBody(event: NotificationEvent): object {
|
|
64
|
+
const color = EVENT_COLORS[event.type];
|
|
65
|
+
const context =
|
|
66
|
+
event.cycle != null
|
|
67
|
+
? `Cycle ${event.cycle}`
|
|
68
|
+
: (event.workflowFile ?? 'Workflow');
|
|
69
|
+
const title = `Weaver: ${EVENT_LABELS[event.type]} (${context})`;
|
|
70
|
+
|
|
71
|
+
const fields: Array<{ name: string; value: string; inline?: boolean }> = [];
|
|
72
|
+
|
|
73
|
+
if (event.summary) {
|
|
74
|
+
fields.push({ name: 'Summary', value: event.summary });
|
|
75
|
+
}
|
|
76
|
+
if (event.outcome) {
|
|
77
|
+
fields.push({ name: 'Outcome', value: event.outcome, inline: true });
|
|
78
|
+
}
|
|
79
|
+
if (event.diff) {
|
|
80
|
+
const s = event.diff.summary as Record<string, number> | undefined;
|
|
81
|
+
if (s) {
|
|
82
|
+
fields.push({
|
|
83
|
+
name: 'Nodes',
|
|
84
|
+
value: `+${s.nodeTypesAdded ?? 0} / -${s.nodeTypesRemoved ?? 0}`,
|
|
85
|
+
inline: true,
|
|
86
|
+
});
|
|
87
|
+
fields.push({
|
|
88
|
+
name: 'Connections',
|
|
89
|
+
value: `+${s.connectionsAdded ?? 0} / -${s.connectionsRemoved ?? 0}`,
|
|
90
|
+
inline: true,
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
if (event.pipelineName) {
|
|
95
|
+
fields.push({ name: 'Pipeline', value: event.pipelineName, inline: true });
|
|
96
|
+
}
|
|
97
|
+
if (event.stageId) {
|
|
98
|
+
fields.push({ name: 'Stage', value: event.stageId, inline: true });
|
|
99
|
+
}
|
|
100
|
+
if (event.totalStages != null) {
|
|
101
|
+
fields.push({ name: 'Progress', value: `${event.completedStages ?? 0}/${event.totalStages}`, inline: true });
|
|
102
|
+
}
|
|
103
|
+
if (event.error) {
|
|
104
|
+
fields.push({ name: 'Error', value: event.error.slice(0, 1024) });
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
return {
|
|
108
|
+
embeds: [
|
|
109
|
+
{
|
|
110
|
+
title,
|
|
111
|
+
description: event.projectDir,
|
|
112
|
+
color,
|
|
113
|
+
fields: fields.length > 0 ? fields : undefined,
|
|
114
|
+
timestamp: new Date().toISOString(),
|
|
115
|
+
},
|
|
116
|
+
],
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
function formatSlackBody(event: NotificationEvent): object {
|
|
121
|
+
const label = EVENT_LABELS[event.type];
|
|
122
|
+
const blocks: Array<Record<string, unknown>> = [
|
|
123
|
+
{
|
|
124
|
+
type: 'header',
|
|
125
|
+
text: {
|
|
126
|
+
type: 'plain_text',
|
|
127
|
+
text: `Weaver: ${label}${event.cycle != null ? ` (Cycle ${event.cycle})` : ''}`,
|
|
128
|
+
},
|
|
129
|
+
},
|
|
130
|
+
];
|
|
131
|
+
|
|
132
|
+
const parts: string[] = [`*Project:* ${event.projectDir}`];
|
|
133
|
+
if (event.summary) parts.push(`*Summary:* ${event.summary}`);
|
|
134
|
+
if (event.outcome) parts.push(`*Outcome:* ${event.outcome}`);
|
|
135
|
+
if (event.pipelineName) parts.push(`*Pipeline:* ${event.pipelineName}`);
|
|
136
|
+
if (event.stageId) parts.push(`*Stage:* ${event.stageId}`);
|
|
137
|
+
if (event.totalStages != null) parts.push(`*Progress:* ${event.completedStages ?? 0}/${event.totalStages}`);
|
|
138
|
+
if (event.error) parts.push(`*Error:* ${event.error.slice(0, 500)}`);
|
|
139
|
+
|
|
140
|
+
blocks.push({
|
|
141
|
+
type: 'section',
|
|
142
|
+
text: { type: 'mrkdwn', text: parts.join('\n') },
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
return { blocks };
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
function formatWebhookBody(event: NotificationEvent): object {
|
|
149
|
+
return { event };
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
async function fetchWithRetry(
|
|
153
|
+
url: string,
|
|
154
|
+
init: RequestInit,
|
|
155
|
+
maxAttempts: number,
|
|
156
|
+
onError?: NotificationErrorHandler,
|
|
157
|
+
channelName?: string,
|
|
158
|
+
event?: NotificationEvent,
|
|
159
|
+
): Promise<Response | null> {
|
|
160
|
+
const delays = [1000, 2000, 4000];
|
|
161
|
+
|
|
162
|
+
for (let attempt = 0; attempt < maxAttempts; attempt++) {
|
|
163
|
+
try {
|
|
164
|
+
const resp = await fetch(url, init);
|
|
165
|
+
if (resp.ok) return resp;
|
|
166
|
+
|
|
167
|
+
const msg = `${resp.status} ${resp.statusText}`;
|
|
168
|
+
if (attempt < maxAttempts - 1) {
|
|
169
|
+
console.error(
|
|
170
|
+
`[weaver] ${channelName} notification failed (attempt ${attempt + 1}/${maxAttempts}): ${msg}`,
|
|
171
|
+
);
|
|
172
|
+
await new Promise((r) => setTimeout(r, delays[attempt] ?? 4000));
|
|
173
|
+
} else {
|
|
174
|
+
const errorMsg = `${channelName} notification failed after ${maxAttempts} attempts: ${msg}`;
|
|
175
|
+
console.error(`[weaver] ${errorMsg}`);
|
|
176
|
+
if (onError && event) onError(channelName ?? 'unknown', event, errorMsg);
|
|
177
|
+
}
|
|
178
|
+
} catch (err: unknown) {
|
|
179
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
180
|
+
if (attempt < maxAttempts - 1) {
|
|
181
|
+
console.error(
|
|
182
|
+
`[weaver] ${channelName} notification error (attempt ${attempt + 1}/${maxAttempts}): ${msg}`,
|
|
183
|
+
);
|
|
184
|
+
await new Promise((r) => setTimeout(r, delays[attempt] ?? 4000));
|
|
185
|
+
} else {
|
|
186
|
+
const errorMsg = `${channelName} notification error after ${maxAttempts} attempts: ${msg}`;
|
|
187
|
+
console.error(`[weaver] ${errorMsg}`);
|
|
188
|
+
if (onError && event) onError(channelName ?? 'unknown', event, errorMsg);
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
|
|
193
|
+
return null;
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
export class WebhookNotificationChannel implements NotificationChannel {
|
|
197
|
+
name: string;
|
|
198
|
+
private url: string;
|
|
199
|
+
private channelType: 'discord' | 'slack' | 'webhook';
|
|
200
|
+
private events: Set<NotificationEventType>;
|
|
201
|
+
private headers: Record<string, string>;
|
|
202
|
+
private onError?: NotificationErrorHandler;
|
|
203
|
+
|
|
204
|
+
constructor(config: BotNotifyConfig, onError?: NotificationErrorHandler) {
|
|
205
|
+
this.name = config.channel;
|
|
206
|
+
this.url = config.url;
|
|
207
|
+
this.channelType = config.channel;
|
|
208
|
+
this.events = new Set(
|
|
209
|
+
config.events ?? [
|
|
210
|
+
'cycle-start',
|
|
211
|
+
'cycle-complete',
|
|
212
|
+
'approval-needed',
|
|
213
|
+
'error',
|
|
214
|
+
],
|
|
215
|
+
);
|
|
216
|
+
this.headers = config.headers ?? {};
|
|
217
|
+
this.onError = onError;
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
shouldSend(eventType: NotificationEventType): boolean {
|
|
221
|
+
return this.events.has(eventType);
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
async send(event: NotificationEvent): Promise<void> {
|
|
225
|
+
if (!this.shouldSend(event.type)) return;
|
|
226
|
+
|
|
227
|
+
let body: object;
|
|
228
|
+
switch (this.channelType) {
|
|
229
|
+
case 'discord':
|
|
230
|
+
body = formatDiscordBody(event);
|
|
231
|
+
break;
|
|
232
|
+
case 'slack':
|
|
233
|
+
body = formatSlackBody(event);
|
|
234
|
+
break;
|
|
235
|
+
default:
|
|
236
|
+
body = formatWebhookBody(event);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
await fetchWithRetry(
|
|
240
|
+
this.url,
|
|
241
|
+
{
|
|
242
|
+
method: 'POST',
|
|
243
|
+
headers: {
|
|
244
|
+
'Content-Type': 'application/json',
|
|
245
|
+
...this.headers,
|
|
246
|
+
},
|
|
247
|
+
body: JSON.stringify(body),
|
|
248
|
+
},
|
|
249
|
+
3,
|
|
250
|
+
this.onError,
|
|
251
|
+
this.channelType,
|
|
252
|
+
event,
|
|
253
|
+
);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
|
|
257
|
+
export function createNotifier(
|
|
258
|
+
channels: NotificationChannel[],
|
|
259
|
+
): (event: NotificationEvent) => Promise<void> {
|
|
260
|
+
return async (event: NotificationEvent) => {
|
|
261
|
+
await Promise.allSettled(channels.map((ch) => ch.send(event)));
|
|
262
|
+
};
|
|
263
|
+
}
|