@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,121 @@
|
|
|
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.MachineController = 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 machine_repository_1 = require("../database/repositories/machine.repository");
|
|
22
|
+
const task_repository_1 = require("../database/repositories/task.repository");
|
|
23
|
+
function stripMachineSecrets(machine) {
|
|
24
|
+
const { recoverySecretHash, ...safe } = machine;
|
|
25
|
+
return safe;
|
|
26
|
+
}
|
|
27
|
+
let MachineController = class MachineController {
|
|
28
|
+
machineRepo;
|
|
29
|
+
taskRepo;
|
|
30
|
+
constructor(machineRepo, taskRepo) {
|
|
31
|
+
this.machineRepo = machineRepo;
|
|
32
|
+
this.taskRepo = taskRepo;
|
|
33
|
+
}
|
|
34
|
+
listMachines(status) {
|
|
35
|
+
const machines = this.machineRepo.findAll();
|
|
36
|
+
if (status) {
|
|
37
|
+
return machines.filter((m) => m.status === status).map(stripMachineSecrets);
|
|
38
|
+
}
|
|
39
|
+
return machines.map(stripMachineSecrets);
|
|
40
|
+
}
|
|
41
|
+
getMachine(id) {
|
|
42
|
+
const machine = this.machineRepo.findById(id);
|
|
43
|
+
if (!machine) {
|
|
44
|
+
throw new common_1.NotFoundException(`Machine '${id}' not found`);
|
|
45
|
+
}
|
|
46
|
+
return stripMachineSecrets(machine);
|
|
47
|
+
}
|
|
48
|
+
getMachineTasks(id, req) {
|
|
49
|
+
const machine = this.machineRepo.findById(id);
|
|
50
|
+
if (!machine) {
|
|
51
|
+
throw new common_1.NotFoundException(`Machine '${id}' not found`);
|
|
52
|
+
}
|
|
53
|
+
const tasks = this.taskRepo.findByMachineId(id);
|
|
54
|
+
if (req.user.role !== 'admin') {
|
|
55
|
+
return tasks.filter(t => t.createdBy === req.user.sub);
|
|
56
|
+
}
|
|
57
|
+
return tasks;
|
|
58
|
+
}
|
|
59
|
+
drainMachine(id) {
|
|
60
|
+
const machine = this.machineRepo.findById(id);
|
|
61
|
+
if (!machine) {
|
|
62
|
+
throw new common_1.NotFoundException(`Machine '${id}' not found`);
|
|
63
|
+
}
|
|
64
|
+
this.machineRepo.updateStatus(id, protocol_1.MachineStatus.DRAINING);
|
|
65
|
+
return stripMachineSecrets(this.machineRepo.findById(id));
|
|
66
|
+
}
|
|
67
|
+
undrainMachine(id) {
|
|
68
|
+
const machine = this.machineRepo.findById(id);
|
|
69
|
+
if (!machine) {
|
|
70
|
+
throw new common_1.NotFoundException(`Machine '${id}' not found`);
|
|
71
|
+
}
|
|
72
|
+
this.machineRepo.updateStatus(id, protocol_1.MachineStatus.ONLINE);
|
|
73
|
+
return stripMachineSecrets(this.machineRepo.findById(id));
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
exports.MachineController = MachineController;
|
|
77
|
+
__decorate([
|
|
78
|
+
(0, common_1.Get)(),
|
|
79
|
+
__param(0, (0, common_1.Query)('status')),
|
|
80
|
+
__metadata("design:type", Function),
|
|
81
|
+
__metadata("design:paramtypes", [String]),
|
|
82
|
+
__metadata("design:returntype", void 0)
|
|
83
|
+
], MachineController.prototype, "listMachines", null);
|
|
84
|
+
__decorate([
|
|
85
|
+
(0, common_1.Get)(':id'),
|
|
86
|
+
__param(0, (0, common_1.Param)('id')),
|
|
87
|
+
__metadata("design:type", Function),
|
|
88
|
+
__metadata("design:paramtypes", [String]),
|
|
89
|
+
__metadata("design:returntype", void 0)
|
|
90
|
+
], MachineController.prototype, "getMachine", null);
|
|
91
|
+
__decorate([
|
|
92
|
+
(0, common_1.Get)(':id/tasks'),
|
|
93
|
+
__param(0, (0, common_1.Param)('id')),
|
|
94
|
+
__param(1, (0, common_1.Req)()),
|
|
95
|
+
__metadata("design:type", Function),
|
|
96
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
97
|
+
__metadata("design:returntype", void 0)
|
|
98
|
+
], MachineController.prototype, "getMachineTasks", null);
|
|
99
|
+
__decorate([
|
|
100
|
+
(0, common_1.Post)(':id/drain'),
|
|
101
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.LEAD),
|
|
102
|
+
__param(0, (0, common_1.Param)('id')),
|
|
103
|
+
__metadata("design:type", Function),
|
|
104
|
+
__metadata("design:paramtypes", [String]),
|
|
105
|
+
__metadata("design:returntype", void 0)
|
|
106
|
+
], MachineController.prototype, "drainMachine", null);
|
|
107
|
+
__decorate([
|
|
108
|
+
(0, common_1.Post)(':id/undrain'),
|
|
109
|
+
(0, roles_decorator_1.Roles)(protocol_1.DeveloperRole.LEAD),
|
|
110
|
+
__param(0, (0, common_1.Param)('id')),
|
|
111
|
+
__metadata("design:type", Function),
|
|
112
|
+
__metadata("design:paramtypes", [String]),
|
|
113
|
+
__metadata("design:returntype", void 0)
|
|
114
|
+
], MachineController.prototype, "undrainMachine", null);
|
|
115
|
+
exports.MachineController = MachineController = __decorate([
|
|
116
|
+
(0, common_1.Controller)('api/web/machines'),
|
|
117
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard),
|
|
118
|
+
__metadata("design:paramtypes", [machine_repository_1.MachineRepository,
|
|
119
|
+
task_repository_1.TaskRepository])
|
|
120
|
+
], MachineController);
|
|
121
|
+
//# sourceMappingURL=machine.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"machine.controller.js","sourceRoot":"","sources":["../../src/web/machine.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { NotificationRepository } from '../database/repositories/notification.repository';
|
|
2
|
+
interface AuthenticatedRequest {
|
|
3
|
+
user: {
|
|
4
|
+
sub: number;
|
|
5
|
+
name: string;
|
|
6
|
+
role: string;
|
|
7
|
+
};
|
|
8
|
+
}
|
|
9
|
+
export declare class NotificationController {
|
|
10
|
+
private readonly notificationRepo;
|
|
11
|
+
constructor(notificationRepo: NotificationRepository);
|
|
12
|
+
listNotifications(req: AuthenticatedRequest, limit?: string, cursor?: string): import("@overlordai/protocol").PaginatedResult<import("@overlordai/protocol").NotificationRecord>;
|
|
13
|
+
markAsRead(id: number, req: AuthenticatedRequest): {
|
|
14
|
+
success: boolean;
|
|
15
|
+
};
|
|
16
|
+
markAllRead(req: AuthenticatedRequest): {
|
|
17
|
+
success: boolean;
|
|
18
|
+
count: number;
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
export {};
|
|
22
|
+
//# sourceMappingURL=notification.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notification.controller.d.ts","sourceRoot":"","sources":["../../src/web/notification.controller.ts"],"names":[],"mappings":"AAYA,OAAO,EAAE,sBAAsB,EAAE,MAAM,kDAAkD,CAAC;AAE1F,UAAU,oBAAoB;IAC5B,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CACnD;AAED,qBAEa,sBAAsB;IAE/B,OAAO,CAAC,QAAQ,CAAC,gBAAgB;gBAAhB,gBAAgB,EAAE,sBAAsB;IAI3D,iBAAiB,CACR,GAAG,EAAE,oBAAoB,EAChB,KAAK,CAAC,EAAE,MAAM,EACb,MAAM,CAAC,EAAE,MAAM;IAWlC,UAAU,CACmB,EAAE,EAAE,MAAM,EAC9B,GAAG,EAAE,oBAAoB;;;IAUlC,WAAW,CAAQ,GAAG,EAAE,oBAAoB;;;;CAI7C"}
|
|
@@ -0,0 +1,70 @@
|
|
|
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.NotificationController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
18
|
+
const notification_repository_1 = require("../database/repositories/notification.repository");
|
|
19
|
+
let NotificationController = class NotificationController {
|
|
20
|
+
notificationRepo;
|
|
21
|
+
constructor(notificationRepo) {
|
|
22
|
+
this.notificationRepo = notificationRepo;
|
|
23
|
+
}
|
|
24
|
+
listNotifications(req, limit, cursor) {
|
|
25
|
+
const parsedLimit = Math.min(Math.max(limit ? parseInt(limit, 10) || 20 : 20, 1), 100);
|
|
26
|
+
return this.notificationRepo.findByDeveloper(req.user.sub, parsedLimit, cursor || undefined);
|
|
27
|
+
}
|
|
28
|
+
markAsRead(id, req) {
|
|
29
|
+
const updated = this.notificationRepo.markAsRead(id, req.user.sub);
|
|
30
|
+
if (!updated) {
|
|
31
|
+
throw new common_1.NotFoundException(`Notification #${id} not found`);
|
|
32
|
+
}
|
|
33
|
+
return { success: true };
|
|
34
|
+
}
|
|
35
|
+
markAllRead(req) {
|
|
36
|
+
const count = this.notificationRepo.markAllAsRead(req.user.sub);
|
|
37
|
+
return { success: true, count };
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
exports.NotificationController = NotificationController;
|
|
41
|
+
__decorate([
|
|
42
|
+
(0, common_1.Get)(),
|
|
43
|
+
__param(0, (0, common_1.Req)()),
|
|
44
|
+
__param(1, (0, common_1.Query)('limit')),
|
|
45
|
+
__param(2, (0, common_1.Query)('cursor')),
|
|
46
|
+
__metadata("design:type", Function),
|
|
47
|
+
__metadata("design:paramtypes", [Object, String, String]),
|
|
48
|
+
__metadata("design:returntype", void 0)
|
|
49
|
+
], NotificationController.prototype, "listNotifications", null);
|
|
50
|
+
__decorate([
|
|
51
|
+
(0, common_1.Post)(':id/read'),
|
|
52
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
53
|
+
__param(1, (0, common_1.Req)()),
|
|
54
|
+
__metadata("design:type", Function),
|
|
55
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
56
|
+
__metadata("design:returntype", void 0)
|
|
57
|
+
], NotificationController.prototype, "markAsRead", null);
|
|
58
|
+
__decorate([
|
|
59
|
+
(0, common_1.Post)('read-all'),
|
|
60
|
+
__param(0, (0, common_1.Req)()),
|
|
61
|
+
__metadata("design:type", Function),
|
|
62
|
+
__metadata("design:paramtypes", [Object]),
|
|
63
|
+
__metadata("design:returntype", void 0)
|
|
64
|
+
], NotificationController.prototype, "markAllRead", null);
|
|
65
|
+
exports.NotificationController = NotificationController = __decorate([
|
|
66
|
+
(0, common_1.Controller)('api/web/notifications'),
|
|
67
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard),
|
|
68
|
+
__metadata("design:paramtypes", [notification_repository_1.NotificationRepository])
|
|
69
|
+
], NotificationController);
|
|
70
|
+
//# sourceMappingURL=notification.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"notification.controller.js","sourceRoot":"","sources":["../../src/web/notification.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAUwB;AACxB,kEAA6D;AAC7D,8FAA0F;AAQnF,IAAM,sBAAsB,GAA5B,MAAM,sBAAsB;IAEd;IADnB,YACmB,gBAAwC;QAAxC,qBAAgB,GAAhB,gBAAgB,CAAwB;IACxD,CAAC;IAGJ,iBAAiB,CACR,GAAyB,EAChB,KAAc,EACb,MAAe;QAEhC,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;QACvF,OAAO,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAC1C,GAAG,CAAC,IAAI,CAAC,GAAG,EACZ,WAAW,EACX,MAAM,IAAI,SAAS,CACpB,CAAC;IACJ,CAAC;IAGD,UAAU,CACmB,EAAU,EAC9B,GAAyB;QAEhC,MAAM,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAC,EAAE,EAAE,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACnE,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;QAC/D,CAAC;QACD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IAC3B,CAAC;IAGD,WAAW,CAAQ,GAAyB;QAC1C,MAAM,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAChE,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;IAClC,CAAC;CACF,CAAA;AApCY,wDAAsB;AAMjC;IADC,IAAA,YAAG,GAAE;IAEH,WAAA,IAAA,YAAG,GAAE,CAAA;IACL,WAAA,IAAA,cAAK,EAAC,OAAO,CAAC,CAAA;IACd,WAAA,IAAA,cAAK,EAAC,QAAQ,CAAC,CAAA;;;;+DAQjB;AAGD;IADC,IAAA,aAAI,EAAC,UAAU,CAAC;IAEd,WAAA,IAAA,cAAK,EAAC,IAAI,EAAE,qBAAY,CAAC,CAAA;IACzB,WAAA,IAAA,YAAG,GAAE,CAAA;;;;wDAOP;AAGD;IADC,IAAA,aAAI,EAAC,UAAU,CAAC;IACJ,WAAA,IAAA,YAAG,GAAE,CAAA;;;;yDAGjB;iCAnCU,sBAAsB;IAFlC,IAAA,mBAAU,EAAC,uBAAuB,CAAC;IACnC,IAAA,kBAAS,EAAC,6BAAY,CAAC;qCAGe,gDAAsB;GAFhD,sBAAsB,CAoClC"}
|
|
@@ -0,0 +1,70 @@
|
|
|
1
|
+
import { DeveloperRepository } from '../database/repositories/developer.repository';
|
|
2
|
+
import { DeveloperTokenRepository } from '../database/repositories/developer-token.repository';
|
|
3
|
+
import { CryptoService } from '../common/crypto.service';
|
|
4
|
+
import { RedisService } from '../redis/redis.service';
|
|
5
|
+
interface AuthenticatedRequest {
|
|
6
|
+
user: {
|
|
7
|
+
sub: number;
|
|
8
|
+
name: string;
|
|
9
|
+
role: string;
|
|
10
|
+
};
|
|
11
|
+
}
|
|
12
|
+
export declare class ProfileController {
|
|
13
|
+
private readonly developerRepo;
|
|
14
|
+
private readonly developerTokenRepo;
|
|
15
|
+
private readonly cryptoService;
|
|
16
|
+
private readonly redis;
|
|
17
|
+
constructor(developerRepo: DeveloperRepository, developerTokenRepo: DeveloperTokenRepository, cryptoService: CryptoService, redis: RedisService);
|
|
18
|
+
getProfile(req: AuthenticatedRequest): {
|
|
19
|
+
id: number;
|
|
20
|
+
name: string;
|
|
21
|
+
gitName: string;
|
|
22
|
+
gitEmail: string;
|
|
23
|
+
role: import("@overlordai/protocol").DeveloperRole;
|
|
24
|
+
status: string;
|
|
25
|
+
totpEnabled: boolean;
|
|
26
|
+
createdAt: string;
|
|
27
|
+
};
|
|
28
|
+
updateProfile(req: AuthenticatedRequest, body: {
|
|
29
|
+
gitName?: string;
|
|
30
|
+
gitEmail?: string;
|
|
31
|
+
}): Promise<{
|
|
32
|
+
success: boolean;
|
|
33
|
+
}>;
|
|
34
|
+
updatePassword(req: AuthenticatedRequest, body: {
|
|
35
|
+
currentPassword: string;
|
|
36
|
+
newPassword: string;
|
|
37
|
+
}): Promise<{
|
|
38
|
+
success: boolean;
|
|
39
|
+
}>;
|
|
40
|
+
setupTotp(req: AuthenticatedRequest): Promise<{
|
|
41
|
+
secret: string;
|
|
42
|
+
}>;
|
|
43
|
+
verifyTotp(req: AuthenticatedRequest, body: {
|
|
44
|
+
code: string;
|
|
45
|
+
}): Promise<{
|
|
46
|
+
success: boolean;
|
|
47
|
+
}>;
|
|
48
|
+
listTokens(req: AuthenticatedRequest): {
|
|
49
|
+
id: number;
|
|
50
|
+
label: string;
|
|
51
|
+
status: string;
|
|
52
|
+
lastUsedAt: string | null;
|
|
53
|
+
expiresAt: string | null;
|
|
54
|
+
createdAt: string;
|
|
55
|
+
}[];
|
|
56
|
+
createToken(req: AuthenticatedRequest, body: {
|
|
57
|
+
label: string;
|
|
58
|
+
expiresAt?: string;
|
|
59
|
+
}): Promise<{
|
|
60
|
+
id: number;
|
|
61
|
+
token: string;
|
|
62
|
+
label: string;
|
|
63
|
+
createdAt: string;
|
|
64
|
+
}>;
|
|
65
|
+
revokeToken(id: number, req: AuthenticatedRequest): {
|
|
66
|
+
success: boolean;
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
export {};
|
|
70
|
+
//# sourceMappingURL=profile.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile.controller.d.ts","sourceRoot":"","sources":["../../src/web/profile.controller.ts"],"names":[],"mappings":"AAiBA,OAAO,EAAE,mBAAmB,EAAE,MAAM,+CAA+C,CAAC;AACpF,OAAO,EAAE,wBAAwB,EAAE,MAAM,qDAAqD,CAAC;AAC/F,OAAO,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAC;AAEzD,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,UAAU,oBAAoB;IAC5B,IAAI,EAAE;QAAE,GAAG,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,MAAM,CAAA;KAAE,CAAC;CACnD;AAED,qBAEa,iBAAiB;IAE1B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAHL,aAAa,EAAE,mBAAmB,EAClC,kBAAkB,EAAE,wBAAwB,EAC5C,aAAa,EAAE,aAAa,EAC5B,KAAK,EAAE,YAAY;IAItC,UAAU,CAAQ,GAAG,EAAE,oBAAoB;;;;;;;;;;IAmBrC,aAAa,CACV,GAAG,EAAE,oBAAoB,EACxB,IAAI,EAAE;QAAE,OAAO,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;KAAE;;;IAejD,cAAc,CACX,GAAG,EAAE,oBAAoB,EACxB,IAAI,EAAE;QAAE,eAAe,EAAE,MAAM,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;;;IA+B1D,SAAS,CAAQ,GAAG,EAAE,oBAAoB;;;IAc1C,UAAU,CACP,GAAG,EAAE,oBAAoB,EACxB,IAAI,EAAE;QAAE,IAAI,EAAE,MAAM,CAAA;KAAE;;;IAsBhC,UAAU,CAAQ,GAAG,EAAE,oBAAoB;;;;;;;;IAcrC,WAAW,CACR,GAAG,EAAE,oBAAoB,EACxB,IAAI,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE;;;;;;IAmCrD,WAAW,CACkB,EAAE,EAAE,MAAM,EAC9B,GAAG,EAAE,oBAAoB;;;CAUnC"}
|
|
@@ -0,0 +1,262 @@
|
|
|
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.ProfileController = void 0;
|
|
49
|
+
const common_1 = require("@nestjs/common");
|
|
50
|
+
const crypto = __importStar(require("node:crypto"));
|
|
51
|
+
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
52
|
+
const allow_totp_setup_decorator_1 = require("../auth/decorators/allow-totp-setup.decorator");
|
|
53
|
+
const developer_repository_1 = require("../database/repositories/developer.repository");
|
|
54
|
+
const developer_token_repository_1 = require("../database/repositories/developer-token.repository");
|
|
55
|
+
const crypto_service_1 = require("../common/crypto.service");
|
|
56
|
+
const rate_limit_guard_1 = require("../common/rate-limit.guard");
|
|
57
|
+
const redis_service_1 = require("../redis/redis.service");
|
|
58
|
+
let ProfileController = class ProfileController {
|
|
59
|
+
developerRepo;
|
|
60
|
+
developerTokenRepo;
|
|
61
|
+
cryptoService;
|
|
62
|
+
redis;
|
|
63
|
+
constructor(developerRepo, developerTokenRepo, cryptoService, redis) {
|
|
64
|
+
this.developerRepo = developerRepo;
|
|
65
|
+
this.developerTokenRepo = developerTokenRepo;
|
|
66
|
+
this.cryptoService = cryptoService;
|
|
67
|
+
this.redis = redis;
|
|
68
|
+
}
|
|
69
|
+
getProfile(req) {
|
|
70
|
+
const developer = this.developerRepo.findById(req.user.sub);
|
|
71
|
+
if (!developer) {
|
|
72
|
+
throw new common_1.NotFoundException('Developer not found');
|
|
73
|
+
}
|
|
74
|
+
// Return profile without sensitive fields
|
|
75
|
+
return {
|
|
76
|
+
id: developer.id,
|
|
77
|
+
name: developer.name,
|
|
78
|
+
gitName: developer.gitName,
|
|
79
|
+
gitEmail: developer.gitEmail,
|
|
80
|
+
role: developer.role,
|
|
81
|
+
status: developer.status,
|
|
82
|
+
totpEnabled: !!developer.totpSecret,
|
|
83
|
+
createdAt: developer.createdAt,
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
async updateProfile(req, body) {
|
|
87
|
+
const data = {};
|
|
88
|
+
if (body.gitName !== undefined)
|
|
89
|
+
data.gitName = body.gitName;
|
|
90
|
+
if (body.gitEmail !== undefined)
|
|
91
|
+
data.gitEmail = body.gitEmail;
|
|
92
|
+
if (Object.keys(data).length === 0) {
|
|
93
|
+
throw new common_1.BadRequestException('No fields to update');
|
|
94
|
+
}
|
|
95
|
+
this.developerRepo.update(req.user.sub, data);
|
|
96
|
+
return { success: true };
|
|
97
|
+
}
|
|
98
|
+
async updatePassword(req, body) {
|
|
99
|
+
const developer = this.developerRepo.findById(req.user.sub);
|
|
100
|
+
if (!developer) {
|
|
101
|
+
throw new common_1.NotFoundException('Developer not found');
|
|
102
|
+
}
|
|
103
|
+
if (!developer.passwordHash) {
|
|
104
|
+
throw new common_1.BadRequestException('No password set');
|
|
105
|
+
}
|
|
106
|
+
const valid = await this.cryptoService.comparePassword(body.currentPassword, developer.passwordHash);
|
|
107
|
+
if (!valid) {
|
|
108
|
+
throw new common_1.BadRequestException('Current password is incorrect');
|
|
109
|
+
}
|
|
110
|
+
if (!body.newPassword || body.newPassword.length < 8) {
|
|
111
|
+
throw new common_1.BadRequestException('New password must be at least 8 characters');
|
|
112
|
+
}
|
|
113
|
+
const newHash = await this.cryptoService.hashPassword(body.newPassword);
|
|
114
|
+
this.developerRepo.update(req.user.sub, { passwordHash: newHash });
|
|
115
|
+
return { success: true };
|
|
116
|
+
}
|
|
117
|
+
async setupTotp(req) {
|
|
118
|
+
const secret = this.cryptoService.generateTotpSecret();
|
|
119
|
+
// Store secret in Redis with 15 min TTL
|
|
120
|
+
await this.redis.setex(`totp_setup:${req.user.sub}`, 900, secret);
|
|
121
|
+
return { secret };
|
|
122
|
+
}
|
|
123
|
+
async verifyTotp(req, body) {
|
|
124
|
+
// Read secret from Redis (not from client)
|
|
125
|
+
const secret = await this.redis.get(`totp_setup:${req.user.sub}`);
|
|
126
|
+
if (!secret) {
|
|
127
|
+
throw new common_1.BadRequestException('No TOTP setup in progress or setup has expired. Please call setup again.');
|
|
128
|
+
}
|
|
129
|
+
const valid = this.cryptoService.verifyTotp(secret, body.code);
|
|
130
|
+
if (!valid) {
|
|
131
|
+
throw new common_1.BadRequestException('Invalid TOTP code');
|
|
132
|
+
}
|
|
133
|
+
// Persist the verified TOTP secret and clean up Redis
|
|
134
|
+
this.developerRepo.update(req.user.sub, { totpSecret: secret });
|
|
135
|
+
await this.redis.del(`totp_setup:${req.user.sub}`);
|
|
136
|
+
return { success: true };
|
|
137
|
+
}
|
|
138
|
+
listTokens(req) {
|
|
139
|
+
const tokens = this.developerTokenRepo.findByDeveloper(req.user.sub);
|
|
140
|
+
// Strip token_hash from response
|
|
141
|
+
return tokens.map((t) => ({
|
|
142
|
+
id: t.id,
|
|
143
|
+
label: t.label,
|
|
144
|
+
status: t.status,
|
|
145
|
+
lastUsedAt: t.lastUsedAt,
|
|
146
|
+
expiresAt: t.expiresAt,
|
|
147
|
+
createdAt: t.createdAt,
|
|
148
|
+
}));
|
|
149
|
+
}
|
|
150
|
+
async createToken(req, body) {
|
|
151
|
+
// Validate expiresAt is a parseable date if provided
|
|
152
|
+
if (body.expiresAt) {
|
|
153
|
+
const expiry = new Date(body.expiresAt);
|
|
154
|
+
if (isNaN(expiry.getTime())) {
|
|
155
|
+
throw new common_1.BadRequestException('Invalid expiresAt date format');
|
|
156
|
+
}
|
|
157
|
+
if (expiry <= new Date()) {
|
|
158
|
+
throw new common_1.BadRequestException('expiresAt must be in the future');
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
const rawToken = crypto.randomBytes(32).toString('hex');
|
|
162
|
+
const tokenHash = crypto
|
|
163
|
+
.createHash('sha256')
|
|
164
|
+
.update(rawToken)
|
|
165
|
+
.digest('hex');
|
|
166
|
+
const record = this.developerTokenRepo.create({
|
|
167
|
+
developerId: req.user.sub,
|
|
168
|
+
tokenHash,
|
|
169
|
+
label: body.label,
|
|
170
|
+
expiresAt: body.expiresAt,
|
|
171
|
+
});
|
|
172
|
+
return {
|
|
173
|
+
id: record.id,
|
|
174
|
+
token: rawToken,
|
|
175
|
+
label: record.label,
|
|
176
|
+
createdAt: record.createdAt,
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
revokeToken(id, req) {
|
|
180
|
+
const token = this.developerTokenRepo.findById(id);
|
|
181
|
+
if (!token || token.developerId !== req.user.sub) {
|
|
182
|
+
throw new common_1.NotFoundException('Token not found');
|
|
183
|
+
}
|
|
184
|
+
this.developerTokenRepo.revoke(id);
|
|
185
|
+
return { success: true };
|
|
186
|
+
}
|
|
187
|
+
};
|
|
188
|
+
exports.ProfileController = ProfileController;
|
|
189
|
+
__decorate([
|
|
190
|
+
(0, common_1.Get)(),
|
|
191
|
+
__param(0, (0, common_1.Req)()),
|
|
192
|
+
__metadata("design:type", Function),
|
|
193
|
+
__metadata("design:paramtypes", [Object]),
|
|
194
|
+
__metadata("design:returntype", void 0)
|
|
195
|
+
], ProfileController.prototype, "getProfile", null);
|
|
196
|
+
__decorate([
|
|
197
|
+
(0, common_1.Put)(),
|
|
198
|
+
__param(0, (0, common_1.Req)()),
|
|
199
|
+
__param(1, (0, common_1.Body)()),
|
|
200
|
+
__metadata("design:type", Function),
|
|
201
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
202
|
+
__metadata("design:returntype", Promise)
|
|
203
|
+
], ProfileController.prototype, "updateProfile", null);
|
|
204
|
+
__decorate([
|
|
205
|
+
(0, common_1.Put)('password'),
|
|
206
|
+
__param(0, (0, common_1.Req)()),
|
|
207
|
+
__param(1, (0, common_1.Body)()),
|
|
208
|
+
__metadata("design:type", Function),
|
|
209
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
210
|
+
__metadata("design:returntype", Promise)
|
|
211
|
+
], ProfileController.prototype, "updatePassword", null);
|
|
212
|
+
__decorate([
|
|
213
|
+
(0, common_1.Post)('totp/setup'),
|
|
214
|
+
(0, allow_totp_setup_decorator_1.AllowTotpSetup)(),
|
|
215
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 5, windowMs: 300_000 }),
|
|
216
|
+
__param(0, (0, common_1.Req)()),
|
|
217
|
+
__metadata("design:type", Function),
|
|
218
|
+
__metadata("design:paramtypes", [Object]),
|
|
219
|
+
__metadata("design:returntype", Promise)
|
|
220
|
+
], ProfileController.prototype, "setupTotp", null);
|
|
221
|
+
__decorate([
|
|
222
|
+
(0, common_1.Post)('totp/verify'),
|
|
223
|
+
(0, allow_totp_setup_decorator_1.AllowTotpSetup)(),
|
|
224
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 5, windowMs: 300_000 }),
|
|
225
|
+
__param(0, (0, common_1.Req)()),
|
|
226
|
+
__param(1, (0, common_1.Body)()),
|
|
227
|
+
__metadata("design:type", Function),
|
|
228
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
229
|
+
__metadata("design:returntype", Promise)
|
|
230
|
+
], ProfileController.prototype, "verifyTotp", null);
|
|
231
|
+
__decorate([
|
|
232
|
+
(0, common_1.Get)('tokens'),
|
|
233
|
+
__param(0, (0, common_1.Req)()),
|
|
234
|
+
__metadata("design:type", Function),
|
|
235
|
+
__metadata("design:paramtypes", [Object]),
|
|
236
|
+
__metadata("design:returntype", void 0)
|
|
237
|
+
], ProfileController.prototype, "listTokens", null);
|
|
238
|
+
__decorate([
|
|
239
|
+
(0, common_1.Post)('tokens'),
|
|
240
|
+
__param(0, (0, common_1.Req)()),
|
|
241
|
+
__param(1, (0, common_1.Body)()),
|
|
242
|
+
__metadata("design:type", Function),
|
|
243
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
244
|
+
__metadata("design:returntype", Promise)
|
|
245
|
+
], ProfileController.prototype, "createToken", null);
|
|
246
|
+
__decorate([
|
|
247
|
+
(0, common_1.Post)('tokens/:id/revoke'),
|
|
248
|
+
__param(0, (0, common_1.Param)('id', common_1.ParseIntPipe)),
|
|
249
|
+
__param(1, (0, common_1.Req)()),
|
|
250
|
+
__metadata("design:type", Function),
|
|
251
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
252
|
+
__metadata("design:returntype", void 0)
|
|
253
|
+
], ProfileController.prototype, "revokeToken", null);
|
|
254
|
+
exports.ProfileController = ProfileController = __decorate([
|
|
255
|
+
(0, common_1.Controller)('api/web/profile'),
|
|
256
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard),
|
|
257
|
+
__metadata("design:paramtypes", [developer_repository_1.DeveloperRepository,
|
|
258
|
+
developer_token_repository_1.DeveloperTokenRepository,
|
|
259
|
+
crypto_service_1.CryptoService,
|
|
260
|
+
redis_service_1.RedisService])
|
|
261
|
+
], ProfileController);
|
|
262
|
+
//# sourceMappingURL=profile.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile.controller.js","sourceRoot":"","sources":["../../src/web/profile.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { ProjectRepository } from '../database/repositories/project.repository';
|
|
2
|
+
export declare class ProjectController {
|
|
3
|
+
private readonly projectRepo;
|
|
4
|
+
constructor(projectRepo: ProjectRepository);
|
|
5
|
+
listProjects(): import("@overlordai/protocol").Project[];
|
|
6
|
+
getProject(key: string): import("@overlordai/protocol").Project;
|
|
7
|
+
}
|
|
8
|
+
//# sourceMappingURL=project.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.controller.d.ts","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,iBAAiB,EAAE,MAAM,6CAA6C,CAAC;AAEhF,qBAEa,iBAAiB;IAChB,OAAO,CAAC,QAAQ,CAAC,WAAW;gBAAX,WAAW,EAAE,iBAAiB;IAG3D,YAAY;IAKZ,UAAU,CAAe,GAAG,EAAE,MAAM;CAOrC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
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.ProjectController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
18
|
+
const project_repository_1 = require("../database/repositories/project.repository");
|
|
19
|
+
let ProjectController = class ProjectController {
|
|
20
|
+
projectRepo;
|
|
21
|
+
constructor(projectRepo) {
|
|
22
|
+
this.projectRepo = projectRepo;
|
|
23
|
+
}
|
|
24
|
+
listProjects() {
|
|
25
|
+
return this.projectRepo.findAll();
|
|
26
|
+
}
|
|
27
|
+
getProject(key) {
|
|
28
|
+
const project = this.projectRepo.findByKey(key);
|
|
29
|
+
if (!project) {
|
|
30
|
+
throw new common_1.NotFoundException(`Project '${key}' not found`);
|
|
31
|
+
}
|
|
32
|
+
return project;
|
|
33
|
+
}
|
|
34
|
+
};
|
|
35
|
+
exports.ProjectController = ProjectController;
|
|
36
|
+
__decorate([
|
|
37
|
+
(0, common_1.Get)(),
|
|
38
|
+
__metadata("design:type", Function),
|
|
39
|
+
__metadata("design:paramtypes", []),
|
|
40
|
+
__metadata("design:returntype", void 0)
|
|
41
|
+
], ProjectController.prototype, "listProjects", null);
|
|
42
|
+
__decorate([
|
|
43
|
+
(0, common_1.Get)(':key'),
|
|
44
|
+
__param(0, (0, common_1.Param)('key')),
|
|
45
|
+
__metadata("design:type", Function),
|
|
46
|
+
__metadata("design:paramtypes", [String]),
|
|
47
|
+
__metadata("design:returntype", void 0)
|
|
48
|
+
], ProjectController.prototype, "getProject", null);
|
|
49
|
+
exports.ProjectController = ProjectController = __decorate([
|
|
50
|
+
(0, common_1.Controller)('api/web/projects'),
|
|
51
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard),
|
|
52
|
+
__metadata("design:paramtypes", [project_repository_1.ProjectRepository])
|
|
53
|
+
], ProjectController);
|
|
54
|
+
//# sourceMappingURL=project.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"project.controller.js","sourceRoot":"","sources":["../../src/web/project.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAMwB;AACxB,kEAA6D;AAC7D,oFAAgF;AAIzE,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IACC;IAA7B,YAA6B,WAA8B;QAA9B,gBAAW,GAAX,WAAW,CAAmB;IAAG,CAAC;IAG/D,YAAY;QACV,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;IACpC,CAAC;IAGD,UAAU,CAAe,GAAW;QAClC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QAChD,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,MAAM,IAAI,0BAAiB,CAAC,YAAY,GAAG,aAAa,CAAC,CAAC;QAC5D,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;CACF,CAAA;AAhBY,8CAAiB;AAI5B;IADC,IAAA,YAAG,GAAE;;;;qDAGL;AAGD;IADC,IAAA,YAAG,EAAC,MAAM,CAAC;IACA,WAAA,IAAA,cAAK,EAAC,KAAK,CAAC,CAAA;;;;mDAMvB;4BAfU,iBAAiB;IAF7B,IAAA,mBAAU,EAAC,kBAAkB,CAAC;IAC9B,IAAA,kBAAS,EAAC,6BAAY,CAAC;qCAEoB,sCAAiB;GADhD,iBAAiB,CAgB7B"}
|