@overlordai/server 1.0.53 → 1.0.55
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/database/migrations/001-init-schema.sql +73 -9
- package/dist/adapters/adapter.interface.d.ts +1 -4
- package/dist/adapters/adapter.interface.d.ts.map +1 -1
- package/dist/adapters/adapter.interface.js.map +1 -1
- package/dist/adapters/adapter.module.d.ts.map +1 -1
- package/dist/adapters/adapter.module.js +8 -7
- package/dist/adapters/adapter.module.js.map +1 -1
- package/dist/adapters/lark/lark-card.builder.d.ts +1 -25
- package/dist/adapters/lark/lark-card.builder.d.ts.map +1 -1
- package/dist/adapters/lark/lark-card.builder.js +6 -110
- package/dist/adapters/lark/lark-card.builder.js.map +1 -1
- package/dist/adapters/lark/lark-message.parser.d.ts +4 -4
- package/dist/adapters/lark/lark-message.parser.d.ts.map +1 -1
- package/dist/adapters/lark/lark-message.parser.js +20 -13
- package/dist/adapters/lark/lark-message.parser.js.map +1 -1
- package/dist/adapters/lark/lark-signature.d.ts.map +1 -1
- package/dist/adapters/lark/lark-signature.js +6 -0
- package/dist/adapters/lark/lark-signature.js.map +1 -1
- package/dist/adapters/lark/lark.adapter.d.ts +14 -9
- package/dist/adapters/lark/lark.adapter.d.ts.map +1 -1
- package/dist/adapters/lark/lark.adapter.js +99 -177
- package/dist/adapters/lark/lark.adapter.js.map +1 -1
- package/dist/adapters/lark/lark.controller.d.ts +10 -1
- package/dist/adapters/lark/lark.controller.d.ts.map +1 -1
- package/dist/adapters/lark/lark.controller.js +48 -14
- package/dist/adapters/lark/lark.controller.js.map +1 -1
- package/dist/adapters/slack/slack-block.builder.d.ts +8 -0
- package/dist/adapters/slack/slack-block.builder.d.ts.map +1 -0
- package/dist/adapters/slack/slack-block.builder.js +117 -0
- package/dist/adapters/slack/slack-block.builder.js.map +1 -0
- package/dist/adapters/slack/slack-message.parser.d.ts +15 -0
- package/dist/adapters/slack/slack-message.parser.d.ts.map +1 -0
- package/dist/adapters/slack/slack-message.parser.js +158 -0
- package/dist/adapters/slack/slack-message.parser.js.map +1 -0
- package/dist/adapters/slack/slack-signature.d.ts +7 -0
- package/dist/adapters/slack/slack-signature.d.ts.map +1 -0
- package/dist/adapters/slack/slack-signature.js +59 -0
- package/dist/adapters/slack/slack-signature.js.map +1 -0
- package/dist/adapters/slack/slack.adapter.d.ts +67 -13
- package/dist/adapters/slack/slack.adapter.d.ts.map +1 -1
- package/dist/adapters/slack/slack.adapter.js +468 -19
- package/dist/adapters/slack/slack.adapter.js.map +1 -1
- package/dist/adapters/slack/slack.controller.d.ts +20 -0
- package/dist/adapters/slack/slack.controller.d.ts.map +1 -0
- package/dist/adapters/slack/slack.controller.js +257 -0
- package/dist/adapters/slack/slack.controller.js.map +1 -0
- package/dist/app.module.d.ts.map +1 -1
- package/dist/app.module.js +4 -0
- package/dist/app.module.js.map +1 -1
- package/dist/auth/auth.controller.d.ts.map +1 -1
- package/dist/auth/auth.controller.js +1 -0
- package/dist/auth/auth.controller.js.map +1 -1
- package/dist/auth/auth.module.d.ts.map +1 -1
- package/dist/auth/auth.module.js +4 -5
- package/dist/auth/auth.module.js.map +1 -1
- package/dist/auth/auth.service.d.ts +9 -2
- package/dist/auth/auth.service.d.ts.map +1 -1
- package/dist/auth/auth.service.js +50 -79
- package/dist/auth/auth.service.js.map +1 -1
- package/dist/auth/authenticated-request.d.ts +10 -0
- package/dist/auth/authenticated-request.d.ts.map +1 -0
- package/dist/auth/authenticated-request.js +3 -0
- package/dist/auth/authenticated-request.js.map +1 -0
- package/dist/auth/extract-user.middleware.d.ts.map +1 -1
- package/dist/auth/extract-user.middleware.js +2 -1
- package/dist/auth/extract-user.middleware.js.map +1 -1
- package/dist/auth/guards/jwt-auth.guard.d.ts.map +1 -1
- package/dist/auth/guards/jwt-auth.guard.js +5 -2
- package/dist/auth/guards/jwt-auth.guard.js.map +1 -1
- package/dist/auth/guards/project-role.guard.d.ts.map +1 -1
- package/dist/auth/guards/project-role.guard.js +6 -8
- package/dist/auth/guards/project-role.guard.js.map +1 -1
- package/dist/auth/jwt.strategy.d.ts +6 -3
- package/dist/auth/jwt.strategy.d.ts.map +1 -1
- package/dist/auth/jwt.strategy.js +15 -5
- package/dist/auth/jwt.strategy.js.map +1 -1
- package/dist/common/command-parser.d.ts +29 -0
- package/dist/common/command-parser.d.ts.map +1 -0
- package/dist/common/command-parser.js +133 -0
- package/dist/common/command-parser.js.map +1 -0
- package/dist/common/config.d.ts +17 -0
- package/dist/common/config.d.ts.map +1 -0
- package/dist/common/config.js +47 -0
- package/dist/common/config.js.map +1 -0
- package/dist/common/crypto.service.d.ts +4 -1
- package/dist/common/crypto.service.d.ts.map +1 -1
- package/dist/common/crypto.service.js +14 -7
- package/dist/common/crypto.service.js.map +1 -1
- package/dist/common/error-filter.d.ts +1 -0
- package/dist/common/error-filter.d.ts.map +1 -1
- package/dist/common/error-filter.js +6 -2
- package/dist/common/error-filter.js.map +1 -1
- package/dist/common/git-utils.d.ts +9 -0
- package/dist/common/git-utils.d.ts.map +1 -0
- package/dist/common/git-utils.js +41 -0
- package/dist/common/git-utils.js.map +1 -0
- package/dist/common/health.controller.d.ts.map +1 -1
- package/dist/common/health.controller.js +3 -5
- package/dist/common/health.controller.js.map +1 -1
- package/dist/common/machine-utils.d.ts +32 -0
- package/dist/common/machine-utils.d.ts.map +1 -0
- package/dist/common/machine-utils.js +12 -0
- package/dist/common/machine-utils.js.map +1 -0
- package/dist/common/pagination.d.ts +12 -5
- package/dist/common/pagination.d.ts.map +1 -1
- package/dist/common/pagination.js +27 -17
- package/dist/common/pagination.js.map +1 -1
- package/dist/common/project-validation.d.ts +7 -0
- package/dist/common/project-validation.d.ts.map +1 -0
- package/dist/common/project-validation.js +86 -0
- package/dist/common/project-validation.js.map +1 -0
- package/dist/common/rate-limit.guard.d.ts +4 -3
- package/dist/common/rate-limit.guard.d.ts.map +1 -1
- package/dist/common/rate-limit.guard.js +14 -5
- package/dist/common/rate-limit.guard.js.map +1 -1
- package/dist/common/sql-utils.d.ts +6 -0
- package/dist/common/sql-utils.d.ts.map +1 -0
- package/dist/common/sql-utils.js +11 -0
- package/dist/common/sql-utils.js.map +1 -0
- package/dist/common/string-utils.d.ts +6 -0
- package/dist/common/string-utils.d.ts.map +1 -0
- package/dist/common/string-utils.js +15 -0
- package/dist/common/string-utils.js.map +1 -0
- package/dist/common/worker-utils.d.ts +31 -0
- package/dist/common/worker-utils.d.ts.map +1 -0
- package/dist/common/worker-utils.js +12 -0
- package/dist/common/worker-utils.js.map +1 -0
- package/dist/database/base.repository.d.ts +56 -0
- package/dist/database/base.repository.d.ts.map +1 -0
- package/dist/database/base.repository.js +82 -0
- package/dist/database/base.repository.js.map +1 -0
- package/dist/database/database.service.d.ts.map +1 -1
- package/dist/database/database.service.js +9 -1
- package/dist/database/database.service.js.map +1 -1
- package/dist/database/migration-runner.d.ts.map +1 -1
- package/dist/database/migration-runner.js +2 -1
- package/dist/database/migration-runner.js.map +1 -1
- package/dist/database/repositories/audit-log.repository.d.ts.map +1 -1
- package/dist/database/repositories/audit-log.repository.js +16 -18
- package/dist/database/repositories/audit-log.repository.js.map +1 -1
- package/dist/database/repositories/bot.repository.d.ts +18 -32
- package/dist/database/repositories/bot.repository.d.ts.map +1 -1
- package/dist/database/repositories/bot.repository.js +42 -21
- package/dist/database/repositories/bot.repository.js.map +1 -1
- package/dist/database/repositories/developer-token.repository.d.ts +7 -17
- package/dist/database/repositories/developer-token.repository.d.ts.map +1 -1
- package/dist/database/repositories/developer-token.repository.js +24 -15
- package/dist/database/repositories/developer-token.repository.js.map +1 -1
- package/dist/database/repositories/developer.repository.d.ts +5 -1
- package/dist/database/repositories/developer.repository.d.ts.map +1 -1
- package/dist/database/repositories/developer.repository.js +60 -49
- package/dist/database/repositories/developer.repository.js.map +1 -1
- package/dist/database/repositories/machine.repository.d.ts.map +1 -1
- package/dist/database/repositories/machine.repository.js +2 -7
- package/dist/database/repositories/machine.repository.js.map +1 -1
- package/dist/database/repositories/notification.repository.d.ts +1 -0
- package/dist/database/repositories/notification.repository.d.ts.map +1 -1
- package/dist/database/repositories/notification.repository.js +25 -20
- package/dist/database/repositories/notification.repository.js.map +1 -1
- package/dist/database/repositories/project-member.repository.d.ts +7 -16
- package/dist/database/repositories/project-member.repository.d.ts.map +1 -1
- package/dist/database/repositories/project-member.repository.js +34 -24
- package/dist/database/repositories/project-member.repository.js.map +1 -1
- package/dist/database/repositories/project.repository.d.ts +2 -1
- package/dist/database/repositories/project.repository.d.ts.map +1 -1
- package/dist/database/repositories/project.repository.js +70 -71
- package/dist/database/repositories/project.repository.js.map +1 -1
- package/dist/database/repositories/session.repository.d.ts.map +1 -1
- package/dist/database/repositories/session.repository.js +22 -25
- package/dist/database/repositories/session.repository.js.map +1 -1
- package/dist/database/repositories/task.repository.d.ts +31 -7
- package/dist/database/repositories/task.repository.d.ts.map +1 -1
- package/dist/database/repositories/task.repository.js +134 -86
- package/dist/database/repositories/task.repository.js.map +1 -1
- package/dist/database/repositories/worker-token.repository.d.ts.map +1 -1
- package/dist/database/repositories/worker-token.repository.js +18 -16
- package/dist/database/repositories/worker-token.repository.js.map +1 -1
- package/dist/database/repositories/worker.repository.d.ts +50 -0
- package/dist/database/repositories/worker.repository.d.ts.map +1 -0
- package/dist/database/repositories/worker.repository.js +215 -0
- package/dist/database/repositories/worker.repository.js.map +1 -0
- package/dist/database/repositories/workspace.repository.d.ts +3 -2
- package/dist/database/repositories/workspace.repository.d.ts.map +1 -1
- package/dist/database/repositories/workspace.repository.js +29 -21
- package/dist/database/repositories/workspace.repository.js.map +1 -1
- package/dist/database/repository.module.d.ts +3 -0
- package/dist/database/repository.module.d.ts.map +1 -0
- package/dist/database/repository.module.js +45 -0
- package/dist/database/repository.module.js.map +1 -0
- package/dist/dispatcher/capability.service.d.ts +19 -14
- package/dist/dispatcher/capability.service.d.ts.map +1 -1
- package/dist/dispatcher/capability.service.js +77 -69
- package/dist/dispatcher/capability.service.js.map +1 -1
- package/dist/dispatcher/cleanup.service.d.ts +1 -1
- package/dist/dispatcher/cleanup.service.d.ts.map +1 -1
- package/dist/dispatcher/cleanup.service.js +13 -13
- package/dist/dispatcher/cleanup.service.js.map +1 -1
- package/dist/dispatcher/dedup.service.d.ts +17 -3
- package/dist/dispatcher/dedup.service.d.ts.map +1 -1
- package/dist/dispatcher/dedup.service.js +76 -82
- package/dist/dispatcher/dedup.service.js.map +1 -1
- package/dist/dispatcher/dispatcher.module.d.ts.map +1 -1
- package/dist/dispatcher/dispatcher.module.js +11 -18
- package/dist/dispatcher/dispatcher.module.js.map +1 -1
- package/dist/dispatcher/dispatcher.service.d.ts +14 -116
- package/dist/dispatcher/dispatcher.service.d.ts.map +1 -1
- package/dist/dispatcher/dispatcher.service.js +62 -940
- package/dist/dispatcher/dispatcher.service.js.map +1 -1
- package/dist/dispatcher/dispatcher.types.d.ts +33 -0
- package/dist/dispatcher/dispatcher.types.d.ts.map +1 -0
- package/dist/dispatcher/dispatcher.types.js +3 -0
- package/dist/dispatcher/dispatcher.types.js.map +1 -0
- package/dist/dispatcher/heartbeat.service.d.ts +17 -10
- package/dist/dispatcher/heartbeat.service.d.ts.map +1 -1
- package/dist/dispatcher/heartbeat.service.js +47 -51
- package/dist/dispatcher/heartbeat.service.js.map +1 -1
- package/dist/dispatcher/pty-relay.service.d.ts.map +1 -1
- package/dist/dispatcher/pty-relay.service.js +7 -15
- package/dist/dispatcher/pty-relay.service.js.map +1 -1
- package/dist/dispatcher/reconciler.d.ts +18 -8
- package/dist/dispatcher/reconciler.d.ts.map +1 -1
- package/dist/dispatcher/reconciler.js +219 -130
- package/dist/dispatcher/reconciler.js.map +1 -1
- package/dist/dispatcher/scheduler.service.d.ts +15 -9
- package/dist/dispatcher/scheduler.service.d.ts.map +1 -1
- package/dist/dispatcher/scheduler.service.js +95 -53
- package/dist/dispatcher/scheduler.service.js.map +1 -1
- package/dist/dispatcher/state-machine.d.ts.map +1 -1
- package/dist/dispatcher/state-machine.js +1 -5
- package/dist/dispatcher/state-machine.js.map +1 -1
- package/dist/dispatcher/task-creation.service.d.ts +30 -0
- package/dist/dispatcher/task-creation.service.d.ts.map +1 -0
- package/dist/dispatcher/task-creation.service.js +242 -0
- package/dist/dispatcher/task-creation.service.js.map +1 -0
- package/dist/dispatcher/task-lifecycle.service.d.ts +63 -0
- package/dist/dispatcher/task-lifecycle.service.d.ts.map +1 -0
- package/dist/dispatcher/task-lifecycle.service.js +584 -0
- package/dist/dispatcher/task-lifecycle.service.js.map +1 -0
- package/dist/dispatcher/task-log-batcher.d.ts.map +1 -1
- package/dist/dispatcher/task-log-batcher.js +4 -11
- package/dist/dispatcher/task-log-batcher.js.map +1 -1
- package/dist/dispatcher/worker-auth.service.d.ts +29 -0
- package/dist/dispatcher/worker-auth.service.d.ts.map +1 -0
- package/dist/dispatcher/worker-auth.service.js +296 -0
- package/dist/dispatcher/worker-auth.service.js.map +1 -0
- package/dist/dispatcher/worker-connection.manager.d.ts +15 -15
- package/dist/dispatcher/worker-connection.manager.d.ts.map +1 -1
- package/dist/dispatcher/worker-connection.manager.js +35 -43
- package/dist/dispatcher/worker-connection.manager.js.map +1 -1
- package/dist/dispatcher/worker-selector.d.ts +18 -0
- package/dist/dispatcher/worker-selector.d.ts.map +1 -0
- package/dist/dispatcher/worker-selector.js +150 -0
- package/dist/dispatcher/worker-selector.js.map +1 -0
- package/dist/events/event-types.d.ts +31 -0
- package/dist/events/event-types.d.ts.map +1 -0
- package/dist/events/event-types.js +16 -0
- package/dist/events/event-types.js.map +1 -0
- package/dist/events/events.module.d.ts +7 -0
- package/dist/events/events.module.d.ts.map +1 -0
- package/dist/events/events.module.js +26 -0
- package/dist/events/events.module.js.map +1 -0
- package/dist/main.js +22 -0
- package/dist/main.js.map +1 -1
- package/dist/notifier/debouncer.d.ts +1 -1
- package/dist/notifier/debouncer.d.ts.map +1 -1
- package/dist/notifier/debouncer.js +2 -1
- package/dist/notifier/debouncer.js.map +1 -1
- package/dist/notifier/notification-consumer.d.ts +1 -1
- package/dist/notifier/notification-consumer.d.ts.map +1 -1
- package/dist/notifier/notification-consumer.js +5 -5
- package/dist/notifier/notification-consumer.js.map +1 -1
- package/dist/notifier/notifier.module.d.ts.map +1 -1
- package/dist/notifier/notifier.module.js +0 -6
- package/dist/notifier/notifier.module.js.map +1 -1
- package/dist/notifier/notifier.service.d.ts +1 -1
- package/dist/notifier/notifier.service.d.ts.map +1 -1
- package/dist/notifier/notifier.service.js +7 -9
- package/dist/notifier/notifier.service.js.map +1 -1
- package/dist/notifier/template.service.d.ts +1 -1
- package/dist/notifier/template.service.d.ts.map +1 -1
- package/dist/notifier/template.service.js +6 -10
- package/dist/notifier/template.service.js.map +1 -1
- package/dist/redis/redis.service.d.ts.map +1 -1
- package/dist/redis/redis.service.js +2 -2
- package/dist/redis/redis.service.js.map +1 -1
- package/dist/web/admin/admin-audit.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-audit.controller.js +2 -1
- package/dist/web/admin/admin-audit.controller.js.map +1 -1
- package/dist/web/admin/admin-bot.controller.d.ts +11 -48
- package/dist/web/admin/admin-bot.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-bot.controller.js +50 -18
- package/dist/web/admin/admin-bot.controller.js.map +1 -1
- package/dist/web/admin/admin-developer.controller.d.ts +14 -27
- package/dist/web/admin/admin-developer.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-developer.controller.js +62 -28
- package/dist/web/admin/admin-developer.controller.js.map +1 -1
- package/dist/web/admin/admin-machine.controller.d.ts +1 -8
- package/dist/web/admin/admin-machine.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-machine.controller.js +3 -6
- package/dist/web/admin/admin-machine.controller.js.map +1 -1
- package/dist/web/admin/admin-project.controller.d.ts +9 -30
- package/dist/web/admin/admin-project.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-project.controller.js +15 -60
- package/dist/web/admin/admin-project.controller.js.map +1 -1
- package/dist/web/admin/admin-settings.controller.d.ts +7 -10
- package/dist/web/admin/admin-settings.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-settings.controller.js +14 -6
- package/dist/web/admin/admin-settings.controller.js.map +1 -1
- package/dist/web/admin/admin-token.controller.d.ts +6 -13
- package/dist/web/admin/admin-token.controller.d.ts.map +1 -1
- package/dist/web/admin/admin-token.controller.js +15 -27
- package/dist/web/admin/admin-token.controller.js.map +1 -1
- package/dist/web/admin/admin-worker.controller.d.ts +26 -0
- package/dist/web/admin/admin-worker.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-worker.controller.js +184 -0
- package/dist/web/admin/admin-worker.controller.js.map +1 -0
- package/dist/web/dashboard.controller.d.ts +6 -12
- package/dist/web/dashboard.controller.d.ts.map +1 -1
- package/dist/web/dashboard.controller.js +30 -18
- package/dist/web/dashboard.controller.js.map +1 -1
- package/dist/web/dashboard.service.d.ts +21 -12
- package/dist/web/dashboard.service.d.ts.map +1 -1
- package/dist/web/dashboard.service.js +169 -119
- package/dist/web/dashboard.service.js.map +1 -1
- package/dist/web/event.gateway.d.ts +32 -0
- package/dist/web/event.gateway.d.ts.map +1 -0
- package/dist/web/event.gateway.js +168 -0
- package/dist/web/event.gateway.js.map +1 -0
- package/dist/web/frame-handlers/frame-handler.interface.d.ts +24 -0
- package/dist/web/frame-handlers/frame-handler.interface.d.ts.map +1 -0
- package/dist/web/frame-handlers/frame-handler.interface.js +3 -0
- package/dist/web/frame-handlers/frame-handler.interface.js.map +1 -0
- package/dist/web/frame-handlers/frame-handler.registry.d.ts +16 -0
- package/dist/web/frame-handlers/frame-handler.registry.d.ts.map +1 -0
- package/dist/web/frame-handlers/frame-handler.registry.js +39 -0
- package/dist/web/frame-handlers/frame-handler.registry.js.map +1 -0
- package/dist/web/frame-handlers/heartbeat.handler.d.ts +13 -0
- package/dist/web/frame-handlers/heartbeat.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/heartbeat.handler.js +35 -0
- package/dist/web/frame-handlers/heartbeat.handler.js.map +1 -0
- package/dist/web/frame-handlers/index.d.ts +7 -0
- package/dist/web/frame-handlers/index.d.ts.map +1 -0
- package/dist/web/frame-handlers/index.js +14 -0
- package/dist/web/frame-handlers/index.js.map +1 -0
- package/dist/web/frame-handlers/progress.handler.d.ts +25 -0
- package/dist/web/frame-handlers/progress.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/progress.handler.js +69 -0
- package/dist/web/frame-handlers/progress.handler.js.map +1 -0
- package/dist/web/frame-handlers/stage-confirm.handler.d.ts +15 -0
- package/dist/web/frame-handlers/stage-confirm.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/stage-confirm.handler.js +39 -0
- package/dist/web/frame-handlers/stage-confirm.handler.js.map +1 -0
- package/dist/web/frame-handlers/tunnel.handler.d.ts +10 -0
- package/dist/web/frame-handlers/tunnel.handler.d.ts.map +1 -0
- package/dist/web/frame-handlers/tunnel.handler.js +31 -0
- package/dist/web/frame-handlers/tunnel.handler.js.map +1 -0
- package/dist/web/interaction.service.d.ts +0 -4
- package/dist/web/interaction.service.d.ts.map +1 -1
- package/dist/web/interaction.service.js +0 -10
- package/dist/web/interaction.service.js.map +1 -1
- package/dist/web/machine.controller.d.ts +1 -8
- package/dist/web/machine.controller.d.ts.map +1 -1
- package/dist/web/machine.controller.js +6 -9
- package/dist/web/machine.controller.js.map +1 -1
- package/dist/web/notification.controller.d.ts +1 -8
- package/dist/web/notification.controller.d.ts.map +1 -1
- package/dist/web/notification.controller.js +3 -2
- package/dist/web/notification.controller.js.map +1 -1
- package/dist/web/profile.controller.d.ts +19 -10
- package/dist/web/profile.controller.d.ts.map +1 -1
- package/dist/web/profile.controller.js +100 -13
- package/dist/web/profile.controller.js.map +1 -1
- package/dist/web/project-member.service.d.ts +16 -0
- package/dist/web/project-member.service.d.ts.map +1 -0
- package/dist/web/project-member.service.js +90 -0
- package/dist/web/project-member.service.js.map +1 -0
- package/dist/web/project.controller.d.ts +43 -26
- package/dist/web/project.controller.d.ts.map +1 -1
- package/dist/web/project.controller.js +73 -46
- package/dist/web/project.controller.js.map +1 -1
- package/dist/web/pty.gateway.d.ts +9 -3
- package/dist/web/pty.gateway.d.ts.map +1 -1
- package/dist/web/pty.gateway.js +46 -18
- package/dist/web/pty.gateway.js.map +1 -1
- package/dist/web/search.service.d.ts +9 -2
- package/dist/web/search.service.d.ts.map +1 -1
- package/dist/web/search.service.js +53 -26
- package/dist/web/search.service.js.map +1 -1
- package/dist/web/task.controller.d.ts +15 -24
- package/dist/web/task.controller.d.ts.map +1 -1
- package/dist/web/task.controller.js +70 -53
- package/dist/web/task.controller.js.map +1 -1
- package/dist/web/tunnel.service.d.ts +74 -0
- package/dist/web/tunnel.service.d.ts.map +1 -0
- package/dist/web/tunnel.service.js +250 -0
- package/dist/web/tunnel.service.js.map +1 -0
- package/dist/web/web-event.service.d.ts +25 -0
- package/dist/web/web-event.service.d.ts.map +1 -0
- package/dist/web/web-event.service.js +116 -0
- package/dist/web/web-event.service.js.map +1 -0
- package/dist/web/web.module.d.ts.map +1 -1
- package/dist/web/web.module.js +13 -28
- package/dist/web/web.module.js.map +1 -1
- package/dist/web/worker-channel.gateway.d.ts +10 -18
- package/dist/web/worker-channel.gateway.d.ts.map +1 -1
- package/dist/web/worker-channel.gateway.js +70 -144
- package/dist/web/worker-channel.gateway.js.map +1 -1
- package/dist/web/worker-web.controller.d.ts +15 -0
- package/dist/web/worker-web.controller.d.ts.map +1 -0
- package/dist/web/worker-web.controller.js +143 -0
- package/dist/web/worker-web.controller.js.map +1 -0
- package/dist/web/worker.controller.d.ts +3 -3
- package/dist/web/worker.controller.d.ts.map +1 -1
- package/dist/web/worker.controller.js +8 -8
- package/dist/web/worker.controller.js.map +1 -1
- package/dist/web/workspace.controller.d.ts +8 -33
- package/dist/web/workspace.controller.d.ts.map +1 -1
- package/dist/web/workspace.controller.js +93 -205
- package/dist/web/workspace.controller.js.map +1 -1
- package/package.json +10 -2
- package/public/apple-touch-icon-120x120.png +0 -0
- package/public/apple-touch-icon-152x152.png +0 -0
- package/public/apple-touch-icon-180x180.png +0 -0
- package/public/assets/AccessTokensPage-DPQB2fbi.js +1 -0
- package/public/assets/AdminPage-BqVelYNu.js +1 -0
- package/public/assets/ApiReferencePage-CiGvbLxL.js +1 -0
- package/public/assets/AuditLogPage-DSo4jVYm.js +6 -0
- package/public/assets/BindPlatformPage-CTqzpOmt.js +1 -0
- package/public/assets/BotManage-CIR0rrK7.js +6 -0
- package/public/assets/CliReferencePage-C8GmlwUz.js +14 -0
- package/public/assets/DeveloperManage-r6y2AoB4.js +16 -0
- package/public/assets/EditProjectPage-7WCsNltj.js +2 -0
- package/public/assets/{EmptyState-CvmhFgWJ.js → EmptyState-D3foEiul.js} +1 -1
- package/public/assets/HomePage-D4yv4orb.js +1 -0
- package/public/assets/InfoRow-DhdTYoY9.js +1 -0
- package/public/assets/LandingPage-CqS0E2eC.js +43 -0
- package/public/assets/LoginPage-DDXkdcz_.js +1 -0
- package/public/assets/MetricBar-DMMHfS0A.js +1 -0
- package/public/assets/{NotFoundPage-BuiAS4g4.js → NotFoundPage-D5x5BrlX.js} +1 -1
- package/public/assets/OnboardingGuide-D8RyPcEd.js +1 -0
- package/public/assets/PipelineEditorPage-y2-Q8ofQ.js +3 -0
- package/public/assets/ProfilePage-DN7usHOi.js +1 -0
- package/public/assets/ProjectDetailPage-DJexg49z.js +7 -0
- package/public/assets/ProjectListPage-Bz7I2D0H.js +6 -0
- package/public/assets/QuickAuth-Dr0Q50ld.js +1 -0
- package/public/assets/{RemoveMemberConfirmDialog-DS9z6jQT.js → RemoveMemberConfirmDialog-BCrue0AP.js} +2 -2
- package/public/assets/Select-BnV8yZlD.js +6 -0
- package/public/assets/SettingsPage-HaUCcsgl.js +6 -0
- package/public/assets/{Skeleton-CcVqz28_.js → Skeleton-DUgWc2LJ.js} +1 -1
- package/public/assets/SkillPage-BInwZTQh.js +1 -0
- package/public/assets/TaskDetailPage-CfwEj1hy.js +31 -0
- package/public/assets/TaskListPage-Dh59ldSZ.js +1 -0
- package/public/assets/TaskStatusBadge-DuOoGIwE.js +1 -0
- package/public/assets/TerminalHomePage-BwXJjr-a.js +16 -0
- package/public/assets/TokenManage-B0Cpv6SO.js +1 -0
- package/public/assets/TotpSetupPage-MSCCURj9.js +9 -0
- package/public/assets/WorkerDetailPage-R2veIzKo.js +1 -0
- package/public/assets/WorkerListPage-CserMjGO.js +6 -0
- package/public/assets/WorkerSetupGuidePage-SqO2lzVa.js +11 -0
- package/public/assets/{arrow-left-CVKez32c.js → arrow-left-DklRsENx.js} +1 -1
- package/public/assets/{arrow-right-g7hTftEi.js → arrow-right-MDrzFe3K.js} +1 -1
- package/public/assets/{bot-DYvBcsZn.js → bot-DPaziJPf.js} +1 -1
- package/public/assets/{chevron-right-COxU2yxz.js → chevron-right-CqyufMDW.js} +1 -1
- package/public/assets/{copy-BGttVgA1.js → copy-BUH7P2Hf.js} +1 -1
- package/public/assets/date-BdNtiQTP.js +1 -0
- package/public/assets/{external-link-DXlCfUjE.js → external-link-ChPgQ7N_.js} +1 -1
- package/public/assets/index-BS0Fbx5V.css +1 -0
- package/public/assets/index-vL7aQJNr.js +225 -0
- package/public/assets/{key-3eDVdGih.js → key-CxvwwHnW.js} +1 -1
- package/public/assets/{loader-circle-DPm92ETj.js → loader-circle-DS5g1-Od.js} +1 -1
- package/public/assets/password-CHk45-jw.js +1 -0
- package/public/assets/{pencil-Bs3PwH2W.js → pencil-B6spIBcw.js} +1 -1
- package/public/assets/{plus-d-PLzbVX.js → plus-Bnd1Vz2Y.js} +1 -1
- package/public/assets/{rotate-ccw-Cus8CABi.js → rotate-ccw-CgcLAXNR.js} +1 -1
- package/public/assets/{scroll-text-CV3wlIy2.js → scroll-text-CecZ0Fk5.js} +1 -1
- package/public/assets/{settings-Ccijf48b.js → settings-C1uOD3PZ.js} +1 -1
- package/public/assets/status-colors-BPEUp90-.js +1 -0
- package/public/assets/string-B39tzdVK.js +1 -0
- package/public/assets/task-constants-BbFyCyKk.js +14 -0
- package/public/assets/task.store-BE6fEPu4.js +1 -0
- package/public/assets/{trash-2-bRJ-xwtq.js → trash-2-A2FsT1yG.js} +1 -1
- package/public/assets/useFetch-vGZMAvGi.js +1 -0
- package/public/assets/{users-LNQqKSEN.js → users-CEdRS_A3.js} +1 -1
- package/public/assets/wifi-D60NkK6F.js +6 -0
- package/public/assets/zap-DXw1NrWz.js +6 -0
- package/public/icon-192x192.png +0 -0
- package/public/icon-512x512.png +0 -0
- package/public/icon-maskable-192x192.png +0 -0
- package/public/icon-maskable-512x512.png +0 -0
- package/public/index.html +21 -4
- package/public/manifest.webmanifest +1 -0
- package/public/og-image.png +0 -0
- package/public/registerSW.js +1 -0
- package/public/sw.js +1 -0
- package/public/workbox-6e9b121d.js +1 -0
- package/database/migrations/002-add-indexes.sql +0 -17
- package/database/migrations/003-add-settings-table.sql +0 -4
- package/database/migrations/004-add-developer-id-index.sql +0 -5
- package/database/migrations/005-add-worker-version.sql +0 -2
- package/database/migrations/006-add-decommission-fields.sql +0 -2
- package/database/migrations/007-add-ssh-url.sql +0 -1
- package/public/assets/AccessTokensPage-Cb5hGBfN.js +0 -1
- package/public/assets/AdminPage-C7Xytkfo.js +0 -1
- package/public/assets/ApiReferencePage-DLGVc4xN.js +0 -1
- package/public/assets/AuditLogPage-BgqsUJ7x.js +0 -6
- package/public/assets/BotManage-Ds9DYQZA.js +0 -6
- package/public/assets/CliReferencePage-WXinn_69.js +0 -8
- package/public/assets/DeveloperManage-saSq3Hfx.js +0 -16
- package/public/assets/EditProjectPage-C4xWYLTo.js +0 -2
- package/public/assets/HomePage-y20pQ52r.js +0 -1
- package/public/assets/LandingPage-CB5BBbdI.js +0 -36
- package/public/assets/LoginPage-DLljhJkQ.js +0 -1
- package/public/assets/MachineDetailPage-CPm9tfdp.js +0 -1
- package/public/assets/MachineListPage-D-nhVz-m.js +0 -6
- package/public/assets/PipelineEditorPage-B9GgqAju.js +0 -3
- package/public/assets/ProfilePage-DASpeJq6.js +0 -1
- package/public/assets/ProjectDetailPage-DWZyNwTV.js +0 -7
- package/public/assets/ProjectListPage-BUMX3Dxa.js +0 -6
- package/public/assets/QuickAuth-B9mvq7ht.js +0 -1
- package/public/assets/Select-A7PXobk_.js +0 -6
- package/public/assets/SettingsPage-WGzxUbGp.js +0 -6
- package/public/assets/SkillPage-BIt2kF3W.js +0 -1
- package/public/assets/TaskDetailPage-CePyNfp6.js +0 -44
- package/public/assets/TaskListPage-MO4_PSve.js +0 -1
- package/public/assets/TaskStatusBadge-QtQUDscM.js +0 -1
- package/public/assets/TokenManage-Sf0RGymw.js +0 -1
- package/public/assets/TotpSetupPage-D-rbEYLf.js +0 -9
- package/public/assets/WorkerSetupGuidePage-D6Fv1MQo.js +0 -16
- package/public/assets/index-CDBuOPx4.js +0 -212
- package/public/assets/index-CQojj7Zu.css +0 -1
- package/public/assets/protocol-C5uQmiiB.js +0 -1
- package/public/assets/task.store-CvjSr507.js +0 -1
- /package/public/assets/{TaskDetailPage-Beg8tuEN.css → task-constants-Beg8tuEN.css} +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-developer.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-developer.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"admin-developer.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-developer.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,13 +3,7 @@ import { MachineRepository } from '../../database/repositories/machine.repositor
|
|
|
3
3
|
import { TaskRepository } from '../../database/repositories/task.repository';
|
|
4
4
|
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
5
|
import { WorkerConnectionManager } from '../../dispatcher/worker-connection.manager';
|
|
6
|
-
|
|
7
|
-
user: {
|
|
8
|
-
sub: number;
|
|
9
|
-
name: string;
|
|
10
|
-
role: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
6
|
+
import type { AuthenticatedRequest } from '../../auth/authenticated-request';
|
|
13
7
|
export declare class AdminMachineController {
|
|
14
8
|
private readonly machineRepo;
|
|
15
9
|
private readonly taskRepo;
|
|
@@ -75,5 +69,4 @@ export declare class AdminMachineController {
|
|
|
75
69
|
success: boolean;
|
|
76
70
|
};
|
|
77
71
|
}
|
|
78
|
-
export {};
|
|
79
72
|
//# sourceMappingURL=admin-machine.controller.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-machine.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAiB,aAAa,EAAc,MAAM,sBAAsB,CAAC;
|
|
1
|
+
{"version":3,"file":"admin-machine.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAiB,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAIhF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AACnF,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAG7E,qBAGa,sBAAsB;IAI/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IANpC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2C;gBAG/C,WAAW,EAAE,iBAAiB,EAC9B,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,kBAAkB,EAChC,iBAAiB,EAAE,uBAAuB;IAI7D,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;IAKZ,aAAa,CACE,EAAE,EAAE,MAAM,EACf,IAAI,EAAE;QAAE,MAAM,CAAC,EAAE,aAAa,CAAA;KAAE,EACjC,GAAG,EAAE,oBAAoB;;;;;;;;;;;;;;;;;;;;;;;;;;IA2DlC,mBAAmB,CACJ,EAAE,EAAE,MAAM,EAChB,GAAG,EAAE,oBAAoB;;;CAgEnC"}
|
|
@@ -23,10 +23,7 @@ const machine_repository_1 = require("../../database/repositories/machine.reposi
|
|
|
23
23
|
const task_repository_1 = require("../../database/repositories/task.repository");
|
|
24
24
|
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
25
25
|
const worker_connection_manager_1 = require("../../dispatcher/worker-connection.manager");
|
|
26
|
-
|
|
27
|
-
const { recoverySecretHash, ...safe } = machine;
|
|
28
|
-
return safe;
|
|
29
|
-
}
|
|
26
|
+
const machine_utils_1 = require("../../common/machine-utils");
|
|
30
27
|
let AdminMachineController = AdminMachineController_1 = class AdminMachineController {
|
|
31
28
|
machineRepo;
|
|
32
29
|
taskRepo;
|
|
@@ -40,7 +37,7 @@ let AdminMachineController = AdminMachineController_1 = class AdminMachineContro
|
|
|
40
37
|
this.connectionManager = connectionManager;
|
|
41
38
|
}
|
|
42
39
|
listMachines() {
|
|
43
|
-
return this.machineRepo.findAll(true).map(stripMachineSecrets);
|
|
40
|
+
return this.machineRepo.findAll(true).map(machine_utils_1.stripMachineSecrets);
|
|
44
41
|
}
|
|
45
42
|
updateMachine(id, body, req) {
|
|
46
43
|
const machine = this.machineRepo.findById(id);
|
|
@@ -87,7 +84,7 @@ let AdminMachineController = AdminMachineController_1 = class AdminMachineContro
|
|
|
87
84
|
resource: `machine:${id}`,
|
|
88
85
|
detail: `Updated machine '${machine.name}'`,
|
|
89
86
|
});
|
|
90
|
-
return stripMachineSecrets(this.machineRepo.findById(id));
|
|
87
|
+
return (0, machine_utils_1.stripMachineSecrets)(this.machineRepo.findById(id));
|
|
91
88
|
}
|
|
92
89
|
decommissionMachine(id, req) {
|
|
93
90
|
const machine = this.machineRepo.findById(id);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-machine.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAYwB;AACxB,mDAAgF;
|
|
1
|
+
{"version":3,"file":"admin-machine.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,47 +1,26 @@
|
|
|
1
1
|
import type { CreateProjectRequest } from '@overlordai/protocol';
|
|
2
2
|
import { ProjectRepository } from '../../database/repositories/project.repository';
|
|
3
|
-
import { ProjectMemberRepository } from '../../database/repositories/project-member.repository';
|
|
4
3
|
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
sub: number;
|
|
8
|
-
name: string;
|
|
9
|
-
role: string;
|
|
10
|
-
};
|
|
11
|
-
}
|
|
4
|
+
import type { AuthenticatedRequest } from '../../auth/authenticated-request';
|
|
5
|
+
import { ProjectMemberService } from '../project-member.service';
|
|
12
6
|
export declare class AdminProjectController {
|
|
13
7
|
private readonly projectRepo;
|
|
14
|
-
private readonly projectMemberRepo;
|
|
15
8
|
private readonly auditLogRepo;
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
9
|
+
private readonly projectMemberService;
|
|
10
|
+
constructor(projectRepo: ProjectRepository, auditLogRepo: AuditLogRepository, projectMemberService: ProjectMemberService);
|
|
11
|
+
listProjects(): Omit<import("@overlordai/protocol").Project, "gitTokenEncrypted">[];
|
|
12
|
+
createProject(body: CreateProjectRequest, req: AuthenticatedRequest): Omit<import("@overlordai/protocol").Project, "gitTokenEncrypted">;
|
|
13
|
+
updateProject(key: string, body: Record<string, unknown>, req: AuthenticatedRequest): Omit<import("@overlordai/protocol").Project, "gitTokenEncrypted"> | null;
|
|
20
14
|
deleteProject(key: string, req: AuthenticatedRequest): {
|
|
21
15
|
success: boolean;
|
|
22
16
|
};
|
|
23
|
-
listMembers(key: string):
|
|
24
|
-
id: number;
|
|
25
|
-
projectKey: string;
|
|
26
|
-
developerId: number;
|
|
27
|
-
developerName: string | null;
|
|
28
|
-
role: string;
|
|
29
|
-
createdAt: string;
|
|
30
|
-
}[];
|
|
17
|
+
listMembers(key: string): import("../../database/repositories/project-member.repository").ProjectMember[];
|
|
31
18
|
addMember(key: string, body: {
|
|
32
19
|
developerId: number;
|
|
33
20
|
role?: string;
|
|
34
|
-
}, req: AuthenticatedRequest):
|
|
35
|
-
id: number;
|
|
36
|
-
projectKey: string;
|
|
37
|
-
developerId: number;
|
|
38
|
-
developerName: string | null;
|
|
39
|
-
role: string;
|
|
40
|
-
createdAt: string;
|
|
41
|
-
};
|
|
21
|
+
}, req: AuthenticatedRequest): import("../../database/repositories/project-member.repository").ProjectMember;
|
|
42
22
|
removeMember(key: string, developerId: string, req: AuthenticatedRequest): {
|
|
43
23
|
success: boolean;
|
|
44
24
|
};
|
|
45
25
|
}
|
|
46
|
-
export {};
|
|
47
26
|
//# sourceMappingURL=admin-project.controller.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-project.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"admin-project.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":"AAcA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAKjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AAEnF,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAE7E,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAEjE,qBAGa,sBAAsB;IAE/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,oBAAoB;gBAFpB,WAAW,EAAE,iBAAiB,EAC9B,YAAY,EAAE,kBAAkB,EAChC,oBAAoB,EAAE,oBAAoB;IAI7D,YAAY;IAKZ,aAAa,CACH,IAAI,EAAE,oBAAoB,EAC3B,GAAG,EAAE,oBAAoB;IA2BlC,aAAa,CACG,GAAG,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,GAAG,EAAE,oBAAoB;IAsBlC,aAAa,CACG,GAAG,EAAE,MAAM,EAClB,GAAG,EAAE,oBAAoB;;;IAoBlC,WAAW,CAAe,GAAG,EAAE,MAAM;IAKrC,SAAS,CACO,GAAG,EAAE,MAAM,EACjB,IAAI,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,EAC7C,GAAG,EAAE,oBAAoB;IAMlC,YAAY,CACI,GAAG,EAAE,MAAM,EACH,WAAW,EAAE,MAAM,EAClC,GAAG,EAAE,oBAAoB;;;CAInC"}
|
|
@@ -19,19 +19,20 @@ const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
|
19
19
|
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
20
20
|
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
21
21
|
const project_repository_1 = require("../../database/repositories/project.repository");
|
|
22
|
-
const project_member_repository_1 = require("../../database/repositories/project-member.repository");
|
|
23
22
|
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
23
|
+
const project_validation_1 = require("../../common/project-validation");
|
|
24
|
+
const project_member_service_1 = require("../project-member.service");
|
|
24
25
|
let AdminProjectController = class AdminProjectController {
|
|
25
26
|
projectRepo;
|
|
26
|
-
projectMemberRepo;
|
|
27
27
|
auditLogRepo;
|
|
28
|
-
|
|
28
|
+
projectMemberService;
|
|
29
|
+
constructor(projectRepo, auditLogRepo, projectMemberService) {
|
|
29
30
|
this.projectRepo = projectRepo;
|
|
30
|
-
this.projectMemberRepo = projectMemberRepo;
|
|
31
31
|
this.auditLogRepo = auditLogRepo;
|
|
32
|
+
this.projectMemberService = projectMemberService;
|
|
32
33
|
}
|
|
33
34
|
listProjects() {
|
|
34
|
-
return this.projectRepo.findAll();
|
|
35
|
+
return this.projectRepo.findAll().map(project_repository_1.ProjectRepository.stripSecrets);
|
|
35
36
|
}
|
|
36
37
|
createProject(body, req) {
|
|
37
38
|
const existing = this.projectRepo.findByKey(body.key);
|
|
@@ -52,19 +53,14 @@ let AdminProjectController = class AdminProjectController {
|
|
|
52
53
|
resource: `project:${project.key}`,
|
|
53
54
|
detail: `Created project '${project.name}'`,
|
|
54
55
|
});
|
|
55
|
-
return project;
|
|
56
|
+
return project_repository_1.ProjectRepository.stripSecrets(project);
|
|
56
57
|
}
|
|
57
58
|
updateProject(key, body, req) {
|
|
58
59
|
const project = this.projectRepo.findByKey(key);
|
|
59
60
|
if (!project) {
|
|
60
61
|
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
61
62
|
}
|
|
62
|
-
const
|
|
63
|
-
const sanitized = {};
|
|
64
|
-
for (const field of allowed) {
|
|
65
|
-
if (field in body)
|
|
66
|
-
sanitized[field] = body[field];
|
|
67
|
-
}
|
|
63
|
+
const sanitized = (0, project_validation_1.validateProjectUpdate)(body);
|
|
68
64
|
this.projectRepo.update(key, sanitized);
|
|
69
65
|
this.auditLogRepo.create({
|
|
70
66
|
userId: req.user.sub,
|
|
@@ -72,7 +68,8 @@ let AdminProjectController = class AdminProjectController {
|
|
|
72
68
|
resource: `project:${key}`,
|
|
73
69
|
detail: `Updated project '${key}'`,
|
|
74
70
|
});
|
|
75
|
-
|
|
71
|
+
const updated = this.projectRepo.findByKey(key);
|
|
72
|
+
return updated ? project_repository_1.ProjectRepository.stripSecrets(updated) : null;
|
|
76
73
|
}
|
|
77
74
|
deleteProject(key, req) {
|
|
78
75
|
const project = this.projectRepo.findByKey(key);
|
|
@@ -89,55 +86,13 @@ let AdminProjectController = class AdminProjectController {
|
|
|
89
86
|
return { success: true };
|
|
90
87
|
}
|
|
91
88
|
listMembers(key) {
|
|
92
|
-
|
|
93
|
-
if (!project) {
|
|
94
|
-
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
95
|
-
}
|
|
96
|
-
return this.projectMemberRepo.findByProject(key);
|
|
89
|
+
return this.projectMemberService.listMembers(key);
|
|
97
90
|
}
|
|
98
91
|
addMember(key, body, req) {
|
|
99
|
-
|
|
100
|
-
if (!project) {
|
|
101
|
-
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
102
|
-
}
|
|
103
|
-
// Check if member already exists
|
|
104
|
-
const existing = this.projectMemberRepo.findByProjectAndDeveloper(key, body.developerId);
|
|
105
|
-
if (existing) {
|
|
106
|
-
throw new common_1.ConflictException('Developer is already a member of this project');
|
|
107
|
-
}
|
|
108
|
-
const member = this.projectMemberRepo.create({
|
|
109
|
-
projectKey: key,
|
|
110
|
-
developerId: body.developerId,
|
|
111
|
-
role: body.role,
|
|
112
|
-
});
|
|
113
|
-
this.auditLogRepo.create({
|
|
114
|
-
userId: req.user.sub,
|
|
115
|
-
action: 'project_member_add',
|
|
116
|
-
resource: `project:${key}`,
|
|
117
|
-
detail: `Added developer #${body.developerId} as ${body.role ?? 'member'}`,
|
|
118
|
-
});
|
|
119
|
-
return member;
|
|
92
|
+
return this.projectMemberService.addMember(key, body.developerId, body.role, req.user.sub);
|
|
120
93
|
}
|
|
121
94
|
removeMember(key, developerId, req) {
|
|
122
|
-
|
|
123
|
-
if (!project) {
|
|
124
|
-
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
125
|
-
}
|
|
126
|
-
const devId = parseInt(developerId, 10);
|
|
127
|
-
if (!developerId || isNaN(devId) || devId < 1) {
|
|
128
|
-
throw new common_1.BadRequestException('developerId query parameter is required and must be a number');
|
|
129
|
-
}
|
|
130
|
-
const deleted = this.projectMemberRepo.delete(key, devId);
|
|
131
|
-
if (!deleted) {
|
|
132
|
-
throw new common_1.NotFoundException('Member not found');
|
|
133
|
-
}
|
|
134
|
-
this.auditLogRepo.create({
|
|
135
|
-
userId: req.user.sub,
|
|
136
|
-
action: 'project_member_remove',
|
|
137
|
-
resource: `project:${key}`,
|
|
138
|
-
detail: `Removed developer #${devId} from project`,
|
|
139
|
-
});
|
|
140
|
-
return { success: true };
|
|
95
|
+
return this.projectMemberService.removeMember(key, developerId, req.user.sub);
|
|
141
96
|
}
|
|
142
97
|
};
|
|
143
98
|
exports.AdminProjectController = AdminProjectController;
|
|
@@ -202,7 +157,7 @@ exports.AdminProjectController = AdminProjectController = __decorate([
|
|
|
202
157
|
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
203
158
|
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
204
159
|
__metadata("design:paramtypes", [project_repository_1.ProjectRepository,
|
|
205
|
-
|
|
206
|
-
|
|
160
|
+
audit_log_repository_1.AuditLogRepository,
|
|
161
|
+
project_member_service_1.ProjectMemberService])
|
|
207
162
|
], AdminProjectController);
|
|
208
163
|
//# sourceMappingURL=admin-project.controller.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-project.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,
|
|
1
|
+
{"version":3,"file":"admin-project.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAawB;AAExB,mDAAqD;AACrD,qEAAgE;AAChE,+DAA2D;AAC3D,2EAA8D;AAC9D,uFAAmF;AAEnF,2FAAsF;AAEtF,wEAAwE;AACxE,sEAAiE;AAK1D,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAEd;IACA;IACA;IAHnB,YACmB,WAA8B,EAC9B,YAAgC,EAChC,oBAA0C;QAF1C,gBAAW,GAAX,WAAW,CAAmB;QAC9B,iBAAY,GAAZ,YAAY,CAAoB;QAChC,yBAAoB,GAApB,oBAAoB,CAAsB;IAC1D,CAAC;IAGJ,YAAY;QACV,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,sCAAiB,CAAC,YAAY,CAAC,CAAC;IACxE,CAAC;IAGD,aAAa,CACH,IAA0B,EAC3B,GAAyB;QAEhC,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtD,IAAI,QAAQ,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,YAAY,IAAI,CAAC,GAAG,kBAAkB,CAAC,CAAC;QACtE,CAAC;QAED,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;YACtC,GAAG,EAAE,IAAI,CAAC,GAAG;YACb,IAAI,EAAE,IAAI,CAAC,IAAI;YACf,OAAO,EAAE,IAAI,CAAC,OAAO;YACrB,MAAM,EAAE,IAAI,CAAC,MAAM,IAAI,IAAI;YAC3B,WAAW,EAAE,IAAI,CAAC,WAAW;YAC7B,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;QAEH,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACvB,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG;YACpB,MAAM,EAAE,gBAAgB;YACxB,QAAQ,EAAE,WAAW,OAAO,CAAC,GAAG,EAAE;YAClC,MAAM,EAAE,oBAAoB,OAAO,CAAC,IAAI,GAAG;SAC5C,CAAC,CAAC;QAEH,OAAO,sCAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC;IACjD,CAAC;IAGD,aAAa,CACG,GAAW,EACjB,IAA6B,EAC9B,GAAyB;QAEhC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC;QAC5D,CAAC;QAED,MAAM,SAAS,GAAG,IAAA,0CAAqB,EAAC,IAAI,CAAC,CAAC;QAC9C,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC;QAExC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACvB,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG;YACpB,MAAM,EAAE,gBAAgB;YACxB,QAAQ,EAAE,WAAW,GAAG,EAAE;YAC1B,MAAM,EAAE,oBAAoB,GAAG,GAAG;SACnC,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAChD,OAAO,OAAO,CAAC,CAAC,CAAC,sCAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAClE,CAAC;IAGD,aAAa,CACG,GAAW,EAClB,GAAyB;QAEhC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC;QAC5D,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;QAE7B,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACvB,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG;YACpB,MAAM,EAAE,gBAAgB;YACxB,QAAQ,EAAE,WAAW,GAAG,EAAE;YAC1B,MAAM,EAAE,oBAAoB,GAAG,GAAG;SACnC,CAAC,CAAC;QAEH,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,WAAW,CAAe,GAAW;QACnC,OAAO,IAAI,CAAC,oBAAoB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;IACpD,CAAC;IAGD,SAAS,CACO,GAAW,EACjB,IAA4C,EAC7C,GAAyB;QAEhC,OAAO,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,GAAG,EAAE,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC7F,CAAC;IAGD,YAAY,CACI,GAAW,EACH,WAAmB,EAClC,GAAyB;QAEhC,OAAO,IAAI,CAAC,oBAAoB,CAAC,YAAY,CAAC,GAAG,EAAE,WAAW,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAChF,CAAC;CACF,CAAA;AA9GY,wDAAsB;AAQjC;IADC,IAAA,YAAG,GAAE;;;;0DAGL;AAGD;IADC,IAAA,aAAI,GAAE;IAEJ,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2DAwBP;AAGD;IADC,IAAA,YAAG,EAAC,MAAM,CAAC;IAET,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;IACZ,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2DAmBP;AAGD;IADC,IAAA,eAAM,EAAC,MAAM,CAAC;IAEZ,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;IACZ,WAAA,IAAA,YAAG,GAAE,CAAA;;;;2DAiBP;AAGD;IADC,IAAA,YAAG,EAAC,cAAc,CAAC;IACP,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;;;;yDAExB;AAGD;IADC,IAAA,aAAI,EAAC,cAAc,CAAC;IAElB,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;IACZ,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,GAAE,CAAA;;;;uDAGP;AAGD;IADC,IAAA,eAAM,EAAC,cAAc,CAAC;IAEpB,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;IACZ,WAAA,IAAA,cAAK,EAAC,aAAa,CAAC,CAAA;IACpB,WAAA,IAAA,YAAG,GAAE,CAAA;;;;0DAGP;iCA7GU,sBAAsB;IAHlC,IAAA,mBAAU,EAAC,oBAAoB,CAAC;IAChC,IAAA,kBAAS,EAAC,6BAAY,EAAE,wBAAU,CAAC;IACnC,IAAA,uBAAK,EAAC,wBAAa,CAAC,KAAK,CAAC;qCAGO,sCAAiB;QAChB,yCAAkB;QACV,6CAAoB;GAJlD,sBAAsB,CA8GlC"}
|
|
@@ -1,18 +1,15 @@
|
|
|
1
1
|
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
2
2
|
import { DatabaseService } from '../../database/database.service';
|
|
3
|
-
|
|
4
|
-
user: {
|
|
5
|
-
sub: number;
|
|
6
|
-
name: string;
|
|
7
|
-
role: string;
|
|
8
|
-
};
|
|
9
|
-
}
|
|
3
|
+
import type { AuthenticatedRequest } from '../../auth/authenticated-request';
|
|
10
4
|
export declare class AdminSettingsController {
|
|
11
5
|
private readonly database;
|
|
12
6
|
private readonly auditLogRepo;
|
|
13
7
|
constructor(database: DatabaseService, auditLogRepo: AuditLogRepository);
|
|
14
|
-
getSettings():
|
|
15
|
-
|
|
8
|
+
getSettings(): {
|
|
9
|
+
[k: string]: string;
|
|
10
|
+
};
|
|
11
|
+
updateSettings(body: Record<string, string>, req: AuthenticatedRequest): {
|
|
12
|
+
[k: string]: string;
|
|
13
|
+
};
|
|
16
14
|
}
|
|
17
|
-
export {};
|
|
18
15
|
//# sourceMappingURL=admin-settings.controller.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-settings.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-settings.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;
|
|
1
|
+
{"version":3,"file":"admin-settings.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-settings.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAmB7E,qBAGa,uBAAuB;IAEhC,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;gBADZ,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,kBAAkB;IAInD,WAAW;;;IAWX,cAAc,CACJ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC7B,GAAG,EAAE,oBAAoB;;;CA2CnC"}
|
|
@@ -20,11 +20,15 @@ const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
|
20
20
|
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
21
21
|
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
22
22
|
const database_service_1 = require("../../database/database.service");
|
|
23
|
+
const NUMERIC_SETTINGS = new Set(['max_concurrent_tasks_per_worker', 'task_timeout_minutes']);
|
|
23
24
|
/** Settings keys that may be read/written via the admin API. */
|
|
24
25
|
const ALLOWED_SETTINGS_KEYS = new Set([
|
|
25
|
-
'
|
|
26
|
+
'max_concurrent_tasks_per_worker',
|
|
26
27
|
'task_timeout_minutes',
|
|
28
|
+
'heartbeat_interval_seconds',
|
|
29
|
+
'worker_offline_threshold_seconds',
|
|
27
30
|
'default_agent_type',
|
|
31
|
+
'server_url',
|
|
28
32
|
]);
|
|
29
33
|
let AdminSettingsController = class AdminSettingsController {
|
|
30
34
|
database;
|
|
@@ -39,17 +43,21 @@ let AdminSettingsController = class AdminSettingsController {
|
|
|
39
43
|
.getDb()
|
|
40
44
|
.prepare(`SELECT key, value FROM settings WHERE key IN (${placeholders})`)
|
|
41
45
|
.all(...ALLOWED_SETTINGS_KEYS);
|
|
42
|
-
|
|
43
|
-
for (const row of rows) {
|
|
44
|
-
settings[row.key] = row.value;
|
|
45
|
-
}
|
|
46
|
-
return settings;
|
|
46
|
+
return Object.fromEntries(rows.map((r) => [r.key, r.value]));
|
|
47
47
|
}
|
|
48
48
|
updateSettings(body, req) {
|
|
49
49
|
const unknownKeys = Object.keys(body).filter((k) => !ALLOWED_SETTINGS_KEYS.has(k));
|
|
50
50
|
if (unknownKeys.length > 0) {
|
|
51
51
|
throw new common_1.BadRequestException(`Unknown settings key(s): ${unknownKeys.join(', ')}. Allowed keys: ${[...ALLOWED_SETTINGS_KEYS].join(', ')}`);
|
|
52
52
|
}
|
|
53
|
+
for (const [key, value] of Object.entries(body)) {
|
|
54
|
+
if (NUMERIC_SETTINGS.has(key)) {
|
|
55
|
+
const parsed = Number(value);
|
|
56
|
+
if (!Number.isInteger(parsed) || parsed <= 0) {
|
|
57
|
+
throw new common_1.BadRequestException(`${key} must be a positive integer`);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
53
61
|
const upsert = this.database
|
|
54
62
|
.getDb()
|
|
55
63
|
.prepare('INSERT INTO settings (key, value) VALUES (?, ?) ON CONFLICT(key) DO UPDATE SET value = excluded.value');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-settings.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-settings.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAQwB;AACxB,mDAAqD;AACrD,qEAAgE;AAChE,+DAA2D;AAC3D,2EAA8D;AAC9D,2FAAsF;AACtF,sEAAkE;
|
|
1
|
+
{"version":3,"file":"admin-settings.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-settings.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAQwB;AACxB,mDAAqD;AACrD,qEAAgE;AAChE,+DAA2D;AAC3D,2EAA8D;AAC9D,2FAAsF;AACtF,sEAAkE;AAQlE,MAAM,gBAAgB,GAAG,IAAI,GAAG,CAAC,CAAC,iCAAiC,EAAE,sBAAsB,CAAC,CAAC,CAAC;AAE9F,gEAAgE;AAChE,MAAM,qBAAqB,GAAG,IAAI,GAAG,CAAC;IACpC,iCAAiC;IACjC,sBAAsB;IACtB,4BAA4B;IAC5B,kCAAkC;IAClC,oBAAoB;IACpB,YAAY;CACb,CAAC,CAAC;AAKI,IAAM,uBAAuB,GAA7B,MAAM,uBAAuB;IAEf;IACA;IAFnB,YACmB,QAAyB,EACzB,YAAgC;QADhC,aAAQ,GAAR,QAAQ,CAAiB;QACzB,iBAAY,GAAZ,YAAY,CAAoB;IAChD,CAAC;IAGJ,WAAW;QACT,MAAM,YAAY,GAAG,CAAC,GAAG,qBAAqB,CAAC,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1E,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ;aACvB,KAAK,EAAE;aACP,OAAO,CAAC,iDAAiD,YAAY,GAAG,CAAC;aACzE,GAAG,CAAC,GAAG,qBAAqB,CAAiB,CAAC;QAEjD,OAAO,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAC/D,CAAC;IAGD,cAAc,CACJ,IAA4B,EAC7B,GAAyB;QAEhC,MAAM,WAAW,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAC1C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,CAAC,CACrC,CAAC;QACF,IAAI,WAAW,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC3B,MAAM,IAAI,4BAAmB,CAC3B,4BAA4B,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,GAAG,qBAAqB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC7G,CAAC;QACJ,CAAC;QAED,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YAChD,IAAI,gBAAgB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC9B,MAAM,MAAM,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;gBAC7B,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,MAAM,IAAI,CAAC,EAAE,CAAC;oBAC7C,MAAM,IAAI,4BAAmB,CAAC,GAAG,GAAG,6BAA6B,CAAC,CAAC;gBACrE,CAAC;YACH,CAAC;QACH,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ;aACzB,KAAK,EAAE;aACP,OAAO,CACN,uGAAuG,CACxG,CAAC;QAEJ,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC,WAAW,CAAC,GAAG,EAAE;YACtD,KAAK,MAAM,CAAC,GAAG,EAAE,KAAK,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;gBAChD,MAAM,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YACzB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,QAAQ,EAAE,CAAC;QAEX,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC;YACvB,MAAM,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG;YACpB,MAAM,EAAE,iBAAiB;YACzB,QAAQ,EAAE,UAAU;YACpB,MAAM,EAAE,qBAAqB,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;SAC5D,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;IAC5B,CAAC;CACF,CAAA;AA/DY,0DAAuB;AAOlC;IADC,IAAA,YAAG,GAAE;;;;0DASL;AAGD;IADC,IAAA,YAAG,GAAE;IAEH,WAAA,IAAA,aAAI,GAAE,CAAA;IACN,WAAA,IAAA,YAAG,GAAE,CAAA;;;;6DA0CP;kCA9DU,uBAAuB;IAHnC,IAAA,mBAAU,EAAC,oBAAoB,CAAC;IAChC,IAAA,kBAAS,EAAC,6BAAY,EAAE,wBAAU,CAAC;IACnC,IAAA,uBAAK,EAAC,wBAAa,CAAC,KAAK,CAAC;qCAGI,kCAAe;QACX,yCAAkB;GAHxC,uBAAuB,CA+DnC"}
|
|
@@ -1,21 +1,15 @@
|
|
|
1
1
|
import type { GenerateWorkerTokenRequest, GenerateWorkerTokenResponse } from '@overlordai/protocol';
|
|
2
2
|
import { WorkerTokenRepository } from '../../database/repositories/worker-token.repository';
|
|
3
|
-
import {
|
|
3
|
+
import { WorkerRepository } from '../../database/repositories/worker.repository';
|
|
4
4
|
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
5
|
import { CryptoService } from '../../common/crypto.service';
|
|
6
|
-
|
|
7
|
-
user: {
|
|
8
|
-
sub: number;
|
|
9
|
-
name: string;
|
|
10
|
-
role: string;
|
|
11
|
-
};
|
|
12
|
-
}
|
|
6
|
+
import type { AuthenticatedRequest } from '../../auth/authenticated-request';
|
|
13
7
|
export declare class AdminTokenController {
|
|
14
8
|
private readonly workerTokenRepo;
|
|
15
|
-
private readonly
|
|
9
|
+
private readonly workerRepo;
|
|
16
10
|
private readonly auditLogRepo;
|
|
17
11
|
private readonly cryptoService;
|
|
18
|
-
constructor(workerTokenRepo: WorkerTokenRepository,
|
|
12
|
+
constructor(workerTokenRepo: WorkerTokenRepository, workerRepo: WorkerRepository, auditLogRepo: AuditLogRepository, cryptoService: CryptoService);
|
|
19
13
|
listTokens(): {
|
|
20
14
|
id: number;
|
|
21
15
|
label: string;
|
|
@@ -37,9 +31,8 @@ export declare class AdminTokenController {
|
|
|
37
31
|
used: boolean;
|
|
38
32
|
usedAt: string | null;
|
|
39
33
|
revokedAt: string | null;
|
|
40
|
-
|
|
41
|
-
|
|
34
|
+
workerName: string | null;
|
|
35
|
+
workerId: string | null;
|
|
42
36
|
};
|
|
43
37
|
}
|
|
44
|
-
export {};
|
|
45
38
|
//# sourceMappingURL=admin-token.controller.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-token.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-token.controller.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,MAAM,sBAAsB,CAAC;AAIpG,OAAO,EAAE,qBAAqB,EAAE,MAAM,qDAAqD,CAAC;AAC5F,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"admin-token.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-token.controller.ts"],"names":[],"mappings":"AAaA,OAAO,KAAK,EAAE,0BAA0B,EAAE,2BAA2B,EAAE,MAAM,sBAAsB,CAAC;AAIpG,OAAO,EAAE,qBAAqB,EAAE,MAAM,qDAAqD,CAAC;AAC5F,OAAO,EAAE,gBAAgB,EAAE,MAAM,+CAA+C,CAAC;AACjF,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAC5D,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAE7E,qBAGa,oBAAoB;IAE7B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAHb,eAAe,EAAE,qBAAqB,EACtC,UAAU,EAAE,gBAAgB,EAC5B,YAAY,EAAE,kBAAkB,EAChC,aAAa,EAAE,aAAa;IAI/C,UAAU;;;;;;;;;;;IAKJ,aAAa,CACT,IAAI,EAAE,0BAA0B,EACjC,GAAG,EAAE,oBAAoB,GAC/B,OAAO,CAAC,2BAA2B,CAAC;IAuBvC,WAAW,CACkB,EAAE,EAAE,MAAM,EAC9B,GAAG,EAAE,oBAAoB;;;IAoBlC,cAAc,CAA4B,EAAE,EAAE,MAAM;;;;;;;;;CA6BrD"}
|
|
@@ -53,34 +53,22 @@ const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
|
53
53
|
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
54
54
|
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
55
55
|
const worker_token_repository_1 = require("../../database/repositories/worker-token.repository");
|
|
56
|
-
const
|
|
56
|
+
const worker_repository_1 = require("../../database/repositories/worker.repository");
|
|
57
57
|
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
58
58
|
const crypto_service_1 = require("../../common/crypto.service");
|
|
59
59
|
let AdminTokenController = class AdminTokenController {
|
|
60
60
|
workerTokenRepo;
|
|
61
|
-
|
|
61
|
+
workerRepo;
|
|
62
62
|
auditLogRepo;
|
|
63
63
|
cryptoService;
|
|
64
|
-
constructor(workerTokenRepo,
|
|
64
|
+
constructor(workerTokenRepo, workerRepo, auditLogRepo, cryptoService) {
|
|
65
65
|
this.workerTokenRepo = workerTokenRepo;
|
|
66
|
-
this.
|
|
66
|
+
this.workerRepo = workerRepo;
|
|
67
67
|
this.auditLogRepo = auditLogRepo;
|
|
68
68
|
this.cryptoService = cryptoService;
|
|
69
69
|
}
|
|
70
70
|
listTokens() {
|
|
71
|
-
|
|
72
|
-
// Strip token_hash from response
|
|
73
|
-
return tokens.map((t) => ({
|
|
74
|
-
id: t.id,
|
|
75
|
-
label: t.label,
|
|
76
|
-
createdBy: t.createdBy,
|
|
77
|
-
status: t.status,
|
|
78
|
-
purpose: t.purpose,
|
|
79
|
-
usedAt: t.usedAt,
|
|
80
|
-
expiresAt: t.expiresAt,
|
|
81
|
-
revokedAt: t.revokedAt,
|
|
82
|
-
createdAt: t.createdAt,
|
|
83
|
-
}));
|
|
71
|
+
return this.workerTokenRepo.findAll().map(({ tokenHash, ...rest }) => rest);
|
|
84
72
|
}
|
|
85
73
|
async generateToken(body, req) {
|
|
86
74
|
const secret = crypto.randomBytes(32).toString('hex');
|
|
@@ -119,14 +107,14 @@ let AdminTokenController = class AdminTokenController {
|
|
|
119
107
|
throw new common_1.NotFoundException(`Worker token #${id} not found`);
|
|
120
108
|
}
|
|
121
109
|
const used = token.usedAt !== null;
|
|
122
|
-
// Look up
|
|
123
|
-
let
|
|
124
|
-
let
|
|
110
|
+
// Look up worker info if the token has been consumed
|
|
111
|
+
let workerName = null;
|
|
112
|
+
let workerId = null;
|
|
125
113
|
if (used) {
|
|
126
|
-
const
|
|
127
|
-
if (
|
|
128
|
-
|
|
129
|
-
|
|
114
|
+
const worker = this.workerRepo.findByTokenId(id);
|
|
115
|
+
if (worker) {
|
|
116
|
+
workerName = worker.name;
|
|
117
|
+
workerId = worker.id;
|
|
130
118
|
}
|
|
131
119
|
}
|
|
132
120
|
return {
|
|
@@ -135,8 +123,8 @@ let AdminTokenController = class AdminTokenController {
|
|
|
135
123
|
used,
|
|
136
124
|
usedAt: token.usedAt,
|
|
137
125
|
revokedAt: token.revokedAt,
|
|
138
|
-
|
|
139
|
-
|
|
126
|
+
workerName,
|
|
127
|
+
workerId,
|
|
140
128
|
};
|
|
141
129
|
}
|
|
142
130
|
};
|
|
@@ -175,7 +163,7 @@ exports.AdminTokenController = AdminTokenController = __decorate([
|
|
|
175
163
|
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
176
164
|
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
177
165
|
__metadata("design:paramtypes", [worker_token_repository_1.WorkerTokenRepository,
|
|
178
|
-
|
|
166
|
+
worker_repository_1.WorkerRepository,
|
|
179
167
|
audit_log_repository_1.AuditLogRepository,
|
|
180
168
|
crypto_service_1.CryptoService])
|
|
181
169
|
], AdminTokenController);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"admin-token.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-token.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAUwB;AACxB,oDAAsC;AACtC,mDAAqD;AAErD,qEAAgE;AAChE,+DAA2D;AAC3D,2EAA8D;AAC9D,iGAA4F;AAC5F,
|
|
1
|
+
{"version":3,"file":"admin-token.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-token.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { WorkerStatus } from '@overlordai/protocol';
|
|
2
|
+
import { WorkerRepository } from '../../database/repositories/worker.repository';
|
|
3
|
+
import { TaskRepository } from '../../database/repositories/task.repository';
|
|
4
|
+
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
|
+
import { DatabaseService } from '../../database/database.service';
|
|
6
|
+
import { WorkerConnectionManager } from '../../dispatcher/worker-connection.manager';
|
|
7
|
+
import { CapabilityService } from '../../dispatcher/capability.service';
|
|
8
|
+
import type { AuthenticatedRequest } from '../../auth/authenticated-request';
|
|
9
|
+
export declare class AdminWorkerController {
|
|
10
|
+
private readonly workerRepo;
|
|
11
|
+
private readonly taskRepo;
|
|
12
|
+
private readonly auditLogRepo;
|
|
13
|
+
private readonly databaseService;
|
|
14
|
+
private readonly connectionManager;
|
|
15
|
+
private readonly capabilityService;
|
|
16
|
+
private readonly logger;
|
|
17
|
+
constructor(workerRepo: WorkerRepository, taskRepo: TaskRepository, auditLogRepo: AuditLogRepository, databaseService: DatabaseService, connectionManager: WorkerConnectionManager, capabilityService: CapabilityService);
|
|
18
|
+
listWorkers(): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">[];
|
|
19
|
+
updateWorker(id: string, body: {
|
|
20
|
+
status?: WorkerStatus;
|
|
21
|
+
}, req: AuthenticatedRequest): Omit<import("@overlordai/protocol").Worker, "recoverySecretHash">;
|
|
22
|
+
decommissionWorker(id: string, req: AuthenticatedRequest): {
|
|
23
|
+
success: boolean;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
//# sourceMappingURL=admin-worker.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-worker.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-worker.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAiB,YAAY,EAAc,MAAM,sBAAsB,CAAC;AAI/E,OAAO,EAAE,gBAAgB,EAAE,MAAM,+CAA+C,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AACrF,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kCAAkC,CAAC;AAE7E,qBAGa,qBAAqB;IAI9B,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IARpC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA0C;gBAG9C,UAAU,EAAE,gBAAgB,EAC5B,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,kBAAkB,EAChC,eAAe,EAAE,eAAe,EAChC,iBAAiB,EAAE,uBAAuB,EAC1C,iBAAiB,EAAE,iBAAiB;IAIvD,WAAW;IAKX,YAAY,CACG,EAAE,EAAE,MAAM,EACf,IAAI,EAAE;QAAE,MAAM,CAAC,EAAE,YAAY,CAAA;KAAE,EAChC,GAAG,EAAE,oBAAoB;IAqElC,kBAAkB,CACH,EAAE,EAAE,MAAM,EAChB,GAAG,EAAE,oBAAoB;;;CA2EnC"}
|