@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
|
@@ -3,21 +3,20 @@ import { ProjectMemberRepository } from '../database/repositories/project-member
|
|
|
3
3
|
import { DeveloperRepository } from '../database/repositories/developer.repository';
|
|
4
4
|
import { TaskRepository } from '../database/repositories/task.repository';
|
|
5
5
|
import { AuditLogRepository } from '../database/repositories/audit-log.repository';
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
name: string;
|
|
10
|
-
role: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
6
|
+
import { CryptoService } from '../common/crypto.service';
|
|
7
|
+
import { ProjectMemberService } from './project-member.service';
|
|
8
|
+
import type { AuthenticatedRequest } from '../auth/authenticated-request';
|
|
13
9
|
export declare class ProjectController {
|
|
14
10
|
private readonly projectRepo;
|
|
15
11
|
private readonly projectMemberRepo;
|
|
16
12
|
private readonly developerRepo;
|
|
17
13
|
private readonly taskRepo;
|
|
18
14
|
private readonly auditLogRepo;
|
|
19
|
-
|
|
15
|
+
private readonly projectMemberService;
|
|
16
|
+
private readonly cryptoService;
|
|
17
|
+
constructor(projectRepo: ProjectRepository, projectMemberRepo: ProjectMemberRepository, developerRepo: DeveloperRepository, taskRepo: TaskRepository, auditLogRepo: AuditLogRepository, projectMemberService: ProjectMemberService, cryptoService: CryptoService);
|
|
20
18
|
listProjects(): {
|
|
19
|
+
gitTokenMasked: boolean | null;
|
|
21
20
|
taskCount: number;
|
|
22
21
|
memberCount: number;
|
|
23
22
|
members: {
|
|
@@ -26,6 +25,7 @@ export declare class ProjectController {
|
|
|
26
25
|
}[];
|
|
27
26
|
lastActivity: string | null;
|
|
28
27
|
key: string;
|
|
28
|
+
createdAt: string;
|
|
29
29
|
name: string;
|
|
30
30
|
aliases: string[];
|
|
31
31
|
repoUrl: string;
|
|
@@ -44,7 +44,7 @@ export declare class ProjectController {
|
|
|
44
44
|
pipeline: string | null;
|
|
45
45
|
ptyOutputFilter: number;
|
|
46
46
|
isDefault: boolean;
|
|
47
|
-
|
|
47
|
+
defaultReviewers: string[];
|
|
48
48
|
}[];
|
|
49
49
|
listDevelopers(): {
|
|
50
50
|
id: number;
|
|
@@ -52,30 +52,47 @@ export declare class ProjectController {
|
|
|
52
52
|
gitEmail: string;
|
|
53
53
|
role: import("@overlordai/protocol").DeveloperRole;
|
|
54
54
|
}[];
|
|
55
|
-
getProject(key: string):
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
id: number;
|
|
59
|
-
projectKey: string;
|
|
60
|
-
developerId: number;
|
|
61
|
-
developerName: string | null;
|
|
62
|
-
role: string;
|
|
55
|
+
getProject(key: string): {
|
|
56
|
+
gitTokenMasked: string | null;
|
|
57
|
+
key: string;
|
|
63
58
|
createdAt: string;
|
|
64
|
-
|
|
59
|
+
name: string;
|
|
60
|
+
aliases: string[];
|
|
61
|
+
repoUrl: string;
|
|
62
|
+
sshUrl: string | null;
|
|
63
|
+
gitPlatform: import("@overlordai/protocol").GitPlatform;
|
|
64
|
+
defaultBranch: string;
|
|
65
|
+
workspaceRoot: string | null;
|
|
66
|
+
setupCommands: string | null;
|
|
67
|
+
testCommand: string | null;
|
|
68
|
+
agentType: import("@overlordai/protocol").AgentType;
|
|
69
|
+
agentCommand: string | null;
|
|
70
|
+
agentEnv: string | null;
|
|
71
|
+
skillsPath: string | null;
|
|
72
|
+
allowedTools: string | null;
|
|
73
|
+
maxTurns: number;
|
|
74
|
+
pipeline: string | null;
|
|
75
|
+
ptyOutputFilter: number;
|
|
76
|
+
isDefault: boolean;
|
|
77
|
+
defaultReviewers: string[];
|
|
78
|
+
};
|
|
79
|
+
updateProject(key: string, body: Record<string, unknown>, req: AuthenticatedRequest): Omit<import("@overlordai/protocol").Project, "gitTokenEncrypted"> | null;
|
|
80
|
+
listMembers(key: string): import("../database/repositories/project-member.repository").ProjectMember[];
|
|
65
81
|
addMember(key: string, body: {
|
|
66
82
|
developerId: number;
|
|
67
83
|
role?: string;
|
|
84
|
+
}, req: AuthenticatedRequest): import("../database/repositories/project-member.repository").ProjectMember;
|
|
85
|
+
removeMember(key: string, developerId: string, req: AuthenticatedRequest): {
|
|
86
|
+
success: boolean;
|
|
87
|
+
};
|
|
88
|
+
setGitToken(key: string, body: {
|
|
89
|
+
token: string;
|
|
68
90
|
}, req: AuthenticatedRequest): {
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
developerId: number;
|
|
72
|
-
developerName: string | null;
|
|
73
|
-
role: string;
|
|
74
|
-
createdAt: string;
|
|
91
|
+
success: boolean;
|
|
92
|
+
gitTokenMasked: string;
|
|
75
93
|
};
|
|
76
|
-
|
|
94
|
+
deleteGitToken(key: string, req: AuthenticatedRequest): {
|
|
77
95
|
success: boolean;
|
|
78
96
|
};
|
|
79
97
|
}
|
|
80
|
-
export {};
|
|
81
98
|
//# sourceMappingURL=project.controller.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.controller.d.ts","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"project.controller.d.ts","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":"AAoBA,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,MAAM,oDAAoD,CAAC;AAC7F,OAAO,EAAE,mBAAmB,EAAE,MAAM,+CAA+C,CAAC;AACpF,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAC;AAC1E,OAAO,EAAE,kBAAkB,EAAE,MAAM,+CAA+C,CAAC;AACnF,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAGzD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAChE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;AAE1E,qBAEa,iBAAiB;IAE1B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,oBAAoB;IACrC,OAAO,CAAC,QAAQ,CAAC,aAAa;gBANb,WAAW,EAAE,iBAAiB,EAC9B,iBAAiB,EAAE,uBAAuB,EAC1C,aAAa,EAAE,mBAAmB,EAClC,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,kBAAkB,EAChC,oBAAoB,EAAE,oBAAoB,EAC1C,aAAa,EAAE,aAAa;IAK/C,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAmBZ,cAAc;;;;;;IAUd,UAAU,CAAe,GAAG,EAAE,MAAM;;;;;;;;;;;;;;;;;;;;;;;;IAuBpC,aAAa,CACU,GAAG,EAAE,MAAM,EACxB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,GAAG,EAAE,oBAAoB;IAwBlC,WAAW,CAAsB,GAAG,EAAE,MAAM;IAO5C,SAAS,CACc,GAAG,EAAE,MAAM,EACxB,IAAI,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,EAC7C,GAAG,EAAE,oBAAoB;IAQlC,YAAY,CACW,GAAG,EAAE,MAAM,EACV,WAAW,EAAE,MAAM,EAClC,GAAG,EAAE,oBAAoB;;;IASlC,WAAW,CACY,GAAG,EAAE,MAAM,EACxB,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,EACxB,GAAG,EAAE,oBAAoB;;;;IA6BlC,cAAc,CACS,GAAG,EAAE,MAAM,EACzB,GAAG,EAAE,oBAAoB;;;CAkBnC"}
|
|
@@ -16,6 +16,7 @@ exports.ProjectController = void 0;
|
|
|
16
16
|
const common_1 = require("@nestjs/common");
|
|
17
17
|
const protocol_1 = require("@overlordai/protocol");
|
|
18
18
|
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
19
|
+
const rate_limit_guard_1 = require("../common/rate-limit.guard");
|
|
19
20
|
const project_role_guard_1 = require("../auth/guards/project-role.guard");
|
|
20
21
|
const project_roles_decorator_1 = require("../auth/decorators/project-roles.decorator");
|
|
21
22
|
const project_repository_1 = require("../database/repositories/project.repository");
|
|
@@ -23,18 +24,26 @@ const project_member_repository_1 = require("../database/repositories/project-me
|
|
|
23
24
|
const developer_repository_1 = require("../database/repositories/developer.repository");
|
|
24
25
|
const task_repository_1 = require("../database/repositories/task.repository");
|
|
25
26
|
const audit_log_repository_1 = require("../database/repositories/audit-log.repository");
|
|
27
|
+
const crypto_service_1 = require("../common/crypto.service");
|
|
28
|
+
const string_utils_1 = require("../common/string-utils");
|
|
29
|
+
const project_validation_1 = require("../common/project-validation");
|
|
30
|
+
const project_member_service_1 = require("./project-member.service");
|
|
26
31
|
let ProjectController = class ProjectController {
|
|
27
32
|
projectRepo;
|
|
28
33
|
projectMemberRepo;
|
|
29
34
|
developerRepo;
|
|
30
35
|
taskRepo;
|
|
31
36
|
auditLogRepo;
|
|
32
|
-
|
|
37
|
+
projectMemberService;
|
|
38
|
+
cryptoService;
|
|
39
|
+
constructor(projectRepo, projectMemberRepo, developerRepo, taskRepo, auditLogRepo, projectMemberService, cryptoService) {
|
|
33
40
|
this.projectRepo = projectRepo;
|
|
34
41
|
this.projectMemberRepo = projectMemberRepo;
|
|
35
42
|
this.developerRepo = developerRepo;
|
|
36
43
|
this.taskRepo = taskRepo;
|
|
37
44
|
this.auditLogRepo = auditLogRepo;
|
|
45
|
+
this.projectMemberService = projectMemberService;
|
|
46
|
+
this.cryptoService = cryptoService;
|
|
38
47
|
}
|
|
39
48
|
listProjects() {
|
|
40
49
|
const projects = this.projectRepo.findAll();
|
|
@@ -43,7 +52,8 @@ let ProjectController = class ProjectController {
|
|
|
43
52
|
const lastActivityMap = this.taskRepo.lastActivityByProject();
|
|
44
53
|
const memberCountMap = this.projectMemberRepo.countByProject();
|
|
45
54
|
return projects.map((p) => ({
|
|
46
|
-
...p,
|
|
55
|
+
...project_repository_1.ProjectRepository.stripSecrets(p),
|
|
56
|
+
gitTokenMasked: p.gitTokenEncrypted ? true : null,
|
|
47
57
|
taskCount: taskCountMap.get(p.key) ?? 0,
|
|
48
58
|
memberCount: memberCountMap.get(p.key) ?? 0,
|
|
49
59
|
members: memberMap.get(p.key) ?? [],
|
|
@@ -63,19 +73,25 @@ let ProjectController = class ProjectController {
|
|
|
63
73
|
if (!project) {
|
|
64
74
|
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
65
75
|
}
|
|
66
|
-
return
|
|
76
|
+
// Mask git token — never return the encrypted blob to the frontend
|
|
77
|
+
let gitTokenMasked = null;
|
|
78
|
+
if (project.gitTokenEncrypted) {
|
|
79
|
+
try {
|
|
80
|
+
const plainToken = this.cryptoService.decryptAes(project.gitTokenEncrypted);
|
|
81
|
+
gitTokenMasked = (0, string_utils_1.maskToken)(plainToken);
|
|
82
|
+
}
|
|
83
|
+
catch {
|
|
84
|
+
gitTokenMasked = '●●●●●●●●';
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
return { ...project_repository_1.ProjectRepository.stripSecrets(project), gitTokenMasked };
|
|
67
88
|
}
|
|
68
89
|
updateProject(key, body, req) {
|
|
69
90
|
const project = this.projectRepo.findByKey(key);
|
|
70
91
|
if (!project) {
|
|
71
92
|
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
72
93
|
}
|
|
73
|
-
const
|
|
74
|
-
const sanitized = {};
|
|
75
|
-
for (const field of allowed) {
|
|
76
|
-
if (field in body)
|
|
77
|
-
sanitized[field] = body[field];
|
|
78
|
-
}
|
|
94
|
+
const sanitized = (0, project_validation_1.validateProjectUpdate)(body);
|
|
79
95
|
this.projectRepo.update(key, sanitized);
|
|
80
96
|
this.auditLogRepo.create({
|
|
81
97
|
userId: req.user.sub,
|
|
@@ -83,63 +99,47 @@ let ProjectController = class ProjectController {
|
|
|
83
99
|
resource: `project:${key}`,
|
|
84
100
|
detail: `Updated project '${key}'`,
|
|
85
101
|
});
|
|
86
|
-
|
|
102
|
+
const updated = this.projectRepo.findByKey(key);
|
|
103
|
+
return updated ? project_repository_1.ProjectRepository.stripSecrets(updated) : null;
|
|
87
104
|
}
|
|
88
105
|
listMembers(key) {
|
|
89
|
-
|
|
90
|
-
if (!project) {
|
|
91
|
-
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
92
|
-
}
|
|
93
|
-
return this.projectMemberRepo.findByProject(key);
|
|
106
|
+
return this.projectMemberService.listMembers(key);
|
|
94
107
|
}
|
|
95
108
|
addMember(key, body, req) {
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
throw new common_1.BadRequestException(`role must be one of: ${validRoles.join(', ')}`);
|
|
103
|
-
}
|
|
109
|
+
return this.projectMemberService.addMember(key, body.developerId, body.role, req.user.sub);
|
|
110
|
+
}
|
|
111
|
+
removeMember(key, developerId, req) {
|
|
112
|
+
return this.projectMemberService.removeMember(key, developerId, req.user.sub);
|
|
113
|
+
}
|
|
114
|
+
setGitToken(key, body, req) {
|
|
104
115
|
const project = this.projectRepo.findByKey(key);
|
|
105
116
|
if (!project) {
|
|
106
117
|
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
107
118
|
}
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
throw new common_1.ConflictException('Developer is already a member of this project');
|
|
119
|
+
if (!body.token || typeof body.token !== 'string' || body.token.trim().length === 0) {
|
|
120
|
+
throw new common_1.BadRequestException('token is required and must be a non-empty string');
|
|
111
121
|
}
|
|
112
|
-
const
|
|
113
|
-
|
|
114
|
-
developerId: body.developerId,
|
|
115
|
-
role,
|
|
116
|
-
});
|
|
122
|
+
const encrypted = this.cryptoService.encryptAes(body.token.trim());
|
|
123
|
+
this.projectRepo.update(key, { gitTokenEncrypted: encrypted });
|
|
117
124
|
this.auditLogRepo.create({
|
|
118
125
|
userId: req.user.sub,
|
|
119
|
-
action: '
|
|
126
|
+
action: 'project_update',
|
|
120
127
|
resource: `project:${key}`,
|
|
121
|
-
detail: `
|
|
128
|
+
detail: `Set git token for project '${key}'`,
|
|
122
129
|
});
|
|
123
|
-
return
|
|
130
|
+
return { success: true, gitTokenMasked: (0, string_utils_1.maskToken)(body.token.trim()) };
|
|
124
131
|
}
|
|
125
|
-
|
|
132
|
+
deleteGitToken(key, req) {
|
|
126
133
|
const project = this.projectRepo.findByKey(key);
|
|
127
134
|
if (!project) {
|
|
128
135
|
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
129
136
|
}
|
|
130
|
-
|
|
131
|
-
if (!developerId || isNaN(devId) || devId < 1) {
|
|
132
|
-
throw new common_1.BadRequestException('developerId query parameter is required');
|
|
133
|
-
}
|
|
134
|
-
const deleted = this.projectMemberRepo.delete(key, devId);
|
|
135
|
-
if (!deleted) {
|
|
136
|
-
throw new common_1.NotFoundException('Member not found');
|
|
137
|
-
}
|
|
137
|
+
this.projectRepo.update(key, { gitTokenEncrypted: null });
|
|
138
138
|
this.auditLogRepo.create({
|
|
139
139
|
userId: req.user.sub,
|
|
140
|
-
action: '
|
|
140
|
+
action: 'project_update',
|
|
141
141
|
resource: `project:${key}`,
|
|
142
|
-
detail: `
|
|
142
|
+
detail: `Cleared git token for project '${key}'`,
|
|
143
143
|
});
|
|
144
144
|
return { success: true };
|
|
145
145
|
}
|
|
@@ -147,6 +147,7 @@ let ProjectController = class ProjectController {
|
|
|
147
147
|
exports.ProjectController = ProjectController;
|
|
148
148
|
__decorate([
|
|
149
149
|
(0, common_1.Get)(),
|
|
150
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 60, windowMs: 60_000 }),
|
|
150
151
|
__metadata("design:type", Function),
|
|
151
152
|
__metadata("design:paramtypes", []),
|
|
152
153
|
__metadata("design:returntype", void 0)
|
|
@@ -206,6 +207,30 @@ __decorate([
|
|
|
206
207
|
__metadata("design:paramtypes", [String, String, Object]),
|
|
207
208
|
__metadata("design:returntype", void 0)
|
|
208
209
|
], ProjectController.prototype, "removeMember", null);
|
|
210
|
+
__decorate([
|
|
211
|
+
(0, common_1.Put)(':projectKey/git-token'),
|
|
212
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 10, windowMs: 60_000 }),
|
|
213
|
+
(0, common_1.UseGuards)(project_role_guard_1.ProjectRoleGuard),
|
|
214
|
+
(0, project_roles_decorator_1.ProjectRoles)(protocol_1.ProjectRole.MAINTAINER),
|
|
215
|
+
__param(0, (0, common_1.Param)('projectKey')),
|
|
216
|
+
__param(1, (0, common_1.Body)()),
|
|
217
|
+
__param(2, (0, common_1.Req)()),
|
|
218
|
+
__metadata("design:type", Function),
|
|
219
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
220
|
+
__metadata("design:returntype", void 0)
|
|
221
|
+
], ProjectController.prototype, "setGitToken", null);
|
|
222
|
+
__decorate([
|
|
223
|
+
(0, common_1.Delete)(':projectKey/git-token'),
|
|
224
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 10, windowMs: 60_000 }),
|
|
225
|
+
(0, common_1.HttpCode)(200),
|
|
226
|
+
(0, common_1.UseGuards)(project_role_guard_1.ProjectRoleGuard),
|
|
227
|
+
(0, project_roles_decorator_1.ProjectRoles)(protocol_1.ProjectRole.MAINTAINER),
|
|
228
|
+
__param(0, (0, common_1.Param)('projectKey')),
|
|
229
|
+
__param(1, (0, common_1.Req)()),
|
|
230
|
+
__metadata("design:type", Function),
|
|
231
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
232
|
+
__metadata("design:returntype", void 0)
|
|
233
|
+
], ProjectController.prototype, "deleteGitToken", null);
|
|
209
234
|
exports.ProjectController = ProjectController = __decorate([
|
|
210
235
|
(0, common_1.Controller)('api/web/projects'),
|
|
211
236
|
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard),
|
|
@@ -213,6 +238,8 @@ exports.ProjectController = ProjectController = __decorate([
|
|
|
213
238
|
project_member_repository_1.ProjectMemberRepository,
|
|
214
239
|
developer_repository_1.DeveloperRepository,
|
|
215
240
|
task_repository_1.TaskRepository,
|
|
216
|
-
audit_log_repository_1.AuditLogRepository
|
|
241
|
+
audit_log_repository_1.AuditLogRepository,
|
|
242
|
+
project_member_service_1.ProjectMemberService,
|
|
243
|
+
crypto_service_1.CryptoService])
|
|
217
244
|
], ProjectController);
|
|
218
245
|
//# sourceMappingURL=project.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"project.controller.js","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAcwB;AACxB,mDAAmD;AACnD,kEAA6D;AAC7D,0EAAqE;AACrE,wFAA0E;AAC1E,oFAAgF;AAChF,kGAA6F;AAC7F,wFAAoF;AACpF,8EAA0E;AAC1E,wFAAmF;
|
|
1
|
+
{"version":3,"file":"project.controller.js","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,19 +5,25 @@ import { AuthService } from '../auth/auth.service';
|
|
|
5
5
|
import { PtyRelayService } from '../dispatcher/pty-relay.service';
|
|
6
6
|
import { RedisService } from '../redis/redis.service';
|
|
7
7
|
import { DeveloperRepository } from '../database/repositories/developer.repository';
|
|
8
|
-
import {
|
|
8
|
+
import { WorkerRepository } from '../database/repositories/worker.repository';
|
|
9
9
|
import { TaskRepository } from '../database/repositories/task.repository';
|
|
10
10
|
export declare class PtyGateway implements OnGatewayConnection, OnGatewayDisconnect {
|
|
11
11
|
private readonly authService;
|
|
12
12
|
private readonly ptyRelayService;
|
|
13
13
|
private readonly redis;
|
|
14
14
|
private readonly developerRepo;
|
|
15
|
-
private readonly
|
|
15
|
+
private readonly workerRepo;
|
|
16
16
|
private readonly taskRepo;
|
|
17
17
|
private readonly logger;
|
|
18
18
|
private readonly authedSockets;
|
|
19
19
|
private readonly AUTH_TIMEOUT_MS;
|
|
20
|
-
|
|
20
|
+
private readonly CACHE_TTL_MS;
|
|
21
|
+
private readonly taskCache;
|
|
22
|
+
private readonly developerCache;
|
|
23
|
+
private getOrFetchCached;
|
|
24
|
+
private getCachedTask;
|
|
25
|
+
private getCachedDeveloper;
|
|
26
|
+
constructor(authService: AuthService, ptyRelayService: PtyRelayService, redis: RedisService, developerRepo: DeveloperRepository, workerRepo: WorkerRepository, taskRepo: TaskRepository);
|
|
21
27
|
handleConnection(client: WebSocket, req: IncomingMessage): void;
|
|
22
28
|
handleDisconnect(client: WebSocket): void;
|
|
23
29
|
private handleAuth;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pty.gateway.d.ts","sourceRoot":"","sources":["../../src/web/pty.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"pty.gateway.d.ts","sourceRoot":"","sources":["../../src/web/pty.gateway.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,mBAAmB,EACnB,mBAAmB,EACpB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,IAAI,CAAC;AAc/B,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EAAE,mBAAmB,EAAE,MAAM,+CAA+C,CAAC;AACpF,OAAO,EAAE,gBAAgB,EAAE,MAAM,4CAA4C,CAAC;AAC9E,OAAO,EAAE,cAAc,EAAE,MAAM,0CAA0C,CAAC;AAyB1E,qBACa,UAAW,YAAW,mBAAmB,EAAE,mBAAmB;IA0BvE,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IA9B3B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA+B;IACtD,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAgD;IAC9E,OAAO,CAAC,QAAQ,CAAC,eAAe,CAAU;IAC1C,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAyE;IACnG,OAAO,CAAC,QAAQ,CAAC,cAAc,CAA8E;IAE7G,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,kBAAkB;gBAKP,WAAW,EAAE,WAAW,EACxB,eAAe,EAAE,eAAe,EAChC,KAAK,EAAE,YAAY,EACnB,aAAa,EAAE,mBAAmB,EAClC,UAAU,EAAE,gBAAgB,EAC5B,QAAQ,EAAE,cAAc;IAG3C,gBAAgB,CAAC,MAAM,EAAE,SAAS,EAAE,GAAG,EAAE,eAAe,GAAG,IAAI;IA+E/D,gBAAgB,CAAC,MAAM,EAAE,SAAS,GAAG,IAAI;YA2B3B,UAAU;IA6KxB,OAAO,CAAC,cAAc;IAwCtB,OAAO,CAAC,YAAY;IAkBpB,OAAO,CAAC,qBAAqB;IAwB7B,OAAO,CAAC,mBAAmB;IAoB3B,OAAO,CAAC,qBAAqB;YASf,iBAAiB;IAyC/B,OAAO,CAAC,aAAa;CAatB"}
|
package/dist/web/pty.gateway.js
CHANGED
|
@@ -13,31 +13,50 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
13
13
|
exports.PtyGateway = void 0;
|
|
14
14
|
const websockets_1 = require("@nestjs/websockets");
|
|
15
15
|
const common_1 = require("@nestjs/common");
|
|
16
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
16
17
|
const ws_1 = require("ws");
|
|
17
18
|
const uuid_1 = require("uuid");
|
|
18
|
-
const
|
|
19
|
+
const protocol_2 = require("@overlordai/protocol");
|
|
19
20
|
const auth_service_1 = require("../auth/auth.service");
|
|
20
21
|
const pty_relay_service_1 = require("../dispatcher/pty-relay.service");
|
|
21
22
|
const redis_service_1 = require("../redis/redis.service");
|
|
22
23
|
const developer_repository_1 = require("../database/repositories/developer.repository");
|
|
23
|
-
const
|
|
24
|
+
const worker_repository_1 = require("../database/repositories/worker.repository");
|
|
24
25
|
const task_repository_1 = require("../database/repositories/task.repository");
|
|
25
26
|
let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
26
27
|
authService;
|
|
27
28
|
ptyRelayService;
|
|
28
29
|
redis;
|
|
29
30
|
developerRepo;
|
|
30
|
-
|
|
31
|
+
workerRepo;
|
|
31
32
|
taskRepo;
|
|
32
33
|
logger = new common_1.Logger(PtyGateway_1.name);
|
|
33
34
|
authedSockets = new Map();
|
|
34
35
|
AUTH_TIMEOUT_MS = 10_000;
|
|
35
|
-
|
|
36
|
+
CACHE_TTL_MS = 5_000;
|
|
37
|
+
taskCache = new Map();
|
|
38
|
+
developerCache = new Map();
|
|
39
|
+
getOrFetchCached(cache, key, fetcher) {
|
|
40
|
+
const now = Date.now();
|
|
41
|
+
const cached = cache.get(key);
|
|
42
|
+
if (cached && cached.expiresAt > now)
|
|
43
|
+
return cached.value;
|
|
44
|
+
const value = fetcher();
|
|
45
|
+
cache.set(key, { value, expiresAt: now + this.CACHE_TTL_MS });
|
|
46
|
+
return value;
|
|
47
|
+
}
|
|
48
|
+
getCachedTask(taskId) {
|
|
49
|
+
return this.getOrFetchCached(this.taskCache, taskId, () => this.taskRepo.findById(taskId));
|
|
50
|
+
}
|
|
51
|
+
getCachedDeveloper(developerId) {
|
|
52
|
+
return this.getOrFetchCached(this.developerCache, developerId, () => this.developerRepo.findById(developerId));
|
|
53
|
+
}
|
|
54
|
+
constructor(authService, ptyRelayService, redis, developerRepo, workerRepo, taskRepo) {
|
|
36
55
|
this.authService = authService;
|
|
37
56
|
this.ptyRelayService = ptyRelayService;
|
|
38
57
|
this.redis = redis;
|
|
39
58
|
this.developerRepo = developerRepo;
|
|
40
|
-
this.
|
|
59
|
+
this.workerRepo = workerRepo;
|
|
41
60
|
this.taskRepo = taskRepo;
|
|
42
61
|
}
|
|
43
62
|
handleConnection(client, req) {
|
|
@@ -52,8 +71,9 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
52
71
|
const isWorkerPath = url.startsWith('/api/workers/pty/');
|
|
53
72
|
this.logger.debug(`New PTY connection for task ${taskId} (${isWorkerPath ? 'worker' : 'web'})`);
|
|
54
73
|
// Set auth timeout
|
|
74
|
+
let authCompleted = false;
|
|
55
75
|
const authTimeout = setTimeout(() => {
|
|
56
|
-
if (!this.authedSockets.has(client)) {
|
|
76
|
+
if (!authCompleted && !this.authedSockets.has(client)) {
|
|
57
77
|
this.logger.warn(`PTY auth timeout for task ${taskId}`);
|
|
58
78
|
client.close(4001, 'Auth timeout');
|
|
59
79
|
}
|
|
@@ -76,6 +96,7 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
76
96
|
return;
|
|
77
97
|
}
|
|
78
98
|
clearTimeout(authTimeout);
|
|
99
|
+
authCompleted = true;
|
|
79
100
|
void this.handleAuth(client, frame, taskId, isWorkerPath, initialHandler);
|
|
80
101
|
return;
|
|
81
102
|
}
|
|
@@ -116,14 +137,14 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
116
137
|
}
|
|
117
138
|
}
|
|
118
139
|
async handleAuth(client, frame, taskId, isWorkerPath, initialHandler) {
|
|
119
|
-
const expectedAud = isWorkerPath ? 'worker' : 'web';
|
|
140
|
+
const expectedAud = isWorkerPath || Boolean(frame.workerJwt) ? 'worker' : 'web';
|
|
120
141
|
// Validate channel token
|
|
121
142
|
let channelPayload;
|
|
122
143
|
try {
|
|
123
144
|
channelPayload = await this.authService.validateChannelToken(frame.channelToken, expectedAud);
|
|
124
145
|
}
|
|
125
|
-
catch {
|
|
126
|
-
this.logger.warn(`PTY auth failed:
|
|
146
|
+
catch (err) {
|
|
147
|
+
this.logger.warn(`PTY auth failed: ${(0, protocol_1.getErrorMessage)(err)}`);
|
|
127
148
|
client.close(4004, 'Invalid channel token');
|
|
128
149
|
return;
|
|
129
150
|
}
|
|
@@ -134,8 +155,9 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
134
155
|
return;
|
|
135
156
|
}
|
|
136
157
|
// Redis jti dedup (atomic SET ... EX ... NX)
|
|
158
|
+
// Keep jti key for 2x token lifetime to guard against clock skew
|
|
137
159
|
const jtiKey = `pty_jti:${channelPayload.jti}`;
|
|
138
|
-
const result = await this.redis.getClient().set(jtiKey, '1', 'EX',
|
|
160
|
+
const result = await this.redis.getClient().set(jtiKey, '1', 'EX', protocol_2.CHANNEL_TOKEN_EXPIRY_SEC * 2, 'NX');
|
|
139
161
|
if (result === null) {
|
|
140
162
|
this.logger.warn(`PTY auth failed: channel token already consumed`);
|
|
141
163
|
client.close(4006, 'Channel token already consumed');
|
|
@@ -147,7 +169,8 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
147
169
|
let messageHandler = null;
|
|
148
170
|
let webJti;
|
|
149
171
|
let webTokenExp;
|
|
150
|
-
|
|
172
|
+
const isWorker = expectedAud === 'worker';
|
|
173
|
+
if (isWorker) {
|
|
151
174
|
// Worker auth: validate Worker JWT
|
|
152
175
|
const workerJwt = frame.workerJwt;
|
|
153
176
|
if (!workerJwt) {
|
|
@@ -164,8 +187,8 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
164
187
|
client.close(4008, 'Invalid worker JWT');
|
|
165
188
|
return;
|
|
166
189
|
}
|
|
167
|
-
// Look up task to get owner info and project filter setting
|
|
168
|
-
const task = this.
|
|
190
|
+
// Look up task to get owner info and project filter setting (cached, 5s TTL)
|
|
191
|
+
const task = this.getCachedTask(taskId);
|
|
169
192
|
const taskOwnerId = task?.developerId ?? 0;
|
|
170
193
|
let projectFilterEnabled = false;
|
|
171
194
|
if (task?.configSnapshot) {
|
|
@@ -224,7 +247,7 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
224
247
|
revalidationTimer = setInterval(() => {
|
|
225
248
|
this.revalidateUserJwt(client, userPayload.sub, userPayload.jti, userPayload.exp)
|
|
226
249
|
.catch((err) => this.logger.error(`PTY revalidation error for developer ${userPayload.sub}`, err));
|
|
227
|
-
},
|
|
250
|
+
}, protocol_2.TOKEN_REVALIDATION_INTERVAL_MS);
|
|
228
251
|
}
|
|
229
252
|
const authedSocket = {
|
|
230
253
|
ws: client,
|
|
@@ -238,6 +261,11 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
238
261
|
tokenExp: webTokenExp,
|
|
239
262
|
};
|
|
240
263
|
this.authedSockets.set(client, authedSocket);
|
|
264
|
+
// Notify PTY clients that auth succeeded before they flush any
|
|
265
|
+
// buffered frames such as the initial resize.
|
|
266
|
+
if (client.readyState === ws_1.WebSocket.OPEN) {
|
|
267
|
+
client.send(JSON.stringify({ type: 'auth_ok' }));
|
|
268
|
+
}
|
|
241
269
|
this.logger.log(`PTY ${expectedAud} authenticated for task ${taskId} (${connectionId})`);
|
|
242
270
|
}
|
|
243
271
|
handlePtyFrame(authed, frame) {
|
|
@@ -329,19 +357,25 @@ let PtyGateway = PtyGateway_1 = class PtyGateway {
|
|
|
329
357
|
return;
|
|
330
358
|
}
|
|
331
359
|
}
|
|
332
|
-
// Check if user account is still active
|
|
333
|
-
const developer = this.
|
|
334
|
-
if (!developer || developer.status !==
|
|
360
|
+
// Check if user account is still active (cached, 5s TTL)
|
|
361
|
+
const developer = this.getCachedDeveloper(developerId);
|
|
362
|
+
if (!developer || developer.status !== protocol_2.DeveloperStatus.ACTIVE) {
|
|
335
363
|
this.logger.warn(`PTY revalidation failed: developer ${developerId} inactive/not found`);
|
|
336
364
|
client.close(4020, 'User inactive');
|
|
337
365
|
}
|
|
338
366
|
}
|
|
339
367
|
extractTaskId(url) {
|
|
340
|
-
//
|
|
341
|
-
const
|
|
342
|
-
if (
|
|
368
|
+
// Try query parameter first: /ws/pty?taskId=123
|
|
369
|
+
const queryMatch = /[?&]taskId=(\d+)/.exec(url);
|
|
370
|
+
if (queryMatch) {
|
|
371
|
+
const id = parseInt(queryMatch[1], 10);
|
|
372
|
+
return isNaN(id) ? null : id;
|
|
373
|
+
}
|
|
374
|
+
// Fallback: path parameter /ws/pty/:taskId or /api/workers/pty/:taskId
|
|
375
|
+
const pathMatch = /\/(?:ws\/pty|api\/workers\/pty)\/(\d+)/.exec(url);
|
|
376
|
+
if (!pathMatch)
|
|
343
377
|
return null;
|
|
344
|
-
const id = parseInt(
|
|
378
|
+
const id = parseInt(pathMatch[1], 10);
|
|
345
379
|
return isNaN(id) ? null : id;
|
|
346
380
|
}
|
|
347
381
|
};
|
|
@@ -352,7 +386,7 @@ exports.PtyGateway = PtyGateway = PtyGateway_1 = __decorate([
|
|
|
352
386
|
pty_relay_service_1.PtyRelayService,
|
|
353
387
|
redis_service_1.RedisService,
|
|
354
388
|
developer_repository_1.DeveloperRepository,
|
|
355
|
-
|
|
389
|
+
worker_repository_1.WorkerRepository,
|
|
356
390
|
task_repository_1.TaskRepository])
|
|
357
391
|
], PtyGateway);
|
|
358
392
|
//# sourceMappingURL=pty.gateway.js.map
|