@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
package/package.json
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@synergenius/flow-weaver-pack-weaver",
|
|
3
|
+
"version": "0.8.1",
|
|
4
|
+
"description": "AI bot for Flow Weaver. Execute tasks, run workflows, evolve autonomously.",
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.js",
|
|
7
|
+
"types": "./dist/index.d.ts",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./dist/index.d.ts",
|
|
11
|
+
"default": "./dist/index.js"
|
|
12
|
+
},
|
|
13
|
+
"./node-types": {
|
|
14
|
+
"types": "./dist/node-types/index.d.ts",
|
|
15
|
+
"default": "./dist/node-types/index.js"
|
|
16
|
+
},
|
|
17
|
+
"./bot": {
|
|
18
|
+
"types": "./dist/bot/index.d.ts",
|
|
19
|
+
"default": "./dist/bot/index.js"
|
|
20
|
+
}
|
|
21
|
+
},
|
|
22
|
+
"keywords": [
|
|
23
|
+
"flowweaver-marketplace-pack",
|
|
24
|
+
"flowweaver-bot-pack",
|
|
25
|
+
"flow-weaver",
|
|
26
|
+
"weaver",
|
|
27
|
+
"automation",
|
|
28
|
+
"ai-agent",
|
|
29
|
+
"bot"
|
|
30
|
+
],
|
|
31
|
+
"flowWeaver": {
|
|
32
|
+
"type": "marketplace-pack",
|
|
33
|
+
"engineVersion": ">=0.17.0",
|
|
34
|
+
"categories": [
|
|
35
|
+
"automation",
|
|
36
|
+
"ai"
|
|
37
|
+
]
|
|
38
|
+
},
|
|
39
|
+
"peerDependencies": {
|
|
40
|
+
"@anthropic-ai/sdk": ">=0.30.0",
|
|
41
|
+
"@synergenius/flow-weaver": ">=0.21.0",
|
|
42
|
+
"zod": ">=3.22.0"
|
|
43
|
+
},
|
|
44
|
+
"peerDependenciesMeta": {
|
|
45
|
+
"@anthropic-ai/sdk": {
|
|
46
|
+
"optional": true
|
|
47
|
+
},
|
|
48
|
+
"zod": {
|
|
49
|
+
"optional": true
|
|
50
|
+
}
|
|
51
|
+
},
|
|
52
|
+
"files": [
|
|
53
|
+
"dist",
|
|
54
|
+
"src",
|
|
55
|
+
"flowweaver.manifest.json",
|
|
56
|
+
"templates.js",
|
|
57
|
+
"LICENSE"
|
|
58
|
+
],
|
|
59
|
+
"scripts": {
|
|
60
|
+
"build": "tsc && cp -r src/docs dist/docs && node -e \"require('fs').writeFileSync('templates.js','export{workflowTemplates}from\\\"./dist/templates/index.js\\\";\\n')\"",
|
|
61
|
+
"prepublishOnly": "npm run build",
|
|
62
|
+
"test": "vitest run",
|
|
63
|
+
"test:watch": "vitest",
|
|
64
|
+
"typecheck": "tsc --noEmit",
|
|
65
|
+
"release": "tsx scripts/release.ts"
|
|
66
|
+
},
|
|
67
|
+
"devDependencies": {
|
|
68
|
+
"@types/node": "^25.3.5",
|
|
69
|
+
"tsx": "^4.0.0",
|
|
70
|
+
"typescript": "^5.0.0",
|
|
71
|
+
"vitest": "^4.0.18"
|
|
72
|
+
},
|
|
73
|
+
"license": "SEE LICENSE IN LICENSE",
|
|
74
|
+
"repository": {
|
|
75
|
+
"type": "git",
|
|
76
|
+
"url": "https://github.com/synergenius-fw/flow-weaver-pack-weaver"
|
|
77
|
+
}
|
|
78
|
+
}
|
|
@@ -0,0 +1,273 @@
|
|
|
1
|
+
import { execFileSync } from 'node:child_process';
|
|
2
|
+
import type { BotProviderConfig, BotConfig, BotAgentProvider, OnUsageCallback, StreamChunk, ToolDefinition, ToolUseResult } from './types.js';
|
|
3
|
+
import { buildSystemPrompt } from './system-prompt.js';
|
|
4
|
+
import { defaultRegistry, loadExternalProvider } from './provider-registry.js';
|
|
5
|
+
import type { ProviderRegistry } from './provider-registry.js';
|
|
6
|
+
|
|
7
|
+
const WHICH_CMD = process.platform === 'win32' ? 'where' : 'which';
|
|
8
|
+
|
|
9
|
+
export type { BotAgentProvider };
|
|
10
|
+
|
|
11
|
+
export function resolveProviderConfig(
|
|
12
|
+
provider: BotConfig['provider'],
|
|
13
|
+
): BotProviderConfig {
|
|
14
|
+
if (provider === 'auto') return detectProvider();
|
|
15
|
+
if (typeof provider === 'string') return { name: provider };
|
|
16
|
+
return provider;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export async function createProvider(
|
|
20
|
+
config: BotProviderConfig,
|
|
21
|
+
registry: ProviderRegistry = defaultRegistry,
|
|
22
|
+
): Promise<BotAgentProvider> {
|
|
23
|
+
// If config.module is set, load and register it first
|
|
24
|
+
if (config.module) {
|
|
25
|
+
if (!registry.has(config.name)) {
|
|
26
|
+
const { factory, metadata } = await loadExternalProvider(config.module);
|
|
27
|
+
registry.register(config.name, factory, metadata);
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
// Check registry (covers built-ins + loaded externals)
|
|
32
|
+
const entry = registry.resolve(config.name);
|
|
33
|
+
if (entry) {
|
|
34
|
+
return entry.factory({
|
|
35
|
+
model: config.model,
|
|
36
|
+
maxTokens: config.maxTokens,
|
|
37
|
+
options: config.options,
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
// Fallback: try conventional npm package names
|
|
42
|
+
const candidates = [
|
|
43
|
+
`flowweaver-provider-${config.name}`,
|
|
44
|
+
`@synergenius/flowweaver-provider-${config.name}`,
|
|
45
|
+
];
|
|
46
|
+
|
|
47
|
+
for (const candidate of candidates) {
|
|
48
|
+
try {
|
|
49
|
+
const { factory, metadata } = await loadExternalProvider(candidate);
|
|
50
|
+
registry.register(config.name, factory, metadata);
|
|
51
|
+
return factory({
|
|
52
|
+
model: config.model,
|
|
53
|
+
maxTokens: config.maxTokens,
|
|
54
|
+
options: config.options,
|
|
55
|
+
});
|
|
56
|
+
} catch {
|
|
57
|
+
// Try next candidate
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
throw new Error(
|
|
62
|
+
`Unknown provider: ${config.name}\n` +
|
|
63
|
+
` Install a provider package: npm install flowweaver-provider-${config.name}\n` +
|
|
64
|
+
` Or specify a module path: { "provider": { "name": "${config.name}", "module": "./my-provider.js" } }`,
|
|
65
|
+
);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
export function detectProvider(registry: ProviderRegistry = defaultRegistry): BotProviderConfig {
|
|
69
|
+
// Check registry metadata for env vars and CLI commands
|
|
70
|
+
for (const { name, metadata } of registry.list()) {
|
|
71
|
+
if (metadata.requiredEnvVars) {
|
|
72
|
+
const allPresent = metadata.requiredEnvVars.every((v) => process.env[v]);
|
|
73
|
+
if (allPresent) return { name };
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
for (const { name, metadata } of registry.list()) {
|
|
78
|
+
if (metadata.detectCliCommand) {
|
|
79
|
+
try {
|
|
80
|
+
execFileSync(WHICH_CMD, [metadata.detectCliCommand], { stdio: 'pipe' });
|
|
81
|
+
return { name };
|
|
82
|
+
} catch { /* not installed */ }
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
throw new Error(
|
|
87
|
+
'No AI provider found. Options:\n' +
|
|
88
|
+
' 1. Set ANTHROPIC_API_KEY environment variable\n' +
|
|
89
|
+
' 2. Install Claude CLI: https://docs.anthropic.com/claude-code\n' +
|
|
90
|
+
' 3. Install GitHub Copilot CLI: https://github.com/features/copilot',
|
|
91
|
+
);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
export class AnthropicAgentProvider implements BotAgentProvider {
|
|
95
|
+
private model: string;
|
|
96
|
+
private maxTokens: number;
|
|
97
|
+
onUsage?: OnUsageCallback;
|
|
98
|
+
|
|
99
|
+
constructor(config: BotProviderConfig) {
|
|
100
|
+
this.model = config.model ?? 'claude-sonnet-4-6';
|
|
101
|
+
this.maxTokens = config.maxTokens ?? 4096;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
async decide(request: {
|
|
105
|
+
agentId: string;
|
|
106
|
+
context: Record<string, unknown>;
|
|
107
|
+
prompt: string;
|
|
108
|
+
}): Promise<Record<string, unknown>> {
|
|
109
|
+
if (!process.env.ANTHROPIC_API_KEY) {
|
|
110
|
+
throw new Error(
|
|
111
|
+
'ANTHROPIC_API_KEY environment variable is required for the Anthropic provider',
|
|
112
|
+
);
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
const Anthropic = await this.loadSdk();
|
|
116
|
+
const client = new Anthropic();
|
|
117
|
+
const systemPrompt = await buildSystemPrompt();
|
|
118
|
+
|
|
119
|
+
const contextStr =
|
|
120
|
+
typeof request.context === 'string'
|
|
121
|
+
? request.context
|
|
122
|
+
: JSON.stringify(request.context, null, 2);
|
|
123
|
+
|
|
124
|
+
const response = await client.messages.create({
|
|
125
|
+
model: this.model,
|
|
126
|
+
max_tokens: this.maxTokens,
|
|
127
|
+
system: systemPrompt,
|
|
128
|
+
messages: [
|
|
129
|
+
{
|
|
130
|
+
role: 'user',
|
|
131
|
+
content: `Context:\n${contextStr}\n\nInstructions:\n${request.prompt}`,
|
|
132
|
+
},
|
|
133
|
+
],
|
|
134
|
+
});
|
|
135
|
+
|
|
136
|
+
if (this.onUsage && response.usage) {
|
|
137
|
+
this.onUsage(request.agentId, response.model ?? this.model, {
|
|
138
|
+
inputTokens: response.usage.input_tokens,
|
|
139
|
+
outputTokens: response.usage.output_tokens,
|
|
140
|
+
cacheCreationInputTokens: response.usage.cache_creation_input_tokens,
|
|
141
|
+
cacheReadInputTokens: response.usage.cache_read_input_tokens,
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
const text =
|
|
146
|
+
response.content[0].type === 'text' ? response.content[0].text : '';
|
|
147
|
+
return this.parseJson(text);
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
async *stream(request: {
|
|
151
|
+
agentId: string;
|
|
152
|
+
context: Record<string, unknown>;
|
|
153
|
+
prompt: string;
|
|
154
|
+
}): AsyncIterable<StreamChunk> {
|
|
155
|
+
if (!process.env.ANTHROPIC_API_KEY) {
|
|
156
|
+
throw new Error('ANTHROPIC_API_KEY environment variable is required for the Anthropic provider');
|
|
157
|
+
}
|
|
158
|
+
|
|
159
|
+
const Anthropic = await this.loadSdk();
|
|
160
|
+
const client = new Anthropic();
|
|
161
|
+
const systemPrompt = await buildSystemPrompt();
|
|
162
|
+
|
|
163
|
+
const contextStr = typeof request.context === 'string'
|
|
164
|
+
? request.context
|
|
165
|
+
: JSON.stringify(request.context, null, 2);
|
|
166
|
+
|
|
167
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
168
|
+
const stream = (client as any).messages.stream({
|
|
169
|
+
model: this.model,
|
|
170
|
+
max_tokens: this.maxTokens,
|
|
171
|
+
system: systemPrompt,
|
|
172
|
+
messages: [{ role: 'user', content: `Context:\n${contextStr}\n\nInstructions:\n${request.prompt}` }],
|
|
173
|
+
});
|
|
174
|
+
|
|
175
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
176
|
+
for await (const event of stream as AsyncIterable<any>) {
|
|
177
|
+
if (event.type === 'content_block_delta' && event.delta?.type === 'text_delta') {
|
|
178
|
+
yield { type: 'text', text: event.delta.text };
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
183
|
+
const finalMessage = await (stream as any).finalMessage();
|
|
184
|
+
if (finalMessage?.usage) {
|
|
185
|
+
const usage = {
|
|
186
|
+
inputTokens: finalMessage.usage.input_tokens,
|
|
187
|
+
outputTokens: finalMessage.usage.output_tokens,
|
|
188
|
+
cacheCreationInputTokens: finalMessage.usage.cache_creation_input_tokens,
|
|
189
|
+
cacheReadInputTokens: finalMessage.usage.cache_read_input_tokens,
|
|
190
|
+
};
|
|
191
|
+
if (this.onUsage) this.onUsage(request.agentId, finalMessage.model ?? this.model, usage);
|
|
192
|
+
yield { type: 'usage', usage };
|
|
193
|
+
}
|
|
194
|
+
yield { type: 'done' };
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
async decideWithTools(request: {
|
|
198
|
+
agentId: string;
|
|
199
|
+
context: Record<string, unknown>;
|
|
200
|
+
prompt: string;
|
|
201
|
+
tools: ToolDefinition[];
|
|
202
|
+
}): Promise<{ result: Record<string, unknown>; toolCalls?: ToolUseResult[] }> {
|
|
203
|
+
if (!process.env.ANTHROPIC_API_KEY) {
|
|
204
|
+
throw new Error('ANTHROPIC_API_KEY environment variable is required for the Anthropic provider');
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
const Anthropic = await this.loadSdk();
|
|
208
|
+
const client = new Anthropic();
|
|
209
|
+
const systemPrompt = await buildSystemPrompt();
|
|
210
|
+
|
|
211
|
+
const contextStr = typeof request.context === 'string'
|
|
212
|
+
? request.context
|
|
213
|
+
: JSON.stringify(request.context, null, 2);
|
|
214
|
+
|
|
215
|
+
const response = await client.messages.create({
|
|
216
|
+
model: this.model,
|
|
217
|
+
max_tokens: this.maxTokens,
|
|
218
|
+
system: systemPrompt,
|
|
219
|
+
messages: [{ role: 'user', content: `Context:\n${contextStr}\n\nInstructions:\n${request.prompt}` }],
|
|
220
|
+
tools: request.tools,
|
|
221
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
222
|
+
} as any);
|
|
223
|
+
|
|
224
|
+
if (this.onUsage && response.usage) {
|
|
225
|
+
this.onUsage(request.agentId, response.model ?? this.model, {
|
|
226
|
+
inputTokens: response.usage.input_tokens,
|
|
227
|
+
outputTokens: response.usage.output_tokens,
|
|
228
|
+
cacheCreationInputTokens: response.usage.cache_creation_input_tokens,
|
|
229
|
+
cacheReadInputTokens: response.usage.cache_read_input_tokens,
|
|
230
|
+
});
|
|
231
|
+
}
|
|
232
|
+
|
|
233
|
+
const toolCalls: ToolUseResult[] = [];
|
|
234
|
+
let text = '';
|
|
235
|
+
for (const block of response.content) {
|
|
236
|
+
if (block.type === 'text') text = block.text;
|
|
237
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
238
|
+
else if (block.type === 'tool_use') toolCalls.push({ toolName: (block as any).name, toolInput: (block as any).input });
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
return { result: this.parseJson(text || '{}'), toolCalls: toolCalls.length > 0 ? toolCalls : undefined };
|
|
242
|
+
}
|
|
243
|
+
|
|
244
|
+
private parseJson(text: string): Record<string, unknown> {
|
|
245
|
+
let cleaned = text.trim();
|
|
246
|
+
if (cleaned.startsWith('```')) {
|
|
247
|
+
cleaned = cleaned.replace(/^```(?:json)?\s*\n?/, '').replace(/\n?```\s*$/, '');
|
|
248
|
+
}
|
|
249
|
+
|
|
250
|
+
try {
|
|
251
|
+
return JSON.parse(cleaned);
|
|
252
|
+
} catch {
|
|
253
|
+
const match = cleaned.match(/\{[\s\S]*\}/);
|
|
254
|
+
if (match) {
|
|
255
|
+
return JSON.parse(match[0]);
|
|
256
|
+
}
|
|
257
|
+
throw new Error(`Failed to parse AI response as JSON: ${text.slice(0, 200)}`);
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
|
|
261
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
262
|
+
private async loadSdk(): Promise<new () => any> {
|
|
263
|
+
try {
|
|
264
|
+
// @ts-expect-error -- optional peer dep, loaded at runtime
|
|
265
|
+
const mod = await import('@anthropic-ai/sdk');
|
|
266
|
+
return mod.default ?? mod.Anthropic;
|
|
267
|
+
} catch {
|
|
268
|
+
throw new Error(
|
|
269
|
+
'Bot mode requires @anthropic-ai/sdk. Install it:\n npm install @anthropic-ai/sdk',
|
|
270
|
+
);
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
}
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
import { execSync, spawn } from 'node:child_process';
|
|
2
|
+
import { parseStreamLine, extractTextFromChunks } from './cli-stream-parser.js';
|
|
3
|
+
import type { ProviderInfo, StreamChunk } from './types.js';
|
|
4
|
+
|
|
5
|
+
// Strip CLAUDECODE from child env so nested claude CLI invocations work.
|
|
6
|
+
const childEnv = { ...process.env };
|
|
7
|
+
delete childEnv.CLAUDECODE;
|
|
8
|
+
|
|
9
|
+
export function callCli(provider: string, prompt: string, model?: string): string {
|
|
10
|
+
if (provider === 'claude-cli') {
|
|
11
|
+
const modelFlag = model ? ` --model ${model}` : '';
|
|
12
|
+
return execSync(`claude -p --output-format text${modelFlag}`, {
|
|
13
|
+
input: prompt, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'], timeout: 300_000, env: childEnv,
|
|
14
|
+
}).trim();
|
|
15
|
+
}
|
|
16
|
+
if (provider === 'copilot-cli') {
|
|
17
|
+
return execSync('copilot -p --silent --allow-all-tools', {
|
|
18
|
+
input: prompt, encoding: 'utf-8', stdio: ['pipe', 'pipe', 'pipe'], timeout: 300_000, env: childEnv,
|
|
19
|
+
}).trim();
|
|
20
|
+
}
|
|
21
|
+
throw new Error(`Unknown CLI provider: ${provider}`);
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
export async function callCliAsync(provider: string, prompt: string, model?: string): Promise<string> {
|
|
25
|
+
if (provider === 'copilot-cli') {
|
|
26
|
+
return callCli(provider, prompt, model);
|
|
27
|
+
}
|
|
28
|
+
if (provider !== 'claude-cli') {
|
|
29
|
+
throw new Error(`Unknown CLI provider: ${provider}`);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const args = ['-p', '--output-format', 'stream-json'];
|
|
33
|
+
if (model) args.push('--model', model);
|
|
34
|
+
|
|
35
|
+
const child = spawn('claude', args, {
|
|
36
|
+
stdio: ['pipe', 'pipe', 'pipe'],
|
|
37
|
+
env: childEnv,
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
child.stdin.write(prompt);
|
|
41
|
+
child.stdin.end();
|
|
42
|
+
|
|
43
|
+
const timeout = setTimeout(() => child.kill('SIGTERM'), 300_000);
|
|
44
|
+
|
|
45
|
+
const chunks: StreamChunk[] = [];
|
|
46
|
+
let buffer = '';
|
|
47
|
+
|
|
48
|
+
try {
|
|
49
|
+
for await (const data of child.stdout) {
|
|
50
|
+
buffer += data.toString();
|
|
51
|
+
const lines = buffer.split('\n');
|
|
52
|
+
buffer = lines.pop()!;
|
|
53
|
+
|
|
54
|
+
for (const line of lines) {
|
|
55
|
+
const chunk = parseStreamLine(line);
|
|
56
|
+
if (chunk) chunks.push(chunk);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
if (buffer.trim()) {
|
|
61
|
+
const chunk = parseStreamLine(buffer);
|
|
62
|
+
if (chunk) chunks.push(chunk);
|
|
63
|
+
}
|
|
64
|
+
} finally {
|
|
65
|
+
clearTimeout(timeout);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
await new Promise<void>((resolve, reject) => {
|
|
69
|
+
child.on('close', (code) => {
|
|
70
|
+
if (code && code !== 0) reject(new Error(`claude CLI exited with code ${code}`));
|
|
71
|
+
else resolve();
|
|
72
|
+
});
|
|
73
|
+
child.on('error', reject);
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
return extractTextFromChunks(chunks);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
export async function callApi(
|
|
80
|
+
apiKey: string, model: string, maxTokens: number,
|
|
81
|
+
systemPrompt: string, userPrompt: string,
|
|
82
|
+
): Promise<string> {
|
|
83
|
+
const body = JSON.stringify({
|
|
84
|
+
model, max_tokens: maxTokens, system: systemPrompt,
|
|
85
|
+
messages: [{ role: 'user', content: userPrompt }],
|
|
86
|
+
});
|
|
87
|
+
const response = await fetch('https://api.anthropic.com/v1/messages', {
|
|
88
|
+
method: 'POST',
|
|
89
|
+
headers: { 'x-api-key': apiKey, 'anthropic-version': '2023-06-01', 'content-type': 'application/json' },
|
|
90
|
+
body,
|
|
91
|
+
});
|
|
92
|
+
if (!response.ok) {
|
|
93
|
+
const text = await response.text();
|
|
94
|
+
throw new Error(`Anthropic API error ${response.status}: ${text.slice(0, 200)}`);
|
|
95
|
+
}
|
|
96
|
+
const json = await response.json() as { content: Array<{ type: string; text: string }> };
|
|
97
|
+
return json.content[0]?.text ?? '';
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
/**
|
|
101
|
+
* Call the platform-injected AI proxy (routes through IPC to the host process).
|
|
102
|
+
* Available when running inside the Studio sandbox.
|
|
103
|
+
*/
|
|
104
|
+
export async function callPlatform(
|
|
105
|
+
systemPrompt: string,
|
|
106
|
+
userPrompt: string,
|
|
107
|
+
model?: string,
|
|
108
|
+
maxTokens?: number,
|
|
109
|
+
): Promise<string> {
|
|
110
|
+
const provider = (globalThis as any).__fw_llm_provider__;
|
|
111
|
+
if (!provider) throw new Error('Platform AI provider not available');
|
|
112
|
+
const messages = [
|
|
113
|
+
{ role: 'system', content: systemPrompt },
|
|
114
|
+
{ role: 'user', content: userPrompt },
|
|
115
|
+
];
|
|
116
|
+
const response = await provider.chat(messages, { model, maxTokens });
|
|
117
|
+
return response.content ?? '';
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
/**
|
|
121
|
+
* Unified AI call that dispatches to the right backend based on provider type.
|
|
122
|
+
*/
|
|
123
|
+
export async function callAI(
|
|
124
|
+
pInfo: Pick<ProviderInfo, 'type' | 'apiKey' | 'model' | 'maxTokens'>,
|
|
125
|
+
systemPrompt: string,
|
|
126
|
+
userPrompt: string,
|
|
127
|
+
defaultMaxTokens = 4096,
|
|
128
|
+
): Promise<string> {
|
|
129
|
+
if (pInfo.type === 'platform') {
|
|
130
|
+
return callPlatform(systemPrompt, userPrompt, pInfo.model, pInfo.maxTokens ?? defaultMaxTokens);
|
|
131
|
+
}
|
|
132
|
+
if (pInfo.type === 'anthropic') {
|
|
133
|
+
return callApi(
|
|
134
|
+
pInfo.apiKey!,
|
|
135
|
+
pInfo.model ?? 'claude-sonnet-4-6',
|
|
136
|
+
pInfo.maxTokens ?? defaultMaxTokens,
|
|
137
|
+
systemPrompt,
|
|
138
|
+
userPrompt,
|
|
139
|
+
);
|
|
140
|
+
}
|
|
141
|
+
return callCli(pInfo.type, systemPrompt + '\n\n' + userPrompt, pInfo.model);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
export function parseJsonResponse(text: string): Record<string, unknown> {
|
|
145
|
+
let cleaned = text.trim();
|
|
146
|
+
if (cleaned.startsWith('```')) {
|
|
147
|
+
cleaned = cleaned.replace(/^```(?:json)?\s*\n?/, '').replace(/\n?```\s*$/, '');
|
|
148
|
+
}
|
|
149
|
+
try { return JSON.parse(cleaned); } catch { /* fallthrough */ }
|
|
150
|
+
const match = cleaned.match(/\{[\s\S]*\}/);
|
|
151
|
+
if (match) return JSON.parse(match[0]);
|
|
152
|
+
throw new Error(`Failed to parse AI response as JSON: ${text.slice(0, 200)}`);
|
|
153
|
+
}
|