@overlordai/server 1.0.1
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 +226 -0
- package/database/migrations/002-add-indexes.sql +17 -0
- package/database/migrations/003-add-settings-table.sql +4 -0
- package/database/migrations/004-add-developer-id-index.sql +5 -0
- package/dist/adapters/adapter.interface.d.ts +41 -0
- package/dist/adapters/adapter.interface.d.ts.map +1 -0
- package/dist/adapters/adapter.interface.js +6 -0
- package/dist/adapters/adapter.interface.js.map +1 -0
- package/dist/adapters/adapter.module.d.ts +3 -0
- package/dist/adapters/adapter.module.d.ts.map +1 -0
- package/dist/adapters/adapter.module.js +54 -0
- package/dist/adapters/adapter.module.js.map +1 -0
- package/dist/adapters/adapter.registry.d.ts +19 -0
- package/dist/adapters/adapter.registry.d.ts.map +1 -0
- package/dist/adapters/adapter.registry.js +51 -0
- package/dist/adapters/adapter.registry.js.map +1 -0
- package/dist/adapters/lark/lark-card.builder.d.ts +48 -0
- package/dist/adapters/lark/lark-card.builder.d.ts.map +1 -0
- package/dist/adapters/lark/lark-card.builder.js +259 -0
- package/dist/adapters/lark/lark-card.builder.js.map +1 -0
- package/dist/adapters/lark/lark-message.parser.d.ts +51 -0
- package/dist/adapters/lark/lark-message.parser.d.ts.map +1 -0
- package/dist/adapters/lark/lark-message.parser.js +189 -0
- package/dist/adapters/lark/lark-message.parser.js.map +1 -0
- package/dist/adapters/lark/lark-signature.d.ts +13 -0
- package/dist/adapters/lark/lark-signature.d.ts.map +1 -0
- package/dist/adapters/lark/lark-signature.js +58 -0
- package/dist/adapters/lark/lark-signature.js.map +1 -0
- package/dist/adapters/lark/lark.adapter.d.ts +65 -0
- package/dist/adapters/lark/lark.adapter.d.ts.map +1 -0
- package/dist/adapters/lark/lark.adapter.js +565 -0
- package/dist/adapters/lark/lark.adapter.js.map +1 -0
- package/dist/adapters/lark/lark.controller.d.ts +21 -0
- package/dist/adapters/lark/lark.controller.d.ts.map +1 -0
- package/dist/adapters/lark/lark.controller.js +120 -0
- package/dist/adapters/lark/lark.controller.js.map +1 -0
- package/dist/adapters/slack/slack.adapter.d.ts +19 -0
- package/dist/adapters/slack/slack.adapter.d.ts.map +1 -0
- package/dist/adapters/slack/slack.adapter.js +42 -0
- package/dist/adapters/slack/slack.adapter.js.map +1 -0
- package/dist/app.module.d.ts +5 -0
- package/dist/app.module.d.ts.map +1 -0
- package/dist/app.module.js +48 -0
- package/dist/app.module.js.map +1 -0
- package/dist/auth/auth.controller.d.ts +15 -0
- package/dist/auth/auth.controller.d.ts.map +1 -0
- package/dist/auth/auth.controller.js +67 -0
- package/dist/auth/auth.controller.js.map +1 -0
- package/dist/auth/auth.module.d.ts +3 -0
- package/dist/auth/auth.module.d.ts.map +1 -0
- package/dist/auth/auth.module.js +46 -0
- package/dist/auth/auth.module.js.map +1 -0
- package/dist/auth/auth.service.d.ts +62 -0
- package/dist/auth/auth.service.d.ts.map +1 -0
- package/dist/auth/auth.service.js +307 -0
- package/dist/auth/auth.service.js.map +1 -0
- package/dist/auth/decorators/allow-totp-setup.decorator.d.ts +3 -0
- package/dist/auth/decorators/allow-totp-setup.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/allow-totp-setup.decorator.js +8 -0
- package/dist/auth/decorators/allow-totp-setup.decorator.js.map +1 -0
- package/dist/auth/decorators/project-roles.decorator.d.ts +4 -0
- package/dist/auth/decorators/project-roles.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/project-roles.decorator.js +8 -0
- package/dist/auth/decorators/project-roles.decorator.js.map +1 -0
- package/dist/auth/decorators/roles.decorator.d.ts +4 -0
- package/dist/auth/decorators/roles.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/roles.decorator.js +8 -0
- package/dist/auth/decorators/roles.decorator.js.map +1 -0
- package/dist/auth/extract-user.middleware.d.ts +21 -0
- package/dist/auth/extract-user.middleware.d.ts.map +1 -0
- package/dist/auth/extract-user.middleware.js +57 -0
- package/dist/auth/extract-user.middleware.js.map +1 -0
- package/dist/auth/guards/jwt-auth.guard.d.ts +14 -0
- package/dist/auth/guards/jwt-auth.guard.d.ts.map +1 -0
- package/dist/auth/guards/jwt-auth.guard.js +139 -0
- package/dist/auth/guards/jwt-auth.guard.js.map +1 -0
- package/dist/auth/guards/project-role.guard.d.ts +10 -0
- package/dist/auth/guards/project-role.guard.d.ts.map +1 -0
- package/dist/auth/guards/project-role.guard.js +72 -0
- package/dist/auth/guards/project-role.guard.js.map +1 -0
- package/dist/auth/guards/roles.guard.d.ts +8 -0
- package/dist/auth/guards/roles.guard.d.ts.map +1 -0
- package/dist/auth/guards/roles.guard.js +56 -0
- package/dist/auth/guards/roles.guard.js.map +1 -0
- package/dist/auth/jwt.strategy.d.ts +23 -0
- package/dist/auth/jwt.strategy.d.ts.map +1 -0
- package/dist/auth/jwt.strategy.js +49 -0
- package/dist/auth/jwt.strategy.js.map +1 -0
- package/dist/common/crypto.service.d.ts +31 -0
- package/dist/common/crypto.service.d.ts.map +1 -0
- package/dist/common/crypto.service.js +120 -0
- package/dist/common/crypto.service.js.map +1 -0
- package/dist/common/error-filter.d.ts +6 -0
- package/dist/common/error-filter.d.ts.map +1 -0
- package/dist/common/error-filter.js +78 -0
- package/dist/common/error-filter.js.map +1 -0
- package/dist/common/health.controller.d.ts +13 -0
- package/dist/common/health.controller.d.ts.map +1 -0
- package/dist/common/health.controller.js +75 -0
- package/dist/common/health.controller.js.map +1 -0
- package/dist/common/logger.service.d.ts +11 -0
- package/dist/common/logger.service.d.ts.map +1 -0
- package/dist/common/logger.service.js +48 -0
- package/dist/common/logger.service.js.map +1 -0
- package/dist/common/pagination.d.ts +18 -0
- package/dist/common/pagination.d.ts.map +1 -0
- package/dist/common/pagination.js +39 -0
- package/dist/common/pagination.js.map +1 -0
- package/dist/common/rate-limit.guard.d.ts +48 -0
- package/dist/common/rate-limit.guard.d.ts.map +1 -0
- package/dist/common/rate-limit.guard.js +129 -0
- package/dist/common/rate-limit.guard.js.map +1 -0
- package/dist/common/sensitive-filter.d.ts +7 -0
- package/dist/common/sensitive-filter.d.ts.map +1 -0
- package/dist/common/sensitive-filter.js +20 -0
- package/dist/common/sensitive-filter.js.map +1 -0
- package/dist/database/database.module.d.ts +3 -0
- package/dist/database/database.module.d.ts.map +1 -0
- package/dist/database/database.module.js +22 -0
- package/dist/database/database.module.js.map +1 -0
- package/dist/database/database.service.d.ts +13 -0
- package/dist/database/database.service.d.ts.map +1 -0
- package/dist/database/database.service.js +107 -0
- package/dist/database/database.service.js.map +1 -0
- package/dist/database/migration-runner.d.ts +5 -0
- package/dist/database/migration-runner.d.ts.map +1 -0
- package/dist/database/migration-runner.js +86 -0
- package/dist/database/migration-runner.js.map +1 -0
- package/dist/database/repositories/audit-log.repository.d.ts +29 -0
- package/dist/database/repositories/audit-log.repository.d.ts.map +1 -0
- package/dist/database/repositories/audit-log.repository.js +80 -0
- package/dist/database/repositories/audit-log.repository.js.map +1 -0
- package/dist/database/repositories/bot.repository.d.ts +67 -0
- package/dist/database/repositories/bot.repository.d.ts.map +1 -0
- package/dist/database/repositories/bot.repository.js +133 -0
- package/dist/database/repositories/bot.repository.js.map +1 -0
- package/dist/database/repositories/developer-token.repository.d.ts +40 -0
- package/dist/database/repositories/developer-token.repository.d.ts.map +1 -0
- package/dist/database/repositories/developer-token.repository.js +84 -0
- package/dist/database/repositories/developer-token.repository.js.map +1 -0
- package/dist/database/repositories/developer.repository.d.ts +25 -0
- package/dist/database/repositories/developer.repository.d.ts.map +1 -0
- package/dist/database/repositories/developer.repository.js +139 -0
- package/dist/database/repositories/developer.repository.js.map +1 -0
- package/dist/database/repositories/machine.repository.d.ts +39 -0
- package/dist/database/repositories/machine.repository.d.ts.map +1 -0
- package/dist/database/repositories/machine.repository.js +176 -0
- package/dist/database/repositories/machine.repository.js.map +1 -0
- package/dist/database/repositories/notification.repository.d.ts +19 -0
- package/dist/database/repositories/notification.repository.d.ts.map +1 -0
- package/dist/database/repositories/notification.repository.js +94 -0
- package/dist/database/repositories/notification.repository.js.map +1 -0
- package/dist/database/repositories/project-member.repository.d.ts +30 -0
- package/dist/database/repositories/project-member.repository.d.ts.map +1 -0
- package/dist/database/repositories/project-member.repository.js +75 -0
- package/dist/database/repositories/project-member.repository.js.map +1 -0
- package/dist/database/repositories/project.repository.d.ts +24 -0
- package/dist/database/repositories/project.repository.d.ts.map +1 -0
- package/dist/database/repositories/project.repository.js +154 -0
- package/dist/database/repositories/project.repository.js.map +1 -0
- package/dist/database/repositories/session.repository.d.ts +19 -0
- package/dist/database/repositories/session.repository.d.ts.map +1 -0
- package/dist/database/repositories/session.repository.js +117 -0
- package/dist/database/repositories/session.repository.js.map +1 -0
- package/dist/database/repositories/task.repository.d.ts +37 -0
- package/dist/database/repositories/task.repository.d.ts.map +1 -0
- package/dist/database/repositories/task.repository.js +229 -0
- package/dist/database/repositories/task.repository.js.map +1 -0
- package/dist/database/repositories/worker-token.repository.d.ts +20 -0
- package/dist/database/repositories/worker-token.repository.d.ts.map +1 -0
- package/dist/database/repositories/worker-token.repository.js +94 -0
- package/dist/database/repositories/worker-token.repository.js.map +1 -0
- package/dist/database/repositories/workspace.repository.d.ts +19 -0
- package/dist/database/repositories/workspace.repository.d.ts.map +1 -0
- package/dist/database/repositories/workspace.repository.js +82 -0
- package/dist/database/repositories/workspace.repository.js.map +1 -0
- package/dist/dispatcher/capability.service.d.ts +50 -0
- package/dist/dispatcher/capability.service.d.ts.map +1 -0
- package/dist/dispatcher/capability.service.js +159 -0
- package/dist/dispatcher/capability.service.js.map +1 -0
- package/dist/dispatcher/cleanup.service.d.ts +23 -0
- package/dist/dispatcher/cleanup.service.d.ts.map +1 -0
- package/dist/dispatcher/cleanup.service.js +107 -0
- package/dist/dispatcher/cleanup.service.js.map +1 -0
- package/dist/dispatcher/dedup.service.d.ts +48 -0
- package/dist/dispatcher/dedup.service.d.ts.map +1 -0
- package/dist/dispatcher/dedup.service.js +189 -0
- package/dist/dispatcher/dedup.service.js.map +1 -0
- package/dist/dispatcher/dispatcher.module.d.ts +3 -0
- package/dist/dispatcher/dispatcher.module.d.ts.map +1 -0
- package/dist/dispatcher/dispatcher.module.js +76 -0
- package/dist/dispatcher/dispatcher.module.js.map +1 -0
- package/dist/dispatcher/dispatcher.service.d.ts +134 -0
- package/dist/dispatcher/dispatcher.service.d.ts.map +1 -0
- package/dist/dispatcher/dispatcher.service.js +1034 -0
- package/dist/dispatcher/dispatcher.service.js.map +1 -0
- package/dist/dispatcher/heartbeat.service.d.ts +50 -0
- package/dist/dispatcher/heartbeat.service.d.ts.map +1 -0
- package/dist/dispatcher/heartbeat.service.js +154 -0
- package/dist/dispatcher/heartbeat.service.js.map +1 -0
- package/dist/dispatcher/machine-selector.d.ts +18 -0
- package/dist/dispatcher/machine-selector.d.ts.map +1 -0
- package/dist/dispatcher/machine-selector.js +144 -0
- package/dist/dispatcher/machine-selector.js.map +1 -0
- package/dist/dispatcher/pty-relay.service.d.ts +75 -0
- package/dist/dispatcher/pty-relay.service.d.ts.map +1 -0
- package/dist/dispatcher/pty-relay.service.js +404 -0
- package/dist/dispatcher/pty-relay.service.js.map +1 -0
- package/dist/dispatcher/reconciler.d.ts +39 -0
- package/dist/dispatcher/reconciler.d.ts.map +1 -0
- package/dist/dispatcher/reconciler.js +556 -0
- package/dist/dispatcher/reconciler.js.map +1 -0
- package/dist/dispatcher/scheduler.service.d.ts +50 -0
- package/dist/dispatcher/scheduler.service.d.ts.map +1 -0
- package/dist/dispatcher/scheduler.service.js +287 -0
- package/dist/dispatcher/scheduler.service.js.map +1 -0
- package/dist/dispatcher/state-machine.d.ts +16 -0
- package/dist/dispatcher/state-machine.d.ts.map +1 -0
- package/dist/dispatcher/state-machine.js +77 -0
- package/dist/dispatcher/state-machine.js.map +1 -0
- package/dist/dispatcher/task-log-batcher.d.ts +50 -0
- package/dist/dispatcher/task-log-batcher.d.ts.map +1 -0
- package/dist/dispatcher/task-log-batcher.js +184 -0
- package/dist/dispatcher/task-log-batcher.js.map +1 -0
- package/dist/dispatcher/worker-connection.manager.d.ts +49 -0
- package/dist/dispatcher/worker-connection.manager.d.ts.map +1 -0
- package/dist/dispatcher/worker-connection.manager.js +128 -0
- package/dist/dispatcher/worker-connection.manager.js.map +1 -0
- package/dist/main.d.ts +2 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +85 -0
- package/dist/main.js.map +1 -0
- package/dist/notifier/debouncer.d.ts +39 -0
- package/dist/notifier/debouncer.d.ts.map +1 -0
- package/dist/notifier/debouncer.js +123 -0
- package/dist/notifier/debouncer.js.map +1 -0
- package/dist/notifier/notification-consumer.d.ts +88 -0
- package/dist/notifier/notification-consumer.d.ts.map +1 -0
- package/dist/notifier/notification-consumer.js +186 -0
- package/dist/notifier/notification-consumer.js.map +1 -0
- package/dist/notifier/notifier.module.d.ts +9 -0
- package/dist/notifier/notifier.module.d.ts.map +1 -0
- package/dist/notifier/notifier.module.js +58 -0
- package/dist/notifier/notifier.module.js.map +1 -0
- package/dist/notifier/notifier.service.d.ts +40 -0
- package/dist/notifier/notifier.service.d.ts.map +1 -0
- package/dist/notifier/notifier.service.js +191 -0
- package/dist/notifier/notifier.service.js.map +1 -0
- package/dist/notifier/template.service.d.ts +42 -0
- package/dist/notifier/template.service.d.ts.map +1 -0
- package/dist/notifier/template.service.js +201 -0
- package/dist/notifier/template.service.js.map +1 -0
- package/dist/redis/redis.module.d.ts +3 -0
- package/dist/redis/redis.module.d.ts.map +1 -0
- package/dist/redis/redis.module.js +22 -0
- package/dist/redis/redis.module.js.map +1 -0
- package/dist/redis/redis.service.d.ts +19 -0
- package/dist/redis/redis.service.d.ts.map +1 -0
- package/dist/redis/redis.service.js +69 -0
- package/dist/redis/redis.service.js.map +1 -0
- package/dist/web/admin/admin-audit.controller.d.ts +7 -0
- package/dist/web/admin/admin-audit.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-audit.controller.js +53 -0
- package/dist/web/admin/admin-audit.controller.js.map +1 -0
- package/dist/web/admin/admin-bot.controller.d.ts +79 -0
- package/dist/web/admin/admin-bot.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-bot.controller.js +193 -0
- package/dist/web/admin/admin-bot.controller.js.map +1 -0
- package/dist/web/admin/admin-developer.controller.d.ts +52 -0
- package/dist/web/admin/admin-developer.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-developer.controller.js +160 -0
- package/dist/web/admin/admin-developer.controller.js.map +1 -0
- package/dist/web/admin/admin-machine.controller.d.ts +64 -0
- package/dist/web/admin/admin-machine.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-machine.controller.js +111 -0
- package/dist/web/admin/admin-machine.controller.js.map +1 -0
- package/dist/web/admin/admin-project.controller.d.ts +45 -0
- package/dist/web/admin/admin-project.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-project.controller.js +207 -0
- package/dist/web/admin/admin-project.controller.js.map +1 -0
- package/dist/web/admin/admin-settings.controller.d.ts +18 -0
- package/dist/web/admin/admin-settings.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-settings.controller.js +93 -0
- package/dist/web/admin/admin-settings.controller.js.map +1 -0
- package/dist/web/admin/admin-token.controller.d.ts +45 -0
- package/dist/web/admin/admin-token.controller.d.ts.map +1 -0
- package/dist/web/admin/admin-token.controller.js +182 -0
- package/dist/web/admin/admin-token.controller.js.map +1 -0
- package/dist/web/dashboard.controller.d.ts +16 -0
- package/dist/web/dashboard.controller.d.ts.map +1 -0
- package/dist/web/dashboard.controller.js +78 -0
- package/dist/web/dashboard.controller.js.map +1 -0
- package/dist/web/dashboard.service.d.ts +39 -0
- package/dist/web/dashboard.service.d.ts.map +1 -0
- package/dist/web/dashboard.service.js +234 -0
- package/dist/web/dashboard.service.js.map +1 -0
- package/dist/web/interaction.service.d.ts +42 -0
- package/dist/web/interaction.service.d.ts.map +1 -0
- package/dist/web/interaction.service.js +102 -0
- package/dist/web/interaction.service.js.map +1 -0
- package/dist/web/machine.controller.d.ts +102 -0
- package/dist/web/machine.controller.d.ts.map +1 -0
- package/dist/web/machine.controller.js +121 -0
- package/dist/web/machine.controller.js.map +1 -0
- package/dist/web/notification.controller.d.ts +22 -0
- package/dist/web/notification.controller.d.ts.map +1 -0
- package/dist/web/notification.controller.js +70 -0
- package/dist/web/notification.controller.js.map +1 -0
- package/dist/web/profile.controller.d.ts +70 -0
- package/dist/web/profile.controller.d.ts.map +1 -0
- package/dist/web/profile.controller.js +262 -0
- package/dist/web/profile.controller.js.map +1 -0
- package/dist/web/project.controller.d.ts +8 -0
- package/dist/web/project.controller.d.ts.map +1 -0
- package/dist/web/project.controller.js +54 -0
- package/dist/web/project.controller.js.map +1 -0
- package/dist/web/pty.gateway.d.ts +32 -0
- package/dist/web/pty.gateway.d.ts.map +1 -0
- package/dist/web/pty.gateway.js +358 -0
- package/dist/web/pty.gateway.js.map +1 -0
- package/dist/web/search.service.d.ts +34 -0
- package/dist/web/search.service.d.ts.map +1 -0
- package/dist/web/search.service.js +106 -0
- package/dist/web/search.service.js.map +1 -0
- package/dist/web/task.controller.d.ts +54 -0
- package/dist/web/task.controller.d.ts.map +1 -0
- package/dist/web/task.controller.js +266 -0
- package/dist/web/task.controller.js.map +1 -0
- package/dist/web/web.module.d.ts +3 -0
- package/dist/web/web.module.d.ts.map +1 -0
- package/dist/web/web.module.js +97 -0
- package/dist/web/web.module.js.map +1 -0
- package/dist/web/worker-channel.gateway.d.ts +45 -0
- package/dist/web/worker-channel.gateway.d.ts.map +1 -0
- package/dist/web/worker-channel.gateway.js +283 -0
- package/dist/web/worker-channel.gateway.js.map +1 -0
- package/dist/web/worker.controller.d.ts +14 -0
- package/dist/web/worker.controller.d.ts.map +1 -0
- package/dist/web/worker.controller.js +73 -0
- package/dist/web/worker.controller.js.map +1 -0
- package/dist/web/workspace.controller.d.ts +109 -0
- package/dist/web/workspace.controller.d.ts.map +1 -0
- package/dist/web/workspace.controller.js +386 -0
- package/dist/web/workspace.controller.js.map +1 -0
- package/package.json +61 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-project.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,sBAAsB,CAAC;AAIjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AACnF,OAAO,EAAE,uBAAuB,EAAE,MAAM,uDAAuD,CAAC;AAChG,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AAEtF,UAAU,oBAAoB;IAC5B,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CACnD;AAED,qBAGa,sBAAsB;IAE/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,YAAY;gBAFZ,WAAW,EAAE,iBAAiB,EAC9B,iBAAiB,EAAE,uBAAuB,EAC1C,YAAY,EAAE,kBAAkB;IAInD,YAAY;IAKZ,aAAa,CACH,IAAI,EAAE,oBAAoB,EAC3B,GAAG,EAAE,oBAAoB;IA0BlC,aAAa,CACG,GAAG,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,GAAG,EAAE,oBAAoB;IAyBlC,aAAa,CACG,GAAG,EAAE,MAAM,EAClB,GAAG,EAAE,oBAAoB;;;IAoBlC,WAAW,CAAe,GAAG,EAAE,MAAM;;;;;;;IASrC,SAAS,CACO,GAAG,EAAE,MAAM,EACjB,IAAI,EAAE;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,EAC7C,GAAG,EAAE,oBAAoB;;;;;;;IA8BlC,YAAY,CACI,GAAG,EAAE,MAAM,EACH,WAAW,EAAE,MAAM,EAClC,GAAG,EAAE,oBAAoB;;;CAyBnC"}
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AdminProjectController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
18
|
+
const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
19
|
+
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
20
|
+
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
21
|
+
const project_repository_1 = require("../../database/repositories/project.repository");
|
|
22
|
+
const project_member_repository_1 = require("../../database/repositories/project-member.repository");
|
|
23
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
24
|
+
let AdminProjectController = class AdminProjectController {
|
|
25
|
+
projectRepo;
|
|
26
|
+
projectMemberRepo;
|
|
27
|
+
auditLogRepo;
|
|
28
|
+
constructor(projectRepo, projectMemberRepo, auditLogRepo) {
|
|
29
|
+
this.projectRepo = projectRepo;
|
|
30
|
+
this.projectMemberRepo = projectMemberRepo;
|
|
31
|
+
this.auditLogRepo = auditLogRepo;
|
|
32
|
+
}
|
|
33
|
+
listProjects() {
|
|
34
|
+
return this.projectRepo.findAll();
|
|
35
|
+
}
|
|
36
|
+
createProject(body, req) {
|
|
37
|
+
const existing = this.projectRepo.findByKey(body.key);
|
|
38
|
+
if (existing) {
|
|
39
|
+
throw new common_1.ConflictException(`Project '${body.key}' already exists`);
|
|
40
|
+
}
|
|
41
|
+
const project = this.projectRepo.create({
|
|
42
|
+
key: body.key,
|
|
43
|
+
name: body.name,
|
|
44
|
+
repoUrl: body.repoUrl,
|
|
45
|
+
gitPlatform: body.gitPlatform,
|
|
46
|
+
defaultBranch: body.defaultBranch,
|
|
47
|
+
});
|
|
48
|
+
this.auditLogRepo.create({
|
|
49
|
+
userId: req.user.sub,
|
|
50
|
+
action: 'project_create',
|
|
51
|
+
resource: `project:${project.key}`,
|
|
52
|
+
detail: `Created project '${project.name}'`,
|
|
53
|
+
});
|
|
54
|
+
return project;
|
|
55
|
+
}
|
|
56
|
+
updateProject(key, body, req) {
|
|
57
|
+
const project = this.projectRepo.findByKey(key);
|
|
58
|
+
if (!project) {
|
|
59
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
60
|
+
}
|
|
61
|
+
const allowed = ['name', 'repoUrl', 'defaultBranch', 'pipeline', 'setupCommands', 'agentType', 'agentEnv', 'agentCommand', 'workspaceRoot', 'testCommand', 'skillsPath', 'allowedTools', 'maxTurns', 'ptyOutputFilter', 'isDefault', 'aliases', 'gitPlatform'];
|
|
62
|
+
const sanitized = {};
|
|
63
|
+
for (const field of allowed) {
|
|
64
|
+
if (field in body)
|
|
65
|
+
sanitized[field] = body[field];
|
|
66
|
+
}
|
|
67
|
+
this.projectRepo.update(key, sanitized);
|
|
68
|
+
this.auditLogRepo.create({
|
|
69
|
+
userId: req.user.sub,
|
|
70
|
+
action: 'project_update',
|
|
71
|
+
resource: `project:${key}`,
|
|
72
|
+
detail: `Updated project '${key}'`,
|
|
73
|
+
});
|
|
74
|
+
return this.projectRepo.findByKey(key);
|
|
75
|
+
}
|
|
76
|
+
deleteProject(key, req) {
|
|
77
|
+
const project = this.projectRepo.findByKey(key);
|
|
78
|
+
if (!project) {
|
|
79
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
80
|
+
}
|
|
81
|
+
this.projectRepo.delete(key);
|
|
82
|
+
this.auditLogRepo.create({
|
|
83
|
+
userId: req.user.sub,
|
|
84
|
+
action: 'project_delete',
|
|
85
|
+
resource: `project:${key}`,
|
|
86
|
+
detail: `Deleted project '${key}'`,
|
|
87
|
+
});
|
|
88
|
+
return { success: true };
|
|
89
|
+
}
|
|
90
|
+
listMembers(key) {
|
|
91
|
+
const project = this.projectRepo.findByKey(key);
|
|
92
|
+
if (!project) {
|
|
93
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
94
|
+
}
|
|
95
|
+
return this.projectMemberRepo.findByProject(key);
|
|
96
|
+
}
|
|
97
|
+
addMember(key, body, req) {
|
|
98
|
+
const project = this.projectRepo.findByKey(key);
|
|
99
|
+
if (!project) {
|
|
100
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
101
|
+
}
|
|
102
|
+
// Check if member already exists
|
|
103
|
+
const existing = this.projectMemberRepo.findByProjectAndDeveloper(key, body.developerId);
|
|
104
|
+
if (existing) {
|
|
105
|
+
throw new common_1.ConflictException('Developer is already a member of this project');
|
|
106
|
+
}
|
|
107
|
+
const member = this.projectMemberRepo.create({
|
|
108
|
+
projectKey: key,
|
|
109
|
+
developerId: body.developerId,
|
|
110
|
+
role: body.role,
|
|
111
|
+
});
|
|
112
|
+
this.auditLogRepo.create({
|
|
113
|
+
userId: req.user.sub,
|
|
114
|
+
action: 'project_member_add',
|
|
115
|
+
resource: `project:${key}`,
|
|
116
|
+
detail: `Added developer #${body.developerId} as ${body.role ?? 'member'}`,
|
|
117
|
+
});
|
|
118
|
+
return member;
|
|
119
|
+
}
|
|
120
|
+
removeMember(key, developerId, req) {
|
|
121
|
+
const project = this.projectRepo.findByKey(key);
|
|
122
|
+
if (!project) {
|
|
123
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
124
|
+
}
|
|
125
|
+
const devId = parseInt(developerId, 10);
|
|
126
|
+
if (!developerId || isNaN(devId) || devId < 1) {
|
|
127
|
+
throw new common_1.BadRequestException('developerId query parameter is required and must be a number');
|
|
128
|
+
}
|
|
129
|
+
const deleted = this.projectMemberRepo.delete(key, devId);
|
|
130
|
+
if (!deleted) {
|
|
131
|
+
throw new common_1.NotFoundException('Member not found');
|
|
132
|
+
}
|
|
133
|
+
this.auditLogRepo.create({
|
|
134
|
+
userId: req.user.sub,
|
|
135
|
+
action: 'project_member_remove',
|
|
136
|
+
resource: `project:${key}`,
|
|
137
|
+
detail: `Removed developer #${devId} from project`,
|
|
138
|
+
});
|
|
139
|
+
return { success: true };
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
exports.AdminProjectController = AdminProjectController;
|
|
143
|
+
__decorate([
|
|
144
|
+
(0, common_1.Get)(),
|
|
145
|
+
__metadata("design:type", Function),
|
|
146
|
+
__metadata("design:paramtypes", []),
|
|
147
|
+
__metadata("design:returntype", void 0)
|
|
148
|
+
], AdminProjectController.prototype, "listProjects", null);
|
|
149
|
+
__decorate([
|
|
150
|
+
(0, common_1.Post)(),
|
|
151
|
+
__param(0, (0, common_1.Body)()),
|
|
152
|
+
__param(1, (0, common_1.Req)()),
|
|
153
|
+
__metadata("design:type", Function),
|
|
154
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
155
|
+
__metadata("design:returntype", void 0)
|
|
156
|
+
], AdminProjectController.prototype, "createProject", null);
|
|
157
|
+
__decorate([
|
|
158
|
+
(0, common_1.Put)(':key'),
|
|
159
|
+
__param(0, (0, common_1.Param)('key')),
|
|
160
|
+
__param(1, (0, common_1.Body)()),
|
|
161
|
+
__param(2, (0, common_1.Req)()),
|
|
162
|
+
__metadata("design:type", Function),
|
|
163
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
164
|
+
__metadata("design:returntype", void 0)
|
|
165
|
+
], AdminProjectController.prototype, "updateProject", null);
|
|
166
|
+
__decorate([
|
|
167
|
+
(0, common_1.Delete)(':key'),
|
|
168
|
+
__param(0, (0, common_1.Param)('key')),
|
|
169
|
+
__param(1, (0, common_1.Req)()),
|
|
170
|
+
__metadata("design:type", Function),
|
|
171
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
172
|
+
__metadata("design:returntype", void 0)
|
|
173
|
+
], AdminProjectController.prototype, "deleteProject", null);
|
|
174
|
+
__decorate([
|
|
175
|
+
(0, common_1.Get)(':key/members'),
|
|
176
|
+
__param(0, (0, common_1.Param)('key')),
|
|
177
|
+
__metadata("design:type", Function),
|
|
178
|
+
__metadata("design:paramtypes", [String]),
|
|
179
|
+
__metadata("design:returntype", void 0)
|
|
180
|
+
], AdminProjectController.prototype, "listMembers", null);
|
|
181
|
+
__decorate([
|
|
182
|
+
(0, common_1.Post)(':key/members'),
|
|
183
|
+
__param(0, (0, common_1.Param)('key')),
|
|
184
|
+
__param(1, (0, common_1.Body)()),
|
|
185
|
+
__param(2, (0, common_1.Req)()),
|
|
186
|
+
__metadata("design:type", Function),
|
|
187
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
188
|
+
__metadata("design:returntype", void 0)
|
|
189
|
+
], AdminProjectController.prototype, "addMember", null);
|
|
190
|
+
__decorate([
|
|
191
|
+
(0, common_1.Delete)(':key/members'),
|
|
192
|
+
__param(0, (0, common_1.Param)('key')),
|
|
193
|
+
__param(1, (0, common_1.Query)('developerId')),
|
|
194
|
+
__param(2, (0, common_1.Req)()),
|
|
195
|
+
__metadata("design:type", Function),
|
|
196
|
+
__metadata("design:paramtypes", [String, String, Object]),
|
|
197
|
+
__metadata("design:returntype", void 0)
|
|
198
|
+
], AdminProjectController.prototype, "removeMember", null);
|
|
199
|
+
exports.AdminProjectController = AdminProjectController = __decorate([
|
|
200
|
+
(0, common_1.Controller)('api/admin/projects'),
|
|
201
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
202
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
203
|
+
__metadata("design:paramtypes", [project_repository_1.ProjectRepository,
|
|
204
|
+
project_member_repository_1.ProjectMemberRepository,
|
|
205
|
+
audit_log_repository_1.AuditLogRepository])
|
|
206
|
+
], AdminProjectController);
|
|
207
|
+
//# sourceMappingURL=admin-project.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-project.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-project.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
2
|
+
import { DatabaseService } from '../../database/database.service';
|
|
3
|
+
interface AuthenticatedRequest {
|
|
4
|
+
user: {
|
|
5
|
+
sub: number;
|
|
6
|
+
name: string;
|
|
7
|
+
role: string;
|
|
8
|
+
};
|
|
9
|
+
}
|
|
10
|
+
export declare class AdminSettingsController {
|
|
11
|
+
private readonly database;
|
|
12
|
+
private readonly auditLogRepo;
|
|
13
|
+
constructor(database: DatabaseService, auditLogRepo: AuditLogRepository);
|
|
14
|
+
getSettings(): Record<string, string>;
|
|
15
|
+
updateSettings(body: Record<string, string>, req: AuthenticatedRequest): Record<string, string>;
|
|
16
|
+
}
|
|
17
|
+
export {};
|
|
18
|
+
//# sourceMappingURL=admin-settings.controller.d.ts.map
|
|
@@ -0,0 +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;AAElE,UAAU,oBAAoB;IAC5B,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CACnD;AAcD,qBAGa,uBAAuB;IAEhC,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;gBADZ,QAAQ,EAAE,eAAe,EACzB,YAAY,EAAE,kBAAkB;IAInD,WAAW;IAeX,cAAc,CACJ,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,EAC7B,GAAG,EAAE,oBAAoB;CAkCnC"}
|
|
@@ -0,0 +1,93 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AdminSettingsController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
18
|
+
const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
19
|
+
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
20
|
+
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
21
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
22
|
+
const database_service_1 = require("../../database/database.service");
|
|
23
|
+
/** Settings keys that may be read/written via the admin API. */
|
|
24
|
+
const ALLOWED_SETTINGS_KEYS = new Set([
|
|
25
|
+
'max_concurrent_tasks',
|
|
26
|
+
'task_timeout_minutes',
|
|
27
|
+
'default_agent_type',
|
|
28
|
+
]);
|
|
29
|
+
let AdminSettingsController = class AdminSettingsController {
|
|
30
|
+
database;
|
|
31
|
+
auditLogRepo;
|
|
32
|
+
constructor(database, auditLogRepo) {
|
|
33
|
+
this.database = database;
|
|
34
|
+
this.auditLogRepo = auditLogRepo;
|
|
35
|
+
}
|
|
36
|
+
getSettings() {
|
|
37
|
+
const placeholders = [...ALLOWED_SETTINGS_KEYS].map(() => '?').join(', ');
|
|
38
|
+
const rows = this.database
|
|
39
|
+
.getDb()
|
|
40
|
+
.prepare(`SELECT key, value FROM settings WHERE key IN (${placeholders})`)
|
|
41
|
+
.all(...ALLOWED_SETTINGS_KEYS);
|
|
42
|
+
const settings = {};
|
|
43
|
+
for (const row of rows) {
|
|
44
|
+
settings[row.key] = row.value;
|
|
45
|
+
}
|
|
46
|
+
return settings;
|
|
47
|
+
}
|
|
48
|
+
updateSettings(body, req) {
|
|
49
|
+
const unknownKeys = Object.keys(body).filter((k) => !ALLOWED_SETTINGS_KEYS.has(k));
|
|
50
|
+
if (unknownKeys.length > 0) {
|
|
51
|
+
throw new common_1.BadRequestException(`Unknown settings key(s): ${unknownKeys.join(', ')}. Allowed keys: ${[...ALLOWED_SETTINGS_KEYS].join(', ')}`);
|
|
52
|
+
}
|
|
53
|
+
const upsert = this.database
|
|
54
|
+
.getDb()
|
|
55
|
+
.prepare('INSERT INTO settings (key, value) VALUES (?, ?) ON CONFLICT(key) DO UPDATE SET value = excluded.value');
|
|
56
|
+
const runBatch = this.database.getDb().transaction(() => {
|
|
57
|
+
for (const [key, value] of Object.entries(body)) {
|
|
58
|
+
upsert.run(key, value);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
runBatch();
|
|
62
|
+
this.auditLogRepo.create({
|
|
63
|
+
userId: req.user.sub,
|
|
64
|
+
action: 'settings_update',
|
|
65
|
+
resource: 'settings',
|
|
66
|
+
detail: `Updated settings: ${Object.keys(body).join(', ')}`,
|
|
67
|
+
});
|
|
68
|
+
return this.getSettings();
|
|
69
|
+
}
|
|
70
|
+
};
|
|
71
|
+
exports.AdminSettingsController = AdminSettingsController;
|
|
72
|
+
__decorate([
|
|
73
|
+
(0, common_1.Get)(),
|
|
74
|
+
__metadata("design:type", Function),
|
|
75
|
+
__metadata("design:paramtypes", []),
|
|
76
|
+
__metadata("design:returntype", void 0)
|
|
77
|
+
], AdminSettingsController.prototype, "getSettings", null);
|
|
78
|
+
__decorate([
|
|
79
|
+
(0, common_1.Put)(),
|
|
80
|
+
__param(0, (0, common_1.Body)()),
|
|
81
|
+
__param(1, (0, common_1.Req)()),
|
|
82
|
+
__metadata("design:type", Function),
|
|
83
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
84
|
+
__metadata("design:returntype", void 0)
|
|
85
|
+
], AdminSettingsController.prototype, "updateSettings", null);
|
|
86
|
+
exports.AdminSettingsController = AdminSettingsController = __decorate([
|
|
87
|
+
(0, common_1.Controller)('api/admin/settings'),
|
|
88
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
89
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
90
|
+
__metadata("design:paramtypes", [database_service_1.DatabaseService,
|
|
91
|
+
audit_log_repository_1.AuditLogRepository])
|
|
92
|
+
], AdminSettingsController);
|
|
93
|
+
//# sourceMappingURL=admin-settings.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-settings.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-settings.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { GenerateWorkerTokenRequest, GenerateWorkerTokenResponse } from '@overlordai/protocol';
|
|
2
|
+
import { WorkerTokenRepository } from '../../database/repositories/worker-token.repository';
|
|
3
|
+
import { MachineRepository } from '../../database/repositories/machine.repository';
|
|
4
|
+
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
|
+
import { CryptoService } from '../../common/crypto.service';
|
|
6
|
+
interface AuthenticatedRequest {
|
|
7
|
+
user: {
|
|
8
|
+
sub: number;
|
|
9
|
+
name: string;
|
|
10
|
+
role: string;
|
|
11
|
+
};
|
|
12
|
+
}
|
|
13
|
+
export declare class AdminTokenController {
|
|
14
|
+
private readonly workerTokenRepo;
|
|
15
|
+
private readonly machineRepo;
|
|
16
|
+
private readonly auditLogRepo;
|
|
17
|
+
private readonly cryptoService;
|
|
18
|
+
constructor(workerTokenRepo: WorkerTokenRepository, machineRepo: MachineRepository, auditLogRepo: AuditLogRepository, cryptoService: CryptoService);
|
|
19
|
+
listTokens(): {
|
|
20
|
+
id: number;
|
|
21
|
+
label: string;
|
|
22
|
+
createdBy: number;
|
|
23
|
+
status: import("@overlordai/protocol").TokenStatus;
|
|
24
|
+
purpose: import("@overlordai/protocol").TokenPurpose;
|
|
25
|
+
usedAt: string | null;
|
|
26
|
+
expiresAt: string | null;
|
|
27
|
+
revokedAt: string | null;
|
|
28
|
+
createdAt: string;
|
|
29
|
+
}[];
|
|
30
|
+
generateToken(body: GenerateWorkerTokenRequest, req: AuthenticatedRequest): Promise<GenerateWorkerTokenResponse>;
|
|
31
|
+
revokeToken(id: number, req: AuthenticatedRequest): {
|
|
32
|
+
success: boolean;
|
|
33
|
+
};
|
|
34
|
+
getTokenStatus(id: number): {
|
|
35
|
+
id: number;
|
|
36
|
+
status: import("@overlordai/protocol").TokenStatus;
|
|
37
|
+
used: boolean;
|
|
38
|
+
usedAt: string | null;
|
|
39
|
+
revokedAt: string | null;
|
|
40
|
+
machineName: string | null;
|
|
41
|
+
machineId: string | null;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export {};
|
|
45
|
+
//# sourceMappingURL=admin-token.controller.d.ts.map
|
|
@@ -0,0 +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,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AACnF,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AACtF,OAAO,EAAE,aAAa,EAAE,MAAM,6BAA6B,CAAC;AAE5D,UAAU,oBAAoB;IAC5B,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CACnD;AAED,qBAGa,oBAAoB;IAE7B,OAAO,CAAC,QAAQ,CAAC,eAAe;IAChC,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAHb,eAAe,EAAE,qBAAqB,EACtC,WAAW,EAAE,iBAAiB,EAC9B,YAAY,EAAE,kBAAkB,EAChC,aAAa,EAAE,aAAa;IAI/C,UAAU;;;;;;;;;;;IAiBJ,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"}
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
19
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
20
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
21
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
22
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
23
|
+
};
|
|
24
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
25
|
+
var ownKeys = function(o) {
|
|
26
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
27
|
+
var ar = [];
|
|
28
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
29
|
+
return ar;
|
|
30
|
+
};
|
|
31
|
+
return ownKeys(o);
|
|
32
|
+
};
|
|
33
|
+
return function (mod) {
|
|
34
|
+
if (mod && mod.__esModule) return mod;
|
|
35
|
+
var result = {};
|
|
36
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
37
|
+
__setModuleDefault(result, mod);
|
|
38
|
+
return result;
|
|
39
|
+
};
|
|
40
|
+
})();
|
|
41
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
42
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
43
|
+
};
|
|
44
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
45
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
46
|
+
};
|
|
47
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
48
|
+
exports.AdminTokenController = void 0;
|
|
49
|
+
const common_1 = require("@nestjs/common");
|
|
50
|
+
const crypto = __importStar(require("node:crypto"));
|
|
51
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
52
|
+
const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
53
|
+
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
54
|
+
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
55
|
+
const worker_token_repository_1 = require("../../database/repositories/worker-token.repository");
|
|
56
|
+
const machine_repository_1 = require("../../database/repositories/machine.repository");
|
|
57
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
58
|
+
const crypto_service_1 = require("../../common/crypto.service");
|
|
59
|
+
let AdminTokenController = class AdminTokenController {
|
|
60
|
+
workerTokenRepo;
|
|
61
|
+
machineRepo;
|
|
62
|
+
auditLogRepo;
|
|
63
|
+
cryptoService;
|
|
64
|
+
constructor(workerTokenRepo, machineRepo, auditLogRepo, cryptoService) {
|
|
65
|
+
this.workerTokenRepo = workerTokenRepo;
|
|
66
|
+
this.machineRepo = machineRepo;
|
|
67
|
+
this.auditLogRepo = auditLogRepo;
|
|
68
|
+
this.cryptoService = cryptoService;
|
|
69
|
+
}
|
|
70
|
+
listTokens() {
|
|
71
|
+
const tokens = this.workerTokenRepo.findAll();
|
|
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
|
+
}));
|
|
84
|
+
}
|
|
85
|
+
async generateToken(body, req) {
|
|
86
|
+
const secret = crypto.randomBytes(32).toString('hex');
|
|
87
|
+
const tokenHash = await this.cryptoService.hashPassword(secret);
|
|
88
|
+
const record = this.workerTokenRepo.create({
|
|
89
|
+
tokenHash,
|
|
90
|
+
label: body.label,
|
|
91
|
+
createdBy: req.user.sub,
|
|
92
|
+
});
|
|
93
|
+
const token = `ovw_${record.id}_${secret}`;
|
|
94
|
+
this.auditLogRepo.create({
|
|
95
|
+
userId: req.user.sub,
|
|
96
|
+
action: 'worker_token_create',
|
|
97
|
+
resource: `worker_token:${record.id}`,
|
|
98
|
+
detail: `Generated worker token '${body.label}'`,
|
|
99
|
+
});
|
|
100
|
+
return { token, tokenId: record.id };
|
|
101
|
+
}
|
|
102
|
+
revokeToken(id, req) {
|
|
103
|
+
const token = this.workerTokenRepo.findById(id);
|
|
104
|
+
if (!token) {
|
|
105
|
+
throw new common_1.NotFoundException(`Worker token #${id} not found`);
|
|
106
|
+
}
|
|
107
|
+
this.workerTokenRepo.revoke(id);
|
|
108
|
+
this.auditLogRepo.create({
|
|
109
|
+
userId: req.user.sub,
|
|
110
|
+
action: 'worker_token_revoke',
|
|
111
|
+
resource: `worker_token:${id}`,
|
|
112
|
+
detail: `Revoked worker token '${token.label}'`,
|
|
113
|
+
});
|
|
114
|
+
return { success: true };
|
|
115
|
+
}
|
|
116
|
+
getTokenStatus(id) {
|
|
117
|
+
const token = this.workerTokenRepo.findById(id);
|
|
118
|
+
if (!token) {
|
|
119
|
+
throw new common_1.NotFoundException(`Worker token #${id} not found`);
|
|
120
|
+
}
|
|
121
|
+
const used = token.usedAt !== null;
|
|
122
|
+
// Look up machine info if the token has been consumed
|
|
123
|
+
let machineName = null;
|
|
124
|
+
let machineId = null;
|
|
125
|
+
if (used) {
|
|
126
|
+
const machine = this.machineRepo.findByTokenId(id);
|
|
127
|
+
if (machine) {
|
|
128
|
+
machineName = machine.name;
|
|
129
|
+
machineId = machine.id;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
return {
|
|
133
|
+
id: token.id,
|
|
134
|
+
status: token.status,
|
|
135
|
+
used,
|
|
136
|
+
usedAt: token.usedAt,
|
|
137
|
+
revokedAt: token.revokedAt,
|
|
138
|
+
machineName,
|
|
139
|
+
machineId,
|
|
140
|
+
};
|
|
141
|
+
}
|
|
142
|
+
};
|
|
143
|
+
exports.AdminTokenController = AdminTokenController;
|
|
144
|
+
__decorate([
|
|
145
|
+
(0, common_1.Get)(),
|
|
146
|
+
__metadata("design:type", Function),
|
|
147
|
+
__metadata("design:paramtypes", []),
|
|
148
|
+
__metadata("design:returntype", void 0)
|
|
149
|
+
], AdminTokenController.prototype, "listTokens", null);
|
|
150
|
+
__decorate([
|
|
151
|
+
(0, common_1.Post)(),
|
|
152
|
+
__param(0, (0, common_1.Body)()),
|
|
153
|
+
__param(1, (0, common_1.Req)()),
|
|
154
|
+
__metadata("design:type", Function),
|
|
155
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
156
|
+
__metadata("design:returntype", Promise)
|
|
157
|
+
], AdminTokenController.prototype, "generateToken", null);
|
|
158
|
+
__decorate([
|
|
159
|
+
(0, common_1.Post)(':id/revoke'),
|
|
160
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
161
|
+
__param(1, (0, common_1.Req)()),
|
|
162
|
+
__metadata("design:type", Function),
|
|
163
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
164
|
+
__metadata("design:returntype", void 0)
|
|
165
|
+
], AdminTokenController.prototype, "revokeToken", null);
|
|
166
|
+
__decorate([
|
|
167
|
+
(0, common_1.Get)(':id/status'),
|
|
168
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
169
|
+
__metadata("design:type", Function),
|
|
170
|
+
__metadata("design:paramtypes", [Number]),
|
|
171
|
+
__metadata("design:returntype", void 0)
|
|
172
|
+
], AdminTokenController.prototype, "getTokenStatus", null);
|
|
173
|
+
exports.AdminTokenController = AdminTokenController = __decorate([
|
|
174
|
+
(0, common_1.Controller)('api/admin/worker-tokens'),
|
|
175
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
176
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
177
|
+
__metadata("design:paramtypes", [worker_token_repository_1.WorkerTokenRepository,
|
|
178
|
+
machine_repository_1.MachineRepository,
|
|
179
|
+
audit_log_repository_1.AuditLogRepository,
|
|
180
|
+
crypto_service_1.CryptoService])
|
|
181
|
+
], AdminTokenController);
|
|
182
|
+
//# sourceMappingURL=admin-token.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
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,16 @@
|
|
|
1
|
+
import { DashboardService } from './dashboard.service';
|
|
2
|
+
import { SearchService } from './search.service';
|
|
3
|
+
export declare class DashboardController {
|
|
4
|
+
private readonly dashboardService;
|
|
5
|
+
private readonly searchService;
|
|
6
|
+
constructor(dashboardService: DashboardService, searchService: SearchService);
|
|
7
|
+
getStats(): import("./dashboard.service").DashboardStats;
|
|
8
|
+
getRecentTasks(limit?: string): import("@overlordai/protocol").Task[];
|
|
9
|
+
getRecentActivity(limit?: string): {
|
|
10
|
+
id: number;
|
|
11
|
+
timestamp: string;
|
|
12
|
+
message: string;
|
|
13
|
+
}[];
|
|
14
|
+
search(q?: string, limit?: string): import("./search.service").SearchResult;
|
|
15
|
+
}
|
|
16
|
+
//# sourceMappingURL=dashboard.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dashboard.controller.d.ts","sourceRoot":"","sources":["../../src/web/dashboard.controller.ts"],"names":[],"mappings":"AAOA,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEjD,qBAEa,mBAAmB;IAE5B,OAAO,CAAC,QAAQ,CAAC,gBAAgB;IACjC,OAAO,CAAC,QAAQ,CAAC,aAAa;gBADb,gBAAgB,EAAE,gBAAgB,EAClC,aAAa,EAAE,aAAa;IAI/C,QAAQ;IAKR,cAAc,CAAiB,KAAK,CAAC,EAAE,MAAM;IAM7C,iBAAiB,CAAiB,KAAK,CAAC,EAAE,MAAM;;;;;IAMhD,MAAM,CACQ,CAAC,CAAC,EAAE,MAAM,EACN,KAAK,CAAC,EAAE,MAAM;CAKjC"}
|