@overlordai/server 1.0.52 → 1.0.54
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 +56 -22
- 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-BOXPalWI.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-griwga5q.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-I3k9sPON.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-0JE10nwo.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-C-OTbm1J.js → arrow-left-DklRsENx.js} +1 -1
- package/public/assets/{arrow-right-B5aaHrGs.js → arrow-right-MDrzFe3K.js} +1 -1
- package/public/assets/{bot-KMbKzBkt.js → bot-DPaziJPf.js} +1 -1
- package/public/assets/{chevron-right-CVPdQ-cP.js → chevron-right-CqyufMDW.js} +1 -1
- package/public/assets/{copy-Dd1cNNWz.js → copy-BUH7P2Hf.js} +1 -1
- package/public/assets/date-BdNtiQTP.js +1 -0
- package/public/assets/{external-link-F-d1_j4T.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-CT_RkMPI.js → key-CxvwwHnW.js} +1 -1
- package/public/assets/{loader-circle-BnJr5Xpn.js → loader-circle-DS5g1-Od.js} +1 -1
- package/public/assets/password-CHk45-jw.js +1 -0
- package/public/assets/{pencil-Srq1Z7Yh.js → pencil-B6spIBcw.js} +1 -1
- package/public/assets/{plus-Ry_MQV9O.js → plus-Bnd1Vz2Y.js} +1 -1
- package/public/assets/{rotate-ccw-B1ZO6xeO.js → rotate-ccw-CgcLAXNR.js} +1 -1
- package/public/assets/{scroll-text-CP6Z7Xff.js → scroll-text-CecZ0Fk5.js} +1 -1
- package/public/assets/{settings-Ac7uhvR0.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-DWv3OoER.js → trash-2-A2FsT1yG.js} +1 -1
- package/public/assets/useFetch-vGZMAvGi.js +1 -0
- package/public/assets/{users-BsM5ZXj8.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-DypSjrzB.js +0 -1
- package/public/assets/AdminPage-BY1ub8Ur.js +0 -1
- package/public/assets/ApiReferencePage-X0c9Bj31.js +0 -1
- package/public/assets/AuditLogPage-B0bBeD2B.js +0 -6
- package/public/assets/BotManage-D7UIzmUX.js +0 -6
- package/public/assets/CliReferencePage-DAqUe3dC.js +0 -8
- package/public/assets/DeveloperManage-Df4qgJ4d.js +0 -16
- package/public/assets/EditProjectPage-B05CUiFx.js +0 -2
- package/public/assets/HomePage-YM1Wcq5V.js +0 -1
- package/public/assets/LandingPage-Dn64_5F4.js +0 -36
- package/public/assets/LoginPage-CcBF1jm-.js +0 -1
- package/public/assets/MachineDetailPage-BHzHO-jG.js +0 -1
- package/public/assets/MachineListPage-sTx1mDtP.js +0 -6
- package/public/assets/PipelineEditorPage-CZQJn5Qd.js +0 -3
- package/public/assets/ProfilePage-CM-HnNqC.js +0 -1
- package/public/assets/ProjectDetailPage-d59hpM1f.js +0 -7
- package/public/assets/ProjectListPage-j4xLknRG.js +0 -6
- package/public/assets/QuickAuth-vbGZYKLu.js +0 -1
- package/public/assets/Select-CmUwVfWJ.js +0 -6
- package/public/assets/SettingsPage-CDTheJqk.js +0 -6
- package/public/assets/SkillPage-ClOtPiNe.js +0 -1
- package/public/assets/TaskDetailPage-CG8zmgwV.js +0 -44
- package/public/assets/TaskListPage-BUjNGBKm.js +0 -1
- package/public/assets/TaskStatusBadge-C8TEMiVe.js +0 -1
- package/public/assets/TokenManage-U3YbhV_d.js +0 -1
- package/public/assets/TotpSetupPage-BlRM2OEF.js +0 -9
- package/public/assets/WorkerSetupGuidePage-BUTz9NXE.js +0 -16
- package/public/assets/index-CQojj7Zu.css +0 -1
- package/public/assets/index-DJxZmj6O.js +0 -212
- package/public/assets/protocol-C5uQmiiB.js +0 -1
- package/public/assets/task.store-DSX--5cK.js +0 -1
- /package/public/assets/{TaskDetailPage-Beg8tuEN.css → task-constants-Beg8tuEN.css} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"web.module.js","sourceRoot":"","sources":["../../src/web/web.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qDAAiD;AACjD,uEAAmE;AACnE,6DAAyD;AAEzD,
|
|
1
|
+
{"version":3,"file":"web.module.js","sourceRoot":"","sources":["../../src/web/web.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qDAAiD;AACjD,uEAAmE;AACnE,6DAAyD;AAEzD,kBAAkB;AAClB,uDAAmD;AACnD,6DAAyD;AACzD,mEAA8D;AAC9D,iEAA6D;AAC7D,uEAAmE;AACnE,6DAAyD;AACzD,2DAAuD;AACvD,iEAA6D;AAC7D,mEAA+D;AAE/D,oBAAoB;AACpB,+EAA0E;AAC1E,mFAA8E;AAC9E,6EAAwE;AACxE,2EAAsE;AACtE,uEAAkE;AAClE,2EAAsE;AACtE,iFAA4E;AAE5E,qBAAqB;AACrB,qEAAgE;AAChE,+CAA2C;AAC3C,mDAA+C;AAE/C,WAAW;AACX,+DAA2D;AAC3D,2DAAuD;AACvD,qDAAiD;AACjD,2DAAsD;AACtD,qDAAiD;AACjD,qEAAgE;AAoCzD,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IAlCrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,wBAAU,EAAE,oCAAgB,CAAC;QACvC,WAAW,EAAE;YACX,gCAAc;YACd,sCAAiB;YACjB,2CAAmB;YACnB,0CAAmB;YACnB,gDAAsB;YACtB,sCAAiB;YACjB,oCAAgB;YAChB,0CAAmB;YACnB,oCAAgB;YAChB,iDAAsB;YACtB,qDAAwB;YACxB,+CAAqB;YACrB,6CAAoB;YACpB,yCAAkB;YAClB,6CAAoB;YACpB,mDAAuB;SACxB;QACD,SAAS,EAAE;YACT,8BAAa;YACb,8BAAa;YACb,6CAAoB;YACpB,wBAAU;YACV,4BAAY;YACZ,mCAAe;YACf,wCAAkB;YAClB,oCAAgB;YAChB,8BAAa;YACb,6CAAoB;SACrB;QACD,OAAO,EAAE,CAAC,wCAAkB,EAAE,oCAAgB,EAAE,8BAAa,EAAE,mCAAe,CAAC;KAChF,CAAC;GACW,SAAS,CAAG"}
|
|
@@ -1,45 +1,37 @@
|
|
|
1
1
|
import { OnGatewayConnection, OnGatewayDisconnect } from '@nestjs/websockets';
|
|
2
2
|
import type { IncomingMessage } from 'node:http';
|
|
3
3
|
import { WebSocket } from 'ws';
|
|
4
|
+
import { EventEmitter2 } from '@nestjs/event-emitter';
|
|
4
5
|
import { AuthService } from '../auth/auth.service';
|
|
5
6
|
import { WorkerConnectionManager } from '../dispatcher/worker-connection.manager';
|
|
6
7
|
import { HeartbeatService } from '../dispatcher/heartbeat.service';
|
|
7
8
|
import { Reconciler } from '../dispatcher/reconciler';
|
|
8
|
-
import {
|
|
9
|
+
import { TaskLifecycleService } from '../dispatcher/task-lifecycle.service';
|
|
9
10
|
import { TaskLogBatcher } from '../dispatcher/task-log-batcher';
|
|
10
11
|
import { DedupService } from '../dispatcher/dedup.service';
|
|
11
|
-
import {
|
|
12
|
+
import { WorkerRepository } from '../database/repositories/worker.repository';
|
|
12
13
|
import { TaskRepository } from '../database/repositories/task.repository';
|
|
13
14
|
import { WorkerTokenRepository } from '../database/repositories/worker-token.repository';
|
|
14
15
|
import { NotifierService } from '../notifier/notifier.service';
|
|
16
|
+
import { TunnelService } from './tunnel.service';
|
|
15
17
|
export declare class WorkerChannelGateway implements OnGatewayConnection, OnGatewayDisconnect {
|
|
16
18
|
private readonly authService;
|
|
17
19
|
private readonly workerConnectionManager;
|
|
18
|
-
private readonly
|
|
19
|
-
private readonly reconciler;
|
|
20
|
-
private readonly dispatcher;
|
|
21
|
-
private readonly taskLogBatcher;
|
|
22
|
-
private readonly dedupService;
|
|
23
|
-
private readonly machineRepo;
|
|
24
|
-
private readonly taskRepo;
|
|
20
|
+
private readonly workerRepo;
|
|
25
21
|
private readonly workerTokenRepo;
|
|
26
|
-
private readonly
|
|
22
|
+
private readonly tunnelService;
|
|
23
|
+
private readonly eventEmitter;
|
|
27
24
|
private readonly logger;
|
|
28
25
|
private readonly authedSockets;
|
|
29
26
|
private readonly AUTH_TIMEOUT_MS;
|
|
30
|
-
|
|
27
|
+
private readonly frameHandlerRegistry;
|
|
28
|
+
constructor(authService: AuthService, workerConnectionManager: WorkerConnectionManager, heartbeatService: HeartbeatService, reconciler: Reconciler, taskLifecycleService: TaskLifecycleService, taskLogBatcher: TaskLogBatcher, dedupService: DedupService, workerRepo: WorkerRepository, taskRepo: TaskRepository, workerTokenRepo: WorkerTokenRepository, notifierService: NotifierService, tunnelService: TunnelService, eventEmitter: EventEmitter2);
|
|
31
29
|
handleConnection(client: WebSocket, _req: IncomingMessage): void;
|
|
32
30
|
handleDisconnect(client: WebSocket): void;
|
|
33
31
|
private handleAuth;
|
|
34
|
-
private handleHeartbeat;
|
|
35
|
-
private handleAck;
|
|
36
|
-
private handleReconnect;
|
|
37
|
-
private handleProgress;
|
|
38
|
-
private handleRecoverySecretAck;
|
|
39
|
-
private handleStageConfirmRequest;
|
|
40
32
|
/**
|
|
41
33
|
* Periodically revalidate Worker JWT. Disconnect if token is invalid,
|
|
42
|
-
*
|
|
34
|
+
* worker tokenId changed, or worker token is revoked/expired.
|
|
43
35
|
* Honors a 2-minute grace period for old JWTs during token refresh.
|
|
44
36
|
*/
|
|
45
37
|
private revalidateWorkerJwt;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-channel.gateway.d.ts","sourceRoot":"","sources":["../../src/web/worker-channel.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;
|
|
1
|
+
{"version":3,"file":"worker-channel.gateway.d.ts","sourceRoot":"","sources":["../../src/web/worker-channel.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAE5B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAc/B,OAAO,EAAE,aAAa,EAAE,MAAM,uBAAuB,CAAC;AAEtD,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,uBAAuB,EAAE,MAAM,yCAAyC,CAAC;AAClF,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AACtD,OAAO,EAAE,oBAAoB,EAAE,MAAM,sCAAsC,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,YAAY,EAAE,MAAM,6BAA6B,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAC;AAC1E,OAAO,EAAE,qBAAqB,EAAE,MAAM,kDAAkD,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAiBjD,qBACa,oBACX,YAAW,mBAAmB,EAAE,mBAAmB;IAQjD,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,uBAAuB;IAMxC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAE3B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAEhC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAlB/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyC;IAChE,OAAO,CAAC,QAAQ,CAAC,aAAa,CAA6C;IAC3E,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,oBAAoB,CAAuB;gBAGzC,WAAW,EAAE,WAAW,EACxB,uBAAuB,EAAE,uBAAuB,EACjE,gBAAgB,EAAE,gBAAgB,EAClC,UAAU,EAAE,UAAU,EACtB,oBAAoB,EAAE,oBAAoB,EAC1C,cAAc,EAAE,cAAc,EAC9B,YAAY,EAAE,YAAY,EACT,UAAU,EAAE,gBAAgB,EAC7C,QAAQ,EAAE,cAAc,EACP,eAAe,EAAE,qBAAqB,EACvD,eAAe,EAAE,eAAe,EACf,aAAa,EAAE,aAAa,EAC5B,YAAY,EAAE,aAAa;IAiB9C,gBAAgB,CAAC,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,eAAe,GAAG,IAAI;IA+ChE,gBAAgB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI;IAmBzC,OAAO,CAAC,UAAU;IA8ElB;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;CA6C5B"}
|
|
@@ -13,47 +13,46 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
13
13
|
exports.WorkerChannelGateway = void 0;
|
|
14
14
|
const websockets_1 = require("@nestjs/websockets");
|
|
15
15
|
const common_1 = require("@nestjs/common");
|
|
16
|
-
const ws_1 = require("ws");
|
|
17
16
|
const protocol_1 = require("@overlordai/protocol");
|
|
17
|
+
const event_emitter_1 = require("@nestjs/event-emitter");
|
|
18
|
+
const event_types_1 = require("../events/event-types");
|
|
18
19
|
const auth_service_1 = require("../auth/auth.service");
|
|
19
20
|
const worker_connection_manager_1 = require("../dispatcher/worker-connection.manager");
|
|
20
21
|
const heartbeat_service_1 = require("../dispatcher/heartbeat.service");
|
|
21
22
|
const reconciler_1 = require("../dispatcher/reconciler");
|
|
22
|
-
const
|
|
23
|
+
const task_lifecycle_service_1 = require("../dispatcher/task-lifecycle.service");
|
|
23
24
|
const task_log_batcher_1 = require("../dispatcher/task-log-batcher");
|
|
24
25
|
const dedup_service_1 = require("../dispatcher/dedup.service");
|
|
25
|
-
const
|
|
26
|
+
const worker_repository_1 = require("../database/repositories/worker.repository");
|
|
26
27
|
const task_repository_1 = require("../database/repositories/task.repository");
|
|
27
28
|
const worker_token_repository_1 = require("../database/repositories/worker-token.repository");
|
|
28
29
|
const notifier_service_1 = require("../notifier/notifier.service");
|
|
29
|
-
const
|
|
30
|
+
const tunnel_service_1 = require("./tunnel.service");
|
|
31
|
+
const frame_handlers_1 = require("./frame-handlers");
|
|
30
32
|
let WorkerChannelGateway = WorkerChannelGateway_1 = class WorkerChannelGateway {
|
|
31
33
|
authService;
|
|
32
34
|
workerConnectionManager;
|
|
33
|
-
|
|
34
|
-
reconciler;
|
|
35
|
-
dispatcher;
|
|
36
|
-
taskLogBatcher;
|
|
37
|
-
dedupService;
|
|
38
|
-
machineRepo;
|
|
39
|
-
taskRepo;
|
|
35
|
+
workerRepo;
|
|
40
36
|
workerTokenRepo;
|
|
41
|
-
|
|
37
|
+
tunnelService;
|
|
38
|
+
eventEmitter;
|
|
42
39
|
logger = new common_1.Logger(WorkerChannelGateway_1.name);
|
|
43
40
|
authedSockets = new Map();
|
|
44
41
|
AUTH_TIMEOUT_MS = 10_000;
|
|
45
|
-
|
|
42
|
+
frameHandlerRegistry;
|
|
43
|
+
constructor(authService, workerConnectionManager, heartbeatService, reconciler, taskLifecycleService, taskLogBatcher, dedupService, workerRepo, taskRepo, workerTokenRepo, notifierService, tunnelService, eventEmitter) {
|
|
46
44
|
this.authService = authService;
|
|
47
45
|
this.workerConnectionManager = workerConnectionManager;
|
|
48
|
-
this.
|
|
49
|
-
this.reconciler = reconciler;
|
|
50
|
-
this.dispatcher = dispatcher;
|
|
51
|
-
this.taskLogBatcher = taskLogBatcher;
|
|
52
|
-
this.dedupService = dedupService;
|
|
53
|
-
this.machineRepo = machineRepo;
|
|
54
|
-
this.taskRepo = taskRepo;
|
|
46
|
+
this.workerRepo = workerRepo;
|
|
55
47
|
this.workerTokenRepo = workerTokenRepo;
|
|
56
|
-
this.
|
|
48
|
+
this.tunnelService = tunnelService;
|
|
49
|
+
this.eventEmitter = eventEmitter;
|
|
50
|
+
this.frameHandlerRegistry = new frame_handlers_1.FrameHandlerRegistry([
|
|
51
|
+
new frame_handlers_1.HeartbeatHandler(heartbeatService, tunnelService),
|
|
52
|
+
new frame_handlers_1.ProgressHandler(workerConnectionManager, reconciler, taskLifecycleService, taskLogBatcher, workerRepo, taskRepo),
|
|
53
|
+
new frame_handlers_1.StageConfirmHandler(dedupService, taskRepo, notifierService),
|
|
54
|
+
new frame_handlers_1.TunnelHandler(tunnelService),
|
|
55
|
+
]);
|
|
57
56
|
}
|
|
58
57
|
handleConnection(client, _req) {
|
|
59
58
|
this.logger.debug('New worker channel connection, awaiting auth frame');
|
|
@@ -87,38 +86,29 @@ let WorkerChannelGateway = WorkerChannelGateway_1 = class WorkerChannelGateway {
|
|
|
87
86
|
this.handleAuth(client, frame);
|
|
88
87
|
return;
|
|
89
88
|
}
|
|
90
|
-
//
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
case 'ack':
|
|
96
|
-
this.handleAck(frame);
|
|
97
|
-
break;
|
|
98
|
-
case 'reconnect':
|
|
99
|
-
void this.handleReconnect(authed, frame);
|
|
100
|
-
break;
|
|
101
|
-
case 'progress':
|
|
102
|
-
this.handleProgress(frame);
|
|
103
|
-
break;
|
|
104
|
-
case 'recovery_secret_ack':
|
|
105
|
-
this.handleRecoverySecretAck(authed, frame);
|
|
106
|
-
break;
|
|
107
|
-
case 'stage_confirm_request':
|
|
108
|
-
void this.handleStageConfirmRequest(frame);
|
|
109
|
-
break;
|
|
110
|
-
default:
|
|
111
|
-
this.logger.debug(`Unknown frame type: ${frame.type}`);
|
|
112
|
-
}
|
|
89
|
+
// Delegate authenticated frames to the handler registry
|
|
90
|
+
this.frameHandlerRegistry.dispatch(frame, {
|
|
91
|
+
workerId: authed.workerId,
|
|
92
|
+
ws: authed.ws,
|
|
93
|
+
});
|
|
113
94
|
});
|
|
114
95
|
}
|
|
115
96
|
handleDisconnect(client) {
|
|
116
97
|
const authed = this.authedSockets.get(client);
|
|
117
98
|
if (authed) {
|
|
118
99
|
clearInterval(authed.revalidationTimer);
|
|
119
|
-
this.workerConnectionManager.unregister(authed.
|
|
100
|
+
this.workerConnectionManager.unregister(authed.workerId);
|
|
101
|
+
const worker = this.workerRepo.findById(authed.workerId);
|
|
102
|
+
const previousStatus = worker?.status ?? protocol_1.WorkerStatus.ONLINE;
|
|
103
|
+
this.workerRepo.updateStatus(authed.workerId, protocol_1.WorkerStatus.OFFLINE);
|
|
104
|
+
this.eventEmitter.emit(event_types_1.DomainEvents.WORKER_STATUS_CHANGED, {
|
|
105
|
+
workerId: authed.workerId,
|
|
106
|
+
status: protocol_1.WorkerStatus.OFFLINE,
|
|
107
|
+
previousStatus,
|
|
108
|
+
});
|
|
109
|
+
this.tunnelService.cleanupTunnelsForWorker(authed.workerId);
|
|
120
110
|
this.authedSockets.delete(client);
|
|
121
|
-
this.logger.log(`Worker ${authed.
|
|
111
|
+
this.logger.log(`Worker ${authed.workerId} disconnected`);
|
|
122
112
|
}
|
|
123
113
|
}
|
|
124
114
|
handleAuth(client, frame) {
|
|
@@ -140,145 +130,79 @@ let WorkerChannelGateway = WorkerChannelGateway_1 = class WorkerChannelGateway {
|
|
|
140
130
|
client.close(4005, 'Protocol version mismatch');
|
|
141
131
|
return;
|
|
142
132
|
}
|
|
143
|
-
// Validate token against
|
|
144
|
-
const
|
|
145
|
-
if (!
|
|
146
|
-
this.logger.warn(`Auth failed:
|
|
147
|
-
client.close(4006, '
|
|
133
|
+
// Validate token against worker record
|
|
134
|
+
const worker = this.workerRepo.findById(payload.sub);
|
|
135
|
+
if (!worker) {
|
|
136
|
+
this.logger.warn(`Auth failed: worker ${payload.sub} not found`);
|
|
137
|
+
client.close(4006, 'Worker not found');
|
|
148
138
|
return;
|
|
149
139
|
}
|
|
150
|
-
if (
|
|
151
|
-
this.logger.warn(`Auth failed: tokenId mismatch for
|
|
140
|
+
if (worker.tokenId !== payload.tokenId) {
|
|
141
|
+
this.logger.warn(`Auth failed: tokenId mismatch for worker ${payload.sub}`);
|
|
152
142
|
client.close(4007, 'Token ID mismatch');
|
|
153
143
|
return;
|
|
154
144
|
}
|
|
155
145
|
// Validate worker token is active
|
|
156
146
|
const workerToken = this.workerTokenRepo.findById(payload.tokenId);
|
|
157
|
-
if (!workerToken || workerToken.status !==
|
|
147
|
+
if (!workerToken || workerToken.status !== protocol_1.TokenStatus.ACTIVE) {
|
|
158
148
|
this.logger.warn(`Auth failed: worker token ${payload.tokenId} not active`);
|
|
159
149
|
client.close(4008, 'Worker token not active');
|
|
160
150
|
return;
|
|
161
151
|
}
|
|
162
152
|
// Register connection
|
|
163
153
|
this.workerConnectionManager.register(payload.sub, client);
|
|
164
|
-
// Mark
|
|
165
|
-
|
|
154
|
+
// Mark worker online (capture previous status before update)
|
|
155
|
+
const previousStatus = worker.status;
|
|
156
|
+
this.workerRepo.updateStatus(payload.sub, protocol_1.WorkerStatus.ONLINE);
|
|
157
|
+
this.eventEmitter.emit(event_types_1.DomainEvents.WORKER_STATUS_CHANGED, {
|
|
158
|
+
workerId: payload.sub,
|
|
159
|
+
status: protocol_1.WorkerStatus.ONLINE,
|
|
160
|
+
previousStatus,
|
|
161
|
+
});
|
|
166
162
|
// Set up periodic revalidation
|
|
167
163
|
const revalidationTimer = setInterval(() => {
|
|
168
164
|
this.revalidateWorkerJwt(client, payload.sub, payload.tokenId);
|
|
169
165
|
}, protocol_1.TOKEN_REVALIDATION_INTERVAL_MS);
|
|
170
166
|
const authedSocket = {
|
|
171
167
|
ws: client,
|
|
172
|
-
|
|
168
|
+
workerId: payload.sub,
|
|
173
169
|
tokenId: payload.tokenId,
|
|
174
170
|
authedAt: Date.now(),
|
|
175
171
|
revalidationTimer,
|
|
176
172
|
};
|
|
177
173
|
this.authedSockets.set(client, authedSocket);
|
|
178
|
-
this.logger.log(`Worker ${payload.sub} authenticated`);
|
|
179
|
-
}
|
|
180
|
-
handleHeartbeat(authed, frame) {
|
|
181
|
-
this.heartbeatService.processHeartbeat(authed.machineId, {
|
|
182
|
-
cpuUsage: frame.metrics.cpuUsage,
|
|
183
|
-
memoryUsage: frame.metrics.memoryUsage,
|
|
184
|
-
diskUsage: frame.metrics.diskUsage,
|
|
185
|
-
activeSlots: frame.metrics.activeSlots,
|
|
186
|
-
}, frame.capabilities, frame.workerVersion, frame.cpuModel, frame.maxSlots);
|
|
187
|
-
// Send heartbeat_ack
|
|
188
|
-
const ack = {
|
|
189
|
-
type: 'heartbeat_ack',
|
|
190
|
-
timestamp: frame.timestamp,
|
|
191
|
-
serverTime: new Date().toISOString(),
|
|
192
|
-
};
|
|
193
|
-
if (authed.ws.readyState === ws_1.WebSocket.OPEN) {
|
|
194
|
-
authed.ws.send(JSON.stringify(ack));
|
|
195
|
-
}
|
|
196
|
-
}
|
|
197
|
-
handleAck(frame) {
|
|
198
|
-
this.workerConnectionManager.handleAck(frame.msgId, frame.payload);
|
|
199
|
-
}
|
|
200
|
-
async handleReconnect(authed, frame) {
|
|
201
|
-
this.logger.log(`Worker ${authed.machineId} reconnecting with ${frame.tasks.length} task(s)`);
|
|
202
|
-
// Update machine status to online
|
|
203
|
-
this.machineRepo.updateStatus(authed.machineId, protocol_1.MachineStatus.ONLINE);
|
|
204
|
-
// Forward to reconciler
|
|
205
|
-
await this.reconciler.handleReconnect(authed.machineId, frame.tasks);
|
|
206
|
-
}
|
|
207
|
-
handleProgress(frame) {
|
|
208
|
-
this.taskLogBatcher.add(frame.taskId, protocol_2.TaskLogType.STAGE_CHANGE, `Stage: ${frame.stage} - ${frame.status}${frame.message ? `: ${frame.message}` : ''}`);
|
|
209
|
-
// Persist current stage so the web UI can show pipeline progress
|
|
210
|
-
this.taskRepo.updateStage(frame.taskId, frame.stage);
|
|
211
|
-
// Transition ASSIGNED → RUNNING on first 'running' progress
|
|
212
|
-
if (frame.status === 'running') {
|
|
213
|
-
if (this.dispatcher.markTaskRunning(frame.taskId)) {
|
|
214
|
-
this.logger.log(`Task #${frame.taskId} marked RUNNING via progress frame`);
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
// Transition task status when worker reports terminal states
|
|
218
|
-
if (frame.status === 'failed' || frame.status === 'cancelled') {
|
|
219
|
-
const targetStatus = frame.status === 'failed' ? protocol_1.TaskStatus.FAILED : protocol_1.TaskStatus.CANCELLED;
|
|
220
|
-
const updated = this.dispatcher.markTaskTerminalFromWorker(frame.taskId, targetStatus, frame.message);
|
|
221
|
-
if (updated) {
|
|
222
|
-
this.logger.log(`Task #${frame.taskId} marked ${frame.status} via progress frame`);
|
|
223
|
-
}
|
|
224
|
-
}
|
|
225
|
-
}
|
|
226
|
-
handleRecoverySecretAck(authed, _frame) {
|
|
227
|
-
this.logger.log(`Worker ${authed.machineId} acknowledged recovery secret bootstrap`);
|
|
228
|
-
}
|
|
229
|
-
async handleStageConfirmRequest(frame) {
|
|
230
|
-
const { taskId, stageIndex, mode, prompt, choices, timeout } = frame;
|
|
231
|
-
this.logger.log(`Stage confirm request for task #${taskId}, stage ${stageIndex}, mode=${mode}`);
|
|
232
|
-
// Store pending confirm in Redis via DedupService
|
|
233
|
-
const confirmKey = `stage:${taskId}:${stageIndex}`;
|
|
234
|
-
await this.dedupService.storePendingConfirm(confirmKey, {
|
|
235
|
-
taskId,
|
|
236
|
-
stageIndex,
|
|
237
|
-
mode,
|
|
238
|
-
prompt,
|
|
239
|
-
choices,
|
|
240
|
-
timeout,
|
|
241
|
-
createdAt: new Date().toISOString(),
|
|
242
|
-
});
|
|
243
|
-
// Notify web clients via the notification channel
|
|
244
|
-
const task = this.taskRepo.findById(taskId);
|
|
245
|
-
if (task) {
|
|
246
|
-
await this.notifierService.notifyStageConfirmRequired(task, `stage_${stageIndex}`);
|
|
247
|
-
}
|
|
248
|
-
else {
|
|
249
|
-
this.logger.warn(`Task #${taskId} not found when processing stage confirm request`);
|
|
250
|
-
}
|
|
174
|
+
this.logger.log(`Worker ${payload.sub} authenticated successfully`);
|
|
251
175
|
}
|
|
252
176
|
/**
|
|
253
177
|
* Periodically revalidate Worker JWT. Disconnect if token is invalid,
|
|
254
|
-
*
|
|
178
|
+
* worker tokenId changed, or worker token is revoked/expired.
|
|
255
179
|
* Honors a 2-minute grace period for old JWTs during token refresh.
|
|
256
180
|
*/
|
|
257
|
-
revalidateWorkerJwt(client,
|
|
258
|
-
// Check
|
|
259
|
-
const
|
|
260
|
-
if (!
|
|
261
|
-
this.logger.warn(`Revalidation failed:
|
|
262
|
-
client.close(4010, '
|
|
181
|
+
revalidateWorkerJwt(client, workerId, tokenId) {
|
|
182
|
+
// Check worker still exists and tokenId matches
|
|
183
|
+
const worker = this.workerRepo.findById(workerId);
|
|
184
|
+
if (!worker) {
|
|
185
|
+
this.logger.warn(`Revalidation failed: worker ${workerId} not found, disconnecting`);
|
|
186
|
+
client.close(4010, 'Worker not found');
|
|
263
187
|
return;
|
|
264
188
|
}
|
|
265
|
-
if (
|
|
189
|
+
if (worker.tokenId !== tokenId) {
|
|
266
190
|
// Check grace period
|
|
267
191
|
const authed = this.authedSockets.get(client);
|
|
268
192
|
if (authed) {
|
|
269
193
|
const elapsed = Date.now() - authed.authedAt;
|
|
270
194
|
if (elapsed < protocol_1.WORKER_JWT_GRACE_PERIOD_MS) {
|
|
271
|
-
this.logger.debug(`TokenId mismatch for ${
|
|
195
|
+
this.logger.debug(`TokenId mismatch for ${workerId} but within grace period (${elapsed}ms)`);
|
|
272
196
|
return;
|
|
273
197
|
}
|
|
274
198
|
}
|
|
275
|
-
this.logger.warn(`Revalidation failed: tokenId mismatch for
|
|
199
|
+
this.logger.warn(`Revalidation failed: tokenId mismatch for worker ${workerId}, disconnecting`);
|
|
276
200
|
client.close(4011, 'Token ID mismatch');
|
|
277
201
|
return;
|
|
278
202
|
}
|
|
279
203
|
// Check worker token is still active
|
|
280
204
|
const workerToken = this.workerTokenRepo.findById(tokenId);
|
|
281
|
-
if (!workerToken || workerToken.status !==
|
|
205
|
+
if (!workerToken || workerToken.status !== protocol_1.TokenStatus.ACTIVE) {
|
|
282
206
|
this.logger.warn(`Revalidation failed: worker token ${tokenId} not active, disconnecting`);
|
|
283
207
|
client.close(4012, 'Worker token not active');
|
|
284
208
|
return;
|
|
@@ -292,12 +216,14 @@ exports.WorkerChannelGateway = WorkerChannelGateway = WorkerChannelGateway_1 = _
|
|
|
292
216
|
worker_connection_manager_1.WorkerConnectionManager,
|
|
293
217
|
heartbeat_service_1.HeartbeatService,
|
|
294
218
|
reconciler_1.Reconciler,
|
|
295
|
-
|
|
219
|
+
task_lifecycle_service_1.TaskLifecycleService,
|
|
296
220
|
task_log_batcher_1.TaskLogBatcher,
|
|
297
221
|
dedup_service_1.DedupService,
|
|
298
|
-
|
|
222
|
+
worker_repository_1.WorkerRepository,
|
|
299
223
|
task_repository_1.TaskRepository,
|
|
300
224
|
worker_token_repository_1.WorkerTokenRepository,
|
|
301
|
-
notifier_service_1.NotifierService
|
|
225
|
+
notifier_service_1.NotifierService,
|
|
226
|
+
tunnel_service_1.TunnelService,
|
|
227
|
+
event_emitter_1.EventEmitter2])
|
|
302
228
|
], WorkerChannelGateway);
|
|
303
229
|
//# sourceMappingURL=worker-channel.gateway.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"worker-channel.gateway.js","sourceRoot":"","sources":["../../src/web/worker-channel.gateway.ts"],"names":[],"mappings":";;;;;;;;;;;;;AAAA,mDAI4B;AAC5B,2CAAwC;
|
|
1
|
+
{"version":3,"file":"worker-channel.gateway.js","sourceRoot":"","sources":["../../src/web/worker-channel.gateway.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { WorkerRepository } from '../database/repositories/worker.repository';
|
|
2
|
+
import { DatabaseService } from '../database/database.service';
|
|
3
|
+
import type { AuthenticatedRequest } from '../auth/authenticated-request';
|
|
4
|
+
export declare class WorkerWebController {
|
|
5
|
+
private readonly workerRepo;
|
|
6
|
+
private readonly db;
|
|
7
|
+
constructor(workerRepo: WorkerRepository, db: DatabaseService);
|
|
8
|
+
listWorkers(status?: string): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">[];
|
|
9
|
+
getWorker(id: string): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">;
|
|
10
|
+
getWorkerTasks(id: string, req: AuthenticatedRequest): import("../database/repositories/task.repository").EnrichedTask[];
|
|
11
|
+
drainWorker(id: string): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">;
|
|
12
|
+
undrainWorker(id: string): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">;
|
|
13
|
+
private setWorkerDrainStatus;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=worker-web.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-web.controller.d.ts","sourceRoot":"","sources":["../../src/web/worker-web.controller.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAE9E,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAU1E,qBAEa,mBAAmB;IAE5B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,EAAE;gBADF,UAAU,EAAE,gBAAgB,EAC5B,EAAE,EAAE,eAAe;IAItC,WAAW,CAAkB,MAAM,CAAC,EAAE,MAAM;IAU5C,SAAS,CAAc,EAAE,EAAE,MAAM;IAUjC,cAAc,CAAc,EAAE,EAAE,MAAM,EAAS,GAAG,EAAE,oBAAoB;IA8BxE,WAAW,CAAc,EAAE,EAAE,MAAM;IAOnC,aAAa,CAAc,EAAE,EAAE,MAAM;IAIrC,OAAO,CAAC,oBAAoB;CAa7B"}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.WorkerWebController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
18
|
+
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
19
|
+
const roles_guard_1 = require("../auth/guards/roles.guard");
|
|
20
|
+
const roles_decorator_1 = require("../auth/decorators/roles.decorator");
|
|
21
|
+
const rate_limit_guard_1 = require("../common/rate-limit.guard");
|
|
22
|
+
const worker_repository_1 = require("../database/repositories/worker.repository");
|
|
23
|
+
const task_repository_1 = require("../database/repositories/task.repository");
|
|
24
|
+
const database_service_1 = require("../database/database.service");
|
|
25
|
+
const UUID_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i;
|
|
26
|
+
function validateWorkerId(id) {
|
|
27
|
+
if (!UUID_REGEX.test(id)) {
|
|
28
|
+
throw new common_1.BadRequestException('Worker ID must be a valid UUID');
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
let WorkerWebController = class WorkerWebController {
|
|
32
|
+
workerRepo;
|
|
33
|
+
db;
|
|
34
|
+
constructor(workerRepo, db) {
|
|
35
|
+
this.workerRepo = workerRepo;
|
|
36
|
+
this.db = db;
|
|
37
|
+
}
|
|
38
|
+
listWorkers(status) {
|
|
39
|
+
// findAll() excludes decommissioned by default
|
|
40
|
+
const workers = this.workerRepo.findAll();
|
|
41
|
+
if (status) {
|
|
42
|
+
return workers.filter((w) => w.status === status).map(worker_repository_1.WorkerRepository.stripSecrets);
|
|
43
|
+
}
|
|
44
|
+
return workers.map(worker_repository_1.WorkerRepository.stripSecrets);
|
|
45
|
+
}
|
|
46
|
+
getWorker(id) {
|
|
47
|
+
validateWorkerId(id);
|
|
48
|
+
const worker = this.workerRepo.findById(id);
|
|
49
|
+
if (!worker) {
|
|
50
|
+
throw new common_1.NotFoundException(`Worker '${id}' not found`);
|
|
51
|
+
}
|
|
52
|
+
return worker_repository_1.WorkerRepository.stripSecrets(worker);
|
|
53
|
+
}
|
|
54
|
+
getWorkerTasks(id, req) {
|
|
55
|
+
validateWorkerId(id);
|
|
56
|
+
const worker = this.workerRepo.findById(id);
|
|
57
|
+
if (!worker) {
|
|
58
|
+
throw new common_1.NotFoundException(`Worker '${id}' not found`);
|
|
59
|
+
}
|
|
60
|
+
const database = this.db.getDb();
|
|
61
|
+
let sql = `SELECT t.*, d.name AS creator_name, w.name AS worker_name, assignee.name AS developer_name
|
|
62
|
+
FROM tasks t
|
|
63
|
+
LEFT JOIN developers d ON t.created_by = d.id
|
|
64
|
+
LEFT JOIN developers assignee ON t.developer_id = assignee.id
|
|
65
|
+
LEFT JOIN workers w ON t.worker_id = w.id
|
|
66
|
+
WHERE t.worker_id = ?`;
|
|
67
|
+
const params = [id];
|
|
68
|
+
if (req.user.role !== protocol_1.DeveloperRole.ADMIN) {
|
|
69
|
+
sql += ' AND (t.created_by = ? OR t.developer_id = ?)';
|
|
70
|
+
params.push(req.user.sub, req.user.sub);
|
|
71
|
+
}
|
|
72
|
+
sql += ' ORDER BY t.updated_at DESC';
|
|
73
|
+
const rows = database.prepare(sql).all(...params);
|
|
74
|
+
return rows.map(task_repository_1.mapEnrichedRow);
|
|
75
|
+
}
|
|
76
|
+
drainWorker(id) {
|
|
77
|
+
return this.setWorkerDrainStatus(id, protocol_1.WorkerStatus.DRAINING);
|
|
78
|
+
}
|
|
79
|
+
undrainWorker(id) {
|
|
80
|
+
return this.setWorkerDrainStatus(id, protocol_1.WorkerStatus.ONLINE);
|
|
81
|
+
}
|
|
82
|
+
setWorkerDrainStatus(id, targetStatus) {
|
|
83
|
+
validateWorkerId(id);
|
|
84
|
+
const worker = this.workerRepo.findById(id);
|
|
85
|
+
if (!worker) {
|
|
86
|
+
throw new common_1.NotFoundException(`Worker '${id}' not found`);
|
|
87
|
+
}
|
|
88
|
+
if (worker.status === protocol_1.WorkerStatus.DECOMMISSIONED) {
|
|
89
|
+
const action = targetStatus === protocol_1.WorkerStatus.DRAINING ? 'drain' : 'undrain';
|
|
90
|
+
throw new common_1.BadRequestException(`Cannot ${action} a decommissioned worker`);
|
|
91
|
+
}
|
|
92
|
+
this.workerRepo.updateStatus(id, targetStatus);
|
|
93
|
+
return worker_repository_1.WorkerRepository.stripSecrets(this.workerRepo.findById(id));
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
exports.WorkerWebController = WorkerWebController;
|
|
97
|
+
__decorate([
|
|
98
|
+
(0, common_1.Get)(),
|
|
99
|
+
__param(0, (0, common_1.Query)('status')),
|
|
100
|
+
__metadata("design:type", Function),
|
|
101
|
+
__metadata("design:paramtypes", [String]),
|
|
102
|
+
__metadata("design:returntype", void 0)
|
|
103
|
+
], WorkerWebController.prototype, "listWorkers", null);
|
|
104
|
+
__decorate([
|
|
105
|
+
(0, common_1.Get)(':id'),
|
|
106
|
+
__param(0, (0, common_1.Param)('id')),
|
|
107
|
+
__metadata("design:type", Function),
|
|
108
|
+
__metadata("design:paramtypes", [String]),
|
|
109
|
+
__metadata("design:returntype", void 0)
|
|
110
|
+
], WorkerWebController.prototype, "getWorker", null);
|
|
111
|
+
__decorate([
|
|
112
|
+
(0, common_1.Get)(':id/tasks'),
|
|
113
|
+
__param(0, (0, common_1.Param)('id')),
|
|
114
|
+
__param(1, (0, common_1.Req)()),
|
|
115
|
+
__metadata("design:type", Function),
|
|
116
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
117
|
+
__metadata("design:returntype", void 0)
|
|
118
|
+
], WorkerWebController.prototype, "getWorkerTasks", null);
|
|
119
|
+
__decorate([
|
|
120
|
+
(0, common_1.Post)(':id/drain'),
|
|
121
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.LEAD),
|
|
122
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 10, windowMs: 60_000 }),
|
|
123
|
+
__param(0, (0, common_1.Param)('id')),
|
|
124
|
+
__metadata("design:type", Function),
|
|
125
|
+
__metadata("design:paramtypes", [String]),
|
|
126
|
+
__metadata("design:returntype", void 0)
|
|
127
|
+
], WorkerWebController.prototype, "drainWorker", null);
|
|
128
|
+
__decorate([
|
|
129
|
+
(0, common_1.Post)(':id/undrain'),
|
|
130
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.LEAD),
|
|
131
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 10, windowMs: 60_000 }),
|
|
132
|
+
__param(0, (0, common_1.Param)('id')),
|
|
133
|
+
__metadata("design:type", Function),
|
|
134
|
+
__metadata("design:paramtypes", [String]),
|
|
135
|
+
__metadata("design:returntype", void 0)
|
|
136
|
+
], WorkerWebController.prototype, "undrainWorker", null);
|
|
137
|
+
exports.WorkerWebController = WorkerWebController = __decorate([
|
|
138
|
+
(0, common_1.Controller)('api/web/workers'),
|
|
139
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
140
|
+
__metadata("design:paramtypes", [worker_repository_1.WorkerRepository,
|
|
141
|
+
database_service_1.DatabaseService])
|
|
142
|
+
], WorkerWebController);
|
|
143
|
+
//# sourceMappingURL=worker-web.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-web.controller.js","sourceRoot":"","sources":["../../src/web/worker-web.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import type { WorkerRegisterRequest, WorkerRegisterResponse, WorkerRefreshRequest, WorkerRefreshResponse, WorkerRecoveryRequest, WorkerRecoveryResponse } from '@overlordai/protocol';
|
|
2
|
-
import {
|
|
2
|
+
import { WorkerAuthService } from '../dispatcher/worker-auth.service';
|
|
3
3
|
import { AuthService } from '../auth/auth.service';
|
|
4
4
|
import { WorkerConnectionManager } from '../dispatcher/worker-connection.manager';
|
|
5
5
|
export declare class WorkerController {
|
|
6
|
-
private readonly
|
|
6
|
+
private readonly workerAuthService;
|
|
7
7
|
private readonly authService;
|
|
8
8
|
private readonly workerConnectionManager;
|
|
9
|
-
constructor(
|
|
9
|
+
constructor(workerAuthService: WorkerAuthService, authService: AuthService, workerConnectionManager: WorkerConnectionManager);
|
|
10
10
|
healthz(): {
|
|
11
11
|
status: string;
|
|
12
12
|
connectedWorkers: number;
|