@overlordai/server 1.0.53 → 1.0.55
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/database/migrations/001-init-schema.sql +73 -9
- package/dist/adapters/adapter.interface.d.ts +1 -4
- package/dist/adapters/adapter.interface.d.ts.map +1 -1
- package/dist/adapters/adapter.interface.js.map +1 -1
- package/dist/adapters/adapter.module.d.ts.map +1 -1
- package/dist/adapters/adapter.module.js +8 -7
- package/dist/adapters/adapter.module.js.map +1 -1
- package/dist/adapters/lark/lark-card.builder.d.ts +1 -25
- package/dist/adapters/lark/lark-card.builder.d.ts.map +1 -1
- package/dist/adapters/lark/lark-card.builder.js +6 -110
- package/dist/adapters/lark/lark-card.builder.js.map +1 -1
- package/dist/adapters/lark/lark-message.parser.d.ts +4 -4
- package/dist/adapters/lark/lark-message.parser.d.ts.map +1 -1
- package/dist/adapters/lark/lark-message.parser.js +20 -13
- package/dist/adapters/lark/lark-message.parser.js.map +1 -1
- package/dist/adapters/lark/lark-signature.d.ts.map +1 -1
- package/dist/adapters/lark/lark-signature.js +6 -0
- package/dist/adapters/lark/lark-signature.js.map +1 -1
- package/dist/adapters/lark/lark.adapter.d.ts +14 -9
- package/dist/adapters/lark/lark.adapter.d.ts.map +1 -1
- package/dist/adapters/lark/lark.adapter.js +99 -177
- package/dist/adapters/lark/lark.adapter.js.map +1 -1
- package/dist/adapters/lark/lark.controller.d.ts +10 -1
- package/dist/adapters/lark/lark.controller.d.ts.map +1 -1
- package/dist/adapters/lark/lark.controller.js +48 -14
- package/dist/adapters/lark/lark.controller.js.map +1 -1
- package/dist/adapters/slack/slack-block.builder.d.ts +8 -0
- package/dist/adapters/slack/slack-block.builder.d.ts.map +1 -0
- package/dist/adapters/slack/slack-block.builder.js +117 -0
- package/dist/adapters/slack/slack-block.builder.js.map +1 -0
- package/dist/adapters/slack/slack-message.parser.d.ts +15 -0
- package/dist/adapters/slack/slack-message.parser.d.ts.map +1 -0
- package/dist/adapters/slack/slack-message.parser.js +158 -0
- package/dist/adapters/slack/slack-message.parser.js.map +1 -0
- package/dist/adapters/slack/slack-signature.d.ts +7 -0
- package/dist/adapters/slack/slack-signature.d.ts.map +1 -0
- package/dist/adapters/slack/slack-signature.js +59 -0
- package/dist/adapters/slack/slack-signature.js.map +1 -0
- package/dist/adapters/slack/slack.adapter.d.ts +67 -13
- package/dist/adapters/slack/slack.adapter.d.ts.map +1 -1
- package/dist/adapters/slack/slack.adapter.js +468 -19
- package/dist/adapters/slack/slack.adapter.js.map +1 -1
- package/dist/adapters/slack/slack.controller.d.ts +20 -0
- package/dist/adapters/slack/slack.controller.d.ts.map +1 -0
- package/dist/adapters/slack/slack.controller.js +257 -0
- package/dist/adapters/slack/slack.controller.js.map +1 -0
- package/dist/app.module.d.ts.map +1 -1
- package/dist/app.module.js +4 -0
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts.map +1 -1
- package/dist/auth/auth.controller.js +1 -0
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.module.d.ts.map +1 -1
- package/dist/auth/auth.module.js +4 -5
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +9 -2
- package/dist/auth/auth.service.d.ts.map +1 -1
- package/dist/auth/auth.service.js +50 -79
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/auth/authenticated-request.d.ts +10 -0
- package/dist/auth/authenticated-request.d.ts.map +1 -0
- package/dist/auth/authenticated-request.js +3 -0
- package/dist/auth/authenticated-request.js.map +1 -0
- package/dist/auth/extract-user.middleware.d.ts.map +1 -1
- package/dist/auth/extract-user.middleware.js +2 -1
- package/dist/auth/extract-user.middleware.js.map +1 -1
- package/dist/auth/guards/jwt-auth.guard.d.ts.map +1 -1
- package/dist/auth/guards/jwt-auth.guard.js +5 -2
- package/dist/auth/guards/jwt-auth.guard.js.map +1 -1
- package/dist/auth/guards/project-role.guard.d.ts.map +1 -1
- package/dist/auth/guards/project-role.guard.js +6 -8
- package/dist/auth/guards/project-role.guard.js.map +1 -1
- package/dist/auth/jwt.strategy.d.ts +6 -3
- package/dist/auth/jwt.strategy.d.ts.map +1 -1
- package/dist/auth/jwt.strategy.js +15 -5
- package/dist/auth/jwt.strategy.js.map +1 -1
- package/dist/common/command-parser.d.ts +29 -0
- package/dist/common/command-parser.d.ts.map +1 -0
- package/dist/common/command-parser.js +133 -0
- package/dist/common/command-parser.js.map +1 -0
- package/dist/common/config.d.ts +17 -0
- package/dist/common/config.d.ts.map +1 -0
- package/dist/common/config.js +47 -0
- package/dist/common/config.js.map +1 -0
- package/dist/common/crypto.service.d.ts +4 -1
- package/dist/common/crypto.service.d.ts.map +1 -1
- package/dist/common/crypto.service.js +14 -7
- package/dist/common/crypto.service.js.map +1 -1
- package/dist/common/error-filter.d.ts +1 -0
- package/dist/common/error-filter.d.ts.map +1 -1
- package/dist/common/error-filter.js +6 -2
- package/dist/common/error-filter.js.map +1 -1
- package/dist/common/git-utils.d.ts +9 -0
- package/dist/common/git-utils.d.ts.map +1 -0
- package/dist/common/git-utils.js +41 -0
- package/dist/common/git-utils.js.map +1 -0
- package/dist/common/health.controller.d.ts.map +1 -1
- package/dist/common/health.controller.js +3 -5
- package/dist/common/health.controller.js.map +1 -1
- package/dist/common/machine-utils.d.ts +32 -0
- package/dist/common/machine-utils.d.ts.map +1 -0
- package/dist/common/machine-utils.js +12 -0
- package/dist/common/machine-utils.js.map +1 -0
- package/dist/common/pagination.d.ts +12 -5
- package/dist/common/pagination.d.ts.map +1 -1
- package/dist/common/pagination.js +27 -17
- package/dist/common/pagination.js.map +1 -1
- package/dist/common/project-validation.d.ts +7 -0
- package/dist/common/project-validation.d.ts.map +1 -0
- package/dist/common/project-validation.js +86 -0
- package/dist/common/project-validation.js.map +1 -0
- package/dist/common/rate-limit.guard.d.ts +4 -3
- package/dist/common/rate-limit.guard.d.ts.map +1 -1
- package/dist/common/rate-limit.guard.js +14 -5
- package/dist/common/rate-limit.guard.js.map +1 -1
- package/dist/common/sql-utils.d.ts +6 -0
- package/dist/common/sql-utils.d.ts.map +1 -0
- package/dist/common/sql-utils.js +11 -0
- package/dist/common/sql-utils.js.map +1 -0
- package/dist/common/string-utils.d.ts +6 -0
- package/dist/common/string-utils.d.ts.map +1 -0
- package/dist/common/string-utils.js +15 -0
- package/dist/common/string-utils.js.map +1 -0
- package/dist/common/worker-utils.d.ts +31 -0
- package/dist/common/worker-utils.d.ts.map +1 -0
- package/dist/common/worker-utils.js +12 -0
- package/dist/common/worker-utils.js.map +1 -0
- package/dist/database/base.repository.d.ts +56 -0
- package/dist/database/base.repository.d.ts.map +1 -0
- package/dist/database/base.repository.js +82 -0
- package/dist/database/base.repository.js.map +1 -0
- package/dist/database/database.service.d.ts.map +1 -1
- package/dist/database/database.service.js +9 -1
- package/dist/database/database.service.js.map +1 -1
- package/dist/database/migration-runner.d.ts.map +1 -1
- package/dist/database/migration-runner.js +2 -1
- package/dist/database/migration-runner.js.map +1 -1
- package/dist/database/repositories/audit-log.repository.d.ts.map +1 -1
- package/dist/database/repositories/audit-log.repository.js +16 -18
- package/dist/database/repositories/audit-log.repository.js.map +1 -1
- package/dist/database/repositories/bot.repository.d.ts +18 -32
- package/dist/database/repositories/bot.repository.d.ts.map +1 -1
- package/dist/database/repositories/bot.repository.js +42 -21
- package/dist/database/repositories/bot.repository.js.map +1 -1
- package/dist/database/repositories/developer-token.repository.d.ts +7 -17
- package/dist/database/repositories/developer-token.repository.d.ts.map +1 -1
- package/dist/database/repositories/developer-token.repository.js +24 -15
- package/dist/database/repositories/developer-token.repository.js.map +1 -1
- package/dist/database/repositories/developer.repository.d.ts +5 -1
- package/dist/database/repositories/developer.repository.d.ts.map +1 -1
- package/dist/database/repositories/developer.repository.js +60 -49
- package/dist/database/repositories/developer.repository.js.map +1 -1
- package/dist/database/repositories/machine.repository.d.ts.map +1 -1
- package/dist/database/repositories/machine.repository.js +2 -7
- package/dist/database/repositories/machine.repository.js.map +1 -1
- package/dist/database/repositories/notification.repository.d.ts +1 -0
- package/dist/database/repositories/notification.repository.d.ts.map +1 -1
- package/dist/database/repositories/notification.repository.js +25 -20
- package/dist/database/repositories/notification.repository.js.map +1 -1
- package/dist/database/repositories/project-member.repository.d.ts +7 -16
- package/dist/database/repositories/project-member.repository.d.ts.map +1 -1
- package/dist/database/repositories/project-member.repository.js +34 -24
- package/dist/database/repositories/project-member.repository.js.map +1 -1
- package/dist/database/repositories/project.repository.d.ts +2 -1
- package/dist/database/repositories/project.repository.d.ts.map +1 -1
- package/dist/database/repositories/project.repository.js +70 -71
- package/dist/database/repositories/project.repository.js.map +1 -1
- package/dist/database/repositories/session.repository.d.ts.map +1 -1
- package/dist/database/repositories/session.repository.js +22 -25
- package/dist/database/repositories/session.repository.js.map +1 -1
- package/dist/database/repositories/task.repository.d.ts +31 -7
- package/dist/database/repositories/task.repository.d.ts.map +1 -1
- package/dist/database/repositories/task.repository.js +134 -86
- package/dist/database/repositories/task.repository.js.map +1 -1
- package/dist/database/repositories/worker-token.repository.d.ts.map +1 -1
- package/dist/database/repositories/worker-token.repository.js +18 -16
- package/dist/database/repositories/worker-token.repository.js.map +1 -1
- package/dist/database/repositories/worker.repository.d.ts +50 -0
- package/dist/database/repositories/worker.repository.d.ts.map +1 -0
- package/dist/database/repositories/worker.repository.js +215 -0
- package/dist/database/repositories/worker.repository.js.map +1 -0
- package/dist/database/repositories/workspace.repository.d.ts +3 -2
- package/dist/database/repositories/workspace.repository.d.ts.map +1 -1
- package/dist/database/repositories/workspace.repository.js +29 -21
- package/dist/database/repositories/workspace.repository.js.map +1 -1
- package/dist/database/repository.module.d.ts +3 -0
- package/dist/database/repository.module.d.ts.map +1 -0
- package/dist/database/repository.module.js +45 -0
- package/dist/database/repository.module.js.map +1 -0
- package/dist/dispatcher/capability.service.d.ts +19 -14
- package/dist/dispatcher/capability.service.d.ts.map +1 -1
- package/dist/dispatcher/capability.service.js +77 -69
- package/dist/dispatcher/capability.service.js.map +1 -1
- package/dist/dispatcher/cleanup.service.d.ts +1 -1
- package/dist/dispatcher/cleanup.service.d.ts.map +1 -1
- package/dist/dispatcher/cleanup.service.js +13 -13
- package/dist/dispatcher/cleanup.service.js.map +1 -1
- package/dist/dispatcher/dedup.service.d.ts +17 -3
- package/dist/dispatcher/dedup.service.d.ts.map +1 -1
- package/dist/dispatcher/dedup.service.js +76 -82
- package/dist/dispatcher/dedup.service.js.map +1 -1
- package/dist/dispatcher/dispatcher.module.d.ts.map +1 -1
- package/dist/dispatcher/dispatcher.module.js +11 -18
- package/dist/dispatcher/dispatcher.module.js.map +1 -1
- package/dist/dispatcher/dispatcher.service.d.ts +14 -116
- package/dist/dispatcher/dispatcher.service.d.ts.map +1 -1
- package/dist/dispatcher/dispatcher.service.js +62 -940
- package/dist/dispatcher/dispatcher.service.js.map +1 -1
- package/dist/dispatcher/dispatcher.types.d.ts +33 -0
- package/dist/dispatcher/dispatcher.types.d.ts.map +1 -0
- package/dist/dispatcher/dispatcher.types.js +3 -0
- package/dist/dispatcher/dispatcher.types.js.map +1 -0
- package/dist/dispatcher/heartbeat.service.d.ts +17 -10
- package/dist/dispatcher/heartbeat.service.d.ts.map +1 -1
- package/dist/dispatcher/heartbeat.service.js +47 -51
- package/dist/dispatcher/heartbeat.service.js.map +1 -1
- package/dist/dispatcher/pty-relay.service.d.ts.map +1 -1
- package/dist/dispatcher/pty-relay.service.js +7 -15
- package/dist/dispatcher/pty-relay.service.js.map +1 -1
- package/dist/dispatcher/reconciler.d.ts +18 -8
- package/dist/dispatcher/reconciler.d.ts.map +1 -1
- package/dist/dispatcher/reconciler.js +219 -130
- package/dist/dispatcher/reconciler.js.map +1 -1
- package/dist/dispatcher/scheduler.service.d.ts +15 -9
- package/dist/dispatcher/scheduler.service.d.ts.map +1 -1
- package/dist/dispatcher/scheduler.service.js +95 -53
- package/dist/dispatcher/scheduler.service.js.map +1 -1
- package/dist/dispatcher/state-machine.d.ts.map +1 -1
- package/dist/dispatcher/state-machine.js +1 -5
- package/dist/dispatcher/state-machine.js.map +1 -1
- package/dist/dispatcher/task-creation.service.d.ts +30 -0
- package/dist/dispatcher/task-creation.service.d.ts.map +1 -0
- package/dist/dispatcher/task-creation.service.js +242 -0
- package/dist/dispatcher/task-creation.service.js.map +1 -0
- package/dist/dispatcher/task-lifecycle.service.d.ts +63 -0
- package/dist/dispatcher/task-lifecycle.service.d.ts.map +1 -0
- package/dist/dispatcher/task-lifecycle.service.js +584 -0
- package/dist/dispatcher/task-lifecycle.service.js.map +1 -0
- package/dist/dispatcher/task-log-batcher.d.ts.map +1 -1
- package/dist/dispatcher/task-log-batcher.js +4 -11
- package/dist/dispatcher/task-log-batcher.js.map +1 -1
- package/dist/dispatcher/worker-auth.service.d.ts +29 -0
- package/dist/dispatcher/worker-auth.service.d.ts.map +1 -0
- package/dist/dispatcher/worker-auth.service.js +296 -0
- package/dist/dispatcher/worker-auth.service.js.map +1 -0
- package/dist/dispatcher/worker-connection.manager.d.ts +15 -15
- package/dist/dispatcher/worker-connection.manager.d.ts.map +1 -1
- package/dist/dispatcher/worker-connection.manager.js +35 -43
- package/dist/dispatcher/worker-connection.manager.js.map +1 -1
- package/dist/dispatcher/worker-selector.d.ts +18 -0
- package/dist/dispatcher/worker-selector.d.ts.map +1 -0
- package/dist/dispatcher/worker-selector.js +150 -0
- package/dist/dispatcher/worker-selector.js.map +1 -0
- package/dist/events/event-types.d.ts +31 -0
- package/dist/events/event-types.d.ts.map +1 -0
- package/dist/events/event-types.js +16 -0
- package/dist/events/event-types.js.map +1 -0
- package/dist/events/events.module.d.ts +7 -0
- package/dist/events/events.module.d.ts.map +1 -0
- package/dist/events/events.module.js +26 -0
- package/dist/events/events.module.js.map +1 -0
- package/dist/main.js +22 -0
- package/dist/main.js.map +1 -1
- package/dist/notifier/debouncer.d.ts +1 -1
- package/dist/notifier/debouncer.d.ts.map +1 -1
- package/dist/notifier/debouncer.js +2 -1
- package/dist/notifier/debouncer.js.map +1 -1
- package/dist/notifier/notification-consumer.d.ts +1 -1
- package/dist/notifier/notification-consumer.d.ts.map +1 -1
- package/dist/notifier/notification-consumer.js +5 -5
- package/dist/notifier/notification-consumer.js.map +1 -1
- package/dist/notifier/notifier.module.d.ts.map +1 -1
- package/dist/notifier/notifier.module.js +0 -6
- package/dist/notifier/notifier.module.js.map +1 -1
- package/dist/notifier/notifier.service.d.ts +1 -1
- package/dist/notifier/notifier.service.d.ts.map +1 -1
- package/dist/notifier/notifier.service.js +7 -9
- package/dist/notifier/notifier.service.js.map +1 -1
- package/dist/notifier/template.service.d.ts +1 -1
- package/dist/notifier/template.service.d.ts.map +1 -1
- package/dist/notifier/template.service.js +6 -10
- package/dist/notifier/template.service.js.map +1 -1
- package/dist/redis/redis.service.d.ts.map +1 -1
- package/dist/redis/redis.service.js +2 -2
- package/dist/redis/redis.service.js.map +1 -1
- package/dist/web/admin/admin-audit.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-audit.controller.js +2 -1
- package/dist/web/admin/admin-audit.controller.js.map +1 -1
- package/dist/web/admin/admin-bot.controller.d.ts +11 -48
- package/dist/web/admin/admin-bot.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-bot.controller.js +50 -18
- package/dist/web/admin/admin-bot.controller.js.map +1 -1
- package/dist/web/admin/admin-developer.controller.d.ts +14 -27
- package/dist/web/admin/admin-developer.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-developer.controller.js +62 -28
- package/dist/web/admin/admin-developer.controller.js.map +1 -1
- package/dist/web/admin/admin-machine.controller.d.ts +1 -8
- package/dist/web/admin/admin-machine.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-machine.controller.js +3 -6
- package/dist/web/admin/admin-machine.controller.js.map +1 -1
- package/dist/web/admin/admin-project.controller.d.ts +9 -30
- package/dist/web/admin/admin-project.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-project.controller.js +15 -60
- package/dist/web/admin/admin-project.controller.js.map +1 -1
- package/dist/web/admin/admin-settings.controller.d.ts +7 -10
- package/dist/web/admin/admin-settings.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-settings.controller.js +14 -6
- package/dist/web/admin/admin-settings.controller.js.map +1 -1
- package/dist/web/admin/admin-token.controller.d.ts +6 -13
- package/dist/web/admin/admin-token.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-token.controller.js +15 -27
- package/dist/web/admin/admin-token.controller.js.map +1 -1
- package/dist/web/admin/admin-worker.controller.d.ts +26 -0
- package/dist/web/admin/admin-worker.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-worker.controller.js +184 -0
- package/dist/web/admin/admin-worker.controller.js.map +1 -0
- package/dist/web/dashboard.controller.d.ts +6 -12
- package/dist/web/dashboard.controller.d.ts.map +1 -1
- package/dist/web/dashboard.controller.js +30 -18
- package/dist/web/dashboard.controller.js.map +1 -1
- package/dist/web/dashboard.service.d.ts +21 -12
- package/dist/web/dashboard.service.d.ts.map +1 -1
- package/dist/web/dashboard.service.js +169 -119
- package/dist/web/dashboard.service.js.map +1 -1
- package/dist/web/event.gateway.d.ts +32 -0
- package/dist/web/event.gateway.d.ts.map +1 -0
- package/dist/web/event.gateway.js +168 -0
- package/dist/web/event.gateway.js.map +1 -0
- package/dist/web/frame-handlers/frame-handler.interface.d.ts +24 -0
- package/dist/web/frame-handlers/frame-handler.interface.d.ts.map +1 -0
- package/dist/web/frame-handlers/frame-handler.interface.js +3 -0
- package/dist/web/frame-handlers/frame-handler.interface.js.map +1 -0
- package/dist/web/frame-handlers/frame-handler.registry.d.ts +16 -0
- package/dist/web/frame-handlers/frame-handler.registry.d.ts.map +1 -0
- package/dist/web/frame-handlers/frame-handler.registry.js +39 -0
- package/dist/web/frame-handlers/frame-handler.registry.js.map +1 -0
- package/dist/web/frame-handlers/heartbeat.handler.d.ts +13 -0
- package/dist/web/frame-handlers/heartbeat.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/heartbeat.handler.js +35 -0
- package/dist/web/frame-handlers/heartbeat.handler.js.map +1 -0
- package/dist/web/frame-handlers/index.d.ts +7 -0
- package/dist/web/frame-handlers/index.d.ts.map +1 -0
- package/dist/web/frame-handlers/index.js +14 -0
- package/dist/web/frame-handlers/index.js.map +1 -0
- package/dist/web/frame-handlers/progress.handler.d.ts +25 -0
- package/dist/web/frame-handlers/progress.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/progress.handler.js +69 -0
- package/dist/web/frame-handlers/progress.handler.js.map +1 -0
- package/dist/web/frame-handlers/stage-confirm.handler.d.ts +15 -0
- package/dist/web/frame-handlers/stage-confirm.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/stage-confirm.handler.js +39 -0
- package/dist/web/frame-handlers/stage-confirm.handler.js.map +1 -0
- package/dist/web/frame-handlers/tunnel.handler.d.ts +10 -0
- package/dist/web/frame-handlers/tunnel.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/tunnel.handler.js +31 -0
- package/dist/web/frame-handlers/tunnel.handler.js.map +1 -0
- package/dist/web/interaction.service.d.ts +0 -4
- package/dist/web/interaction.service.d.ts.map +1 -1
- package/dist/web/interaction.service.js +0 -10
- package/dist/web/interaction.service.js.map +1 -1
- package/dist/web/machine.controller.d.ts +1 -8
- package/dist/web/machine.controller.d.ts.map +1 -1
- package/dist/web/machine.controller.js +6 -9
- package/dist/web/machine.controller.js.map +1 -1
- package/dist/web/notification.controller.d.ts +1 -8
- package/dist/web/notification.controller.d.ts.map +1 -1
- package/dist/web/notification.controller.js +3 -2
- package/dist/web/notification.controller.js.map +1 -1
- package/dist/web/profile.controller.d.ts +19 -10
- package/dist/web/profile.controller.d.ts.map +1 -1
- package/dist/web/profile.controller.js +100 -13
- package/dist/web/profile.controller.js.map +1 -1
- package/dist/web/project-member.service.d.ts +16 -0
- package/dist/web/project-member.service.d.ts.map +1 -0
- package/dist/web/project-member.service.js +90 -0
- package/dist/web/project-member.service.js.map +1 -0
- package/dist/web/project.controller.d.ts +43 -26
- package/dist/web/project.controller.d.ts.map +1 -1
- package/dist/web/project.controller.js +73 -46
- package/dist/web/project.controller.js.map +1 -1
- package/dist/web/pty.gateway.d.ts +9 -3
- package/dist/web/pty.gateway.d.ts.map +1 -1
- package/dist/web/pty.gateway.js +46 -18
- package/dist/web/pty.gateway.js.map +1 -1
- package/dist/web/search.service.d.ts +9 -2
- package/dist/web/search.service.d.ts.map +1 -1
- package/dist/web/search.service.js +53 -26
- package/dist/web/search.service.js.map +1 -1
- package/dist/web/task.controller.d.ts +15 -24
- package/dist/web/task.controller.d.ts.map +1 -1
- package/dist/web/task.controller.js +70 -53
- package/dist/web/task.controller.js.map +1 -1
- package/dist/web/tunnel.service.d.ts +74 -0
- package/dist/web/tunnel.service.d.ts.map +1 -0
- package/dist/web/tunnel.service.js +250 -0
- package/dist/web/tunnel.service.js.map +1 -0
- package/dist/web/web-event.service.d.ts +25 -0
- package/dist/web/web-event.service.d.ts.map +1 -0
- package/dist/web/web-event.service.js +116 -0
- package/dist/web/web-event.service.js.map +1 -0
- package/dist/web/web.module.d.ts.map +1 -1
- package/dist/web/web.module.js +13 -28
- package/dist/web/web.module.js.map +1 -1
- package/dist/web/worker-channel.gateway.d.ts +10 -18
- package/dist/web/worker-channel.gateway.d.ts.map +1 -1
- package/dist/web/worker-channel.gateway.js +70 -144
- package/dist/web/worker-channel.gateway.js.map +1 -1
- package/dist/web/worker-web.controller.d.ts +15 -0
- package/dist/web/worker-web.controller.d.ts.map +1 -0
- package/dist/web/worker-web.controller.js +143 -0
- package/dist/web/worker-web.controller.js.map +1 -0
- package/dist/web/worker.controller.d.ts +3 -3
- package/dist/web/worker.controller.d.ts.map +1 -1
- package/dist/web/worker.controller.js +8 -8
- package/dist/web/worker.controller.js.map +1 -1
- package/dist/web/workspace.controller.d.ts +8 -33
- package/dist/web/workspace.controller.d.ts.map +1 -1
- package/dist/web/workspace.controller.js +93 -205
- package/dist/web/workspace.controller.js.map +1 -1
- package/package.json +10 -2
- package/public/apple-touch-icon-120x120.png +0 -0
- package/public/apple-touch-icon-152x152.png +0 -0
- package/public/apple-touch-icon-180x180.png +0 -0
- package/public/assets/AccessTokensPage-DPQB2fbi.js +1 -0
- package/public/assets/AdminPage-BqVelYNu.js +1 -0
- package/public/assets/ApiReferencePage-CiGvbLxL.js +1 -0
- package/public/assets/AuditLogPage-DSo4jVYm.js +6 -0
- package/public/assets/BindPlatformPage-CTqzpOmt.js +1 -0
- package/public/assets/BotManage-CIR0rrK7.js +6 -0
- package/public/assets/CliReferencePage-C8GmlwUz.js +14 -0
- package/public/assets/DeveloperManage-r6y2AoB4.js +16 -0
- package/public/assets/EditProjectPage-7WCsNltj.js +2 -0
- package/public/assets/{EmptyState-CvmhFgWJ.js → EmptyState-D3foEiul.js} +1 -1
- package/public/assets/HomePage-D4yv4orb.js +1 -0
- package/public/assets/InfoRow-DhdTYoY9.js +1 -0
- package/public/assets/LandingPage-CqS0E2eC.js +43 -0
- package/public/assets/LoginPage-DDXkdcz_.js +1 -0
- package/public/assets/MetricBar-DMMHfS0A.js +1 -0
- package/public/assets/{NotFoundPage-BuiAS4g4.js → NotFoundPage-D5x5BrlX.js} +1 -1
- package/public/assets/OnboardingGuide-D8RyPcEd.js +1 -0
- package/public/assets/PipelineEditorPage-y2-Q8ofQ.js +3 -0
- package/public/assets/ProfilePage-DN7usHOi.js +1 -0
- package/public/assets/ProjectDetailPage-DJexg49z.js +7 -0
- package/public/assets/ProjectListPage-Bz7I2D0H.js +6 -0
- package/public/assets/QuickAuth-Dr0Q50ld.js +1 -0
- package/public/assets/{RemoveMemberConfirmDialog-DS9z6jQT.js → RemoveMemberConfirmDialog-BCrue0AP.js} +2 -2
- package/public/assets/Select-BnV8yZlD.js +6 -0
- package/public/assets/SettingsPage-HaUCcsgl.js +6 -0
- package/public/assets/{Skeleton-CcVqz28_.js → Skeleton-DUgWc2LJ.js} +1 -1
- package/public/assets/SkillPage-BInwZTQh.js +1 -0
- package/public/assets/TaskDetailPage-CfwEj1hy.js +31 -0
- package/public/assets/TaskListPage-Dh59ldSZ.js +1 -0
- package/public/assets/TaskStatusBadge-DuOoGIwE.js +1 -0
- package/public/assets/TerminalHomePage-BwXJjr-a.js +16 -0
- package/public/assets/TokenManage-B0Cpv6SO.js +1 -0
- package/public/assets/TotpSetupPage-MSCCURj9.js +9 -0
- package/public/assets/WorkerDetailPage-R2veIzKo.js +1 -0
- package/public/assets/WorkerListPage-CserMjGO.js +6 -0
- package/public/assets/WorkerSetupGuidePage-SqO2lzVa.js +11 -0
- package/public/assets/{arrow-left-CVKez32c.js → arrow-left-DklRsENx.js} +1 -1
- package/public/assets/{arrow-right-g7hTftEi.js → arrow-right-MDrzFe3K.js} +1 -1
- package/public/assets/{bot-DYvBcsZn.js → bot-DPaziJPf.js} +1 -1
- package/public/assets/{chevron-right-COxU2yxz.js → chevron-right-CqyufMDW.js} +1 -1
- package/public/assets/{copy-BGttVgA1.js → copy-BUH7P2Hf.js} +1 -1
- package/public/assets/date-BdNtiQTP.js +1 -0
- package/public/assets/{external-link-DXlCfUjE.js → external-link-ChPgQ7N_.js} +1 -1
- package/public/assets/index-BS0Fbx5V.css +1 -0
- package/public/assets/index-vL7aQJNr.js +225 -0
- package/public/assets/{key-3eDVdGih.js → key-CxvwwHnW.js} +1 -1
- package/public/assets/{loader-circle-DPm92ETj.js → loader-circle-DS5g1-Od.js} +1 -1
- package/public/assets/password-CHk45-jw.js +1 -0
- package/public/assets/{pencil-Bs3PwH2W.js → pencil-B6spIBcw.js} +1 -1
- package/public/assets/{plus-d-PLzbVX.js → plus-Bnd1Vz2Y.js} +1 -1
- package/public/assets/{rotate-ccw-Cus8CABi.js → rotate-ccw-CgcLAXNR.js} +1 -1
- package/public/assets/{scroll-text-CV3wlIy2.js → scroll-text-CecZ0Fk5.js} +1 -1
- package/public/assets/{settings-Ccijf48b.js → settings-C1uOD3PZ.js} +1 -1
- package/public/assets/status-colors-BPEUp90-.js +1 -0
- package/public/assets/string-B39tzdVK.js +1 -0
- package/public/assets/task-constants-BbFyCyKk.js +14 -0
- package/public/assets/task.store-BE6fEPu4.js +1 -0
- package/public/assets/{trash-2-bRJ-xwtq.js → trash-2-A2FsT1yG.js} +1 -1
- package/public/assets/useFetch-vGZMAvGi.js +1 -0
- package/public/assets/{users-LNQqKSEN.js → users-CEdRS_A3.js} +1 -1
- package/public/assets/wifi-D60NkK6F.js +6 -0
- package/public/assets/zap-DXw1NrWz.js +6 -0
- package/public/icon-192x192.png +0 -0
- package/public/icon-512x512.png +0 -0
- package/public/icon-maskable-192x192.png +0 -0
- package/public/icon-maskable-512x512.png +0 -0
- package/public/index.html +21 -4
- package/public/manifest.webmanifest +1 -0
- package/public/og-image.png +0 -0
- package/public/registerSW.js +1 -0
- package/public/sw.js +1 -0
- package/public/workbox-6e9b121d.js +1 -0
- package/database/migrations/002-add-indexes.sql +0 -17
- package/database/migrations/003-add-settings-table.sql +0 -4
- package/database/migrations/004-add-developer-id-index.sql +0 -5
- package/database/migrations/005-add-worker-version.sql +0 -2
- package/database/migrations/006-add-decommission-fields.sql +0 -2
- package/database/migrations/007-add-ssh-url.sql +0 -1
- package/public/assets/AccessTokensPage-Cb5hGBfN.js +0 -1
- package/public/assets/AdminPage-C7Xytkfo.js +0 -1
- package/public/assets/ApiReferencePage-DLGVc4xN.js +0 -1
- package/public/assets/AuditLogPage-BgqsUJ7x.js +0 -6
- package/public/assets/BotManage-Ds9DYQZA.js +0 -6
- package/public/assets/CliReferencePage-WXinn_69.js +0 -8
- package/public/assets/DeveloperManage-saSq3Hfx.js +0 -16
- package/public/assets/EditProjectPage-C4xWYLTo.js +0 -2
- package/public/assets/HomePage-y20pQ52r.js +0 -1
- package/public/assets/LandingPage-CB5BBbdI.js +0 -36
- package/public/assets/LoginPage-DLljhJkQ.js +0 -1
- package/public/assets/MachineDetailPage-CPm9tfdp.js +0 -1
- package/public/assets/MachineListPage-D-nhVz-m.js +0 -6
- package/public/assets/PipelineEditorPage-B9GgqAju.js +0 -3
- package/public/assets/ProfilePage-DASpeJq6.js +0 -1
- package/public/assets/ProjectDetailPage-DWZyNwTV.js +0 -7
- package/public/assets/ProjectListPage-BUMX3Dxa.js +0 -6
- package/public/assets/QuickAuth-B9mvq7ht.js +0 -1
- package/public/assets/Select-A7PXobk_.js +0 -6
- package/public/assets/SettingsPage-WGzxUbGp.js +0 -6
- package/public/assets/SkillPage-BIt2kF3W.js +0 -1
- package/public/assets/TaskDetailPage-CePyNfp6.js +0 -44
- package/public/assets/TaskListPage-MO4_PSve.js +0 -1
- package/public/assets/TaskStatusBadge-QtQUDscM.js +0 -1
- package/public/assets/TokenManage-Sf0RGymw.js +0 -1
- package/public/assets/TotpSetupPage-D-rbEYLf.js +0 -9
- package/public/assets/WorkerSetupGuidePage-D6Fv1MQo.js +0 -16
- package/public/assets/index-CDBuOPx4.js +0 -212
- package/public/assets/index-CQojj7Zu.css +0 -1
- package/public/assets/protocol-C5uQmiiB.js +0 -1
- package/public/assets/task.store-CvjSr507.js +0 -1
- /package/public/assets/{TaskDetailPage-Beg8tuEN.css → task-constants-Beg8tuEN.css} +0 -0
|
@@ -20,122 +20,115 @@ const RECOVERY_DELAYS = {
|
|
|
20
20
|
};
|
|
21
21
|
let CapabilityService = CapabilityService_1 = class CapabilityService {
|
|
22
22
|
logger = new common_1.Logger(CapabilityService_1.name);
|
|
23
|
-
/**
|
|
23
|
+
/** workerId -> agentType -> failure record */
|
|
24
24
|
failureRecords = new Map();
|
|
25
|
-
/**
|
|
25
|
+
/** workerId -> Set of degraded agent types */
|
|
26
26
|
degraded = new Map();
|
|
27
|
-
/** Timers for auto-recovery, keyed by `${
|
|
27
|
+
/** Timers for auto-recovery, keyed by `${workerId}:${agentType}` */
|
|
28
28
|
recoveryTimers = new Map();
|
|
29
29
|
/**
|
|
30
|
-
* Record a failure for a specific agent type on a
|
|
30
|
+
* Record a failure for a specific agent type on a worker.
|
|
31
31
|
* After DEGRADATION_THRESHOLD consecutive failures the capability is marked
|
|
32
|
-
* as degraded and the
|
|
32
|
+
* as degraded and the worker will no longer be considered capable for that
|
|
33
33
|
* agent type until it is restored (automatically or manually).
|
|
34
34
|
*/
|
|
35
|
-
recordFailure(
|
|
36
|
-
if (!this.failureRecords.has(
|
|
37
|
-
this.failureRecords.set(
|
|
35
|
+
recordFailure(workerId, agentType, reason, failureType = 'unknown') {
|
|
36
|
+
if (!this.failureRecords.has(workerId)) {
|
|
37
|
+
this.failureRecords.set(workerId, new Map());
|
|
38
38
|
}
|
|
39
|
-
const
|
|
40
|
-
const existing =
|
|
39
|
+
const workerFailures = this.failureRecords.get(workerId);
|
|
40
|
+
const existing = workerFailures.get(agentType);
|
|
41
41
|
const newCount = (existing?.count ?? 0) + 1;
|
|
42
|
-
|
|
42
|
+
workerFailures.set(agentType, {
|
|
43
43
|
count: newCount,
|
|
44
44
|
type: failureType,
|
|
45
45
|
lastFailure: Date.now(),
|
|
46
46
|
});
|
|
47
|
-
this.logger.warn(`
|
|
47
|
+
this.logger.warn(`Worker ${workerId} failure #${newCount} for ${agentType} [${failureType}]: ${reason}`);
|
|
48
48
|
if (newCount >= DEGRADATION_THRESHOLD) {
|
|
49
|
-
if (!this.degraded.has(
|
|
50
|
-
this.degraded.set(
|
|
49
|
+
if (!this.degraded.has(workerId)) {
|
|
50
|
+
this.degraded.set(workerId, new Set());
|
|
51
51
|
}
|
|
52
|
-
const wasAlreadyDegraded = this.degraded.get(
|
|
53
|
-
this.degraded.get(
|
|
52
|
+
const wasAlreadyDegraded = this.degraded.get(workerId).has(agentType);
|
|
53
|
+
this.degraded.get(workerId).add(agentType);
|
|
54
54
|
if (!wasAlreadyDegraded) {
|
|
55
|
-
this.logger.warn(`
|
|
55
|
+
this.logger.warn(`Worker ${workerId} capability '${agentType}' degraded after ${newCount} consecutive failures [${failureType}]`);
|
|
56
56
|
// Schedule auto-recovery if the failure type supports it
|
|
57
|
-
this.scheduleRecovery(
|
|
57
|
+
this.scheduleRecovery(workerId, agentType, failureType);
|
|
58
58
|
}
|
|
59
59
|
}
|
|
60
60
|
}
|
|
61
61
|
/**
|
|
62
|
-
* Record a successful execution of an agent type on a
|
|
62
|
+
* Record a successful execution of an agent type on a worker.
|
|
63
63
|
* Resets the failure counter and restores the capability if it was degraded.
|
|
64
64
|
*/
|
|
65
|
-
recordSuccess(
|
|
66
|
-
const
|
|
67
|
-
if (
|
|
68
|
-
|
|
69
|
-
if (machineFailures.size === 0) {
|
|
70
|
-
this.failureRecords.delete(machineId);
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
this.cancelRecoveryTimer(machineId, agentType);
|
|
74
|
-
const machineDegraded = this.degraded.get(machineId);
|
|
75
|
-
if (machineDegraded && machineDegraded.has(agentType)) {
|
|
76
|
-
machineDegraded.delete(agentType);
|
|
77
|
-
this.logger.log(`Machine ${machineId} capability '${agentType}' restored after successful execution`);
|
|
78
|
-
if (machineDegraded.size === 0) {
|
|
79
|
-
this.degraded.delete(machineId);
|
|
80
|
-
}
|
|
65
|
+
recordSuccess(workerId, agentType) {
|
|
66
|
+
const wasDegraded = this.clearCapabilityState(workerId, agentType);
|
|
67
|
+
if (wasDegraded) {
|
|
68
|
+
this.logger.log(`Worker ${workerId} capability '${agentType}' restored after successful execution`);
|
|
81
69
|
}
|
|
82
70
|
}
|
|
83
71
|
/**
|
|
84
|
-
* Check whether a
|
|
72
|
+
* Check whether a worker is capable of running a specific agent type.
|
|
85
73
|
* Returns false if the capability has been degraded due to repeated failures.
|
|
86
74
|
*/
|
|
87
|
-
isCapable(
|
|
88
|
-
const
|
|
89
|
-
if (!
|
|
75
|
+
isCapable(workerId, agentType) {
|
|
76
|
+
const workerDegraded = this.degraded.get(workerId);
|
|
77
|
+
if (!workerDegraded) {
|
|
90
78
|
return true;
|
|
91
79
|
}
|
|
92
|
-
return !
|
|
80
|
+
return !workerDegraded.has(agentType);
|
|
93
81
|
}
|
|
94
82
|
/**
|
|
95
|
-
* Get the failure record for a
|
|
83
|
+
* Get the failure record for a worker + capability, if any.
|
|
96
84
|
*/
|
|
97
|
-
getFailureRecord(
|
|
98
|
-
return this.failureRecords.get(
|
|
85
|
+
getFailureRecord(workerId, agentType) {
|
|
86
|
+
return this.failureRecords.get(workerId)?.get(agentType);
|
|
99
87
|
}
|
|
100
88
|
/**
|
|
101
|
-
* Manually restore a degraded capability for a
|
|
89
|
+
* Manually restore a degraded capability for a worker (admin action).
|
|
102
90
|
* Resets both the failure count and the degraded flag.
|
|
103
91
|
*/
|
|
104
|
-
restoreCapability(
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
machineFailures.delete(agentType);
|
|
108
|
-
if (machineFailures.size === 0) {
|
|
109
|
-
this.failureRecords.delete(machineId);
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
this.cancelRecoveryTimer(machineId, agentType);
|
|
113
|
-
const machineDegraded = this.degraded.get(machineId);
|
|
114
|
-
if (machineDegraded) {
|
|
115
|
-
machineDegraded.delete(agentType);
|
|
116
|
-
if (machineDegraded.size === 0) {
|
|
117
|
-
this.degraded.delete(machineId);
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
this.logger.log(`Machine ${machineId} capability '${agentType}' manually restored`);
|
|
92
|
+
restoreCapability(workerId, agentType) {
|
|
93
|
+
this.clearCapabilityState(workerId, agentType);
|
|
94
|
+
this.logger.log(`Worker ${workerId} capability '${agentType}' manually restored`);
|
|
121
95
|
}
|
|
122
96
|
/**
|
|
123
97
|
* Schedule automatic recovery for a degraded capability based on its failure type.
|
|
124
98
|
* binary_missing failures are permanent and will not auto-recover.
|
|
125
99
|
*/
|
|
126
|
-
|
|
100
|
+
clearCapabilityState(workerId, agentType) {
|
|
101
|
+
const workerFailures = this.failureRecords.get(workerId);
|
|
102
|
+
if (workerFailures) {
|
|
103
|
+
workerFailures.delete(agentType);
|
|
104
|
+
if (workerFailures.size === 0) {
|
|
105
|
+
this.failureRecords.delete(workerId);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
this.cancelRecoveryTimer(workerId, agentType);
|
|
109
|
+
const workerDegraded = this.degraded.get(workerId);
|
|
110
|
+
if (workerDegraded && workerDegraded.has(agentType)) {
|
|
111
|
+
workerDegraded.delete(agentType);
|
|
112
|
+
if (workerDegraded.size === 0) {
|
|
113
|
+
this.degraded.delete(workerId);
|
|
114
|
+
}
|
|
115
|
+
return true;
|
|
116
|
+
}
|
|
117
|
+
return false;
|
|
118
|
+
}
|
|
119
|
+
scheduleRecovery(workerId, agentType, failureType) {
|
|
127
120
|
const delay = RECOVERY_DELAYS[failureType];
|
|
128
121
|
if (delay === null) {
|
|
129
|
-
this.logger.warn(`
|
|
122
|
+
this.logger.warn(`Worker ${workerId} capability '${agentType}' permanently degraded (${failureType}) — manual restore required`);
|
|
130
123
|
return;
|
|
131
124
|
}
|
|
132
|
-
const timerKey = `${
|
|
125
|
+
const timerKey = `${workerId}:${agentType}`;
|
|
133
126
|
// Cancel any existing recovery timer
|
|
134
|
-
this.cancelRecoveryTimer(
|
|
127
|
+
this.cancelRecoveryTimer(workerId, agentType);
|
|
135
128
|
const timer = setTimeout(() => {
|
|
136
129
|
this.recoveryTimers.delete(timerKey);
|
|
137
|
-
this.restoreCapability(
|
|
138
|
-
this.logger.log(`
|
|
130
|
+
this.restoreCapability(workerId, agentType);
|
|
131
|
+
this.logger.log(`Worker ${workerId} capability '${agentType}' auto-recovered after ${delay / 1000}s (${failureType})`);
|
|
139
132
|
}, delay);
|
|
140
133
|
// Prevent the timer from keeping the process alive
|
|
141
134
|
if (timer.unref) {
|
|
@@ -143,8 +136,23 @@ let CapabilityService = CapabilityService_1 = class CapabilityService {
|
|
|
143
136
|
}
|
|
144
137
|
this.recoveryTimers.set(timerKey, timer);
|
|
145
138
|
}
|
|
146
|
-
|
|
147
|
-
|
|
139
|
+
/**
|
|
140
|
+
* Clear all capability state for a worker (call when worker is deleted/decommissioned).
|
|
141
|
+
*/
|
|
142
|
+
clearWorker(workerId) {
|
|
143
|
+
this.failureRecords.delete(workerId);
|
|
144
|
+
this.degraded.delete(workerId);
|
|
145
|
+
// Cancel all recovery timers for this worker
|
|
146
|
+
const prefix = `${workerId}:`;
|
|
147
|
+
for (const [key, timer] of this.recoveryTimers) {
|
|
148
|
+
if (key.startsWith(prefix)) {
|
|
149
|
+
clearTimeout(timer);
|
|
150
|
+
this.recoveryTimers.delete(key);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
cancelRecoveryTimer(workerId, agentType) {
|
|
155
|
+
const timerKey = `${workerId}:${agentType}`;
|
|
148
156
|
const existing = this.recoveryTimers.get(timerKey);
|
|
149
157
|
if (existing) {
|
|
150
158
|
clearTimeout(existing);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"capability.service.js","sourceRoot":"","sources":["../../src/dispatcher/capability.service.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoD;AAEpD,sEAAsE;AACtE,MAAM,qBAAqB,GAAG,CAAC,CAAC;AAKhC,sFAAsF;AACtF,MAAM,eAAe,GAAuC;IAC1D,cAAc,EAAE,IAAI,EAAS,wBAAwB;IACrD,YAAY,EAAE,CAAC,GAAG,MAAM,EAAI,YAAY;IACxC,UAAU,EAAE,CAAC,GAAG,MAAM,EAAM,WAAW;IACvC,OAAO,EAAE,EAAE,GAAG,MAAM,EAAQ,aAAa;CAC1C,CAAC;AASK,IAAM,iBAAiB,yBAAvB,MAAM,iBAAiB;IACX,MAAM,GAAG,IAAI,eAAM,CAAC,mBAAiB,CAAC,IAAI,CAAC,CAAC;IAE7D
|
|
1
|
+
{"version":3,"file":"capability.service.js","sourceRoot":"","sources":["../../src/dispatcher/capability.service.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoD;AAEpD,sEAAsE;AACtE,MAAM,qBAAqB,GAAG,CAAC,CAAC;AAKhC,sFAAsF;AACtF,MAAM,eAAe,GAAuC;IAC1D,cAAc,EAAE,IAAI,EAAS,wBAAwB;IACrD,YAAY,EAAE,CAAC,GAAG,MAAM,EAAI,YAAY;IACxC,UAAU,EAAE,CAAC,GAAG,MAAM,EAAM,WAAW;IACvC,OAAO,EAAE,EAAE,GAAG,MAAM,EAAQ,aAAa;CAC1C,CAAC;AASK,IAAM,iBAAiB,yBAAvB,MAAM,iBAAiB;IACX,MAAM,GAAG,IAAI,eAAM,CAAC,mBAAiB,CAAC,IAAI,CAAC,CAAC;IAE7D,8CAA8C;IAC7B,cAAc,GAAG,IAAI,GAAG,EAAsC,CAAC;IAEhF,8CAA8C;IAC7B,QAAQ,GAAG,IAAI,GAAG,EAAuB,CAAC;IAE3D,oEAAoE;IACnD,cAAc,GAAG,IAAI,GAAG,EAA0B,CAAC;IAEpE;;;;;OAKG;IACH,aAAa,CACX,QAAgB,EAChB,SAAiB,EACjB,MAAc,EACd,cAA2B,SAAS;QAEpC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACvC,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAC/C,CAAC;QACD,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;QAC1D,MAAM,QAAQ,GAAG,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/C,MAAM,QAAQ,GAAG,CAAC,QAAQ,EAAE,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAE5C,cAAc,CAAC,GAAG,CAAC,SAAS,EAAE;YAC5B,KAAK,EAAE,QAAQ;YACf,IAAI,EAAE,WAAW;YACjB,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE;SACxB,CAAC,CAAC;QAEH,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,UAAU,QAAQ,aAAa,QAAQ,QAAQ,SAAS,KAAK,WAAW,MAAM,MAAM,EAAE,CACvF,CAAC;QAEF,IAAI,QAAQ,IAAI,qBAAqB,EAAE,CAAC;YACtC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACjC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;YACzC,CAAC;YACD,MAAM,kBAAkB,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACvE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YAE5C,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,UAAU,QAAQ,gBAAgB,SAAS,oBAAoB,QAAQ,0BAA0B,WAAW,GAAG,CAChH,CAAC;gBAEF,yDAAyD;gBACzD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;YAC1D,CAAC;QACH,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,aAAa,CAAC,QAAgB,EAAE,SAAiB;QAC/C,MAAM,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QACnE,IAAI,WAAW,EAAE,CAAC;YAChB,IAAI,CAAC,MAAM,CAAC,GAAG,CACb,UAAU,QAAQ,gBAAgB,SAAS,uCAAuC,CACnF,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,SAAS,CAAC,QAAgB,EAAE,SAAiB;QAC3C,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,CAAC,cAAc,EAAE,CAAC;YACpB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACH,gBAAgB,CAAC,QAAgB,EAAE,SAAiB;QAClD,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;IAC3D,CAAC;IAED;;;OAGG;IACH,iBAAiB,CAAC,QAAgB,EAAE,SAAiB;QACnD,IAAI,CAAC,oBAAoB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAC/C,IAAI,CAAC,MAAM,CAAC,GAAG,CACb,UAAU,QAAQ,gBAAgB,SAAS,qBAAqB,CACjE,CAAC;IACJ,CAAC;IAED;;;OAGG;IACK,oBAAoB,CAAC,QAAgB,EAAE,SAAiB;QAC9D,MAAM,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACzD,IAAI,cAAc,EAAE,CAAC;YACnB,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,cAAc,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBAC9B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACvC,CAAC;QACH,CAAC;QAED,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAE9C,MAAM,cAAc,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,cAAc,IAAI,cAAc,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YACpD,cAAc,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,cAAc,CAAC,IAAI,KAAK,CAAC,EAAE,CAAC;gBAC9B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACjC,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,gBAAgB,CACtB,QAAgB,EAChB,SAAiB,EACjB,WAAwB;QAExB,MAAM,KAAK,GAAG,eAAe,CAAC,WAAW,CAAC,CAAC;QAC3C,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CACd,UAAU,QAAQ,gBAAgB,SAAS,2BAA2B,WAAW,6BAA6B,CAC/G,CAAC;YACF,OAAO;QACT,CAAC;QAED,MAAM,QAAQ,GAAG,GAAG,QAAQ,IAAI,SAAS,EAAE,CAAC;QAE5C,qCAAqC;QACrC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;QAE9C,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;YACrC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,EAAE,SAAS,CAAC,CAAC;YAC5C,IAAI,CAAC,MAAM,CAAC,GAAG,CACb,UAAU,QAAQ,gBAAgB,SAAS,0BAA0B,KAAK,GAAG,IAAI,MAAM,WAAW,GAAG,CACtG,CAAC;QACJ,CAAC,EAAE,KAAK,CAAC,CAAC;QAEV,mDAAmD;QACnD,IAAI,KAAK,CAAC,KAAK,EAAE,CAAC;YAChB,KAAK,CAAC,KAAK,EAAE,CAAC;QAChB,CAAC;QAED,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,WAAW,CAAC,QAAgB;QAC1B,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACrC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAE/B,6CAA6C;QAC7C,MAAM,MAAM,GAAG,GAAG,QAAQ,GAAG,CAAC;QAC9B,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YAC/C,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC3B,YAAY,CAAC,KAAK,CAAC,CAAC;gBACpB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;YAClC,CAAC;QACH,CAAC;IACH,CAAC;IAEO,mBAAmB,CAAC,QAAgB,EAAE,SAAiB;QAC7D,MAAM,QAAQ,GAAG,GAAG,QAAQ,IAAI,SAAS,EAAE,CAAC;QAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QACnD,IAAI,QAAQ,EAAE,CAAC;YACb,YAAY,CAAC,QAAQ,CAAC,CAAC;YACvB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QACvC,CAAC;IACH,CAAC;CACF,CAAA;AA3LY,8CAAiB;4BAAjB,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;GACA,iBAAiB,CA2L7B"}
|
|
@@ -12,7 +12,7 @@ export declare class CleanupService implements OnModuleInit, OnModuleDestroy {
|
|
|
12
12
|
* Schedule a workspace cleanup job, delayed by WORKSPACE_RETENTION_MS (24h).
|
|
13
13
|
* The job will send a cleanup_workspace frame to the worker when it fires.
|
|
14
14
|
*/
|
|
15
|
-
scheduleCleanup(taskId: number,
|
|
15
|
+
scheduleCleanup(taskId: number, workerId: string, workspacePath: string, delay?: number): Promise<void>;
|
|
16
16
|
/**
|
|
17
17
|
* Process a cleanup job: send a cleanup_workspace frame to the worker via
|
|
18
18
|
* WorkerConnectionManager. If the worker is not connected, the job will fail
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup.service.d.ts","sourceRoot":"","sources":["../../src/dispatcher/cleanup.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cleanup.service.d.ts","sourceRoot":"","sources":["../../src/dispatcher/cleanup.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,YAAY,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAGnF,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAiBtE,qBACa,cAAe,YAAW,YAAY,EAAE,eAAe;IAMhE,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IALpC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAmC;IAC1D,OAAO,CAAC,KAAK,CAAyB;IACtC,OAAO,CAAC,MAAM,CAA0B;gBAGrB,iBAAiB,EAAE,uBAAuB;IAG7D,YAAY,IAAI,IAAI;IAsCd,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAMtC;;;OAGG;IACG,eAAe,CACnB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,aAAa,EAAE,MAAM,EACrB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC;IAgBhB;;;;OAIG;YACW,cAAc;CAmC7B"}
|
|
@@ -11,9 +11,10 @@ var __metadata = (this && this.__metadata) || function (k, v) {
|
|
|
11
11
|
var CleanupService_1;
|
|
12
12
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
13
|
exports.CleanupService = void 0;
|
|
14
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
14
15
|
const common_1 = require("@nestjs/common");
|
|
15
16
|
const bullmq_1 = require("bullmq");
|
|
16
|
-
const
|
|
17
|
+
const config_1 = require("../common/config");
|
|
17
18
|
const worker_connection_manager_1 = require("./worker-connection.manager");
|
|
18
19
|
/** Base delay for exponential backoff retries (10 minutes). */
|
|
19
20
|
const RETRY_BASE_DELAY_MS = 10 * 60 * 1000;
|
|
@@ -30,9 +31,8 @@ let CleanupService = CleanupService_1 = class CleanupService {
|
|
|
30
31
|
this.connectionManager = connectionManager;
|
|
31
32
|
}
|
|
32
33
|
onModuleInit() {
|
|
33
|
-
const redisUrl = process.env.REDIS_URL || 'redis://localhost:6379';
|
|
34
34
|
this.queue = new bullmq_1.Queue('workspace-cleanup', {
|
|
35
|
-
connection: { url:
|
|
35
|
+
connection: { url: (0, config_1.getRedisUrl)(), maxRetriesPerRequest: null },
|
|
36
36
|
defaultJobOptions: {
|
|
37
37
|
attempts: MAX_RETRIES,
|
|
38
38
|
backoff: {
|
|
@@ -44,7 +44,7 @@ let CleanupService = CleanupService_1 = class CleanupService {
|
|
|
44
44
|
},
|
|
45
45
|
});
|
|
46
46
|
this.worker = new bullmq_1.Worker('workspace-cleanup', async (job) => this.processCleanup(job), {
|
|
47
|
-
connection: { url:
|
|
47
|
+
connection: { url: (0, config_1.getRedisUrl)(), maxRetriesPerRequest: null },
|
|
48
48
|
concurrency: 1,
|
|
49
49
|
});
|
|
50
50
|
this.worker.on('failed', (job, err) => {
|
|
@@ -64,14 +64,14 @@ let CleanupService = CleanupService_1 = class CleanupService {
|
|
|
64
64
|
* Schedule a workspace cleanup job, delayed by WORKSPACE_RETENTION_MS (24h).
|
|
65
65
|
* The job will send a cleanup_workspace frame to the worker when it fires.
|
|
66
66
|
*/
|
|
67
|
-
async scheduleCleanup(taskId,
|
|
67
|
+
async scheduleCleanup(taskId, workerId, workspacePath, delay) {
|
|
68
68
|
const effectiveDelay = delay ?? protocol_1.WORKSPACE_RETENTION_MS;
|
|
69
69
|
const jobId = `cleanup-${taskId}`;
|
|
70
|
-
await this.queue.add('cleanup', { taskId,
|
|
70
|
+
await this.queue.add('cleanup', { taskId, workerId, workspacePath }, {
|
|
71
71
|
jobId,
|
|
72
72
|
delay: effectiveDelay,
|
|
73
73
|
});
|
|
74
|
-
this.logger.log(`Scheduled workspace cleanup for task ${taskId} on
|
|
74
|
+
this.logger.log(`Scheduled workspace cleanup for task ${taskId} on worker ${workerId} in ${effectiveDelay / 3600000}h`);
|
|
75
75
|
}
|
|
76
76
|
/**
|
|
77
77
|
* Process a cleanup job: send a cleanup_workspace frame to the worker via
|
|
@@ -79,10 +79,10 @@ let CleanupService = CleanupService_1 = class CleanupService {
|
|
|
79
79
|
* and be retried with exponential backoff.
|
|
80
80
|
*/
|
|
81
81
|
async processCleanup(job) {
|
|
82
|
-
const { taskId,
|
|
83
|
-
this.logger.log(`Processing cleanup for task ${taskId} on
|
|
84
|
-
if (!this.connectionManager.isConnected(
|
|
85
|
-
throw new Error(`
|
|
82
|
+
const { taskId, workerId, workspacePath } = job.data;
|
|
83
|
+
this.logger.log(`Processing cleanup for task ${taskId} on worker ${workerId}`);
|
|
84
|
+
if (!this.connectionManager.isConnected(workerId)) {
|
|
85
|
+
throw new Error(`Worker ${workerId} is not connected; cannot send cleanup for task ${taskId}`);
|
|
86
86
|
}
|
|
87
87
|
const msgId = this.connectionManager.generateMsgId();
|
|
88
88
|
const frame = {
|
|
@@ -92,10 +92,10 @@ let CleanupService = CleanupService_1 = class CleanupService {
|
|
|
92
92
|
workspacePath,
|
|
93
93
|
};
|
|
94
94
|
try {
|
|
95
|
-
await this.connectionManager.sendWithAck(
|
|
95
|
+
await this.connectionManager.sendWithAck(workerId, frame, CLEANUP_ACK_TIMEOUT_MS);
|
|
96
96
|
}
|
|
97
97
|
catch (err) {
|
|
98
|
-
throw new Error(`Cleanup for task ${taskId} on
|
|
98
|
+
throw new Error(`Cleanup for task ${taskId} on worker ${workerId} failed: ${(0, protocol_1.getErrorMessage)(err)}`);
|
|
99
99
|
}
|
|
100
100
|
}
|
|
101
101
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cleanup.service.js","sourceRoot":"","sources":["../../src/dispatcher/cleanup.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"cleanup.service.js","sourceRoot":"","sources":["../../src/dispatcher/cleanup.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -34,10 +34,24 @@ export declare class DedupService {
|
|
|
34
34
|
*/
|
|
35
35
|
deletePendingConfirm(key: string): Promise<void>;
|
|
36
36
|
/**
|
|
37
|
-
*
|
|
38
|
-
*
|
|
37
|
+
* Atomically consume pending confirm data for a task.
|
|
38
|
+
* Returns { raw, confirmKey } if found, or null if nothing pending.
|
|
39
|
+
* Caller is responsible for auth checks and cleanup decisions.
|
|
39
40
|
*/
|
|
40
|
-
|
|
41
|
+
consumePendingConfirm(taskId: number): Promise<{
|
|
42
|
+
raw: string;
|
|
43
|
+
confirmKey: string;
|
|
44
|
+
indexKey: string;
|
|
45
|
+
} | null>;
|
|
46
|
+
/** Clean up the index key after successful confirm consumption. */
|
|
47
|
+
cleanupConfirmIndex(indexKey: string): Promise<void>;
|
|
48
|
+
/** Restore consumed confirm data (e.g. on auth failure in bot flow). */
|
|
49
|
+
restoreConfirmData(confirmKey: string, raw: string): Promise<void>;
|
|
50
|
+
/**
|
|
51
|
+
* Handle a confirm command from bot: retrieve, auth-check, and return payload.
|
|
52
|
+
* On auth failure, restores the data so the correct user can still confirm.
|
|
53
|
+
*/
|
|
54
|
+
handleConfirm(taskId: number, userId: number, _msgId?: string): Promise<{
|
|
41
55
|
action: string;
|
|
42
56
|
request?: object;
|
|
43
57
|
createdBy: number;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dedup.service.d.ts","sourceRoot":"","sources":["../../src/dispatcher/dedup.service.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,qBACa,YAAY;IACX,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,YAAY;IAEhD;;;;OAIG;IACG,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQxD;;;OAGG;IACH,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM;IAMnE;;;OAGG;IACG,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnE;;;OAGG;IACG,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAS5D;;;;OAIG;IACG,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"dedup.service.d.ts","sourceRoot":"","sources":["../../src/dispatcher/dedup.service.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,qBACa,YAAY;IACX,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAAL,KAAK,EAAE,YAAY;IAEhD;;;;OAIG;IACG,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAQxD;;;OAGG;IACH,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,MAAM;IAMnE;;;OAGG;IACG,mBAAmB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKnE;;;OAGG;IACG,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAS5D;;;;OAIG;IACG,wBAAwB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAgDtE;;OAEG;IACG,oBAAoB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKtD;;;;OAIG;IACG,qBAAqB,CACzB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,UAAU,EAAE,MAAM,CAAC;QAAC,QAAQ,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI,CAAC;IAexE,mEAAmE;IAC7D,mBAAmB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1D,wEAAwE;IAClE,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIxE;;;OAGG;IACG,aAAa,CACjB,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,MAAM,GACd,OAAO,CAAC;QACT,MAAM,EAAE,MAAM,CAAC;QACf,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,SAAS,EAAE,MAAM,CAAC;QAClB,MAAM,CAAC,EAAE,MAAM,CAAC;QAChB,MAAM,CAAC,EAAE,MAAM,CAAC;KACjB,GAAG,IAAI,CAAC;CA2BV"}
|
|
@@ -71,28 +71,36 @@ let DedupService = class DedupService {
|
|
|
71
71
|
const stream = client.scanStream({ match: pattern, count: 100 });
|
|
72
72
|
return new Promise((resolve, reject) => {
|
|
73
73
|
let resolved = false;
|
|
74
|
-
stream.on('data',
|
|
75
|
-
if (resolved)
|
|
74
|
+
stream.on('data', (keys) => {
|
|
75
|
+
if (resolved || keys.length === 0)
|
|
76
76
|
return;
|
|
77
77
|
stream.pause();
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
78
|
+
// Batch fetch all keys in this scan page using mget
|
|
79
|
+
client.mget(...keys).then((values) => {
|
|
80
|
+
for (const raw of values) {
|
|
81
|
+
if (resolved)
|
|
82
|
+
break;
|
|
83
|
+
if (!raw)
|
|
84
|
+
continue;
|
|
85
|
+
try {
|
|
86
|
+
const data = JSON.parse(raw);
|
|
87
|
+
resolved = true;
|
|
88
|
+
stream.destroy();
|
|
89
|
+
resolve(data);
|
|
90
|
+
return;
|
|
91
|
+
}
|
|
92
|
+
catch {
|
|
93
|
+
continue;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
stream.resume();
|
|
97
|
+
}).catch((err) => {
|
|
98
|
+
if (!resolved) {
|
|
86
99
|
resolved = true;
|
|
87
100
|
stream.destroy();
|
|
88
|
-
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
catch {
|
|
92
|
-
continue;
|
|
101
|
+
reject(err);
|
|
93
102
|
}
|
|
94
|
-
}
|
|
95
|
-
stream.resume();
|
|
103
|
+
});
|
|
96
104
|
});
|
|
97
105
|
stream.on('end', () => {
|
|
98
106
|
if (!resolved)
|
|
@@ -112,73 +120,59 @@ let DedupService = class DedupService {
|
|
|
112
120
|
await this.redis.del(redisKey);
|
|
113
121
|
}
|
|
114
122
|
/**
|
|
115
|
-
*
|
|
116
|
-
*
|
|
123
|
+
* Atomically consume pending confirm data for a task.
|
|
124
|
+
* Returns { raw, confirmKey } if found, or null if nothing pending.
|
|
125
|
+
* Caller is responsible for auth checks and cleanup decisions.
|
|
117
126
|
*/
|
|
118
|
-
async
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
127
|
+
async consumePendingConfirm(taskId) {
|
|
128
|
+
const indexKey = `pending_confirm_idx:task:${taskId}`;
|
|
129
|
+
const confirmKey = await this.redis.get(indexKey);
|
|
130
|
+
if (!confirmKey)
|
|
131
|
+
return null;
|
|
132
|
+
const raw = await this.redis.getdel(confirmKey);
|
|
133
|
+
if (!raw) {
|
|
134
|
+
// Index exists but data expired — clean up index
|
|
135
|
+
await this.redis.del(indexKey);
|
|
136
|
+
return null;
|
|
137
|
+
}
|
|
138
|
+
return { raw, confirmKey, indexKey };
|
|
139
|
+
}
|
|
140
|
+
/** Clean up the index key after successful confirm consumption. */
|
|
141
|
+
async cleanupConfirmIndex(indexKey) {
|
|
142
|
+
await this.redis.del(indexKey);
|
|
143
|
+
}
|
|
144
|
+
/** Restore consumed confirm data (e.g. on auth failure in bot flow). */
|
|
145
|
+
async restoreConfirmData(confirmKey, raw) {
|
|
146
|
+
await this.redis.setex(confirmKey, protocol_1.CONFIRM_PENDING_TTL_SEC, raw);
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Handle a confirm command from bot: retrieve, auth-check, and return payload.
|
|
150
|
+
* On auth failure, restores the data so the correct user can still confirm.
|
|
151
|
+
*/
|
|
152
|
+
async handleConfirm(taskId, userId, _msgId) {
|
|
153
|
+
const consumed = await this.consumePendingConfirm(taskId);
|
|
154
|
+
if (!consumed)
|
|
155
|
+
return null;
|
|
156
|
+
try {
|
|
157
|
+
const data = JSON.parse(consumed.raw);
|
|
158
|
+
const createdBy = data['createdBy'] ?? userId;
|
|
159
|
+
if (createdBy !== userId) {
|
|
160
|
+
// Restore — wrong user consumed the data via getdel
|
|
161
|
+
await this.restoreConfirmData(consumed.confirmKey, consumed.raw);
|
|
162
|
+
return null;
|
|
163
|
+
}
|
|
164
|
+
await this.cleanupConfirmIndex(consumed.indexKey);
|
|
165
|
+
return {
|
|
166
|
+
action: data['action'],
|
|
167
|
+
request: data['request'],
|
|
168
|
+
createdBy,
|
|
169
|
+
source: data['source'],
|
|
170
|
+
taskId: data['taskId'],
|
|
171
|
+
};
|
|
172
|
+
}
|
|
173
|
+
catch {
|
|
174
|
+
return null;
|
|
125
175
|
}
|
|
126
|
-
// Try to find by scanning — in the real flow, the confirmKey is passed directly
|
|
127
|
-
// This is a simplified implementation; the adapter layer should pass the confirmKey
|
|
128
|
-
// Uses SCAN instead of KEYS to avoid blocking the Redis event loop in production.
|
|
129
|
-
const client = this.redis.getClient();
|
|
130
|
-
const stream = client.scanStream({
|
|
131
|
-
match: 'pending_confirm:*',
|
|
132
|
-
count: 100,
|
|
133
|
-
});
|
|
134
|
-
const result = await new Promise((resolve, reject) => {
|
|
135
|
-
let resolved = false;
|
|
136
|
-
stream.on('data', async (keys) => {
|
|
137
|
-
if (resolved)
|
|
138
|
-
return;
|
|
139
|
-
// Pause the stream while we process this batch to avoid concurrent writes
|
|
140
|
-
stream.pause();
|
|
141
|
-
for (const key of keys) {
|
|
142
|
-
if (resolved)
|
|
143
|
-
break;
|
|
144
|
-
const raw = await this.redis.get(key);
|
|
145
|
-
if (!raw)
|
|
146
|
-
continue;
|
|
147
|
-
try {
|
|
148
|
-
const data = JSON.parse(raw);
|
|
149
|
-
if ((data['taskId'] === taskId || data['existingTaskId'] === taskId) &&
|
|
150
|
-
data['action']) {
|
|
151
|
-
await this.redis.del(key);
|
|
152
|
-
resolved = true;
|
|
153
|
-
stream.destroy();
|
|
154
|
-
resolve({
|
|
155
|
-
action: data['action'],
|
|
156
|
-
request: data['request'],
|
|
157
|
-
createdBy: data['createdBy'] ?? userId,
|
|
158
|
-
source: data['source'],
|
|
159
|
-
taskId: data['taskId'],
|
|
160
|
-
});
|
|
161
|
-
return;
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
catch {
|
|
165
|
-
continue;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
stream.resume();
|
|
169
|
-
});
|
|
170
|
-
stream.on('end', () => {
|
|
171
|
-
if (!resolved) {
|
|
172
|
-
resolve(null);
|
|
173
|
-
}
|
|
174
|
-
});
|
|
175
|
-
stream.on('error', (err) => {
|
|
176
|
-
if (!resolved) {
|
|
177
|
-
reject(err);
|
|
178
|
-
}
|
|
179
|
-
});
|
|
180
|
-
});
|
|
181
|
-
return result;
|
|
182
176
|
}
|
|
183
177
|
};
|
|
184
178
|
exports.DedupService = DedupService;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dedup.service.js","sourceRoot":"","sources":["../../src/dispatcher/dedup.service.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,2CAA4C;AAC5C,6CAAyC;AACzC,mDAG8B;AAC9B,0DAAsD;AAG/C,IAAM,YAAY,GAAlB,MAAM,YAAY;IACM;IAA7B,YAA6B,KAAmB;QAAnB,UAAK,GAAL,KAAK,CAAc;IAAG,CAAC;IAEpD;;;;OAIG;IACH,KAAK,CAAC,eAAe,CAAC,OAAe;QACnC,MAAM,GAAG,GAAG,WAAW,OAAO,EAAE,CAAC;QACjC,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;QACtC,sFAAsF;QACtF,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,IAAI,EAAE,8BAAmB,EAAE,IAAI,CAAC,CAAC;QAC3E,OAAO,MAAM,KAAK,IAAI,CAAC;IACzB,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,UAAkB,EAAE,WAAmB;QACxD,MAAM,IAAI,GAAG,IAAA,wBAAU,EAAC,QAAQ,CAAC,CAAC;QAClC,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG,IAAI,GAAG,WAAW,CAAC,CAAC;QAC7C,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,mBAAmB,CAAC,GAAW,EAAE,IAAY;QACjD,MAAM,QAAQ,GAAG,WAAW,GAAG,EAAE,CAAC;QAClC,MAAM,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,QAAQ,EAAE,kCAAuB,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IAClF,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,iBAAiB,CAAC,GAAW;QACjC,MAAM,QAAQ,GAAG,WAAW,GAAG,EAAE,CAAC;QAClC,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;QAC7C,IAAI,KAAK,KAAK,IAAI,EAAE,CAAC;YACnB,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,CAAW,CAAC;IACrC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,wBAAwB,CAAC,MAAc;QAC3C,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAE,CAAC;QACtC,MAAM,OAAO,GAAG,iBAAiB,MAAM,IAAI,CAAC;QAC5C,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,KAAK,EAAE,GAAG,EAAE,CAAC,CAAC;QAEjE,OAAO,IAAI,OAAO,CAAgB,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACpD,IAAI,QAAQ,GAAG,KAAK,CAAC;YAErB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,
|
|
1
|
+
{"version":3,"file":"dedup.service.js","sourceRoot":"","sources":["../../src/dispatcher/dedup.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dispatcher.module.d.ts","sourceRoot":"","sources":["../../src/dispatcher/dispatcher.module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"dispatcher.module.d.ts","sourceRoot":"","sources":["../../src/dispatcher/dispatcher.module.ts"],"names":[],"mappings":"AAoBA,qBAmCa,gBAAgB;CAAG"}
|