@slaw-ai/server 2026.611.0
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 +26 -0
- package/dist/adapters/builtin-adapter-types.d.ts +5 -0
- package/dist/adapters/builtin-adapter-types.d.ts.map +1 -0
- package/dist/adapters/builtin-adapter-types.js +18 -0
- package/dist/adapters/builtin-adapter-types.js.map +1 -0
- package/dist/adapters/codex-models.d.ts +5 -0
- package/dist/adapters/codex-models.d.ts.map +1 -0
- package/dist/adapters/codex-models.js +105 -0
- package/dist/adapters/codex-models.js.map +1 -0
- package/dist/adapters/cursor-models.d.ts +13 -0
- package/dist/adapters/cursor-models.d.ts.map +1 -0
- package/dist/adapters/cursor-models.js +148 -0
- package/dist/adapters/cursor-models.js.map +1 -0
- package/dist/adapters/http/execute.d.ts +3 -0
- package/dist/adapters/http/execute.d.ts.map +1 -0
- package/dist/adapters/http/execute.js +51 -0
- package/dist/adapters/http/execute.js.map +1 -0
- package/dist/adapters/http/execute.test.d.ts +2 -0
- package/dist/adapters/http/execute.test.d.ts.map +1 -0
- package/dist/adapters/http/execute.test.js +40 -0
- package/dist/adapters/http/execute.test.js.map +1 -0
- package/dist/adapters/http/index.d.ts +3 -0
- package/dist/adapters/http/index.d.ts.map +1 -0
- package/dist/adapters/http/index.js +20 -0
- package/dist/adapters/http/index.js.map +1 -0
- package/dist/adapters/http/test.d.ts +3 -0
- package/dist/adapters/http/test.d.ts.map +1 -0
- package/dist/adapters/http/test.js +106 -0
- package/dist/adapters/http/test.js.map +1 -0
- package/dist/adapters/index.d.ts +4 -0
- package/dist/adapters/index.d.ts.map +1 -0
- package/dist/adapters/index.js +3 -0
- package/dist/adapters/index.js.map +1 -0
- package/dist/adapters/plugin-loader.d.ts +28 -0
- package/dist/adapters/plugin-loader.d.ts.map +1 -0
- package/dist/adapters/plugin-loader.js +196 -0
- package/dist/adapters/plugin-loader.js.map +1 -0
- package/dist/adapters/process/execute.d.ts +3 -0
- package/dist/adapters/process/execute.d.ts.map +1 -0
- package/dist/adapters/process/execute.js +70 -0
- package/dist/adapters/process/execute.js.map +1 -0
- package/dist/adapters/process/index.d.ts +3 -0
- package/dist/adapters/process/index.d.ts.map +1 -0
- package/dist/adapters/process/index.js +23 -0
- package/dist/adapters/process/index.js.map +1 -0
- package/dist/adapters/process/test.d.ts +3 -0
- package/dist/adapters/process/test.d.ts.map +1 -0
- package/dist/adapters/process/test.js +77 -0
- package/dist/adapters/process/test.js.map +1 -0
- package/dist/adapters/registry.d.ts +69 -0
- package/dist/adapters/registry.d.ts.map +1 -0
- package/dist/adapters/registry.js +598 -0
- package/dist/adapters/registry.js.map +1 -0
- package/dist/adapters/types.d.ts +2 -0
- package/dist/adapters/types.d.ts.map +1 -0
- package/dist/adapters/types.js +2 -0
- package/dist/adapters/types.js.map +1 -0
- package/dist/adapters/utils.d.ts +43 -0
- package/dist/adapters/utils.d.ts.map +1 -0
- package/dist/adapters/utils.js +52 -0
- package/dist/adapters/utils.js.map +1 -0
- package/dist/agent-auth-jwt.d.ts +14 -0
- package/dist/agent-auth-jwt.d.ts.map +1 -0
- package/dist/agent-auth-jwt.js +117 -0
- package/dist/agent-auth-jwt.js.map +1 -0
- package/dist/app.d.ts +39 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.js +386 -0
- package/dist/app.js.map +1 -0
- package/dist/attachment-types.d.ts +23 -0
- package/dist/attachment-types.d.ts.map +1 -0
- package/dist/attachment-types.js +98 -0
- package/dist/attachment-types.js.map +1 -0
- package/dist/auth/better-auth.d.ts +40 -0
- package/dist/auth/better-auth.d.ts.map +1 -0
- package/dist/auth/better-auth.js +148 -0
- package/dist/auth/better-auth.js.map +1 -0
- package/dist/config-file.d.ts +24 -0
- package/dist/config-file.d.ts.map +1 -0
- package/dist/config-file.js +73 -0
- package/dist/config-file.js.map +1 -0
- package/dist/config.d.ts +44 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +247 -0
- package/dist/config.js.map +1 -0
- package/dist/dev-runner-worktree.d.ts +15 -0
- package/dist/dev-runner-worktree.d.ts.map +1 -0
- package/dist/dev-runner-worktree.js +101 -0
- package/dist/dev-runner-worktree.js.map +1 -0
- package/dist/dev-server-status.d.ts +33 -0
- package/dist/dev-server-status.d.ts.map +1 -0
- package/dist/dev-server-status.js +89 -0
- package/dist/dev-server-status.js.map +1 -0
- package/dist/dev-watch-ignore.d.ts +2 -0
- package/dist/dev-watch-ignore.d.ts.map +1 -0
- package/dist/dev-watch-ignore.js +36 -0
- package/dist/dev-watch-ignore.js.map +1 -0
- package/dist/errors.d.ts +12 -0
- package/dist/errors.d.ts.map +1 -0
- package/dist/errors.js +28 -0
- package/dist/errors.js.map +1 -0
- package/dist/first-admin-claim.d.ts +17 -0
- package/dist/first-admin-claim.d.ts.map +1 -0
- package/dist/first-admin-claim.js +30 -0
- package/dist/first-admin-claim.js.map +1 -0
- package/dist/home-paths.d.ts +15 -0
- package/dist/home-paths.d.ts.map +1 -0
- package/dist/home-paths.js +48 -0
- package/dist/home-paths.js.map +1 -0
- package/dist/http/body-limits.d.ts +4 -0
- package/dist/http/body-limits.d.ts.map +1 -0
- package/dist/http/body-limits.js +4 -0
- package/dist/http/body-limits.js.map +1 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +786 -0
- package/dist/index.js.map +1 -0
- package/dist/instance-claim.d.ts +23 -0
- package/dist/instance-claim.d.ts.map +1 -0
- package/dist/instance-claim.js +126 -0
- package/dist/instance-claim.js.map +1 -0
- package/dist/lib/join-request-dedupe.d.ts +11 -0
- package/dist/lib/join-request-dedupe.d.ts.map +1 -0
- package/dist/lib/join-request-dedupe.js +49 -0
- package/dist/lib/join-request-dedupe.js.map +1 -0
- package/dist/log-redaction.d.ts +11 -0
- package/dist/log-redaction.d.ts.map +1 -0
- package/dist/log-redaction.js +122 -0
- package/dist/log-redaction.js.map +1 -0
- package/dist/middleware/auth.d.ts +12 -0
- package/dist/middleware/auth.d.ts.map +1 -0
- package/dist/middleware/auth.js +302 -0
- package/dist/middleware/auth.js.map +1 -0
- package/dist/middleware/error-handler.d.ts +17 -0
- package/dist/middleware/error-handler.d.ts.map +1 -0
- package/dist/middleware/error-handler.js +46 -0
- package/dist/middleware/error-handler.js.map +1 -0
- package/dist/middleware/http-log-policy.d.ts +2 -0
- package/dist/middleware/http-log-policy.d.ts.map +1 -0
- package/dist/middleware/http-log-policy.js +52 -0
- package/dist/middleware/http-log-policy.js.map +1 -0
- package/dist/middleware/index.d.ts +4 -0
- package/dist/middleware/index.d.ts.map +1 -0
- package/dist/middleware/index.js +4 -0
- package/dist/middleware/index.js.map +1 -0
- package/dist/middleware/logger.d.ts +4 -0
- package/dist/middleware/logger.d.ts.map +1 -0
- package/dist/middleware/logger.js +92 -0
- package/dist/middleware/logger.js.map +1 -0
- package/dist/middleware/operator-mutation-guard.d.ts +3 -0
- package/dist/middleware/operator-mutation-guard.d.ts.map +1 -0
- package/dist/middleware/operator-mutation-guard.js +70 -0
- package/dist/middleware/operator-mutation-guard.js.map +1 -0
- package/dist/middleware/private-hostname-guard.d.ts +11 -0
- package/dist/middleware/private-hostname-guard.d.ts.map +1 -0
- package/dist/middleware/private-hostname-guard.js +78 -0
- package/dist/middleware/private-hostname-guard.js.map +1 -0
- package/dist/middleware/validate.d.ts +4 -0
- package/dist/middleware/validate.d.ts.map +1 -0
- package/dist/middleware/validate.js +7 -0
- package/dist/middleware/validate.js.map +1 -0
- package/dist/onboarding-assets/default/AGENTS.md +18 -0
- package/dist/onboarding-assets/squad_lead/AGENTS.md +61 -0
- package/dist/onboarding-assets/squad_lead/HEARTBEAT.md +85 -0
- package/dist/onboarding-assets/squad_lead/SOUL.md +33 -0
- package/dist/onboarding-assets/squad_lead/TOOLS.md +3 -0
- package/dist/paths.d.ts +3 -0
- package/dist/paths.d.ts.map +1 -0
- package/dist/paths.js +31 -0
- package/dist/paths.js.map +1 -0
- package/dist/realtime/live-events-ws.d.ts +28 -0
- package/dist/realtime/live-events-ws.d.ts.map +1 -0
- package/dist/realtime/live-events-ws.js +187 -0
- package/dist/realtime/live-events-ws.js.map +1 -0
- package/dist/redaction.d.ts +5 -0
- package/dist/redaction.d.ts.map +1 -0
- package/dist/redaction.js +125 -0
- package/dist/redaction.js.map +1 -0
- package/dist/routes/access.d.ts +75 -0
- package/dist/routes/access.d.ts.map +1 -0
- package/dist/routes/access.js +3070 -0
- package/dist/routes/access.js.map +1 -0
- package/dist/routes/activity.d.ts +3 -0
- package/dist/routes/activity.d.ts.map +1 -0
- package/dist/routes/activity.js +90 -0
- package/dist/routes/activity.js.map +1 -0
- package/dist/routes/adapters.d.ts +16 -0
- package/dist/routes/adapters.d.ts.map +1 -0
- package/dist/routes/adapters.js +539 -0
- package/dist/routes/adapters.js.map +1 -0
- package/dist/routes/agents.d.ts +6 -0
- package/dist/routes/agents.d.ts.map +1 -0
- package/dist/routes/agents.js +2733 -0
- package/dist/routes/agents.js.map +1 -0
- package/dist/routes/approvals.d.ts +6 -0
- package/dist/routes/approvals.d.ts.map +1 -0
- package/dist/routes/approvals.js +300 -0
- package/dist/routes/approvals.js.map +1 -0
- package/dist/routes/assets.d.ts +4 -0
- package/dist/routes/assets.d.ts.map +1 -0
- package/dist/routes/assets.js +309 -0
- package/dist/routes/assets.js.map +1 -0
- package/dist/routes/auth.d.ts +3 -0
- package/dist/routes/auth.d.ts.map +1 -0
- package/dist/routes/auth.js +82 -0
- package/dist/routes/auth.js.map +1 -0
- package/dist/routes/authz.d.ts +19 -0
- package/dist/routes/authz.d.ts.map +1 -0
- package/dist/routes/authz.js +75 -0
- package/dist/routes/authz.js.map +1 -0
- package/dist/routes/botfather.d.ts +9 -0
- package/dist/routes/botfather.d.ts.map +1 -0
- package/dist/routes/botfather.js +127 -0
- package/dist/routes/botfather.js.map +1 -0
- package/dist/routes/cloud-upstreams.d.ts +5 -0
- package/dist/routes/cloud-upstreams.d.ts.map +1 -0
- package/dist/routes/cloud-upstreams.js +103 -0
- package/dist/routes/cloud-upstreams.js.map +1 -0
- package/dist/routes/costs.d.ts +11 -0
- package/dist/routes/costs.d.ts.map +1 -0
- package/dist/routes/costs.js +285 -0
- package/dist/routes/costs.js.map +1 -0
- package/dist/routes/dashboard.d.ts +3 -0
- package/dist/routes/dashboard.d.ts.map +1 -0
- package/dist/routes/dashboard.js +15 -0
- package/dist/routes/dashboard.js.map +1 -0
- package/dist/routes/environment-selection.d.ts +13 -0
- package/dist/routes/environment-selection.d.ts.map +1 -0
- package/dist/routes/environment-selection.js +30 -0
- package/dist/routes/environment-selection.js.map +1 -0
- package/dist/routes/environments.d.ts +6 -0
- package/dist/routes/environments.d.ts.map +1 -0
- package/dist/routes/environments.js +414 -0
- package/dist/routes/environments.js.map +1 -0
- package/dist/routes/execution-workspaces.d.ts +3 -0
- package/dist/routes/execution-workspaces.d.ts.map +1 -0
- package/dist/routes/execution-workspaces.js +537 -0
- package/dist/routes/execution-workspaces.js.map +1 -0
- package/dist/routes/goals.d.ts +3 -0
- package/dist/routes/goals.d.ts.map +1 -0
- package/dist/routes/goals.js +95 -0
- package/dist/routes/goals.js.map +1 -0
- package/dist/routes/health.d.ts +9 -0
- package/dist/routes/health.d.ts.map +1 -0
- package/dist/routes/health.js +143 -0
- package/dist/routes/health.js.map +1 -0
- package/dist/routes/inbox-dismissals.d.ts +3 -0
- package/dist/routes/inbox-dismissals.d.ts.map +1 -0
- package/dist/routes/inbox-dismissals.js +58 -0
- package/dist/routes/inbox-dismissals.js.map +1 -0
- package/dist/routes/index.d.ts +24 -0
- package/dist/routes/index.d.ts.map +1 -0
- package/dist/routes/index.js +24 -0
- package/dist/routes/index.js.map +1 -0
- package/dist/routes/instance-database-backups.d.ts +15 -0
- package/dist/routes/instance-database-backups.d.ts.map +1 -0
- package/dist/routes/instance-database-backups.js +12 -0
- package/dist/routes/instance-database-backups.js.map +1 -0
- package/dist/routes/instance-settings.d.ts +3 -0
- package/dist/routes/instance-settings.d.ts.map +1 -0
- package/dist/routes/instance-settings.js +110 -0
- package/dist/routes/instance-settings.js.map +1 -0
- package/dist/routes/issue-tree-control.d.ts +3 -0
- package/dist/routes/issue-tree-control.d.ts.map +1 -0
- package/dist/routes/issue-tree-control.js +373 -0
- package/dist/routes/issue-tree-control.js.map +1 -0
- package/dist/routes/issues-checkout-wakeup.d.ts +9 -0
- package/dist/routes/issues-checkout-wakeup.d.ts.map +1 -0
- package/dist/routes/issues-checkout-wakeup.js +12 -0
- package/dist/routes/issues-checkout-wakeup.js.map +1 -0
- package/dist/routes/issues.d.ts +15 -0
- package/dist/routes/issues.d.ts.map +1 -0
- package/dist/routes/issues.js +5276 -0
- package/dist/routes/issues.js.map +1 -0
- package/dist/routes/llms.d.ts +3 -0
- package/dist/routes/llms.d.ts.map +1 -0
- package/dist/routes/llms.js +80 -0
- package/dist/routes/llms.js.map +1 -0
- package/dist/routes/openapi.d.ts +4 -0
- package/dist/routes/openapi.d.ts.map +1 -0
- package/dist/routes/openapi.js +3284 -0
- package/dist/routes/openapi.js.map +1 -0
- package/dist/routes/org-chart-svg.d.ts +25 -0
- package/dist/routes/org-chart-svg.d.ts.map +1 -0
- package/dist/routes/org-chart-svg.js +656 -0
- package/dist/routes/org-chart-svg.js.map +1 -0
- package/dist/routes/plugin-ui-static.d.ts +69 -0
- package/dist/routes/plugin-ui-static.d.ts.map +1 -0
- package/dist/routes/plugin-ui-static.js +411 -0
- package/dist/routes/plugin-ui-static.js.map +1 -0
- package/dist/routes/plugins.d.ts +121 -0
- package/dist/routes/plugins.d.ts.map +1 -0
- package/dist/routes/plugins.js +2390 -0
- package/dist/routes/plugins.js.map +1 -0
- package/dist/routes/projects.d.ts +3 -0
- package/dist/routes/projects.d.ts.map +1 -0
- package/dist/routes/projects.js +566 -0
- package/dist/routes/projects.js.map +1 -0
- package/dist/routes/resource-memberships.d.ts +3 -0
- package/dist/routes/resource-memberships.d.ts.map +1 -0
- package/dist/routes/resource-memberships.js +97 -0
- package/dist/routes/resource-memberships.js.map +1 -0
- package/dist/routes/routines.d.ts +6 -0
- package/dist/routes/routines.d.ts.map +1 -0
- package/dist/routes/routines.js +411 -0
- package/dist/routes/routines.js.map +1 -0
- package/dist/routes/secrets.d.ts +3 -0
- package/dist/routes/secrets.d.ts.map +1 -0
- package/dist/routes/secrets.js +419 -0
- package/dist/routes/secrets.js.map +1 -0
- package/dist/routes/sidebar-badges.d.ts +3 -0
- package/dist/routes/sidebar-badges.d.ts.map +1 -0
- package/dist/routes/sidebar-badges.js +68 -0
- package/dist/routes/sidebar-badges.js.map +1 -0
- package/dist/routes/sidebar-preferences.d.ts +3 -0
- package/dist/routes/sidebar-preferences.d.ts.map +1 -0
- package/dist/routes/sidebar-preferences.js +63 -0
- package/dist/routes/sidebar-preferences.js.map +1 -0
- package/dist/routes/squad-import-paths.d.ts +3 -0
- package/dist/routes/squad-import-paths.d.ts.map +1 -0
- package/dist/routes/squad-import-paths.js +3 -0
- package/dist/routes/squad-import-paths.js.map +1 -0
- package/dist/routes/squad-skills.d.ts +3 -0
- package/dist/routes/squad-skills.d.ts.map +1 -0
- package/dist/routes/squad-skills.js +366 -0
- package/dist/routes/squad-skills.js.map +1 -0
- package/dist/routes/squads.d.ts +4 -0
- package/dist/routes/squads.d.ts.map +1 -0
- package/dist/routes/squads.js +450 -0
- package/dist/routes/squads.js.map +1 -0
- package/dist/routes/user-profiles.d.ts +3 -0
- package/dist/routes/user-profiles.d.ts.map +1 -0
- package/dist/routes/user-profiles.js +337 -0
- package/dist/routes/user-profiles.js.map +1 -0
- package/dist/routes/workspace-command-authz.d.ts +14 -0
- package/dist/routes/workspace-command-authz.d.ts.map +1 -0
- package/dist/routes/workspace-command-authz.js +83 -0
- package/dist/routes/workspace-command-authz.js.map +1 -0
- package/dist/routes/workspace-runtime-service-authz.d.ts +12 -0
- package/dist/routes/workspace-runtime-service-authz.d.ts.map +1 -0
- package/dist/routes/workspace-runtime-service-authz.js +96 -0
- package/dist/routes/workspace-runtime-service-authz.js.map +1 -0
- package/dist/runtime-api.d.ts +19 -0
- package/dist/runtime-api.d.ts.map +1 -0
- package/dist/runtime-api.js +137 -0
- package/dist/runtime-api.js.map +1 -0
- package/dist/secrets/aws-secrets-manager-provider.d.ts +87 -0
- package/dist/secrets/aws-secrets-manager-provider.d.ts.map +1 -0
- package/dist/secrets/aws-secrets-manager-provider.js +964 -0
- package/dist/secrets/aws-secrets-manager-provider.js.map +1 -0
- package/dist/secrets/configured-provider.d.ts +3 -0
- package/dist/secrets/configured-provider.d.ts.map +1 -0
- package/dist/secrets/configured-provider.js +8 -0
- package/dist/secrets/configured-provider.js.map +1 -0
- package/dist/secrets/external-stub-providers.d.ts +5 -0
- package/dist/secrets/external-stub-providers.d.ts.map +1 -0
- package/dist/secrets/external-stub-providers.js +71 -0
- package/dist/secrets/external-stub-providers.js.map +1 -0
- package/dist/secrets/local-encrypted-provider.d.ts +3 -0
- package/dist/secrets/local-encrypted-provider.d.ts.map +1 -0
- package/dist/secrets/local-encrypted-provider.js +244 -0
- package/dist/secrets/local-encrypted-provider.js.map +1 -0
- package/dist/secrets/provider-registry.d.ts +6 -0
- package/dist/secrets/provider-registry.d.ts.map +1 -0
- package/dist/secrets/provider-registry.js +24 -0
- package/dist/secrets/provider-registry.js.map +1 -0
- package/dist/secrets/types.d.ts +138 -0
- package/dist/secrets/types.d.ts.map +1 -0
- package/dist/secrets/types.js +36 -0
- package/dist/secrets/types.js.map +1 -0
- package/dist/services/access.d.ts +184 -0
- package/dist/services/access.d.ts.map +1 -0
- package/dist/services/access.js +542 -0
- package/dist/services/access.js.map +1 -0
- package/dist/services/activity-log.d.ts +19 -0
- package/dist/services/activity-log.d.ts.map +1 -0
- package/dist/services/activity-log.js +99 -0
- package/dist/services/activity-log.js.map +1 -0
- package/dist/services/activity.d.ts +462 -0
- package/dist/services/activity.d.ts.map +1 -0
- package/dist/services/activity.js +443 -0
- package/dist/services/activity.js.map +1 -0
- package/dist/services/adapter-plugin-store.d.ts +36 -0
- package/dist/services/adapter-plugin-store.d.ts.map +1 -0
- package/dist/services/adapter-plugin-store.js +154 -0
- package/dist/services/adapter-plugin-store.js.map +1 -0
- package/dist/services/agent-instructions.d.ts +91 -0
- package/dist/services/agent-instructions.d.ts.map +1 -0
- package/dist/services/agent-instructions.js +580 -0
- package/dist/services/agent-instructions.js.map +1 -0
- package/dist/services/agent-permissions.d.ts +6 -0
- package/dist/services/agent-permissions.d.ts.map +1 -0
- package/dist/services/agent-permissions.js +20 -0
- package/dist/services/agent-permissions.js.map +1 -0
- package/dist/services/agent-start-lock.d.ts +2 -0
- package/dist/services/agent-start-lock.d.ts.map +1 -0
- package/dist/services/agent-start-lock.js +43 -0
- package/dist/services/agent-start-lock.js.map +1 -0
- package/dist/services/agents.d.ts +2253 -0
- package/dist/services/agents.d.ts.map +1 -0
- package/dist/services/agents.js +609 -0
- package/dist/services/agents.js.map +1 -0
- package/dist/services/approvals.d.ts +546 -0
- package/dist/services/approvals.d.ts.map +1 -0
- package/dist/services/approvals.js +212 -0
- package/dist/services/approvals.js.map +1 -0
- package/dist/services/assets.d.ts +33 -0
- package/dist/services/assets.d.ts.map +1 -0
- package/dist/services/assets.js +17 -0
- package/dist/services/assets.js.map +1 -0
- package/dist/services/authorization.d.ts +67 -0
- package/dist/services/authorization.d.ts.map +1 -0
- package/dist/services/authorization.js +608 -0
- package/dist/services/authorization.js.map +1 -0
- package/dist/services/botfather/authoring-lock.d.ts +17 -0
- package/dist/services/botfather/authoring-lock.d.ts.map +1 -0
- package/dist/services/botfather/authoring-lock.js +23 -0
- package/dist/services/botfather/authoring-lock.js.map +1 -0
- package/dist/services/botfather/authoring-lock.test.d.ts +2 -0
- package/dist/services/botfather/authoring-lock.test.d.ts.map +1 -0
- package/dist/services/botfather/authoring-lock.test.js +25 -0
- package/dist/services/botfather/authoring-lock.test.js.map +1 -0
- package/dist/services/botfather/client.d.ts +26 -0
- package/dist/services/botfather/client.d.ts.map +1 -0
- package/dist/services/botfather/client.js +113 -0
- package/dist/services/botfather/client.js.map +1 -0
- package/dist/services/botfather/credentials.d.ts +15 -0
- package/dist/services/botfather/credentials.d.ts.map +1 -0
- package/dist/services/botfather/credentials.js +39 -0
- package/dist/services/botfather/credentials.js.map +1 -0
- package/dist/services/botfather/enrollment.d.ts +49 -0
- package/dist/services/botfather/enrollment.d.ts.map +1 -0
- package/dist/services/botfather/enrollment.js +145 -0
- package/dist/services/botfather/enrollment.js.map +1 -0
- package/dist/services/botfather/instance-limit-enforcement.d.ts +44 -0
- package/dist/services/botfather/instance-limit-enforcement.d.ts.map +1 -0
- package/dist/services/botfather/instance-limit-enforcement.js +83 -0
- package/dist/services/botfather/instance-limit-enforcement.js.map +1 -0
- package/dist/services/botfather/instance-limit-enforcement.test.d.ts +2 -0
- package/dist/services/botfather/instance-limit-enforcement.test.d.ts.map +1 -0
- package/dist/services/botfather/instance-limit-enforcement.test.js +66 -0
- package/dist/services/botfather/instance-limit-enforcement.test.js.map +1 -0
- package/dist/services/botfather/limits-store.d.ts +36 -0
- package/dist/services/botfather/limits-store.d.ts.map +1 -0
- package/dist/services/botfather/limits-store.js +94 -0
- package/dist/services/botfather/limits-store.js.map +1 -0
- package/dist/services/botfather/limits-store.test.d.ts +2 -0
- package/dist/services/botfather/limits-store.test.d.ts.map +1 -0
- package/dist/services/botfather/limits-store.test.js +70 -0
- package/dist/services/botfather/limits-store.test.js.map +1 -0
- package/dist/services/botfather/reporter.d.ts +41 -0
- package/dist/services/botfather/reporter.d.ts.map +1 -0
- package/dist/services/botfather/reporter.js +448 -0
- package/dist/services/botfather/reporter.js.map +1 -0
- package/dist/services/botfather/service.d.ts +84 -0
- package/dist/services/botfather/service.d.ts.map +1 -0
- package/dist/services/botfather/service.js +229 -0
- package/dist/services/botfather/service.js.map +1 -0
- package/dist/services/botfather/service.test.d.ts +2 -0
- package/dist/services/botfather/service.test.d.ts.map +1 -0
- package/dist/services/botfather/service.test.js +120 -0
- package/dist/services/botfather/service.test.js.map +1 -0
- package/dist/services/botfather/skill-catalog.d.ts +28 -0
- package/dist/services/botfather/skill-catalog.d.ts.map +1 -0
- package/dist/services/botfather/skill-catalog.js +101 -0
- package/dist/services/botfather/skill-catalog.js.map +1 -0
- package/dist/services/botfather/skill-catalog.test.d.ts +2 -0
- package/dist/services/botfather/skill-catalog.test.d.ts.map +1 -0
- package/dist/services/botfather/skill-catalog.test.js +151 -0
- package/dist/services/botfather/skill-catalog.test.js.map +1 -0
- package/dist/services/budgets.d.ts +38 -0
- package/dist/services/budgets.d.ts.map +1 -0
- package/dist/services/budgets.js +833 -0
- package/dist/services/budgets.js.map +1 -0
- package/dist/services/catalog-provenance.d.ts +7 -0
- package/dist/services/catalog-provenance.d.ts.map +1 -0
- package/dist/services/catalog-provenance.js +64 -0
- package/dist/services/catalog-provenance.js.map +1 -0
- package/dist/services/cloud-upstreams.d.ts +42 -0
- package/dist/services/cloud-upstreams.d.ts.map +1 -0
- package/dist/services/cloud-upstreams.js +1071 -0
- package/dist/services/cloud-upstreams.js.map +1 -0
- package/dist/services/costs.d.ts +127 -0
- package/dist/services/costs.d.ts.map +1 -0
- package/dist/services/costs.js +409 -0
- package/dist/services/costs.js.map +1 -0
- package/dist/services/cron.d.ts +80 -0
- package/dist/services/cron.d.ts.map +1 -0
- package/dist/services/cron.js +300 -0
- package/dist/services/cron.js.map +1 -0
- package/dist/services/dashboard.d.ts +34 -0
- package/dist/services/dashboard.d.ts.map +1 -0
- package/dist/services/dashboard.js +142 -0
- package/dist/services/dashboard.js.map +1 -0
- package/dist/services/default-agent-instructions.d.ts +9 -0
- package/dist/services/default-agent-instructions.d.ts.map +1 -0
- package/dist/services/default-agent-instructions.js +20 -0
- package/dist/services/default-agent-instructions.js.map +1 -0
- package/dist/services/document-annotations.d.ts +160 -0
- package/dist/services/document-annotations.d.ts.map +1 -0
- package/dist/services/document-annotations.js +324 -0
- package/dist/services/document-annotations.js.map +1 -0
- package/dist/services/documents.d.ts +347 -0
- package/dist/services/documents.d.ts.map +1 -0
- package/dist/services/documents.js +638 -0
- package/dist/services/documents.js.map +1 -0
- package/dist/services/environment-config.d.ts +55 -0
- package/dist/services/environment-config.d.ts.map +1 -0
- package/dist/services/environment-config.js +441 -0
- package/dist/services/environment-config.js.map +1 -0
- package/dist/services/environment-execution-target.d.ts +21 -0
- package/dist/services/environment-execution-target.d.ts.map +1 -0
- package/dist/services/environment-execution-target.js +121 -0
- package/dist/services/environment-execution-target.js.map +1 -0
- package/dist/services/environment-probe.d.ts +9 -0
- package/dist/services/environment-probe.d.ts.map +1 -0
- package/dist/services/environment-probe.js +106 -0
- package/dist/services/environment-probe.js.map +1 -0
- package/dist/services/environment-run-orchestrator.d.ts +124 -0
- package/dist/services/environment-run-orchestrator.d.ts.map +1 -0
- package/dist/services/environment-run-orchestrator.js +392 -0
- package/dist/services/environment-run-orchestrator.js.map +1 -0
- package/dist/services/environment-runtime.d.ts +90 -0
- package/dist/services/environment-runtime.d.ts.map +1 -0
- package/dist/services/environment-runtime.js +968 -0
- package/dist/services/environment-runtime.js.map +1 -0
- package/dist/services/environments.d.ts +36 -0
- package/dist/services/environments.d.ts.map +1 -0
- package/dist/services/environments.js +260 -0
- package/dist/services/environments.js.map +1 -0
- package/dist/services/execution-workspace-policy.d.ts +42 -0
- package/dist/services/execution-workspace-policy.d.ts.map +1 -0
- package/dist/services/execution-workspace-policy.js +262 -0
- package/dist/services/execution-workspace-policy.js.map +1 -0
- package/dist/services/execution-workspaces.d.ts +30 -0
- package/dist/services/execution-workspaces.d.ts.map +1 -0
- package/dist/services/execution-workspaces.js +645 -0
- package/dist/services/execution-workspaces.js.map +1 -0
- package/dist/services/finance.d.ts +93 -0
- package/dist/services/finance.d.ts.map +1 -0
- package/dist/services/finance.js +120 -0
- package/dist/services/finance.js.map +1 -0
- package/dist/services/github-fetch.d.ts +4 -0
- package/dist/services/github-fetch.d.ts.map +1 -0
- package/dist/services/github-fetch.js +23 -0
- package/dist/services/github-fetch.js.map +1 -0
- package/dist/services/goals.d.ts +433 -0
- package/dist/services/goals.d.ts.map +1 -0
- package/dist/services/goals.js +54 -0
- package/dist/services/goals.js.map +1 -0
- package/dist/services/heartbeat-circuit-breaker.d.ts +89 -0
- package/dist/services/heartbeat-circuit-breaker.d.ts.map +1 -0
- package/dist/services/heartbeat-circuit-breaker.js +156 -0
- package/dist/services/heartbeat-circuit-breaker.js.map +1 -0
- package/dist/services/heartbeat-circuit-breaker.test.d.ts +2 -0
- package/dist/services/heartbeat-circuit-breaker.test.d.ts.map +1 -0
- package/dist/services/heartbeat-circuit-breaker.test.js +97 -0
- package/dist/services/heartbeat-circuit-breaker.test.js.map +1 -0
- package/dist/services/heartbeat-run-summary.d.ts +7 -0
- package/dist/services/heartbeat-run-summary.d.ts.map +1 -0
- package/dist/services/heartbeat-run-summary.js +84 -0
- package/dist/services/heartbeat-run-summary.js.map +1 -0
- package/dist/services/heartbeat-stop-metadata.d.ts +28 -0
- package/dist/services/heartbeat-stop-metadata.d.ts.map +1 -0
- package/dist/services/heartbeat-stop-metadata.js +86 -0
- package/dist/services/heartbeat-stop-metadata.js.map +1 -0
- package/dist/services/heartbeat-stop-metadata.test.d.ts +2 -0
- package/dist/services/heartbeat-stop-metadata.test.d.ts.map +1 -0
- package/dist/services/heartbeat-stop-metadata.test.js +93 -0
- package/dist/services/heartbeat-stop-metadata.test.js.map +1 -0
- package/dist/services/heartbeat.d.ts +1578 -0
- package/dist/services/heartbeat.d.ts.map +1 -0
- package/dist/services/heartbeat.js +8274 -0
- package/dist/services/heartbeat.js.map +1 -0
- package/dist/services/hire-hook.d.ts +14 -0
- package/dist/services/hire-hook.d.ts.map +1 -0
- package/dist/services/hire-hook.js +85 -0
- package/dist/services/hire-hook.js.map +1 -0
- package/dist/services/inbox-dismissals.d.ts +22 -0
- package/dist/services/inbox-dismissals.d.ts.map +1 -0
- package/dist/services/inbox-dismissals.js +33 -0
- package/dist/services/inbox-dismissals.js.map +1 -0
- package/dist/services/index.d.ts +50 -0
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +49 -0
- package/dist/services/index.js.map +1 -0
- package/dist/services/instance-settings.d.ts +12 -0
- package/dist/services/instance-settings.d.ts.map +1 -0
- package/dist/services/instance-settings.js +142 -0
- package/dist/services/instance-settings.js.map +1 -0
- package/dist/services/invite-grants.d.ts +15 -0
- package/dist/services/invite-grants.d.ts.map +1 -0
- package/dist/services/invite-grants.js +50 -0
- package/dist/services/invite-grants.js.map +1 -0
- package/dist/services/issue-approvals.d.ts +56 -0
- package/dist/services/issue-approvals.d.ts.map +1 -0
- package/dist/services/issue-approvals.js +153 -0
- package/dist/services/issue-approvals.js.map +1 -0
- package/dist/services/issue-assignment-wakeup.d.ts +29 -0
- package/dist/services/issue-assignment-wakeup.d.ts.map +1 -0
- package/dist/services/issue-assignment-wakeup.js +22 -0
- package/dist/services/issue-assignment-wakeup.js.map +1 -0
- package/dist/services/issue-continuation-summary.d.ts +71 -0
- package/dist/services/issue-continuation-summary.d.ts.map +1 -0
- package/dist/services/issue-continuation-summary.js +222 -0
- package/dist/services/issue-continuation-summary.js.map +1 -0
- package/dist/services/issue-execution-policy.d.ts +93 -0
- package/dist/services/issue-execution-policy.d.ts.map +1 -0
- package/dist/services/issue-execution-policy.js +838 -0
- package/dist/services/issue-execution-policy.js.map +1 -0
- package/dist/services/issue-goal-fallback.d.ts +18 -0
- package/dist/services/issue-goal-fallback.d.ts.map +1 -0
- package/dist/services/issue-goal-fallback.js +33 -0
- package/dist/services/issue-goal-fallback.js.map +1 -0
- package/dist/services/issue-liveness.d.ts +3 -0
- package/dist/services/issue-liveness.d.ts.map +1 -0
- package/dist/services/issue-liveness.js +2 -0
- package/dist/services/issue-liveness.js.map +1 -0
- package/dist/services/issue-recovery-actions.d.ts +40 -0
- package/dist/services/issue-recovery-actions.d.ts.map +1 -0
- package/dist/services/issue-recovery-actions.js +204 -0
- package/dist/services/issue-recovery-actions.js.map +1 -0
- package/dist/services/issue-references.d.ts +22 -0
- package/dist/services/issue-references.d.ts.map +1 -0
- package/dist/services/issue-references.js +341 -0
- package/dist/services/issue-references.js.map +1 -0
- package/dist/services/issue-thread-interactions.d.ts +81 -0
- package/dist/services/issue-thread-interactions.d.ts.map +1 -0
- package/dist/services/issue-thread-interactions.js +1017 -0
- package/dist/services/issue-thread-interactions.js.map +1 -0
- package/dist/services/issue-thread-interactions.test.d.ts +2 -0
- package/dist/services/issue-thread-interactions.test.d.ts.map +1 -0
- package/dist/services/issue-thread-interactions.test.js +195 -0
- package/dist/services/issue-thread-interactions.test.js.map +1 -0
- package/dist/services/issue-tree-control.d.ts +89 -0
- package/dist/services/issue-tree-control.d.ts.map +1 -0
- package/dist/services/issue-tree-control.js +933 -0
- package/dist/services/issue-tree-control.js.map +1 -0
- package/dist/services/issues.d.ts +898 -0
- package/dist/services/issues.d.ts.map +1 -0
- package/dist/services/issues.js +4705 -0
- package/dist/services/issues.js.map +1 -0
- package/dist/services/json-schema-secret-refs.d.ts +5 -0
- package/dist/services/json-schema-secret-refs.d.ts.map +1 -0
- package/dist/services/json-schema-secret-refs.js +67 -0
- package/dist/services/json-schema-secret-refs.js.map +1 -0
- package/dist/services/live-events.d.ts +17 -0
- package/dist/services/live-events.d.ts.map +1 -0
- package/dist/services/live-events.js +33 -0
- package/dist/services/live-events.js.map +1 -0
- package/dist/services/local-service-supervisor.d.ts +56 -0
- package/dist/services/local-service-supervisor.d.ts.map +1 -0
- package/dist/services/local-service-supervisor.js +284 -0
- package/dist/services/local-service-supervisor.js.map +1 -0
- package/dist/services/operator-auth.d.ts +271 -0
- package/dist/services/operator-auth.d.ts.map +1 -0
- package/dist/services/operator-auth.js +361 -0
- package/dist/services/operator-auth.js.map +1 -0
- package/dist/services/plugin-capability-validator.d.ts +108 -0
- package/dist/services/plugin-capability-validator.d.ts.map +1 -0
- package/dist/services/plugin-capability-validator.js +314 -0
- package/dist/services/plugin-capability-validator.js.map +1 -0
- package/dist/services/plugin-config-validator.d.ts +26 -0
- package/dist/services/plugin-config-validator.d.ts.map +1 -0
- package/dist/services/plugin-config-validator.js +41 -0
- package/dist/services/plugin-config-validator.js.map +1 -0
- package/dist/services/plugin-database.d.ts +49 -0
- package/dist/services/plugin-database.d.ts.map +1 -0
- package/dist/services/plugin-database.js +475 -0
- package/dist/services/plugin-database.js.map +1 -0
- package/dist/services/plugin-dev-watcher.d.ts +30 -0
- package/dist/services/plugin-dev-watcher.d.ts.map +1 -0
- package/dist/services/plugin-dev-watcher.js +246 -0
- package/dist/services/plugin-dev-watcher.js.map +1 -0
- package/dist/services/plugin-environment-driver.d.ts +126 -0
- package/dist/services/plugin-environment-driver.d.ts.map +1 -0
- package/dist/services/plugin-environment-driver.js +226 -0
- package/dist/services/plugin-environment-driver.js.map +1 -0
- package/dist/services/plugin-event-bus.d.ts +149 -0
- package/dist/services/plugin-event-bus.d.ts.map +1 -0
- package/dist/services/plugin-event-bus.js +258 -0
- package/dist/services/plugin-event-bus.js.map +1 -0
- package/dist/services/plugin-host-service-cleanup.d.ts +14 -0
- package/dist/services/plugin-host-service-cleanup.d.ts.map +1 -0
- package/dist/services/plugin-host-service-cleanup.js +37 -0
- package/dist/services/plugin-host-service-cleanup.js.map +1 -0
- package/dist/services/plugin-host-services.d.ts +17 -0
- package/dist/services/plugin-host-services.d.ts.map +1 -0
- package/dist/services/plugin-host-services.js +2460 -0
- package/dist/services/plugin-host-services.js.map +1 -0
- package/dist/services/plugin-job-coordinator.d.ts +81 -0
- package/dist/services/plugin-job-coordinator.d.ts.map +1 -0
- package/dist/services/plugin-job-coordinator.js +172 -0
- package/dist/services/plugin-job-coordinator.js.map +1 -0
- package/dist/services/plugin-job-scheduler.d.ts +163 -0
- package/dist/services/plugin-job-scheduler.d.ts.map +1 -0
- package/dist/services/plugin-job-scheduler.js +454 -0
- package/dist/services/plugin-job-scheduler.js.map +1 -0
- package/dist/services/plugin-job-store.d.ts +208 -0
- package/dist/services/plugin-job-store.d.ts.map +1 -0
- package/dist/services/plugin-job-store.js +350 -0
- package/dist/services/plugin-job-store.js.map +1 -0
- package/dist/services/plugin-lifecycle.d.ts +203 -0
- package/dist/services/plugin-lifecycle.d.ts.map +1 -0
- package/dist/services/plugin-lifecycle.js +501 -0
- package/dist/services/plugin-lifecycle.js.map +1 -0
- package/dist/services/plugin-loader.d.ts +453 -0
- package/dist/services/plugin-loader.d.ts.map +1 -0
- package/dist/services/plugin-loader.js +1295 -0
- package/dist/services/plugin-loader.js.map +1 -0
- package/dist/services/plugin-local-folders.d.ts +49 -0
- package/dist/services/plugin-local-folders.d.ts.map +1 -0
- package/dist/services/plugin-local-folders.js +510 -0
- package/dist/services/plugin-local-folders.js.map +1 -0
- package/dist/services/plugin-log-retention.d.ts +20 -0
- package/dist/services/plugin-log-retention.d.ts.map +1 -0
- package/dist/services/plugin-log-retention.js +63 -0
- package/dist/services/plugin-log-retention.js.map +1 -0
- package/dist/services/plugin-managed-agents.d.ts +15 -0
- package/dist/services/plugin-managed-agents.d.ts.map +1 -0
- package/dist/services/plugin-managed-agents.js +457 -0
- package/dist/services/plugin-managed-agents.js.map +1 -0
- package/dist/services/plugin-managed-routines.d.ts +42 -0
- package/dist/services/plugin-managed-routines.d.ts.map +1 -0
- package/dist/services/plugin-managed-routines.js +416 -0
- package/dist/services/plugin-managed-routines.js.map +1 -0
- package/dist/services/plugin-managed-skills.d.ts +14 -0
- package/dist/services/plugin-managed-skills.d.ts.map +1 -0
- package/dist/services/plugin-managed-skills.js +264 -0
- package/dist/services/plugin-managed-skills.js.map +1 -0
- package/dist/services/plugin-manifest-validator.d.ts +79 -0
- package/dist/services/plugin-manifest-validator.d.ts.map +1 -0
- package/dist/services/plugin-manifest-validator.js +84 -0
- package/dist/services/plugin-manifest-validator.js.map +1 -0
- package/dist/services/plugin-registry.d.ts +2550 -0
- package/dist/services/plugin-registry.d.ts.map +1 -0
- package/dist/services/plugin-registry.js +581 -0
- package/dist/services/plugin-registry.js.map +1 -0
- package/dist/services/plugin-runtime-sandbox.d.ts +40 -0
- package/dist/services/plugin-runtime-sandbox.d.ts.map +1 -0
- package/dist/services/plugin-runtime-sandbox.js +154 -0
- package/dist/services/plugin-runtime-sandbox.js.map +1 -0
- package/dist/services/plugin-secrets-handler.d.ts +83 -0
- package/dist/services/plugin-secrets-handler.d.ts.map +1 -0
- package/dist/services/plugin-secrets-handler.js +168 -0
- package/dist/services/plugin-secrets-handler.js.map +1 -0
- package/dist/services/plugin-state-store.d.ts +92 -0
- package/dist/services/plugin-state-store.d.ts.map +1 -0
- package/dist/services/plugin-state-store.js +190 -0
- package/dist/services/plugin-state-store.js.map +1 -0
- package/dist/services/plugin-stream-bus.d.ts +29 -0
- package/dist/services/plugin-stream-bus.d.ts.map +1 -0
- package/dist/services/plugin-stream-bus.js +48 -0
- package/dist/services/plugin-stream-bus.js.map +1 -0
- package/dist/services/plugin-tool-dispatcher.d.ts +181 -0
- package/dist/services/plugin-tool-dispatcher.d.ts.map +1 -0
- package/dist/services/plugin-tool-dispatcher.js +224 -0
- package/dist/services/plugin-tool-dispatcher.js.map +1 -0
- package/dist/services/plugin-tool-registry.d.ts +192 -0
- package/dist/services/plugin-tool-registry.d.ts.map +1 -0
- package/dist/services/plugin-tool-registry.js +224 -0
- package/dist/services/plugin-tool-registry.js.map +1 -0
- package/dist/services/plugin-worker-manager.d.ts +262 -0
- package/dist/services/plugin-worker-manager.d.ts.map +1 -0
- package/dist/services/plugin-worker-manager.js +942 -0
- package/dist/services/plugin-worker-manager.js.map +1 -0
- package/dist/services/portable-path.d.ts +2 -0
- package/dist/services/portable-path.d.ts.map +1 -0
- package/dist/services/portable-path.js +15 -0
- package/dist/services/portable-path.js.map +1 -0
- package/dist/services/principal-access-compatibility.d.ts +26 -0
- package/dist/services/principal-access-compatibility.d.ts.map +1 -0
- package/dist/services/principal-access-compatibility.js +94 -0
- package/dist/services/principal-access-compatibility.js.map +1 -0
- package/dist/services/productivity-review.d.ts +83 -0
- package/dist/services/productivity-review.d.ts.map +1 -0
- package/dist/services/productivity-review.js +652 -0
- package/dist/services/productivity-review.js.map +1 -0
- package/dist/services/project-workspace-runtime-config.d.ts +4 -0
- package/dist/services/project-workspace-runtime-config.d.ts.map +1 -0
- package/dist/services/project-workspace-runtime-config.js +54 -0
- package/dist/services/project-workspace-runtime-config.js.map +1 -0
- package/dist/services/projects.d.ts +99 -0
- package/dist/services/projects.d.ts.map +1 -0
- package/dist/services/projects.js +879 -0
- package/dist/services/projects.js.map +1 -0
- package/dist/services/quota-windows.d.ts +9 -0
- package/dist/services/quota-windows.d.ts.map +1 -0
- package/dist/services/quota-windows.js +56 -0
- package/dist/services/quota-windows.js.map +1 -0
- package/dist/services/recovery/index.d.ts +10 -0
- package/dist/services/recovery/index.d.ts.map +1 -0
- package/dist/services/recovery/index.js +6 -0
- package/dist/services/recovery/index.js.map +1 -0
- package/dist/services/recovery/issue-graph-liveness.d.ts +85 -0
- package/dist/services/recovery/issue-graph-liveness.d.ts.map +1 -0
- package/dist/services/recovery/issue-graph-liveness.js +356 -0
- package/dist/services/recovery/issue-graph-liveness.js.map +1 -0
- package/dist/services/recovery/model-profile-hint.d.ts +21 -0
- package/dist/services/recovery/model-profile-hint.d.ts.map +1 -0
- package/dist/services/recovery/model-profile-hint.js +36 -0
- package/dist/services/recovery/model-profile-hint.js.map +1 -0
- package/dist/services/recovery/model-profile-hint.test.d.ts +2 -0
- package/dist/services/recovery/model-profile-hint.test.d.ts.map +1 -0
- package/dist/services/recovery/model-profile-hint.test.js +38 -0
- package/dist/services/recovery/model-profile-hint.test.js.map +1 -0
- package/dist/services/recovery/origins.d.ts +36 -0
- package/dist/services/recovery/origins.d.ts.map +1 -0
- package/dist/services/recovery/origins.js +45 -0
- package/dist/services/recovery/origins.js.map +1 -0
- package/dist/services/recovery/pause-hold-guard.d.ts +6 -0
- package/dist/services/recovery/pause-hold-guard.d.ts.map +1 -0
- package/dist/services/recovery/pause-hold-guard.js +6 -0
- package/dist/services/recovery/pause-hold-guard.js.map +1 -0
- package/dist/services/recovery/run-liveness-continuations.d.ts +50 -0
- package/dist/services/recovery/run-liveness-continuations.d.ts.map +1 -0
- package/dist/services/recovery/run-liveness-continuations.js +117 -0
- package/dist/services/recovery/run-liveness-continuations.js.map +1 -0
- package/dist/services/recovery/service.d.ts +258 -0
- package/dist/services/recovery/service.d.ts.map +1 -0
- package/dist/services/recovery/service.js +2892 -0
- package/dist/services/recovery/service.js.map +1 -0
- package/dist/services/recovery/successful-run-handoff.d.ts +89 -0
- package/dist/services/recovery/successful-run-handoff.d.ts.map +1 -0
- package/dist/services/recovery/successful-run-handoff.js +304 -0
- package/dist/services/recovery/successful-run-handoff.js.map +1 -0
- package/dist/services/recovery/successful-run-handoff.test.d.ts +2 -0
- package/dist/services/recovery/successful-run-handoff.test.d.ts.map +1 -0
- package/dist/services/recovery/successful-run-handoff.test.js +276 -0
- package/dist/services/recovery/successful-run-handoff.test.js.map +1 -0
- package/dist/services/resource-memberships.d.ts +55 -0
- package/dist/services/resource-memberships.d.ts.map +1 -0
- package/dist/services/resource-memberships.js +213 -0
- package/dist/services/resource-memberships.js.map +1 -0
- package/dist/services/routines.d.ts +170 -0
- package/dist/services/routines.d.ts.map +1 -0
- package/dist/services/routines.js +2015 -0
- package/dist/services/routines.js.map +1 -0
- package/dist/services/run-continuations.d.ts +3 -0
- package/dist/services/run-continuations.d.ts.map +1 -0
- package/dist/services/run-continuations.js +2 -0
- package/dist/services/run-continuations.js.map +1 -0
- package/dist/services/run-liveness.d.ts +46 -0
- package/dist/services/run-liveness.d.ts.map +1 -0
- package/dist/services/run-liveness.js +275 -0
- package/dist/services/run-liveness.js.map +1 -0
- package/dist/services/run-log-store.d.ts +34 -0
- package/dist/services/run-log-store.d.ts.map +1 -0
- package/dist/services/run-log-store.js +111 -0
- package/dist/services/run-log-store.js.map +1 -0
- package/dist/services/sandbox-provider-runtime.d.ts +132 -0
- package/dist/services/sandbox-provider-runtime.d.ts.map +1 -0
- package/dist/services/sandbox-provider-runtime.js +216 -0
- package/dist/services/sandbox-provider-runtime.js.map +1 -0
- package/dist/services/secrets.d.ts +1991 -0
- package/dist/services/secrets.d.ts.map +1 -0
- package/dist/services/secrets.js +1781 -0
- package/dist/services/secrets.js.map +1 -0
- package/dist/services/session-workspace-cwd.d.ts +2 -0
- package/dist/services/session-workspace-cwd.d.ts.map +1 -0
- package/dist/services/session-workspace-cwd.js +24 -0
- package/dist/services/session-workspace-cwd.js.map +1 -0
- package/dist/services/session-workspace-cwd.test.d.ts +2 -0
- package/dist/services/session-workspace-cwd.test.d.ts.map +1 -0
- package/dist/services/session-workspace-cwd.test.js +25 -0
- package/dist/services/session-workspace-cwd.test.js.map +1 -0
- package/dist/services/sidebar-badges.d.ts +14 -0
- package/dist/services/sidebar-badges.d.ts.map +1 -0
- package/dist/services/sidebar-badges.js +48 -0
- package/dist/services/sidebar-badges.js.map +1 -0
- package/dist/services/sidebar-preferences.d.ts +9 -0
- package/dist/services/sidebar-preferences.d.ts.map +1 -0
- package/dist/services/sidebar-preferences.js +82 -0
- package/dist/services/sidebar-preferences.js.map +1 -0
- package/dist/services/skills-catalog.d.ts +14 -0
- package/dist/services/skills-catalog.d.ts.map +1 -0
- package/dist/services/skills-catalog.js +171 -0
- package/dist/services/skills-catalog.js.map +1 -0
- package/dist/services/squad-export-readme.d.ts +17 -0
- package/dist/services/squad-export-readme.d.ts.map +1 -0
- package/dist/services/squad-export-readme.js +148 -0
- package/dist/services/squad-export-readme.js.map +1 -0
- package/dist/services/squad-member-roles.d.ts +9 -0
- package/dist/services/squad-member-roles.d.ts.map +1 -0
- package/dist/services/squad-member-roles.js +48 -0
- package/dist/services/squad-member-roles.js.map +1 -0
- package/dist/services/squad-portability.d.ts +24 -0
- package/dist/services/squad-portability.d.ts.map +1 -0
- package/dist/services/squad-portability.js +4093 -0
- package/dist/services/squad-portability.js.map +1 -0
- package/dist/services/squad-search-rate-limit.d.ts +22 -0
- package/dist/services/squad-search-rate-limit.d.ts.map +1 -0
- package/dist/services/squad-search-rate-limit.js +38 -0
- package/dist/services/squad-search-rate-limit.js.map +1 -0
- package/dist/services/squad-search.d.ts +8 -0
- package/dist/services/squad-search.d.ts.map +1 -0
- package/dist/services/squad-search.js +626 -0
- package/dist/services/squad-search.js.map +1 -0
- package/dist/services/squad-skills.d.ts +107 -0
- package/dist/services/squad-skills.d.ts.map +1 -0
- package/dist/services/squad-skills.js +3044 -0
- package/dist/services/squad-skills.js.map +1 -0
- package/dist/services/squads.d.ts +154 -0
- package/dist/services/squads.d.ts.map +1 -0
- package/dist/services/squads.js +278 -0
- package/dist/services/squads.js.map +1 -0
- package/dist/services/wake-cycle-guard.d.ts +44 -0
- package/dist/services/wake-cycle-guard.d.ts.map +1 -0
- package/dist/services/wake-cycle-guard.js +79 -0
- package/dist/services/wake-cycle-guard.js.map +1 -0
- package/dist/services/wake-cycle-guard.test.d.ts +2 -0
- package/dist/services/wake-cycle-guard.test.d.ts.map +1 -0
- package/dist/services/wake-cycle-guard.test.js +67 -0
- package/dist/services/wake-cycle-guard.test.js.map +1 -0
- package/dist/services/work-products.d.ts +14 -0
- package/dist/services/work-products.d.ts.map +1 -0
- package/dist/services/work-products.js +100 -0
- package/dist/services/work-products.js.map +1 -0
- package/dist/services/workspace-operation-log-store.d.ts +33 -0
- package/dist/services/workspace-operation-log-store.d.ts.map +1 -0
- package/dist/services/workspace-operation-log-store.js +110 -0
- package/dist/services/workspace-operation-log-store.js.map +1 -0
- package/dist/services/workspace-operations.d.ts +44 -0
- package/dist/services/workspace-operations.d.ts.map +1 -0
- package/dist/services/workspace-operations.js +211 -0
- package/dist/services/workspace-operations.js.map +1 -0
- package/dist/services/workspace-realization.d.ts +33 -0
- package/dist/services/workspace-realization.d.ts.map +1 -0
- package/dist/services/workspace-realization.js +221 -0
- package/dist/services/workspace-realization.js.map +1 -0
- package/dist/services/workspace-runtime-read-model.d.ts +92 -0
- package/dist/services/workspace-runtime-read-model.d.ts.map +1 -0
- package/dist/services/workspace-runtime-read-model.js +67 -0
- package/dist/services/workspace-runtime-read-model.js.map +1 -0
- package/dist/services/workspace-runtime.d.ts +252 -0
- package/dist/services/workspace-runtime.d.ts.map +1 -0
- package/dist/services/workspace-runtime.js +2519 -0
- package/dist/services/workspace-runtime.js.map +1 -0
- package/dist/startup-banner.d.ts +32 -0
- package/dist/startup-banner.d.ts.map +1 -0
- package/dist/startup-banner.js +118 -0
- package/dist/startup-banner.js.map +1 -0
- package/dist/static-index-html.d.ts +2 -0
- package/dist/static-index-html.d.ts.map +1 -0
- package/dist/static-index-html.js +7 -0
- package/dist/static-index-html.js.map +1 -0
- package/dist/storage/index.d.ts +6 -0
- package/dist/storage/index.d.ts.map +1 -0
- package/dist/storage/index.js +29 -0
- package/dist/storage/index.js.map +1 -0
- package/dist/storage/local-disk-provider.d.ts +3 -0
- package/dist/storage/local-disk-provider.d.ts.map +1 -0
- package/dist/storage/local-disk-provider.js +85 -0
- package/dist/storage/local-disk-provider.js.map +1 -0
- package/dist/storage/provider-registry.d.ts +4 -0
- package/dist/storage/provider-registry.d.ts.map +1 -0
- package/dist/storage/provider-registry.js +15 -0
- package/dist/storage/provider-registry.js.map +1 -0
- package/dist/storage/s3-provider.d.ts +11 -0
- package/dist/storage/s3-provider.d.ts.map +1 -0
- package/dist/storage/s3-provider.js +124 -0
- package/dist/storage/s3-provider.js.map +1 -0
- package/dist/storage/service.d.ts +3 -0
- package/dist/storage/service.d.ts.map +1 -0
- package/dist/storage/service.js +120 -0
- package/dist/storage/service.js.map +1 -0
- package/dist/storage/types.d.ts +59 -0
- package/dist/storage/types.d.ts.map +1 -0
- package/dist/storage/types.js +2 -0
- package/dist/storage/types.js.map +1 -0
- package/dist/ui-branding.d.ts +13 -0
- package/dist/ui-branding.d.ts.map +1 -0
- package/dist/ui-branding.js +187 -0
- package/dist/ui-branding.js.map +1 -0
- package/dist/version.d.ts +2 -0
- package/dist/version.d.ts.map +1 -0
- package/dist/version.js +5 -0
- package/dist/version.js.map +1 -0
- package/dist/vite-html-renderer.d.ts +18 -0
- package/dist/vite-html-renderer.d.ts.map +1 -0
- package/dist/vite-html-renderer.js +61 -0
- package/dist/vite-html-renderer.js.map +1 -0
- package/dist/worktree-config.d.ts +19 -0
- package/dist/worktree-config.d.ts.map +1 -0
- package/dist/worktree-config.js +373 -0
- package/dist/worktree-config.js.map +1 -0
- package/package.json +92 -0
- package/skills/diagnose-why-work-stopped/SKILL.md +161 -0
- package/skills/para-memory-files/SKILL.md +104 -0
- package/skills/para-memory-files/references/schemas.md +35 -0
- package/skills/slaw/SKILL.md +371 -0
- package/skills/slaw/references/api-reference.md +879 -0
- package/skills/slaw/references/artifacts.md +44 -0
- package/skills/slaw/references/issue-workspaces.md +80 -0
- package/skills/slaw/references/routines.md +187 -0
- package/skills/slaw/references/squad-skills.md +258 -0
- package/skills/slaw/references/workflows.md +113 -0
- package/skills/slaw/scripts/slaw-upload-artifact.sh +371 -0
- package/skills/slaw-converting-plans-to-tasks/SKILL.md +42 -0
- package/skills/slaw-create-agent/SKILL.md +163 -0
- package/skills/slaw-create-agent/references/agent-instruction-templates.md +123 -0
- package/skills/slaw-create-agent/references/agents/coder.md +64 -0
- package/skills/slaw-create-agent/references/agents/qa.md +88 -0
- package/skills/slaw-create-agent/references/agents/securityengineer.md +135 -0
- package/skills/slaw-create-agent/references/agents/uxdesigner.md +115 -0
- package/skills/slaw-create-agent/references/api-reference.md +110 -0
- package/skills/slaw-create-agent/references/baseline-role-guide.md +168 -0
- package/skills/slaw-create-agent/references/draft-review-checklist.md +95 -0
- package/skills/slaw-create-plugin/SKILL.md +154 -0
- package/skills/slaw-dev/SKILL.md +267 -0
- package/skills/terminal-bench-loop/SKILL.md +236 -0
- package/ui-dist/android-chrome-192x192.png +0 -0
- package/ui-dist/android-chrome-512x512.png +0 -0
- package/ui-dist/apple-touch-icon.png +0 -0
- package/ui-dist/assets/apl-B4CMkyY2.js +1 -0
- package/ui-dist/assets/arc-xbLjL0VN.js +1 -0
- package/ui-dist/assets/architectureDiagram-3BPJPVTR-KcFd4B-U.js +36 -0
- package/ui-dist/assets/asciiarmor-Df11BRmG.js +1 -0
- package/ui-dist/assets/asn1-EdZsLKOL.js +1 -0
- package/ui-dist/assets/asterisk-B-8jnY81.js +1 -0
- package/ui-dist/assets/blockDiagram-GPEHLZMM-CSD4otEL.js +132 -0
- package/ui-dist/assets/brainfuck-C4LP7Hcl.js +1 -0
- package/ui-dist/assets/c4Diagram-AAUBKEIU-Cre_NEHp.js +10 -0
- package/ui-dist/assets/channel-BFN8obi8.js +1 -0
- package/ui-dist/assets/chunk-2J33WTMH-CssLBsbh.js +1 -0
- package/ui-dist/assets/chunk-4BX2VUAB-DjiavNFv.js +1 -0
- package/ui-dist/assets/chunk-55IACEB6-C_F0yeYq.js +1 -0
- package/ui-dist/assets/chunk-727SXJPM-B1FAOW4a.js +206 -0
- package/ui-dist/assets/chunk-AQP2D5EJ-Do1241W-.js +231 -0
- package/ui-dist/assets/chunk-FMBD7UC4-BQRrOMZD.js +15 -0
- package/ui-dist/assets/chunk-ND2GUHAM-BPSt3kZ1.js +1 -0
- package/ui-dist/assets/chunk-QZHKN3VN-BSpmhWDD.js +1 -0
- package/ui-dist/assets/classDiagram-4FO5ZUOK-1Ay0zFCU.js +1 -0
- package/ui-dist/assets/classDiagram-v2-Q7XG4LA2-1Ay0zFCU.js +1 -0
- package/ui-dist/assets/clike-B9uivgTg.js +1 -0
- package/ui-dist/assets/clojure-BMjYHr_A.js +1 -0
- package/ui-dist/assets/cmake-BQqOBYOt.js +1 -0
- package/ui-dist/assets/cobol-CWcv1MsR.js +1 -0
- package/ui-dist/assets/coffeescript-S37ZYGWr.js +1 -0
- package/ui-dist/assets/commonlisp-DBKNyK5s.js +1 -0
- package/ui-dist/assets/cose-bilkent-S5V4N54A-CK2f2Te4.js +1 -0
- package/ui-dist/assets/crystal-SjHAIU92.js +1 -0
- package/ui-dist/assets/css-BnMrqG3P.js +1 -0
- package/ui-dist/assets/cypher-C_CwsFkJ.js +1 -0
- package/ui-dist/assets/cytoscape.esm-D8joxN9f.js +321 -0
- package/ui-dist/assets/d-pRatUO7H.js +1 -0
- package/ui-dist/assets/dagre-BM42HDAG-DaOXTN9-.js +4 -0
- package/ui-dist/assets/defaultLocale-DX6XiGOO.js +1 -0
- package/ui-dist/assets/diagram-2AECGRRQ-D0ScQUGy.js +43 -0
- package/ui-dist/assets/diagram-5GNKFQAL-7mH4Cncd.js +10 -0
- package/ui-dist/assets/diagram-KO2AKTUF-aA9kuK-7.js +3 -0
- package/ui-dist/assets/diagram-LMA3HP47-C9UXfmdK.js +24 -0
- package/ui-dist/assets/diagram-OG6HWLK6-Ba3U-x1r.js +24 -0
- package/ui-dist/assets/diff-DbItnlRl.js +1 -0
- package/ui-dist/assets/dockerfile-BKs6k2Af.js +1 -0
- package/ui-dist/assets/dtd-DF_7sFjM.js +1 -0
- package/ui-dist/assets/dylan-DwRh75JA.js +1 -0
- package/ui-dist/assets/ebnf-CDyGwa7X.js +1 -0
- package/ui-dist/assets/ecl-Cabwm37j.js +1 -0
- package/ui-dist/assets/eiffel-CnydiIhH.js +1 -0
- package/ui-dist/assets/elm-vLlmbW-K.js +1 -0
- package/ui-dist/assets/erDiagram-TEJ5UH35-CmskPKH1.js +85 -0
- package/ui-dist/assets/erlang-BNw1qcRV.js +1 -0
- package/ui-dist/assets/factor-kuTfRLto.js +1 -0
- package/ui-dist/assets/fcl-Kvtd6kyn.js +1 -0
- package/ui-dist/assets/flowDiagram-I6XJVG4X-B0iEPqGd.js +162 -0
- package/ui-dist/assets/forth-Ffai-XNe.js +1 -0
- package/ui-dist/assets/fortran-DYz_wnZ1.js +1 -0
- package/ui-dist/assets/ganttDiagram-6RSMTGT7-DtpxlgWQ.js +292 -0
- package/ui-dist/assets/gas-Bneqetm1.js +1 -0
- package/ui-dist/assets/gherkin-heZmZLOM.js +1 -0
- package/ui-dist/assets/gitGraphDiagram-PVQCEYII-VefBjqya.js +106 -0
- package/ui-dist/assets/graph-CAnANduQ.js +1 -0
- package/ui-dist/assets/groovy-D9Dt4D0W.js +1 -0
- package/ui-dist/assets/haskell-Cw1EW3IL.js +1 -0
- package/ui-dist/assets/haxe-H-WmDvRZ.js +1 -0
- package/ui-dist/assets/http-DBlCnlav.js +1 -0
- package/ui-dist/assets/idl-BEugSyMb.js +1 -0
- package/ui-dist/assets/index-B9KxOFt-.js +1 -0
- package/ui-dist/assets/index-BMPCuc-W.js +1 -0
- package/ui-dist/assets/index-Bbfs2D7R.js +1 -0
- package/ui-dist/assets/index-BrgHE5Lg.js +1 -0
- package/ui-dist/assets/index-C5q-Cwlp.js +7 -0
- package/ui-dist/assets/index-C6LpKpr3.js +1 -0
- package/ui-dist/assets/index-CIzt5DFV.js +1 -0
- package/ui-dist/assets/index-CRwAuYPj.js +1 -0
- package/ui-dist/assets/index-CTEnIXsJ.js +1 -0
- package/ui-dist/assets/index-CXGemv2V.js +1 -0
- package/ui-dist/assets/index-ClDiS51u.js +1 -0
- package/ui-dist/assets/index-CvKYfvpz.js +1 -0
- package/ui-dist/assets/index-D2IqxlXD.js +1 -0
- package/ui-dist/assets/index-D97fJMFR.js +522 -0
- package/ui-dist/assets/index-DDHdUa2f.js +1 -0
- package/ui-dist/assets/index-DMZ0QXqi.js +1 -0
- package/ui-dist/assets/index-DMi4KpxO.js +6 -0
- package/ui-dist/assets/index-DZB48Gve.js +1 -0
- package/ui-dist/assets/index-Drr9zRdK.css +1 -0
- package/ui-dist/assets/index-DtGqpE43.js +1 -0
- package/ui-dist/assets/index-Du18kURt.js +2 -0
- package/ui-dist/assets/index-KaLXuTqA.js +1 -0
- package/ui-dist/assets/index-j5NgiILm.js +13 -0
- package/ui-dist/assets/index-u0SfLZ3g.js +3 -0
- package/ui-dist/assets/infoDiagram-5YYISTIA-D2OGH-dO.js +2 -0
- package/ui-dist/assets/init-Gi6I4Gst.js +1 -0
- package/ui-dist/assets/ishikawaDiagram-YF4QCWOH-CnMf3BJj.js +70 -0
- package/ui-dist/assets/javascript-iXu5QeM3.js +1 -0
- package/ui-dist/assets/journeyDiagram-JHISSGLW-BaXdD53T.js +139 -0
- package/ui-dist/assets/julia-DuME0IfC.js +1 -0
- package/ui-dist/assets/kanban-definition-UN3LZRKU-Brt7LjHm.js +89 -0
- package/ui-dist/assets/katex-yT8l5JNH.js +257 -0
- package/ui-dist/assets/layout-DGIYPm2g.js +1 -0
- package/ui-dist/assets/linear-536T6Mkh.js +1 -0
- package/ui-dist/assets/livescript-BwQOo05w.js +1 -0
- package/ui-dist/assets/lua-VAEuO923.js +1 -0
- package/ui-dist/assets/mathematica-DTrFuWx2.js +1 -0
- package/ui-dist/assets/mbox-CNhZ1qSd.js +1 -0
- package/ui-dist/assets/mermaid.core-CURTLVBm.js +303 -0
- package/ui-dist/assets/mindmap-definition-RKZ34NQL-S2tDCU-U.js +96 -0
- package/ui-dist/assets/mirc-CjQqDB4T.js +1 -0
- package/ui-dist/assets/mllike-CXdrOF99.js +1 -0
- package/ui-dist/assets/modelica-Dc1JOy9r.js +1 -0
- package/ui-dist/assets/mscgen-BA5vi2Kp.js +1 -0
- package/ui-dist/assets/mumps-BT43cFF4.js +1 -0
- package/ui-dist/assets/nginx-DdIZxoE0.js +1 -0
- package/ui-dist/assets/nsis-LdVXkNf5.js +1 -0
- package/ui-dist/assets/ntriples-BfvgReVJ.js +1 -0
- package/ui-dist/assets/octave-Ck1zUtKM.js +1 -0
- package/ui-dist/assets/ordinal-Cboi1Yqb.js +1 -0
- package/ui-dist/assets/oz-BzwKVEFT.js +1 -0
- package/ui-dist/assets/pascal--L3eBynH.js +1 -0
- package/ui-dist/assets/perl-CdXCOZ3F.js +1 -0
- package/ui-dist/assets/pieDiagram-4H26LBE5-DD_Ih32z.js +30 -0
- package/ui-dist/assets/pig-CevX1Tat.js +1 -0
- package/ui-dist/assets/powershell-CFHJl5sT.js +1 -0
- package/ui-dist/assets/properties-C78fOPTZ.js +1 -0
- package/ui-dist/assets/protobuf-ChK-085T.js +1 -0
- package/ui-dist/assets/pug-DeIclll2.js +1 -0
- package/ui-dist/assets/puppet-DMA9R1ak.js +1 -0
- package/ui-dist/assets/python-BuPzkPfP.js +1 -0
- package/ui-dist/assets/q-pXgVlZs6.js +1 -0
- package/ui-dist/assets/quadrantDiagram-W4KKPZXB-DA5BPBIK.js +7 -0
- package/ui-dist/assets/r-B6wPVr8A.js +1 -0
- package/ui-dist/assets/requirementDiagram-4Y6WPE33-Em8SPCro.js +84 -0
- package/ui-dist/assets/rpm-CTu-6PCP.js +1 -0
- package/ui-dist/assets/ruby-B2Rjki9n.js +1 -0
- package/ui-dist/assets/sankeyDiagram-5OEKKPKP-BJVC4haY.js +40 -0
- package/ui-dist/assets/sas-B4kiWyti.js +1 -0
- package/ui-dist/assets/scheme-C41bIUwD.js +1 -0
- package/ui-dist/assets/sequenceDiagram-3UESZ5HK-Cskntadf.js +162 -0
- package/ui-dist/assets/shell-CjFT_Tl9.js +1 -0
- package/ui-dist/assets/sieve-C3Gn_uJK.js +1 -0
- package/ui-dist/assets/simple-mode-GW_nhZxv.js +1 -0
- package/ui-dist/assets/smalltalk-CnHTOXQT.js +1 -0
- package/ui-dist/assets/solr-DehyRSwq.js +1 -0
- package/ui-dist/assets/sparql-DkYu6x3z.js +1 -0
- package/ui-dist/assets/spreadsheet-BCZA_wO0.js +1 -0
- package/ui-dist/assets/sql-D0XecflT.js +1 -0
- package/ui-dist/assets/stateDiagram-AJRCARHV-CxlfdaOi.js +1 -0
- package/ui-dist/assets/stateDiagram-v2-BHNVJYJU-eTgftUjW.js +1 -0
- package/ui-dist/assets/stex-C3f8Ysf7.js +1 -0
- package/ui-dist/assets/stylus-B533Al4x.js +1 -0
- package/ui-dist/assets/swift-BzpIVaGY.js +1 -0
- package/ui-dist/assets/tcl-DVfN8rqt.js +1 -0
- package/ui-dist/assets/textile-CnDTJFAw.js +1 -0
- package/ui-dist/assets/tiddlywiki-DO-Gjzrf.js +1 -0
- package/ui-dist/assets/tiki-DGYXhP31.js +1 -0
- package/ui-dist/assets/timeline-definition-PNZ67QCA-LOdaWSSa.js +120 -0
- package/ui-dist/assets/toml-Bm5Em-hy.js +1 -0
- package/ui-dist/assets/troff-wAsdV37c.js +1 -0
- package/ui-dist/assets/ttcn-CfJYG6tj.js +1 -0
- package/ui-dist/assets/ttcn-cfg-B9xdYoR4.js +1 -0
- package/ui-dist/assets/turtle-B1tBg_DP.js +1 -0
- package/ui-dist/assets/vb-CmGdzxic.js +1 -0
- package/ui-dist/assets/vbscript-BuJXcnF6.js +1 -0
- package/ui-dist/assets/velocity-D8B20fx6.js +1 -0
- package/ui-dist/assets/vennDiagram-CIIHVFJN-CJ4ji6B3.js +34 -0
- package/ui-dist/assets/verilog-C6RDOZhf.js +1 -0
- package/ui-dist/assets/vhdl-lSbBsy5d.js +1 -0
- package/ui-dist/assets/wardley-L42UT6IY-CxnVdUVH.js +153 -0
- package/ui-dist/assets/wardleyDiagram-YWT4CUSO-CgGDttpl.js +78 -0
- package/ui-dist/assets/webidl-ZXfAyPTL.js +1 -0
- package/ui-dist/assets/xquery-DzFWVndE.js +1 -0
- package/ui-dist/assets/xychartDiagram-2RQKCTM6-zuQa7bqx.js +7 -0
- package/ui-dist/assets/yacas-BJ4BC0dw.js +1 -0
- package/ui-dist/assets/z80-Hz9HOZM7.js +1 -0
- package/ui-dist/brands/opencode-logo-dark-square.svg +18 -0
- package/ui-dist/brands/opencode-logo-light-square.svg +18 -0
- package/ui-dist/favicon-16x16.png +0 -0
- package/ui-dist/favicon-32x32.png +0 -0
- package/ui-dist/favicon.ico +0 -0
- package/ui-dist/favicon.svg +8 -0
- package/ui-dist/index.html +46 -0
- package/ui-dist/site.webmanifest +30 -0
- package/ui-dist/sw.js +42 -0
- package/ui-dist/worktree-favicon-16x16.png +0 -0
- package/ui-dist/worktree-favicon-32x32.png +0 -0
- package/ui-dist/worktree-favicon.ico +0 -0
- package/ui-dist/worktree-favicon.svg +9 -0
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import { readBotfatherConfigSection } from "../../config-file.js";
|
|
2
|
+
import { readBotfatherCredentials } from "./credentials.js";
|
|
3
|
+
/**
|
|
4
|
+
* Tower-only authoring lock predicate. An instance is "tower-governed" — and so
|
|
5
|
+
* local skill authoring/import is disabled — when a control-tower URL is
|
|
6
|
+
* configured AND the instance is enrolled (active credentials with an apiKey
|
|
7
|
+
* exist). Standalone or not-yet-enrolled instances are NOT governed, so their
|
|
8
|
+
* local skill authoring keeps working exactly as before.
|
|
9
|
+
*
|
|
10
|
+
* See DESIGN-skill-registry.md §8.1. Kept tiny + dependency-injectable so the
|
|
11
|
+
* decision is unit-testable without touching disk.
|
|
12
|
+
*/
|
|
13
|
+
export function isTowerGoverned(deps = {}) {
|
|
14
|
+
const readConfig = deps.readConfigSection ?? readBotfatherConfigSection;
|
|
15
|
+
const readCreds = deps.readCredentials ?? readBotfatherCredentials;
|
|
16
|
+
const section = readConfig();
|
|
17
|
+
const hasTowerUrl = typeof section?.url === "string" && section.url.length > 0;
|
|
18
|
+
if (!hasTowerUrl)
|
|
19
|
+
return false;
|
|
20
|
+
const creds = readCreds();
|
|
21
|
+
return Boolean(creds?.apiKey);
|
|
22
|
+
}
|
|
23
|
+
//# sourceMappingURL=authoring-lock.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authoring-lock.js","sourceRoot":"","sources":["../../../src/services/botfather/authoring-lock.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,0BAA0B,EAAE,MAAM,sBAAsB,CAAC;AAClE,OAAO,EAAE,wBAAwB,EAAE,MAAM,kBAAkB,CAAC;AAE5D;;;;;;;;;GASG;AACH,MAAM,UAAU,eAAe,CAC7B,OAGI,EAAE;IAEN,MAAM,UAAU,GAAG,IAAI,CAAC,iBAAiB,IAAI,0BAA0B,CAAC;IACxE,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,IAAI,wBAAwB,CAAC;IACnE,MAAM,OAAO,GAAG,UAAU,EAAE,CAAC;IAC7B,MAAM,WAAW,GAAG,OAAO,OAAO,EAAE,GAAG,KAAK,QAAQ,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/E,IAAI,CAAC,WAAW;QAAE,OAAO,KAAK,CAAC;IAC/B,MAAM,KAAK,GAAG,SAAS,EAAE,CAAC;IAC1B,OAAO,OAAO,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;AAChC,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authoring-lock.test.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/authoring-lock.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { describe, it, expect } from "vitest";
|
|
2
|
+
import { isTowerGoverned } from "./authoring-lock.js";
|
|
3
|
+
/**
|
|
4
|
+
* P5 — tower-only authoring lock predicate. Local skill authoring is blocked
|
|
5
|
+
* ONLY when an instance is both connected to a tower (url configured) AND
|
|
6
|
+
* enrolled (active credentials). Standalone or pre-enrollment instances keep
|
|
7
|
+
* local authoring.
|
|
8
|
+
*/
|
|
9
|
+
const cfg = (url) => () => (url ? { url } : undefined);
|
|
10
|
+
const creds = (apiKey) => () => (apiKey ? { apiKey, enrollmentId: "e" } : null);
|
|
11
|
+
describe("isTowerGoverned", () => {
|
|
12
|
+
it("is GOVERNED when a tower url is configured and credentials are active", () => {
|
|
13
|
+
expect(isTowerGoverned({ readConfigSection: cfg("http://tower:8400"), readCredentials: creds("key123") })).toBe(true);
|
|
14
|
+
});
|
|
15
|
+
it("is NOT governed standalone (no tower url)", () => {
|
|
16
|
+
expect(isTowerGoverned({ readConfigSection: cfg(undefined), readCredentials: creds("key123") })).toBe(false);
|
|
17
|
+
});
|
|
18
|
+
it("is NOT governed when connected but not yet enrolled (no apiKey)", () => {
|
|
19
|
+
expect(isTowerGoverned({ readConfigSection: cfg("http://tower:8400"), readCredentials: creds(undefined) })).toBe(false);
|
|
20
|
+
});
|
|
21
|
+
it("is NOT governed with an empty url string", () => {
|
|
22
|
+
expect(isTowerGoverned({ readConfigSection: cfg(""), readCredentials: creds("key123") })).toBe(false);
|
|
23
|
+
});
|
|
24
|
+
});
|
|
25
|
+
//# sourceMappingURL=authoring-lock.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"authoring-lock.test.js","sourceRoot":"","sources":["../../../src/services/botfather/authoring-lock.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAEtD;;;;;GAKG;AACH,MAAM,GAAG,GAAG,CAAC,GAAY,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAE,EAAE,GAAG,EAAU,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC;AACzE,MAAM,KAAK,GAAG,CAAC,MAAe,EAAE,EAAE,CAAC,GAAG,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAE,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,EAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;AAElG,QAAQ,CAAC,iBAAiB,EAAE,GAAG,EAAE;IAC/B,EAAE,CAAC,uEAAuE,EAAE,GAAG,EAAE;QAC/E,MAAM,CACJ,eAAe,CAAC,EAAE,iBAAiB,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CACnG,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACf,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,2CAA2C,EAAE,GAAG,EAAE;QACnD,MAAM,CAAC,eAAe,CAAC,EAAE,iBAAiB,EAAE,GAAG,CAAC,SAAS,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/G,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,iEAAiE,EAAE,GAAG,EAAE;QACzE,MAAM,CAAC,eAAe,CAAC,EAAE,iBAAiB,EAAE,GAAG,CAAC,mBAAmB,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAC9G,KAAK,CACN,CAAC;IACJ,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,CAAC,eAAe,CAAC,EAAE,iBAAiB,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,eAAe,EAAE,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACxG,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { type InstanceIdentity, type EnrollResponse, type EnrollPollResponse, type HeartbeatRequest, type HeartbeatResponse, type SyncRequest, type SyncResponse, type SkillCatalogResponse, type SkillContentResponse } from "@slaw-ai/shared/botfather/protocol";
|
|
2
|
+
/**
|
|
3
|
+
* HTTP client for the botfather tower. The tower's ingest endpoints accept
|
|
4
|
+
* plain JSON (its Zod schemas parse the request body directly), so we send
|
|
5
|
+
* plain JSON with a Bearer token — no gzip envelope. Errors are surfaced as
|
|
6
|
+
* thrown BotfatherHttpError; callers decide whether to spool/back off.
|
|
7
|
+
*/
|
|
8
|
+
export declare class BotfatherHttpError extends Error {
|
|
9
|
+
readonly status: number;
|
|
10
|
+
readonly code?: string | undefined;
|
|
11
|
+
constructor(message: string, status: number, code?: string | undefined);
|
|
12
|
+
}
|
|
13
|
+
export declare function createBotfatherClient(baseUrl: string): {
|
|
14
|
+
/** token-less self-enrollment → pending (or active if an auto-approve rule matches) */
|
|
15
|
+
enroll(instance: InstanceIdentity, reportIssueTitles: boolean): Promise<EnrollResponse>;
|
|
16
|
+
/** poll until approved; returns the per-instance apiKey once active */
|
|
17
|
+
pollEnrollment(enrollmentId: string): Promise<EnrollPollResponse>;
|
|
18
|
+
heartbeat(apiKey: string, body: HeartbeatRequest): Promise<HeartbeatResponse>;
|
|
19
|
+
sync(apiKey: string, body: SyncRequest): Promise<SyncResponse>;
|
|
20
|
+
/** pull the tower's published skill catalog (descriptors only) */
|
|
21
|
+
skillCatalog(apiKey: string): Promise<SkillCatalogResponse>;
|
|
22
|
+
/** pull full content (markdown + files) for one published skill */
|
|
23
|
+
skillContent(apiKey: string, key: string): Promise<SkillContentResponse>;
|
|
24
|
+
};
|
|
25
|
+
export type BotfatherClient = ReturnType<typeof createBotfatherClient>;
|
|
26
|
+
//# sourceMappingURL=client.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/client.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,KAAK,gBAAgB,EACrB,KAAK,cAAc,EACnB,KAAK,kBAAkB,EACvB,KAAK,gBAAgB,EACrB,KAAK,iBAAiB,EACtB,KAAK,WAAW,EAChB,KAAK,YAAY,EACjB,KAAK,oBAAoB,EACzB,KAAK,oBAAoB,EAC1B,MAAM,oCAAoC,CAAC;AAE5C;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,KAAK;IAGzC,QAAQ,CAAC,MAAM,EAAE,MAAM;IACvB,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM;gBAFtB,OAAO,EAAE,MAAM,EACN,MAAM,EAAE,MAAM,EACd,IAAI,CAAC,EAAE,MAAM,YAAA;CAKzB;AAsED,wBAAgB,qBAAqB,CAAC,OAAO,EAAE,MAAM;IAGjD,uFAAuF;qBAChE,gBAAgB,qBAAqB,OAAO,GAAG,OAAO,CAAC,cAAc,CAAC;IAO7F,uEAAuE;iCACpC,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;sBAM/C,MAAM,QAAQ,gBAAgB,GAAG,OAAO,CAAC,iBAAiB,CAAC;iBAGhE,MAAM,QAAQ,WAAW,GAAG,OAAO,CAAC,YAAY,CAAC;IAGpE,kEAAkE;yBACvC,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;IAGjE,mEAAmE;yBACxC,MAAM,OAAO,MAAM,GAAG,OAAO,CAAC,oBAAoB,CAAC;EAIjF;AAED,MAAM,MAAM,eAAe,GAAG,UAAU,CAAC,OAAO,qBAAqB,CAAC,CAAC"}
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { PROTOCOL_VERSION, } from "@slaw-ai/shared/botfather/protocol";
|
|
2
|
+
/**
|
|
3
|
+
* HTTP client for the botfather tower. The tower's ingest endpoints accept
|
|
4
|
+
* plain JSON (its Zod schemas parse the request body directly), so we send
|
|
5
|
+
* plain JSON with a Bearer token — no gzip envelope. Errors are surfaced as
|
|
6
|
+
* thrown BotfatherHttpError; callers decide whether to spool/back off.
|
|
7
|
+
*/
|
|
8
|
+
export class BotfatherHttpError extends Error {
|
|
9
|
+
status;
|
|
10
|
+
code;
|
|
11
|
+
constructor(message, status, code) {
|
|
12
|
+
super(message);
|
|
13
|
+
this.status = status;
|
|
14
|
+
this.code = code;
|
|
15
|
+
this.name = "BotfatherHttpError";
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
function joinUrl(base, p) {
|
|
19
|
+
return new URL(p, base.endsWith("/") ? base : base + "/").toString();
|
|
20
|
+
}
|
|
21
|
+
async function postJson(url, body, apiKey, timeoutMs = 15_000) {
|
|
22
|
+
const ctrl = new AbortController();
|
|
23
|
+
const timer = setTimeout(() => ctrl.abort(), timeoutMs);
|
|
24
|
+
try {
|
|
25
|
+
const res = await fetch(url, {
|
|
26
|
+
method: "POST",
|
|
27
|
+
headers: {
|
|
28
|
+
"content-type": "application/json",
|
|
29
|
+
...(apiKey ? { authorization: `Bearer ${apiKey}` } : {}),
|
|
30
|
+
},
|
|
31
|
+
body: JSON.stringify(body),
|
|
32
|
+
signal: ctrl.signal,
|
|
33
|
+
});
|
|
34
|
+
const text = await res.text();
|
|
35
|
+
let parsed = undefined;
|
|
36
|
+
try {
|
|
37
|
+
parsed = text ? JSON.parse(text) : undefined;
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
/* non-JSON body */
|
|
41
|
+
}
|
|
42
|
+
if (!res.ok) {
|
|
43
|
+
const code = parsed?.code;
|
|
44
|
+
throw new BotfatherHttpError(parsed?.error ?? `HTTP ${res.status}`, res.status, code);
|
|
45
|
+
}
|
|
46
|
+
return parsed;
|
|
47
|
+
}
|
|
48
|
+
finally {
|
|
49
|
+
clearTimeout(timer);
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
async function getJson(url, apiKey, timeoutMs = 15_000) {
|
|
53
|
+
const ctrl = new AbortController();
|
|
54
|
+
const timer = setTimeout(() => ctrl.abort(), timeoutMs);
|
|
55
|
+
try {
|
|
56
|
+
const res = await fetch(url, {
|
|
57
|
+
method: "GET",
|
|
58
|
+
headers: { authorization: `Bearer ${apiKey}` },
|
|
59
|
+
signal: ctrl.signal,
|
|
60
|
+
});
|
|
61
|
+
const text = await res.text();
|
|
62
|
+
let parsed = undefined;
|
|
63
|
+
try {
|
|
64
|
+
parsed = text ? JSON.parse(text) : undefined;
|
|
65
|
+
}
|
|
66
|
+
catch {
|
|
67
|
+
/* non-JSON body */
|
|
68
|
+
}
|
|
69
|
+
if (!res.ok) {
|
|
70
|
+
const code = parsed?.code;
|
|
71
|
+
throw new BotfatherHttpError(parsed?.error ?? `HTTP ${res.status}`, res.status, code);
|
|
72
|
+
}
|
|
73
|
+
return parsed;
|
|
74
|
+
}
|
|
75
|
+
finally {
|
|
76
|
+
clearTimeout(timer);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
export function createBotfatherClient(baseUrl) {
|
|
80
|
+
const ingest = (p) => joinUrl(baseUrl, `api/ingest/v1/${p}`);
|
|
81
|
+
return {
|
|
82
|
+
/** token-less self-enrollment → pending (or active if an auto-approve rule matches) */
|
|
83
|
+
async enroll(instance, reportIssueTitles) {
|
|
84
|
+
return postJson(ingest("enroll"), {
|
|
85
|
+
protocolVersion: PROTOCOL_VERSION,
|
|
86
|
+
instance,
|
|
87
|
+
capabilities: { reportIssueTitles, liveStream: false },
|
|
88
|
+
});
|
|
89
|
+
},
|
|
90
|
+
/** poll until approved; returns the per-instance apiKey once active */
|
|
91
|
+
async pollEnrollment(enrollmentId) {
|
|
92
|
+
return postJson(ingest("enroll/poll"), {
|
|
93
|
+
protocolVersion: PROTOCOL_VERSION,
|
|
94
|
+
enrollmentId,
|
|
95
|
+
});
|
|
96
|
+
},
|
|
97
|
+
async heartbeat(apiKey, body) {
|
|
98
|
+
return postJson(ingest("heartbeat"), body, apiKey);
|
|
99
|
+
},
|
|
100
|
+
async sync(apiKey, body) {
|
|
101
|
+
return postJson(ingest("sync"), body, apiKey);
|
|
102
|
+
},
|
|
103
|
+
/** pull the tower's published skill catalog (descriptors only) */
|
|
104
|
+
async skillCatalog(apiKey) {
|
|
105
|
+
return getJson(ingest("skills"), apiKey);
|
|
106
|
+
},
|
|
107
|
+
/** pull full content (markdown + files) for one published skill */
|
|
108
|
+
async skillContent(apiKey, key) {
|
|
109
|
+
return getJson(ingest(`skills/${encodeURIComponent(key)}`), apiKey);
|
|
110
|
+
},
|
|
111
|
+
};
|
|
112
|
+
}
|
|
113
|
+
//# sourceMappingURL=client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client.js","sourceRoot":"","sources":["../../../src/services/botfather/client.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Per-instance botfather credentials, stored outside the squad-scoped secrets
|
|
3
|
+
* vault because this key is instance-level, not squad-level. File mode 0600 at
|
|
4
|
+
* ~/.slaw/instances/<id>/botfather/credentials.json (ARCHITECTURE §6.2).
|
|
5
|
+
*/
|
|
6
|
+
export interface BotfatherCredentials {
|
|
7
|
+
apiKey: string;
|
|
8
|
+
enrollmentId: string;
|
|
9
|
+
enrolledAt: string;
|
|
10
|
+
url: string;
|
|
11
|
+
}
|
|
12
|
+
export declare function readBotfatherCredentials(instanceId?: string): BotfatherCredentials | null;
|
|
13
|
+
export declare function writeBotfatherCredentials(creds: BotfatherCredentials, instanceId?: string): void;
|
|
14
|
+
export declare function clearBotfatherCredentials(instanceId?: string): void;
|
|
15
|
+
//# sourceMappingURL=credentials.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/credentials.ts"],"names":[],"mappings":"AAIA;;;;GAIG;AACH,MAAM,WAAW,oBAAoB;IACnC,MAAM,EAAE,MAAM,CAAC;IACf,YAAY,EAAE,MAAM,CAAC;IACrB,UAAU,EAAE,MAAM,CAAC;IACnB,GAAG,EAAE,MAAM,CAAC;CACb;AAED,wBAAgB,wBAAwB,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,oBAAoB,GAAG,IAAI,CAiBzF;AAED,wBAAgB,yBAAyB,CAAC,KAAK,EAAE,oBAAoB,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAIhG;AAED,wBAAgB,yBAAyB,CAAC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,CAOnE"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { resolveBotfatherCredentialsPath } from "@slaw-ai/shared";
|
|
4
|
+
export function readBotfatherCredentials(instanceId) {
|
|
5
|
+
const file = resolveBotfatherCredentialsPath({ instanceId });
|
|
6
|
+
try {
|
|
7
|
+
if (!fs.existsSync(file))
|
|
8
|
+
return null;
|
|
9
|
+
const parsed = JSON.parse(fs.readFileSync(file, "utf8"));
|
|
10
|
+
if (typeof parsed.apiKey === "string" && parsed.apiKey.length > 0) {
|
|
11
|
+
return {
|
|
12
|
+
apiKey: parsed.apiKey,
|
|
13
|
+
enrollmentId: parsed.enrollmentId ?? "",
|
|
14
|
+
enrolledAt: parsed.enrolledAt ?? "",
|
|
15
|
+
url: parsed.url ?? "",
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
catch {
|
|
20
|
+
/* corrupt → treat as not enrolled */
|
|
21
|
+
}
|
|
22
|
+
return null;
|
|
23
|
+
}
|
|
24
|
+
export function writeBotfatherCredentials(creds, instanceId) {
|
|
25
|
+
const file = resolveBotfatherCredentialsPath({ instanceId });
|
|
26
|
+
fs.mkdirSync(path.dirname(file), { recursive: true });
|
|
27
|
+
fs.writeFileSync(file, JSON.stringify(creds, null, 2), { encoding: "utf8", mode: 0o600 });
|
|
28
|
+
}
|
|
29
|
+
export function clearBotfatherCredentials(instanceId) {
|
|
30
|
+
const file = resolveBotfatherCredentialsPath({ instanceId });
|
|
31
|
+
try {
|
|
32
|
+
if (fs.existsSync(file))
|
|
33
|
+
fs.rmSync(file);
|
|
34
|
+
}
|
|
35
|
+
catch {
|
|
36
|
+
/* best effort */
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=credentials.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"credentials.js","sourceRoot":"","sources":["../../../src/services/botfather/credentials.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,SAAS,CAAC;AACzB,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAE,+BAA+B,EAAE,MAAM,iBAAiB,CAAC;AAclE,MAAM,UAAU,wBAAwB,CAAC,UAAmB;IAC1D,MAAM,IAAI,GAAG,+BAA+B,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7D,IAAI,CAAC;QACH,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,OAAO,IAAI,CAAC;QACtC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,CAAkC,CAAC;QAC1F,IAAI,OAAO,MAAM,CAAC,MAAM,KAAK,QAAQ,IAAI,MAAM,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAClE,OAAO;gBACL,MAAM,EAAE,MAAM,CAAC,MAAM;gBACrB,YAAY,EAAE,MAAM,CAAC,YAAY,IAAI,EAAE;gBACvC,UAAU,EAAE,MAAM,CAAC,UAAU,IAAI,EAAE;gBACnC,GAAG,EAAE,MAAM,CAAC,GAAG,IAAI,EAAE;aACtB,CAAC;QACJ,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,qCAAqC;IACvC,CAAC;IACD,OAAO,IAAI,CAAC;AACd,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,KAA2B,EAAE,UAAmB;IACxF,MAAM,IAAI,GAAG,+BAA+B,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7D,EAAE,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IACtD,EAAE,CAAC,aAAa,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC,CAAC;AAC5F,CAAC;AAED,MAAM,UAAU,yBAAyB,CAAC,UAAmB;IAC3D,MAAM,IAAI,GAAG,+BAA+B,CAAC,EAAE,UAAU,EAAE,CAAC,CAAC;IAC7D,IAAI,CAAC;QACH,IAAI,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IAC3C,CAAC;IAAC,MAAM,CAAC;QACP,iBAAiB;IACnB,CAAC;AACH,CAAC"}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import type { InstanceIdentity } from "@slaw-ai/shared/botfather/protocol";
|
|
2
|
+
/** Gate-facing enrollment state (ARCHITECTURE §6.3). */
|
|
3
|
+
export type EnrollmentState = "connecting" | "pending" | "rejected" | "active" | "unreachable" | "revoked" | "standalone";
|
|
4
|
+
export interface EnrollmentStatus {
|
|
5
|
+
state: EnrollmentState;
|
|
6
|
+
url: string | null;
|
|
7
|
+
enforcement: "enforce" | "advisory";
|
|
8
|
+
machineId: string;
|
|
9
|
+
instanceId: string;
|
|
10
|
+
hostname: string;
|
|
11
|
+
/** true once we hold a valid API key (enrolled at least once) */
|
|
12
|
+
enrolled: boolean;
|
|
13
|
+
detail?: string;
|
|
14
|
+
}
|
|
15
|
+
export declare function buildIdentity(): InstanceIdentity;
|
|
16
|
+
export interface BotfatherSettings {
|
|
17
|
+
url: string | undefined;
|
|
18
|
+
enforcement: "enforce" | "advisory";
|
|
19
|
+
reportIssueTitles: boolean;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Drives the enrollment lifecycle. Holds the current state in memory so the
|
|
23
|
+
* gate API can report it without re-hitting the network on every poll.
|
|
24
|
+
*/
|
|
25
|
+
export declare class BotfatherEnrollment {
|
|
26
|
+
private readonly settings;
|
|
27
|
+
private state;
|
|
28
|
+
private enrollmentId;
|
|
29
|
+
private detail;
|
|
30
|
+
private readonly client;
|
|
31
|
+
readonly identity: InstanceIdentity;
|
|
32
|
+
constructor(settings: BotfatherSettings);
|
|
33
|
+
get apiKey(): string | null;
|
|
34
|
+
status(): EnrollmentStatus;
|
|
35
|
+
/** Should the SLAW UI be blocked behind the gate right now? */
|
|
36
|
+
isGated(): boolean;
|
|
37
|
+
/**
|
|
38
|
+
* One enrollment step. Idempotent + safe to call on an interval until active.
|
|
39
|
+
* Returns the current state after the step.
|
|
40
|
+
*/
|
|
41
|
+
tick(): Promise<EnrollmentState>;
|
|
42
|
+
/** Called by the reporter when a heartbeat/sync returns 401 (revoked). */
|
|
43
|
+
onRevoked(): void;
|
|
44
|
+
/** Force a fresh enrollment (CLI `reenroll`). */
|
|
45
|
+
reenroll(): Promise<EnrollmentState>;
|
|
46
|
+
private persistKey;
|
|
47
|
+
static isRevokedError(err: unknown): boolean;
|
|
48
|
+
}
|
|
49
|
+
//# sourceMappingURL=enrollment.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enrollment.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/enrollment.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAC;AAS3E,wDAAwD;AACxD,MAAM,MAAM,eAAe,GACvB,YAAY,GACZ,SAAS,GACT,UAAU,GACV,QAAQ,GACR,aAAa,GACb,SAAS,GACT,YAAY,CAAC;AAEjB,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,eAAe,CAAC;IACvB,GAAG,EAAE,MAAM,GAAG,IAAI,CAAC;IACnB,WAAW,EAAE,SAAS,GAAG,UAAU,CAAC;IACpC,SAAS,EAAE,MAAM,CAAC;IAClB,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,iEAAiE;IACjE,QAAQ,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAOD,wBAAgB,aAAa,IAAI,gBAAgB,CAShD;AAED,MAAM,WAAW,iBAAiB;IAChC,GAAG,EAAE,MAAM,GAAG,SAAS,CAAC;IACxB,WAAW,EAAE,SAAS,GAAG,UAAU,CAAC;IACpC,iBAAiB,EAAE,OAAO,CAAC;CAC5B;AAED;;;GAGG;AACH,qBAAa,mBAAmB;IAOlB,OAAO,CAAC,QAAQ,CAAC,QAAQ;IANrC,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,YAAY,CAAuB;IAC3C,OAAO,CAAC,MAAM,CAAqB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyB;IAChD,QAAQ,CAAC,QAAQ,EAAE,gBAAgB,CAAC;gBAEP,QAAQ,EAAE,iBAAiB;IAYxD,IAAI,MAAM,IAAI,MAAM,GAAG,IAAI,CAE1B;IAED,MAAM,IAAI,gBAAgB;IAa1B,+DAA+D;IAC/D,OAAO,IAAI,OAAO;IASlB;;;OAGG;IACG,IAAI,IAAI,OAAO,CAAC,eAAe,CAAC;IA2CtC,0EAA0E;IAC1E,SAAS,IAAI,IAAI;IAMjB,iDAAiD;IAC3C,QAAQ,IAAI,OAAO,CAAC,eAAe,CAAC;IAO1C,OAAO,CAAC,UAAU;IAUlB,MAAM,CAAC,cAAc,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO;CAM7C"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import os from "node:os";
|
|
2
|
+
import { loadOrCreateMachineIdentity, resolveSlawInstanceId } from "@slaw-ai/shared";
|
|
3
|
+
import { serverVersion } from "../../version.js";
|
|
4
|
+
import { createBotfatherClient, BotfatherHttpError } from "./client.js";
|
|
5
|
+
import { readBotfatherCredentials, writeBotfatherCredentials, clearBotfatherCredentials, } from "./credentials.js";
|
|
6
|
+
function osTag() {
|
|
7
|
+
const p = process.platform;
|
|
8
|
+
return p === "darwin" || p === "win32" ? p : "linux";
|
|
9
|
+
}
|
|
10
|
+
export function buildIdentity() {
|
|
11
|
+
const machine = loadOrCreateMachineIdentity();
|
|
12
|
+
return {
|
|
13
|
+
machineId: machine.machineId,
|
|
14
|
+
instanceId: resolveSlawInstanceId(),
|
|
15
|
+
hostname: os.hostname(),
|
|
16
|
+
os: osTag(),
|
|
17
|
+
slawVersion: serverVersion,
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
/**
|
|
21
|
+
* Drives the enrollment lifecycle. Holds the current state in memory so the
|
|
22
|
+
* gate API can report it without re-hitting the network on every poll.
|
|
23
|
+
*/
|
|
24
|
+
export class BotfatherEnrollment {
|
|
25
|
+
settings;
|
|
26
|
+
state;
|
|
27
|
+
enrollmentId = null;
|
|
28
|
+
detail;
|
|
29
|
+
client;
|
|
30
|
+
identity;
|
|
31
|
+
constructor(settings) {
|
|
32
|
+
this.settings = settings;
|
|
33
|
+
this.identity = buildIdentity();
|
|
34
|
+
if (!settings.url) {
|
|
35
|
+
this.state = "standalone";
|
|
36
|
+
this.client = null;
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
this.client = createBotfatherClient(settings.url);
|
|
40
|
+
const creds = readBotfatherCredentials();
|
|
41
|
+
this.state = creds ? "active" : "connecting";
|
|
42
|
+
}
|
|
43
|
+
get apiKey() {
|
|
44
|
+
return readBotfatherCredentials()?.apiKey ?? null;
|
|
45
|
+
}
|
|
46
|
+
status() {
|
|
47
|
+
return {
|
|
48
|
+
state: this.state,
|
|
49
|
+
url: this.settings.url ?? null,
|
|
50
|
+
enforcement: this.settings.enforcement,
|
|
51
|
+
machineId: this.identity.machineId,
|
|
52
|
+
instanceId: this.identity.instanceId,
|
|
53
|
+
hostname: this.identity.hostname,
|
|
54
|
+
enrolled: this.apiKey !== null,
|
|
55
|
+
detail: this.detail,
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
/** Should the SLAW UI be blocked behind the gate right now? */
|
|
59
|
+
isGated() {
|
|
60
|
+
if (this.state === "standalone" || this.state === "active")
|
|
61
|
+
return false;
|
|
62
|
+
if (this.settings.enforcement === "advisory")
|
|
63
|
+
return false;
|
|
64
|
+
// enforce: an already-enrolled instance is allowed to run even if the tower
|
|
65
|
+
// is momentarily unreachable (fail-open for the enrolled, §6.4).
|
|
66
|
+
if (this.state === "unreachable" && this.apiKey)
|
|
67
|
+
return false;
|
|
68
|
+
return true;
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* One enrollment step. Idempotent + safe to call on an interval until active.
|
|
72
|
+
* Returns the current state after the step.
|
|
73
|
+
*/
|
|
74
|
+
async tick() {
|
|
75
|
+
if (!this.client || this.state === "standalone")
|
|
76
|
+
return this.state;
|
|
77
|
+
// already have a key → consider ourselves active (heartbeat will detect revocation)
|
|
78
|
+
if (this.apiKey && this.state !== "revoked") {
|
|
79
|
+
this.state = "active";
|
|
80
|
+
return this.state;
|
|
81
|
+
}
|
|
82
|
+
try {
|
|
83
|
+
if (!this.enrollmentId) {
|
|
84
|
+
const res = await this.client.enroll(this.identity, this.settings.reportIssueTitles);
|
|
85
|
+
this.enrollmentId = res.enrollmentId;
|
|
86
|
+
if (res.state === "active" && res.apiKey) {
|
|
87
|
+
this.persistKey(res.apiKey, res.enrollmentId);
|
|
88
|
+
this.state = "active";
|
|
89
|
+
return this.state;
|
|
90
|
+
}
|
|
91
|
+
this.state = res.state === "rejected" ? "rejected" : "pending";
|
|
92
|
+
return this.state;
|
|
93
|
+
}
|
|
94
|
+
const poll = await this.client.pollEnrollment(this.enrollmentId);
|
|
95
|
+
if (poll.state === "active" && poll.apiKey) {
|
|
96
|
+
this.persistKey(poll.apiKey, this.enrollmentId);
|
|
97
|
+
this.state = "active";
|
|
98
|
+
}
|
|
99
|
+
else if (poll.state === "rejected") {
|
|
100
|
+
this.state = "rejected";
|
|
101
|
+
}
|
|
102
|
+
else if (poll.state === "revoked") {
|
|
103
|
+
// revoked mid-flight → restart enrollment
|
|
104
|
+
this.enrollmentId = null;
|
|
105
|
+
this.state = "revoked";
|
|
106
|
+
}
|
|
107
|
+
else {
|
|
108
|
+
this.state = "pending";
|
|
109
|
+
}
|
|
110
|
+
return this.state;
|
|
111
|
+
}
|
|
112
|
+
catch (err) {
|
|
113
|
+
this.detail = err instanceof Error ? err.message : String(err);
|
|
114
|
+
this.state = "unreachable";
|
|
115
|
+
return this.state;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
/** Called by the reporter when a heartbeat/sync returns 401 (revoked). */
|
|
119
|
+
onRevoked() {
|
|
120
|
+
clearBotfatherCredentials();
|
|
121
|
+
this.enrollmentId = null;
|
|
122
|
+
this.state = "revoked";
|
|
123
|
+
}
|
|
124
|
+
/** Force a fresh enrollment (CLI `reenroll`). */
|
|
125
|
+
async reenroll() {
|
|
126
|
+
clearBotfatherCredentials();
|
|
127
|
+
this.enrollmentId = null;
|
|
128
|
+
this.state = "connecting";
|
|
129
|
+
return this.tick();
|
|
130
|
+
}
|
|
131
|
+
persistKey(apiKey, enrollmentId) {
|
|
132
|
+
writeBotfatherCredentials({
|
|
133
|
+
apiKey,
|
|
134
|
+
enrollmentId,
|
|
135
|
+
enrolledAt: new Date().toISOString(),
|
|
136
|
+
url: this.settings.url ?? "",
|
|
137
|
+
});
|
|
138
|
+
this.detail = undefined;
|
|
139
|
+
}
|
|
140
|
+
static isRevokedError(err) {
|
|
141
|
+
return (err instanceof BotfatherHttpError &&
|
|
142
|
+
(err.status === 401 || err.code === "enrollment_revoked"));
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=enrollment.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"enrollment.js","sourceRoot":"","sources":["../../../src/services/botfather/enrollment.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import type { Db } from "@slaw-ai/db";
|
|
2
|
+
import { type StoredInstanceLimit } from "./limits-store.js";
|
|
3
|
+
/**
|
|
4
|
+
* Enforcement for the tower-pushed INSTANCE-WIDE budget limit. This is an
|
|
5
|
+
* additive ceiling layered on top of the existing squad/agent budget policies
|
|
6
|
+
* ("tower caps, local can be stricter"). It is plan-aware: metered/API runs are
|
|
7
|
+
* measured in COST (cents); subscription runs are measured in TOKENS (cost ≈ $0
|
|
8
|
+
* there). An instance running a mix is governed on both axes at once.
|
|
9
|
+
*/
|
|
10
|
+
export interface InstanceUsageMtd {
|
|
11
|
+
/** sum of cost_cents for metered_api rows this calendar month (UTC) */
|
|
12
|
+
meteredCostCents: number;
|
|
13
|
+
/** sum of input+cached+output tokens for subscription rows this month */
|
|
14
|
+
subscriptionTokens: number;
|
|
15
|
+
}
|
|
16
|
+
/** Current month-to-date metered cost (cents) and subscription tokens, instance-wide. */
|
|
17
|
+
export declare function computeInstanceUsageMtd(db: Db): Promise<InstanceUsageMtd>;
|
|
18
|
+
export type LimitMetric = "cost" | "tokens";
|
|
19
|
+
export interface LimitEvaluation {
|
|
20
|
+
/** is any ceiling hit at/over 100%? (block when mode === hard) */
|
|
21
|
+
exceeded: boolean;
|
|
22
|
+
/** is any ceiling at/over warnPercent? */
|
|
23
|
+
warned: boolean;
|
|
24
|
+
/** which metric drove the highest utilisation (for messaging) */
|
|
25
|
+
metric: LimitMetric | null;
|
|
26
|
+
/** observed / ceiling for the driving metric */
|
|
27
|
+
observed: number;
|
|
28
|
+
ceiling: number | null;
|
|
29
|
+
percent: number;
|
|
30
|
+
mode: StoredInstanceLimit["mode"];
|
|
31
|
+
}
|
|
32
|
+
/** Pure evaluation of usage against a stored limit — testable without a DB. */
|
|
33
|
+
export declare function evaluateInstanceLimit(limit: StoredInstanceLimit, usage: InstanceUsageMtd): LimitEvaluation;
|
|
34
|
+
export interface InstanceLimitBlock {
|
|
35
|
+
reason: string;
|
|
36
|
+
metric: LimitMetric;
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* Returns a block when the tower limit is in HARD mode and a ceiling is hit.
|
|
40
|
+
* Soft/off modes never block here (they warn at cost-event time instead).
|
|
41
|
+
* Used as an additive gate at the top of getInvocationBlock.
|
|
42
|
+
*/
|
|
43
|
+
export declare function getInstanceLimitBlock(db: Db): Promise<InstanceLimitBlock | null>;
|
|
44
|
+
//# sourceMappingURL=instance-limit-enforcement.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-limit-enforcement.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/instance-limit-enforcement.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,aAAa,CAAC;AACtC,OAAO,EAAqB,KAAK,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AAEhF;;;;;;GAMG;AAEH,MAAM,WAAW,gBAAgB;IAC/B,uEAAuE;IACvE,gBAAgB,EAAE,MAAM,CAAC;IACzB,yEAAyE;IACzE,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAID,yFAAyF;AACzF,wBAAsB,uBAAuB,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,gBAAgB,CAAC,CAiB/E;AAED,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,QAAQ,CAAC;AAE5C,MAAM,WAAW,eAAe;IAC9B,kEAAkE;IAClE,QAAQ,EAAE,OAAO,CAAC;IAClB,0CAA0C;IAC1C,MAAM,EAAE,OAAO,CAAC;IAChB,iEAAiE;IACjE,MAAM,EAAE,WAAW,GAAG,IAAI,CAAC;IAC3B,gDAAgD;IAChD,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvB,OAAO,EAAE,MAAM,CAAC;IAChB,IAAI,EAAE,mBAAmB,CAAC,MAAM,CAAC,CAAC;CACnC;AAED,+EAA+E;AAC/E,wBAAgB,qBAAqB,CACnC,KAAK,EAAE,mBAAmB,EAC1B,KAAK,EAAE,gBAAgB,GACtB,eAAe,CAqCjB;AAED,MAAM,WAAW,kBAAkB;IACjC,MAAM,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,WAAW,CAAC;CACrB;AAED;;;;GAIG;AACH,wBAAsB,qBAAqB,CAAC,EAAE,EAAE,EAAE,GAAG,OAAO,CAAC,kBAAkB,GAAG,IAAI,CAAC,CActF"}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
import { sql } from "drizzle-orm";
|
|
2
|
+
import { readInstanceLimit } from "./limits-store.js";
|
|
3
|
+
const SUBSCRIPTION_TYPES = ["subscription_included", "subscription_overage"];
|
|
4
|
+
/** Current month-to-date metered cost (cents) and subscription tokens, instance-wide. */
|
|
5
|
+
export async function computeInstanceUsageMtd(db) {
|
|
6
|
+
const res = await db.execute(sql `
|
|
7
|
+
SELECT
|
|
8
|
+
coalesce(sum(case when billing_type = 'metered_api' then cost_cents else 0 end), 0)::double precision
|
|
9
|
+
AS metered_cost_cents,
|
|
10
|
+
coalesce(sum(case when billing_type in ('subscription_included','subscription_overage')
|
|
11
|
+
then input_tokens + cached_input_tokens + output_tokens else 0 end), 0)::double precision
|
|
12
|
+
AS subscription_tokens
|
|
13
|
+
FROM cost_events
|
|
14
|
+
WHERE occurred_at >= date_trunc('month', now() at time zone 'utc')
|
|
15
|
+
`);
|
|
16
|
+
const rows = res.rows ?? res;
|
|
17
|
+
const r = Array.isArray(rows) ? rows[0] : undefined;
|
|
18
|
+
return {
|
|
19
|
+
meteredCostCents: Number(r?.metered_cost_cents ?? 0),
|
|
20
|
+
subscriptionTokens: Number(r?.subscription_tokens ?? 0),
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
/** Pure evaluation of usage against a stored limit — testable without a DB. */
|
|
24
|
+
export function evaluateInstanceLimit(limit, usage) {
|
|
25
|
+
const base = {
|
|
26
|
+
exceeded: false,
|
|
27
|
+
warned: false,
|
|
28
|
+
metric: null,
|
|
29
|
+
observed: 0,
|
|
30
|
+
ceiling: null,
|
|
31
|
+
percent: 0,
|
|
32
|
+
mode: limit.mode,
|
|
33
|
+
};
|
|
34
|
+
if (limit.mode === "off")
|
|
35
|
+
return base;
|
|
36
|
+
const candidates = [
|
|
37
|
+
{ metric: "cost", observed: usage.meteredCostCents, ceiling: limit.costLimitCents },
|
|
38
|
+
{ metric: "tokens", observed: usage.subscriptionTokens, ceiling: limit.tokenLimit },
|
|
39
|
+
];
|
|
40
|
+
let driver = base;
|
|
41
|
+
for (const c of candidates) {
|
|
42
|
+
if (c.ceiling == null || c.ceiling <= 0)
|
|
43
|
+
continue;
|
|
44
|
+
const percent = (c.observed / c.ceiling) * 100;
|
|
45
|
+
const exceeded = c.observed >= c.ceiling;
|
|
46
|
+
const warned = percent >= limit.warnPercent;
|
|
47
|
+
// keep the metric with the highest utilisation as the driver
|
|
48
|
+
if (percent >= driver.percent) {
|
|
49
|
+
driver = {
|
|
50
|
+
exceeded,
|
|
51
|
+
warned,
|
|
52
|
+
metric: c.metric,
|
|
53
|
+
observed: c.observed,
|
|
54
|
+
ceiling: c.ceiling,
|
|
55
|
+
percent: Math.round(percent),
|
|
56
|
+
mode: limit.mode,
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
return driver;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Returns a block when the tower limit is in HARD mode and a ceiling is hit.
|
|
64
|
+
* Soft/off modes never block here (they warn at cost-event time instead).
|
|
65
|
+
* Used as an additive gate at the top of getInvocationBlock.
|
|
66
|
+
*/
|
|
67
|
+
export async function getInstanceLimitBlock(db) {
|
|
68
|
+
const limit = await readInstanceLimit(db);
|
|
69
|
+
if (limit.mode !== "hard")
|
|
70
|
+
return null;
|
|
71
|
+
const usage = await computeInstanceUsageMtd(db);
|
|
72
|
+
const ev = evaluateInstanceLimit(limit, usage);
|
|
73
|
+
if (!ev.exceeded || !ev.metric)
|
|
74
|
+
return null;
|
|
75
|
+
const human = ev.metric === "cost"
|
|
76
|
+
? `$${(ev.observed / 100).toFixed(2)} of $${((ev.ceiling ?? 0) / 100).toFixed(2)}`
|
|
77
|
+
: `${Math.round(ev.observed).toLocaleString()} of ${(ev.ceiling ?? 0).toLocaleString()} tokens`;
|
|
78
|
+
return {
|
|
79
|
+
metric: ev.metric,
|
|
80
|
+
reason: `Control-tower budget limit reached for this instance (${human}). New work is blocked until the limit resets or is raised.`,
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
//# sourceMappingURL=instance-limit-enforcement.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-limit-enforcement.js","sourceRoot":"","sources":["../../../src/services/botfather/instance-limit-enforcement.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"instance-limit-enforcement.test.d.ts","sourceRoot":"","sources":["../../../src/services/botfather/instance-limit-enforcement.test.ts"],"names":[],"mappings":""}
|