@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,193 @@
|
|
|
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.AdminBotController = 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 bot_repository_1 = require("../../database/repositories/bot.repository");
|
|
22
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
23
|
+
const crypto_service_1 = require("../../common/crypto.service");
|
|
24
|
+
let AdminBotController = class AdminBotController {
|
|
25
|
+
botRepo;
|
|
26
|
+
auditLogRepo;
|
|
27
|
+
cryptoService;
|
|
28
|
+
constructor(botRepo, auditLogRepo, cryptoService) {
|
|
29
|
+
this.botRepo = botRepo;
|
|
30
|
+
this.auditLogRepo = auditLogRepo;
|
|
31
|
+
this.cryptoService = cryptoService;
|
|
32
|
+
}
|
|
33
|
+
listBots() {
|
|
34
|
+
const bots = this.botRepo.findAll();
|
|
35
|
+
// Strip appSecret from response
|
|
36
|
+
return bots.map((b) => ({
|
|
37
|
+
id: b.id,
|
|
38
|
+
platform: b.platform,
|
|
39
|
+
appId: b.appId,
|
|
40
|
+
name: b.name,
|
|
41
|
+
status: b.status,
|
|
42
|
+
createdAt: b.createdAt,
|
|
43
|
+
}));
|
|
44
|
+
}
|
|
45
|
+
createBot(body, req) {
|
|
46
|
+
// Encrypt appSecret before storage
|
|
47
|
+
const encryptedSecret = this.cryptoService.encryptAes(body.appSecret);
|
|
48
|
+
const bot = this.botRepo.create({
|
|
49
|
+
platform: body.platform,
|
|
50
|
+
appId: body.appId,
|
|
51
|
+
appSecret: encryptedSecret,
|
|
52
|
+
webhookToken: body.webhookToken,
|
|
53
|
+
name: body.name,
|
|
54
|
+
});
|
|
55
|
+
this.auditLogRepo.create({
|
|
56
|
+
userId: req.user.sub,
|
|
57
|
+
action: 'bot_create',
|
|
58
|
+
resource: `bot:${bot.id}`,
|
|
59
|
+
detail: `Created bot '${bot.name}' for platform '${bot.platform}'`,
|
|
60
|
+
});
|
|
61
|
+
return {
|
|
62
|
+
id: bot.id,
|
|
63
|
+
platform: bot.platform,
|
|
64
|
+
appId: bot.appId,
|
|
65
|
+
name: bot.name,
|
|
66
|
+
status: bot.status,
|
|
67
|
+
createdAt: bot.createdAt,
|
|
68
|
+
};
|
|
69
|
+
}
|
|
70
|
+
listAllBindings() {
|
|
71
|
+
return this.botRepo.findAllBindings();
|
|
72
|
+
}
|
|
73
|
+
listBindings(id) {
|
|
74
|
+
const bot = this.botRepo.findById(id);
|
|
75
|
+
if (!bot) {
|
|
76
|
+
throw new common_1.NotFoundException(`Bot #${id} not found`);
|
|
77
|
+
}
|
|
78
|
+
return this.botRepo.findBindingsByBotId(id);
|
|
79
|
+
}
|
|
80
|
+
createBinding(id, body, req) {
|
|
81
|
+
const bot = this.botRepo.findById(id);
|
|
82
|
+
if (!bot) {
|
|
83
|
+
throw new common_1.NotFoundException(`Bot #${id} not found`);
|
|
84
|
+
}
|
|
85
|
+
const binding = this.botRepo.createBinding({
|
|
86
|
+
botInstanceId: id,
|
|
87
|
+
platformChatId: body.platformChatId,
|
|
88
|
+
projectKey: body.projectKey,
|
|
89
|
+
chatName: body.chatName,
|
|
90
|
+
});
|
|
91
|
+
this.auditLogRepo.create({
|
|
92
|
+
userId: req.user.sub,
|
|
93
|
+
action: 'bot_binding_create',
|
|
94
|
+
resource: `bot:${id}`,
|
|
95
|
+
detail: `Created binding for chat '${body.platformChatId}'`,
|
|
96
|
+
});
|
|
97
|
+
return binding;
|
|
98
|
+
}
|
|
99
|
+
deleteBot(id, req) {
|
|
100
|
+
const bot = this.botRepo.findById(id);
|
|
101
|
+
if (!bot) {
|
|
102
|
+
throw new common_1.NotFoundException(`Bot #${id} not found`);
|
|
103
|
+
}
|
|
104
|
+
this.botRepo.deleteBot(id);
|
|
105
|
+
this.auditLogRepo.create({
|
|
106
|
+
userId: req.user.sub,
|
|
107
|
+
action: 'bot_delete',
|
|
108
|
+
resource: `bot:${id}`,
|
|
109
|
+
detail: `Deleted bot '${bot.name}' and its bindings`,
|
|
110
|
+
});
|
|
111
|
+
return { success: true };
|
|
112
|
+
}
|
|
113
|
+
deleteBinding(id, body, req) {
|
|
114
|
+
const bot = this.botRepo.findById(id);
|
|
115
|
+
if (!bot) {
|
|
116
|
+
throw new common_1.NotFoundException(`Bot #${id} not found`);
|
|
117
|
+
}
|
|
118
|
+
const deleted = this.botRepo.deleteBinding(body.platformChatId);
|
|
119
|
+
if (!deleted) {
|
|
120
|
+
throw new common_1.NotFoundException('Binding not found');
|
|
121
|
+
}
|
|
122
|
+
this.auditLogRepo.create({
|
|
123
|
+
userId: req.user.sub,
|
|
124
|
+
action: 'bot_binding_delete',
|
|
125
|
+
resource: `bot:${id}`,
|
|
126
|
+
detail: `Deleted binding for chat '${body.platformChatId}'`,
|
|
127
|
+
});
|
|
128
|
+
return { success: true };
|
|
129
|
+
}
|
|
130
|
+
};
|
|
131
|
+
exports.AdminBotController = AdminBotController;
|
|
132
|
+
__decorate([
|
|
133
|
+
(0, common_1.Get)(),
|
|
134
|
+
__metadata("design:type", Function),
|
|
135
|
+
__metadata("design:paramtypes", []),
|
|
136
|
+
__metadata("design:returntype", void 0)
|
|
137
|
+
], AdminBotController.prototype, "listBots", null);
|
|
138
|
+
__decorate([
|
|
139
|
+
(0, common_1.Post)(),
|
|
140
|
+
__param(0, (0, common_1.Body)()),
|
|
141
|
+
__param(1, (0, common_1.Req)()),
|
|
142
|
+
__metadata("design:type", Function),
|
|
143
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
144
|
+
__metadata("design:returntype", void 0)
|
|
145
|
+
], AdminBotController.prototype, "createBot", null);
|
|
146
|
+
__decorate([
|
|
147
|
+
(0, common_1.Get)('all-bindings'),
|
|
148
|
+
__metadata("design:type", Function),
|
|
149
|
+
__metadata("design:paramtypes", []),
|
|
150
|
+
__metadata("design:returntype", void 0)
|
|
151
|
+
], AdminBotController.prototype, "listAllBindings", null);
|
|
152
|
+
__decorate([
|
|
153
|
+
(0, common_1.Get)(':id/bindings'),
|
|
154
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
155
|
+
__metadata("design:type", Function),
|
|
156
|
+
__metadata("design:paramtypes", [Number]),
|
|
157
|
+
__metadata("design:returntype", void 0)
|
|
158
|
+
], AdminBotController.prototype, "listBindings", null);
|
|
159
|
+
__decorate([
|
|
160
|
+
(0, common_1.Post)(':id/bindings'),
|
|
161
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
162
|
+
__param(1, (0, common_1.Body)()),
|
|
163
|
+
__param(2, (0, common_1.Req)()),
|
|
164
|
+
__metadata("design:type", Function),
|
|
165
|
+
__metadata("design:paramtypes", [Number, Object, Object]),
|
|
166
|
+
__metadata("design:returntype", void 0)
|
|
167
|
+
], AdminBotController.prototype, "createBinding", null);
|
|
168
|
+
__decorate([
|
|
169
|
+
(0, common_1.Delete)(':id'),
|
|
170
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
171
|
+
__param(1, (0, common_1.Req)()),
|
|
172
|
+
__metadata("design:type", Function),
|
|
173
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
174
|
+
__metadata("design:returntype", void 0)
|
|
175
|
+
], AdminBotController.prototype, "deleteBot", null);
|
|
176
|
+
__decorate([
|
|
177
|
+
(0, common_1.Delete)(':id/bindings'),
|
|
178
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
179
|
+
__param(1, (0, common_1.Body)()),
|
|
180
|
+
__param(2, (0, common_1.Req)()),
|
|
181
|
+
__metadata("design:type", Function),
|
|
182
|
+
__metadata("design:paramtypes", [Number, Object, Object]),
|
|
183
|
+
__metadata("design:returntype", void 0)
|
|
184
|
+
], AdminBotController.prototype, "deleteBinding", null);
|
|
185
|
+
exports.AdminBotController = AdminBotController = __decorate([
|
|
186
|
+
(0, common_1.Controller)('api/admin/bots'),
|
|
187
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
188
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
189
|
+
__metadata("design:paramtypes", [bot_repository_1.BotRepository,
|
|
190
|
+
audit_log_repository_1.AuditLogRepository,
|
|
191
|
+
crypto_service_1.CryptoService])
|
|
192
|
+
], AdminBotController);
|
|
193
|
+
//# sourceMappingURL=admin-bot.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-bot.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-bot.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { DeveloperRole } from '@overlordai/protocol';
|
|
2
|
+
import type { CreateDeveloperRequest } from '@overlordai/protocol';
|
|
3
|
+
import { DeveloperRepository } from '../../database/repositories/developer.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 AdminDeveloperController {
|
|
14
|
+
private readonly developerRepo;
|
|
15
|
+
private readonly auditLogRepo;
|
|
16
|
+
private readonly cryptoService;
|
|
17
|
+
constructor(developerRepo: DeveloperRepository, auditLogRepo: AuditLogRepository, cryptoService: CryptoService);
|
|
18
|
+
listDevelopers(): {
|
|
19
|
+
id: number;
|
|
20
|
+
name: string;
|
|
21
|
+
gitName: string;
|
|
22
|
+
gitEmail: string;
|
|
23
|
+
role: DeveloperRole;
|
|
24
|
+
status: string;
|
|
25
|
+
totpEnabled: boolean;
|
|
26
|
+
createdAt: string;
|
|
27
|
+
}[];
|
|
28
|
+
createDeveloper(body: CreateDeveloperRequest, req: AuthenticatedRequest): Promise<{
|
|
29
|
+
id: number;
|
|
30
|
+
name: string;
|
|
31
|
+
gitName: string;
|
|
32
|
+
gitEmail: string;
|
|
33
|
+
role: DeveloperRole;
|
|
34
|
+
status: string;
|
|
35
|
+
createdAt: string;
|
|
36
|
+
}>;
|
|
37
|
+
updateDeveloper(id: number, body: Record<string, unknown>, req: AuthenticatedRequest): {
|
|
38
|
+
id: number;
|
|
39
|
+
name: string;
|
|
40
|
+
gitName: string;
|
|
41
|
+
gitEmail: string;
|
|
42
|
+
role: DeveloperRole;
|
|
43
|
+
status: string;
|
|
44
|
+
totpEnabled: boolean;
|
|
45
|
+
createdAt: string;
|
|
46
|
+
};
|
|
47
|
+
resetTotp(id: number, req: AuthenticatedRequest): {
|
|
48
|
+
success: boolean;
|
|
49
|
+
};
|
|
50
|
+
}
|
|
51
|
+
export {};
|
|
52
|
+
//# sourceMappingURL=admin-developer.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-developer.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-developer.controller.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AACrD,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,sBAAsB,CAAC;AAInE,OAAO,EAAE,mBAAmB,EAAE,MAAM,kDAAkD,CAAC;AACvF,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,wBAAwB;IAEjC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,YAAY;IAC7B,OAAO,CAAC,QAAQ,CAAC,aAAa;gBAFb,aAAa,EAAE,mBAAmB,EAClC,YAAY,EAAE,kBAAkB,EAChC,aAAa,EAAE,aAAa;IAI/C,cAAc;;;;;;;;;;IAgBR,eAAe,CACX,IAAI,EAAE,sBAAsB,EAC7B,GAAG,EAAE,oBAAoB;;;;;;;;;IA8BlC,eAAe,CACc,EAAE,EAAE,MAAM,EAC7B,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAC9B,GAAG,EAAE,oBAAoB;;;;;;;;;;IAmClC,SAAS,CACoB,EAAE,EAAE,MAAM,EAC9B,GAAG,EAAE,oBAAoB;;;CAsBnC"}
|
|
@@ -0,0 +1,160 @@
|
|
|
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.AdminDeveloperController = 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 developer_repository_1 = require("../../database/repositories/developer.repository");
|
|
22
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
23
|
+
const crypto_service_1 = require("../../common/crypto.service");
|
|
24
|
+
let AdminDeveloperController = class AdminDeveloperController {
|
|
25
|
+
developerRepo;
|
|
26
|
+
auditLogRepo;
|
|
27
|
+
cryptoService;
|
|
28
|
+
constructor(developerRepo, auditLogRepo, cryptoService) {
|
|
29
|
+
this.developerRepo = developerRepo;
|
|
30
|
+
this.auditLogRepo = auditLogRepo;
|
|
31
|
+
this.cryptoService = cryptoService;
|
|
32
|
+
}
|
|
33
|
+
listDevelopers() {
|
|
34
|
+
const developers = this.developerRepo.findAll();
|
|
35
|
+
// Strip sensitive fields
|
|
36
|
+
return developers.map((d) => ({
|
|
37
|
+
id: d.id,
|
|
38
|
+
name: d.name,
|
|
39
|
+
gitName: d.gitName,
|
|
40
|
+
gitEmail: d.gitEmail,
|
|
41
|
+
role: d.role,
|
|
42
|
+
status: d.status,
|
|
43
|
+
totpEnabled: !!d.totpSecret,
|
|
44
|
+
createdAt: d.createdAt,
|
|
45
|
+
}));
|
|
46
|
+
}
|
|
47
|
+
async createDeveloper(body, req) {
|
|
48
|
+
const passwordHash = await this.cryptoService.hashPassword(body.password);
|
|
49
|
+
const developer = this.developerRepo.create({
|
|
50
|
+
name: body.name,
|
|
51
|
+
gitName: body.gitName,
|
|
52
|
+
gitEmail: body.gitEmail,
|
|
53
|
+
passwordHash,
|
|
54
|
+
role: body.role,
|
|
55
|
+
});
|
|
56
|
+
this.auditLogRepo.create({
|
|
57
|
+
userId: req.user.sub,
|
|
58
|
+
action: 'developer_create',
|
|
59
|
+
resource: `developer:${developer.id}`,
|
|
60
|
+
detail: `Created developer '${developer.name}' with role '${developer.role}'`,
|
|
61
|
+
});
|
|
62
|
+
return {
|
|
63
|
+
id: developer.id,
|
|
64
|
+
name: developer.name,
|
|
65
|
+
gitName: developer.gitName,
|
|
66
|
+
gitEmail: developer.gitEmail,
|
|
67
|
+
role: developer.role,
|
|
68
|
+
status: developer.status,
|
|
69
|
+
createdAt: developer.createdAt,
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
updateDeveloper(id, body, req) {
|
|
73
|
+
const developer = this.developerRepo.findById(id);
|
|
74
|
+
if (!developer) {
|
|
75
|
+
throw new common_1.NotFoundException(`Developer #${id} not found`);
|
|
76
|
+
}
|
|
77
|
+
const allowed = ['name', 'role', 'status', 'gitName', 'gitEmail'];
|
|
78
|
+
const sanitized = {};
|
|
79
|
+
for (const key of allowed) {
|
|
80
|
+
if (key in body)
|
|
81
|
+
sanitized[key] = body[key];
|
|
82
|
+
}
|
|
83
|
+
this.developerRepo.update(id, sanitized);
|
|
84
|
+
this.auditLogRepo.create({
|
|
85
|
+
userId: req.user.sub,
|
|
86
|
+
action: 'developer_update',
|
|
87
|
+
resource: `developer:${id}`,
|
|
88
|
+
detail: `Updated developer #${id}`,
|
|
89
|
+
});
|
|
90
|
+
const updated = this.developerRepo.findById(id);
|
|
91
|
+
return {
|
|
92
|
+
id: updated.id,
|
|
93
|
+
name: updated.name,
|
|
94
|
+
gitName: updated.gitName,
|
|
95
|
+
gitEmail: updated.gitEmail,
|
|
96
|
+
role: updated.role,
|
|
97
|
+
status: updated.status,
|
|
98
|
+
totpEnabled: !!updated.totpSecret,
|
|
99
|
+
createdAt: updated.createdAt,
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
resetTotp(id, req) {
|
|
103
|
+
if (id === req.user.sub) {
|
|
104
|
+
throw new common_1.BadRequestException('Cannot reset your own TOTP');
|
|
105
|
+
}
|
|
106
|
+
const developer = this.developerRepo.findById(id);
|
|
107
|
+
if (!developer) {
|
|
108
|
+
throw new common_1.NotFoundException(`Developer #${id} not found`);
|
|
109
|
+
}
|
|
110
|
+
this.developerRepo.update(id, { totpSecret: null });
|
|
111
|
+
this.auditLogRepo.create({
|
|
112
|
+
userId: req.user.sub,
|
|
113
|
+
action: 'reset_totp',
|
|
114
|
+
resource: `developer:${id}`,
|
|
115
|
+
detail: `Reset TOTP for developer '${developer.name}'`,
|
|
116
|
+
});
|
|
117
|
+
return { success: true };
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
exports.AdminDeveloperController = AdminDeveloperController;
|
|
121
|
+
__decorate([
|
|
122
|
+
(0, common_1.Get)(),
|
|
123
|
+
__metadata("design:type", Function),
|
|
124
|
+
__metadata("design:paramtypes", []),
|
|
125
|
+
__metadata("design:returntype", void 0)
|
|
126
|
+
], AdminDeveloperController.prototype, "listDevelopers", null);
|
|
127
|
+
__decorate([
|
|
128
|
+
(0, common_1.Post)(),
|
|
129
|
+
__param(0, (0, common_1.Body)()),
|
|
130
|
+
__param(1, (0, common_1.Req)()),
|
|
131
|
+
__metadata("design:type", Function),
|
|
132
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
133
|
+
__metadata("design:returntype", Promise)
|
|
134
|
+
], AdminDeveloperController.prototype, "createDeveloper", null);
|
|
135
|
+
__decorate([
|
|
136
|
+
(0, common_1.Put)(':id'),
|
|
137
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
138
|
+
__param(1, (0, common_1.Body)()),
|
|
139
|
+
__param(2, (0, common_1.Req)()),
|
|
140
|
+
__metadata("design:type", Function),
|
|
141
|
+
__metadata("design:paramtypes", [Number, Object, Object]),
|
|
142
|
+
__metadata("design:returntype", void 0)
|
|
143
|
+
], AdminDeveloperController.prototype, "updateDeveloper", null);
|
|
144
|
+
__decorate([
|
|
145
|
+
(0, common_1.Put)(':id/reset-totp'),
|
|
146
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
147
|
+
__param(1, (0, common_1.Req)()),
|
|
148
|
+
__metadata("design:type", Function),
|
|
149
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
150
|
+
__metadata("design:returntype", void 0)
|
|
151
|
+
], AdminDeveloperController.prototype, "resetTotp", null);
|
|
152
|
+
exports.AdminDeveloperController = AdminDeveloperController = __decorate([
|
|
153
|
+
(0, common_1.Controller)('api/admin/developers'),
|
|
154
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
155
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
156
|
+
__metadata("design:paramtypes", [developer_repository_1.DeveloperRepository,
|
|
157
|
+
audit_log_repository_1.AuditLogRepository,
|
|
158
|
+
crypto_service_1.CryptoService])
|
|
159
|
+
], AdminDeveloperController);
|
|
160
|
+
//# sourceMappingURL=admin-developer.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-developer.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-developer.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { MachineStatus } from '@overlordai/protocol';
|
|
2
|
+
import { MachineRepository } from '../../database/repositories/machine.repository';
|
|
3
|
+
import { TaskRepository } from '../../database/repositories/task.repository';
|
|
4
|
+
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
|
+
interface AuthenticatedRequest {
|
|
6
|
+
user: {
|
|
7
|
+
sub: number;
|
|
8
|
+
name: string;
|
|
9
|
+
role: string;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export declare class AdminMachineController {
|
|
13
|
+
private readonly machineRepo;
|
|
14
|
+
private readonly taskRepo;
|
|
15
|
+
private readonly auditLogRepo;
|
|
16
|
+
private readonly logger;
|
|
17
|
+
constructor(machineRepo: MachineRepository, taskRepo: TaskRepository, auditLogRepo: AuditLogRepository);
|
|
18
|
+
listMachines(): {
|
|
19
|
+
id: string;
|
|
20
|
+
name: string;
|
|
21
|
+
host: string;
|
|
22
|
+
port: number;
|
|
23
|
+
tokenId: number;
|
|
24
|
+
os: string | null;
|
|
25
|
+
cpuCores: number | null;
|
|
26
|
+
memoryGb: number | null;
|
|
27
|
+
maxSlots: number;
|
|
28
|
+
activeSlots: number;
|
|
29
|
+
cpuUsage: number;
|
|
30
|
+
memoryUsage: number;
|
|
31
|
+
diskUsage: number;
|
|
32
|
+
loadThreshold: number;
|
|
33
|
+
tags: string[];
|
|
34
|
+
capabilities: string[];
|
|
35
|
+
protocolVersion: string;
|
|
36
|
+
lastHeartbeat: string | null;
|
|
37
|
+
status: MachineStatus;
|
|
38
|
+
}[];
|
|
39
|
+
updateMachine(id: string, body: {
|
|
40
|
+
status?: MachineStatus;
|
|
41
|
+
}, req: AuthenticatedRequest): {
|
|
42
|
+
id: string;
|
|
43
|
+
name: string;
|
|
44
|
+
host: string;
|
|
45
|
+
port: number;
|
|
46
|
+
tokenId: number;
|
|
47
|
+
os: string | null;
|
|
48
|
+
cpuCores: number | null;
|
|
49
|
+
memoryGb: number | null;
|
|
50
|
+
maxSlots: number;
|
|
51
|
+
activeSlots: number;
|
|
52
|
+
cpuUsage: number;
|
|
53
|
+
memoryUsage: number;
|
|
54
|
+
diskUsage: number;
|
|
55
|
+
loadThreshold: number;
|
|
56
|
+
tags: string[];
|
|
57
|
+
capabilities: string[];
|
|
58
|
+
protocolVersion: string;
|
|
59
|
+
lastHeartbeat: string | null;
|
|
60
|
+
status: MachineStatus;
|
|
61
|
+
};
|
|
62
|
+
}
|
|
63
|
+
export {};
|
|
64
|
+
//# sourceMappingURL=admin-machine.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-machine.controller.d.ts","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":"AAYA,OAAO,EAAiB,aAAa,EAAc,MAAM,sBAAsB,CAAC;AAKhF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gDAAgD,CAAC;AACnF,OAAO,EAAE,cAAc,EAAE,MAAM,6CAA6C,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,kDAAkD,CAAC;AAOtF,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;IAI/B,OAAO,CAAC,QAAQ,CAAC,WAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,QAAQ;IACzB,OAAO,CAAC,QAAQ,CAAC,YAAY;IAL/B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA2C;gBAG/C,WAAW,EAAE,iBAAiB,EAC9B,QAAQ,EAAE,cAAc,EACxB,YAAY,EAAE,kBAAkB;IAInD,YAAY;;;;;;;;;;;;;;;;;;;;;IAKZ,aAAa,CACE,EAAE,EAAE,MAAM,EACf,IAAI,EAAE;QAAE,MAAM,CAAC,EAAE,aAAa,CAAA;KAAE,EACjC,GAAG,EAAE,oBAAoB;;;;;;;;;;;;;;;;;;;;;CAqDnC"}
|
|
@@ -0,0 +1,111 @@
|
|
|
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
|
+
var AdminMachineController_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.AdminMachineController = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
19
|
+
const jwt_auth_guard_1 = require("../../auth/guards/jwt-auth.guard");
|
|
20
|
+
const roles_guard_1 = require("../../auth/guards/roles.guard");
|
|
21
|
+
const roles_decorator_1 = require("../../auth/decorators/roles.decorator");
|
|
22
|
+
const machine_repository_1 = require("../../database/repositories/machine.repository");
|
|
23
|
+
const task_repository_1 = require("../../database/repositories/task.repository");
|
|
24
|
+
const audit_log_repository_1 = require("../../database/repositories/audit-log.repository");
|
|
25
|
+
function stripMachineSecrets(machine) {
|
|
26
|
+
const { recoverySecretHash, ...safe } = machine;
|
|
27
|
+
return safe;
|
|
28
|
+
}
|
|
29
|
+
let AdminMachineController = AdminMachineController_1 = class AdminMachineController {
|
|
30
|
+
machineRepo;
|
|
31
|
+
taskRepo;
|
|
32
|
+
auditLogRepo;
|
|
33
|
+
logger = new common_1.Logger(AdminMachineController_1.name);
|
|
34
|
+
constructor(machineRepo, taskRepo, auditLogRepo) {
|
|
35
|
+
this.machineRepo = machineRepo;
|
|
36
|
+
this.taskRepo = taskRepo;
|
|
37
|
+
this.auditLogRepo = auditLogRepo;
|
|
38
|
+
}
|
|
39
|
+
listMachines() {
|
|
40
|
+
return this.machineRepo.findAll().map(stripMachineSecrets);
|
|
41
|
+
}
|
|
42
|
+
updateMachine(id, body, req) {
|
|
43
|
+
const machine = this.machineRepo.findById(id);
|
|
44
|
+
if (!machine) {
|
|
45
|
+
throw new common_1.NotFoundException(`Machine '${id}' not found`);
|
|
46
|
+
}
|
|
47
|
+
const validStatuses = ['online', 'offline', 'draining'];
|
|
48
|
+
if (body.status && !validStatuses.includes(body.status)) {
|
|
49
|
+
throw new common_1.BadRequestException(`Invalid status. Must be one of: ${validStatuses.join(', ')}`);
|
|
50
|
+
}
|
|
51
|
+
if (body.status) {
|
|
52
|
+
this.machineRepo.updateStatus(id, body.status);
|
|
53
|
+
// When forcing a machine offline, reconcile its active tasks
|
|
54
|
+
if (body.status === 'offline') {
|
|
55
|
+
const activeTasks = this.taskRepo.findByMachineId(id, [
|
|
56
|
+
protocol_1.TaskStatus.ASSIGNED,
|
|
57
|
+
protocol_1.TaskStatus.RUNNING,
|
|
58
|
+
]);
|
|
59
|
+
for (const task of activeTasks) {
|
|
60
|
+
if (task.status === protocol_1.TaskStatus.ASSIGNED) {
|
|
61
|
+
// ASSIGNED tasks can be re-queued for another machine
|
|
62
|
+
this.taskRepo.updateStatus(task.id, protocol_1.TaskStatus.QUEUED, task.revision, {
|
|
63
|
+
machineId: null,
|
|
64
|
+
});
|
|
65
|
+
this.logger.warn(`Task #${task.id} re-queued: machine '${machine.name}' forced offline`);
|
|
66
|
+
}
|
|
67
|
+
else if (task.status === protocol_1.TaskStatus.RUNNING) {
|
|
68
|
+
// RUNNING tasks must be failed — their state is indeterminate
|
|
69
|
+
this.taskRepo.updateStatus(task.id, protocol_1.TaskStatus.FAILED, task.revision, {
|
|
70
|
+
errorMessage: `Machine '${machine.name}' forced offline by administrator`,
|
|
71
|
+
completedAt: new Date().toISOString(),
|
|
72
|
+
});
|
|
73
|
+
this.logger.warn(`Task #${task.id} marked FAILED: machine '${machine.name}' forced offline`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
this.auditLogRepo.create({
|
|
79
|
+
userId: req.user.sub,
|
|
80
|
+
action: 'machine_update',
|
|
81
|
+
resource: `machine:${id}`,
|
|
82
|
+
detail: `Updated machine '${machine.name}'`,
|
|
83
|
+
});
|
|
84
|
+
return stripMachineSecrets(this.machineRepo.findById(id));
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
exports.AdminMachineController = AdminMachineController;
|
|
88
|
+
__decorate([
|
|
89
|
+
(0, common_1.Get)(),
|
|
90
|
+
__metadata("design:type", Function),
|
|
91
|
+
__metadata("design:paramtypes", []),
|
|
92
|
+
__metadata("design:returntype", void 0)
|
|
93
|
+
], AdminMachineController.prototype, "listMachines", null);
|
|
94
|
+
__decorate([
|
|
95
|
+
(0, common_1.Put)(':id'),
|
|
96
|
+
__param(0, (0, common_1.Param)('id')),
|
|
97
|
+
__param(1, (0, common_1.Body)()),
|
|
98
|
+
__param(2, (0, common_1.Req)()),
|
|
99
|
+
__metadata("design:type", Function),
|
|
100
|
+
__metadata("design:paramtypes", [String, Object, Object]),
|
|
101
|
+
__metadata("design:returntype", void 0)
|
|
102
|
+
], AdminMachineController.prototype, "updateMachine", null);
|
|
103
|
+
exports.AdminMachineController = AdminMachineController = AdminMachineController_1 = __decorate([
|
|
104
|
+
(0, common_1.Controller)('api/admin/machines'),
|
|
105
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
106
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.ADMIN),
|
|
107
|
+
__metadata("design:paramtypes", [machine_repository_1.MachineRepository,
|
|
108
|
+
task_repository_1.TaskRepository,
|
|
109
|
+
audit_log_repository_1.AuditLogRepository])
|
|
110
|
+
], AdminMachineController);
|
|
111
|
+
//# sourceMappingURL=admin-machine.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-machine.controller.js","sourceRoot":"","sources":["../../../src/web/admin/admin-machine.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
import type { CreateProjectRequest } from '@overlordai/protocol';
|
|
2
|
+
import { ProjectRepository } from '../../database/repositories/project.repository';
|
|
3
|
+
import { ProjectMemberRepository } from '../../database/repositories/project-member.repository';
|
|
4
|
+
import { AuditLogRepository } from '../../database/repositories/audit-log.repository';
|
|
5
|
+
interface AuthenticatedRequest {
|
|
6
|
+
user: {
|
|
7
|
+
sub: number;
|
|
8
|
+
name: string;
|
|
9
|
+
role: string;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export declare class AdminProjectController {
|
|
13
|
+
private readonly projectRepo;
|
|
14
|
+
private readonly projectMemberRepo;
|
|
15
|
+
private readonly auditLogRepo;
|
|
16
|
+
constructor(projectRepo: ProjectRepository, projectMemberRepo: ProjectMemberRepository, auditLogRepo: AuditLogRepository);
|
|
17
|
+
listProjects(): import("@overlordai/protocol").Project[];
|
|
18
|
+
createProject(body: CreateProjectRequest, req: AuthenticatedRequest): import("@overlordai/protocol").Project;
|
|
19
|
+
updateProject(key: string, body: Record<string, unknown>, req: AuthenticatedRequest): import("@overlordai/protocol").Project | null;
|
|
20
|
+
deleteProject(key: string, req: AuthenticatedRequest): {
|
|
21
|
+
success: boolean;
|
|
22
|
+
};
|
|
23
|
+
listMembers(key: string): {
|
|
24
|
+
id: number;
|
|
25
|
+
projectKey: string;
|
|
26
|
+
developerId: number;
|
|
27
|
+
role: string;
|
|
28
|
+
createdAt: string;
|
|
29
|
+
}[];
|
|
30
|
+
addMember(key: string, body: {
|
|
31
|
+
developerId: number;
|
|
32
|
+
role?: string;
|
|
33
|
+
}, req: AuthenticatedRequest): {
|
|
34
|
+
id: number;
|
|
35
|
+
projectKey: string;
|
|
36
|
+
developerId: number;
|
|
37
|
+
role: string;
|
|
38
|
+
createdAt: string;
|
|
39
|
+
};
|
|
40
|
+
removeMember(key: string, developerId: string, req: AuthenticatedRequest): {
|
|
41
|
+
success: boolean;
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
export {};
|
|
45
|
+
//# sourceMappingURL=admin-project.controller.d.ts.map
|