@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,386 @@
|
|
|
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
|
+
var WorkspaceController_1;
|
|
48
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
49
|
+
exports.WorkspaceController = void 0;
|
|
50
|
+
const common_1 = require("@nestjs/common");
|
|
51
|
+
const crypto = __importStar(require("node:crypto"));
|
|
52
|
+
const jwt_auth_guard_1 = require("../auth/guards/jwt-auth.guard");
|
|
53
|
+
const workspace_repository_1 = require("../database/repositories/workspace.repository");
|
|
54
|
+
const task_repository_1 = require("../database/repositories/task.repository");
|
|
55
|
+
const worker_connection_manager_1 = require("../dispatcher/worker-connection.manager");
|
|
56
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
57
|
+
/** Default tunnel TTL in hours, configurable via TUNNEL_TTL_HOURS env var. */
|
|
58
|
+
const TUNNEL_TTL_HOURS = Math.min(parseInt(process.env.TUNNEL_TTL_HOURS || '4', 10) || 4, 24);
|
|
59
|
+
let WorkspaceController = WorkspaceController_1 = class WorkspaceController {
|
|
60
|
+
workspaceRepo;
|
|
61
|
+
taskRepo;
|
|
62
|
+
workerConnectionManager;
|
|
63
|
+
logger = new common_1.Logger(WorkspaceController_1.name);
|
|
64
|
+
/**
|
|
65
|
+
* In-memory tunnel state per taskId.
|
|
66
|
+
* NOTE: This state is lost on server restart. This is acceptable because
|
|
67
|
+
* tunnels have a TTL and self-expire, and Workers will detect stale tunnels
|
|
68
|
+
* via heartbeat. After a restart, getTunnelStatus returns 'IDLE' which
|
|
69
|
+
* allows clients to start a new tunnel.
|
|
70
|
+
*/
|
|
71
|
+
tunnels = new Map();
|
|
72
|
+
constructor(workspaceRepo, taskRepo, workerConnectionManager) {
|
|
73
|
+
this.workspaceRepo = workspaceRepo;
|
|
74
|
+
this.taskRepo = taskRepo;
|
|
75
|
+
this.workerConnectionManager = workerConnectionManager;
|
|
76
|
+
}
|
|
77
|
+
getWorkspace(taskId, req) {
|
|
78
|
+
const workspace = this.workspaceRepo.findByTaskId(taskId);
|
|
79
|
+
if (!workspace) {
|
|
80
|
+
throw new common_1.NotFoundException(`Workspace for task #${taskId} not found`);
|
|
81
|
+
}
|
|
82
|
+
const task = this.taskRepo.findById(taskId);
|
|
83
|
+
if (!task) {
|
|
84
|
+
throw new common_1.NotFoundException(`Task #${taskId} not found`);
|
|
85
|
+
}
|
|
86
|
+
// Authorization: only task owner or admin
|
|
87
|
+
this.assertOwnerOrAdmin(req, task.createdBy ?? 0);
|
|
88
|
+
return workspace;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* Start a Cursor Remote Tunnel for the given task's workspace.
|
|
92
|
+
* Sends a start_tunnel command to the Worker via the WebSocket control channel.
|
|
93
|
+
* Only the task owner or an admin can start a tunnel.
|
|
94
|
+
*/
|
|
95
|
+
async startTunnel(taskId, req) {
|
|
96
|
+
const workspace = this.workspaceRepo.findByTaskId(taskId);
|
|
97
|
+
if (!workspace) {
|
|
98
|
+
throw new common_1.NotFoundException(`Workspace for task #${taskId} not found`);
|
|
99
|
+
}
|
|
100
|
+
const task = this.taskRepo.findById(taskId);
|
|
101
|
+
if (!task) {
|
|
102
|
+
throw new common_1.NotFoundException(`Task #${taskId} not found`);
|
|
103
|
+
}
|
|
104
|
+
// Authorization: only task owner or admin
|
|
105
|
+
this.assertOwnerOrAdmin(req, task.createdBy ?? 0);
|
|
106
|
+
// Check current tunnel state — must be IDLE or CLOSED to start
|
|
107
|
+
const existing = this.tunnels.get(taskId);
|
|
108
|
+
if (existing && existing.status !== 'IDLE' && existing.status !== 'CLOSED') {
|
|
109
|
+
throw new common_1.ConflictException({
|
|
110
|
+
error: 'tunnel_already_active',
|
|
111
|
+
currentStatus: existing.status,
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
// Verify worker is connected
|
|
115
|
+
if (!task.machineId || !this.workerConnectionManager.isConnected(task.machineId)) {
|
|
116
|
+
throw new common_1.ServiceUnavailableException('Worker for this task is not connected');
|
|
117
|
+
}
|
|
118
|
+
// Transition to STARTING
|
|
119
|
+
const tunnelState = {
|
|
120
|
+
status: 'STARTING',
|
|
121
|
+
taskId,
|
|
122
|
+
};
|
|
123
|
+
this.tunnels.set(taskId, tunnelState);
|
|
124
|
+
// Send start_tunnel command to Worker
|
|
125
|
+
const msgId = crypto.randomUUID();
|
|
126
|
+
try {
|
|
127
|
+
const ackPayload = await this.workerConnectionManager.sendWithAck(task.machineId, {
|
|
128
|
+
type: 'start_tunnel',
|
|
129
|
+
msgId,
|
|
130
|
+
taskId,
|
|
131
|
+
workspacePath: workspace.path,
|
|
132
|
+
}, 30_000);
|
|
133
|
+
// Check if the worker reported an error
|
|
134
|
+
if (ackPayload?.status === 'error') {
|
|
135
|
+
tunnelState.status = 'CLOSED';
|
|
136
|
+
throw new common_1.ServiceUnavailableException(ackPayload.error || 'Worker failed to start tunnel');
|
|
137
|
+
}
|
|
138
|
+
// Worker ack should include the tunnel URL
|
|
139
|
+
const tunnelUrl = ackPayload?.tunnelUrl;
|
|
140
|
+
if (tunnelUrl) {
|
|
141
|
+
this.transitionToConnected(taskId, tunnelUrl);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
catch (err) {
|
|
145
|
+
// Ack timeout or send failure — reset to IDLE
|
|
146
|
+
this.logger.warn(`Failed to start tunnel for task #${taskId}: ${err instanceof Error ? err.message : String(err)}`);
|
|
147
|
+
tunnelState.status = 'CLOSED';
|
|
148
|
+
throw new common_1.ServiceUnavailableException('Failed to start tunnel: worker did not respond');
|
|
149
|
+
}
|
|
150
|
+
const state = this.tunnels.get(taskId);
|
|
151
|
+
return {
|
|
152
|
+
status: state.status,
|
|
153
|
+
taskId,
|
|
154
|
+
tunnelUrl: state.tunnelUrl,
|
|
155
|
+
expiresAt: state.expiresAt,
|
|
156
|
+
};
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Stop a running Cursor Remote Tunnel for the given task.
|
|
160
|
+
* Sends a stop_tunnel command to the Worker.
|
|
161
|
+
* Only the task owner or an admin can stop a tunnel.
|
|
162
|
+
*/
|
|
163
|
+
async stopTunnel(taskId, req) {
|
|
164
|
+
const workspace = this.workspaceRepo.findByTaskId(taskId);
|
|
165
|
+
if (!workspace) {
|
|
166
|
+
throw new common_1.NotFoundException(`Workspace for task #${taskId} not found`);
|
|
167
|
+
}
|
|
168
|
+
const task = this.taskRepo.findById(taskId);
|
|
169
|
+
if (!task) {
|
|
170
|
+
throw new common_1.NotFoundException(`Task #${taskId} not found`);
|
|
171
|
+
}
|
|
172
|
+
// Authorization: only task owner or admin
|
|
173
|
+
this.assertOwnerOrAdmin(req, task.createdBy ?? 0);
|
|
174
|
+
const tunnel = this.tunnels.get(taskId);
|
|
175
|
+
if (!tunnel || tunnel.status === 'IDLE' || tunnel.status === 'CLOSED') {
|
|
176
|
+
return { status: tunnel?.status ?? 'IDLE', taskId };
|
|
177
|
+
}
|
|
178
|
+
// Transition to CLOSING
|
|
179
|
+
tunnel.status = 'CLOSING';
|
|
180
|
+
// Clear the expiry timer if set
|
|
181
|
+
if (tunnel.expiryTimer) {
|
|
182
|
+
clearTimeout(tunnel.expiryTimer);
|
|
183
|
+
tunnel.expiryTimer = undefined;
|
|
184
|
+
}
|
|
185
|
+
// Send stop_tunnel command to Worker
|
|
186
|
+
if (task.machineId && this.workerConnectionManager.isConnected(task.machineId)) {
|
|
187
|
+
const msgId = crypto.randomUUID();
|
|
188
|
+
try {
|
|
189
|
+
await this.workerConnectionManager.sendWithAck(task.machineId, {
|
|
190
|
+
type: 'stop_tunnel',
|
|
191
|
+
msgId,
|
|
192
|
+
taskId,
|
|
193
|
+
reason: 'manual',
|
|
194
|
+
}, 15_000);
|
|
195
|
+
}
|
|
196
|
+
catch (err) {
|
|
197
|
+
this.logger.warn(`Stop tunnel ack timeout for task #${taskId}: ${err instanceof Error ? err.message : String(err)}`);
|
|
198
|
+
}
|
|
199
|
+
}
|
|
200
|
+
// Transition to CLOSED
|
|
201
|
+
tunnel.status = 'CLOSED';
|
|
202
|
+
tunnel.tunnelUrl = undefined;
|
|
203
|
+
tunnel.expiresAt = undefined;
|
|
204
|
+
this.logger.log(`Tunnel for task #${taskId} stopped (manual)`);
|
|
205
|
+
return { status: 'CLOSED', taskId };
|
|
206
|
+
}
|
|
207
|
+
/**
|
|
208
|
+
* Get the current tunnel status for a task.
|
|
209
|
+
* tunnelUrl is only returned when the tunnel is in CONNECTED state.
|
|
210
|
+
*/
|
|
211
|
+
getTunnelStatus(taskId, req) {
|
|
212
|
+
const workspace = this.workspaceRepo.findByTaskId(taskId);
|
|
213
|
+
if (!workspace) {
|
|
214
|
+
throw new common_1.NotFoundException(`Workspace for task #${taskId} not found`);
|
|
215
|
+
}
|
|
216
|
+
const task = this.taskRepo.findById(taskId);
|
|
217
|
+
if (!task) {
|
|
218
|
+
throw new common_1.NotFoundException(`Task #${taskId} not found`);
|
|
219
|
+
}
|
|
220
|
+
this.assertOwnerOrAdmin(req, task.createdBy ?? 0);
|
|
221
|
+
const tunnel = this.tunnels.get(taskId);
|
|
222
|
+
if (!tunnel) {
|
|
223
|
+
return { status: 'IDLE', taskId };
|
|
224
|
+
}
|
|
225
|
+
return {
|
|
226
|
+
status: tunnel.status,
|
|
227
|
+
taskId,
|
|
228
|
+
tunnelUrl: tunnel.status === 'CONNECTED' ? tunnel.tunnelUrl : undefined,
|
|
229
|
+
expiresAt: tunnel.status === 'CONNECTED' ? tunnel.expiresAt : undefined,
|
|
230
|
+
};
|
|
231
|
+
}
|
|
232
|
+
/**
|
|
233
|
+
* Handle a tunnel_started event from the Worker (called by WorkerChannelGateway).
|
|
234
|
+
* Transitions the tunnel state to CONNECTED and starts the expiry timer.
|
|
235
|
+
*/
|
|
236
|
+
handleTunnelStarted(taskId, tunnelUrl) {
|
|
237
|
+
this.transitionToConnected(taskId, tunnelUrl);
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Handle a tunnel_closed event from the Worker (called by WorkerChannelGateway).
|
|
241
|
+
* Worker-side tunnel process exited unexpectedly.
|
|
242
|
+
*/
|
|
243
|
+
handleTunnelClosed(taskId, _reason) {
|
|
244
|
+
const tunnel = this.tunnels.get(taskId);
|
|
245
|
+
if (!tunnel)
|
|
246
|
+
return;
|
|
247
|
+
if (tunnel.expiryTimer) {
|
|
248
|
+
clearTimeout(tunnel.expiryTimer);
|
|
249
|
+
tunnel.expiryTimer = undefined;
|
|
250
|
+
}
|
|
251
|
+
tunnel.status = 'CLOSED';
|
|
252
|
+
tunnel.tunnelUrl = undefined;
|
|
253
|
+
tunnel.expiresAt = undefined;
|
|
254
|
+
this.logger.log(`Tunnel for task #${taskId} closed (${_reason})`);
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Force-close all tunnels for a task (called when task reaches terminal state).
|
|
258
|
+
*/
|
|
259
|
+
async cleanupTunnelForTask(taskId, machineId) {
|
|
260
|
+
const tunnel = this.tunnels.get(taskId);
|
|
261
|
+
if (!tunnel || tunnel.status === 'IDLE' || tunnel.status === 'CLOSED') {
|
|
262
|
+
return;
|
|
263
|
+
}
|
|
264
|
+
if (tunnel.expiryTimer) {
|
|
265
|
+
clearTimeout(tunnel.expiryTimer);
|
|
266
|
+
tunnel.expiryTimer = undefined;
|
|
267
|
+
}
|
|
268
|
+
// Send stop_tunnel to worker (fire-and-forget)
|
|
269
|
+
if (machineId && this.workerConnectionManager.isConnected(machineId)) {
|
|
270
|
+
const msgId = crypto.randomUUID();
|
|
271
|
+
this.workerConnectionManager.send(machineId, {
|
|
272
|
+
type: 'stop_tunnel',
|
|
273
|
+
msgId,
|
|
274
|
+
taskId,
|
|
275
|
+
reason: 'task_ended',
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
tunnel.status = 'CLOSED';
|
|
279
|
+
tunnel.tunnelUrl = undefined;
|
|
280
|
+
tunnel.expiresAt = undefined;
|
|
281
|
+
this.logger.log(`Tunnel for task #${taskId} force-closed (task ended)`);
|
|
282
|
+
}
|
|
283
|
+
// ---------------------------------------------------------------------------
|
|
284
|
+
// Private helpers
|
|
285
|
+
// ---------------------------------------------------------------------------
|
|
286
|
+
/**
|
|
287
|
+
* Transition a tunnel to CONNECTED state with a URL and start the expiry timer.
|
|
288
|
+
*/
|
|
289
|
+
transitionToConnected(taskId, tunnelUrl) {
|
|
290
|
+
const expiresAt = new Date(Date.now() + TUNNEL_TTL_HOURS * 60 * 60 * 1000).toISOString();
|
|
291
|
+
let tunnel = this.tunnels.get(taskId);
|
|
292
|
+
if (!tunnel) {
|
|
293
|
+
tunnel = { status: 'STARTING', taskId };
|
|
294
|
+
this.tunnels.set(taskId, tunnel);
|
|
295
|
+
}
|
|
296
|
+
tunnel.status = 'CONNECTED';
|
|
297
|
+
tunnel.tunnelUrl = tunnelUrl;
|
|
298
|
+
tunnel.expiresAt = expiresAt;
|
|
299
|
+
// Start expiry timer
|
|
300
|
+
tunnel.expiryTimer = setTimeout(() => {
|
|
301
|
+
this.handleTunnelExpired(taskId);
|
|
302
|
+
}, TUNNEL_TTL_HOURS * 60 * 60 * 1000);
|
|
303
|
+
this.logger.log(`Tunnel for task #${taskId} connected: ${tunnelUrl} (expires ${expiresAt})`);
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Handle tunnel expiry: transition to EXPIRED, then send stop_tunnel to Worker.
|
|
307
|
+
*/
|
|
308
|
+
async handleTunnelExpired(taskId) {
|
|
309
|
+
const tunnel = this.tunnels.get(taskId);
|
|
310
|
+
if (!tunnel || tunnel.status !== 'CONNECTED')
|
|
311
|
+
return;
|
|
312
|
+
tunnel.status = 'EXPIRED';
|
|
313
|
+
this.logger.log(`Tunnel for task #${taskId} expired`);
|
|
314
|
+
// Find the task to get the machineId
|
|
315
|
+
const task = this.taskRepo.findById(taskId);
|
|
316
|
+
if (task?.machineId && this.workerConnectionManager.isConnected(task.machineId)) {
|
|
317
|
+
tunnel.status = 'CLOSING';
|
|
318
|
+
const msgId = crypto.randomUUID();
|
|
319
|
+
try {
|
|
320
|
+
await this.workerConnectionManager.sendWithAck(task.machineId, {
|
|
321
|
+
type: 'stop_tunnel',
|
|
322
|
+
msgId,
|
|
323
|
+
taskId,
|
|
324
|
+
reason: 'expired',
|
|
325
|
+
}, 15_000);
|
|
326
|
+
}
|
|
327
|
+
catch {
|
|
328
|
+
// Best effort
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
tunnel.status = 'CLOSED';
|
|
332
|
+
tunnel.tunnelUrl = undefined;
|
|
333
|
+
tunnel.expiresAt = undefined;
|
|
334
|
+
this.logger.log(`Tunnel for task #${taskId} closed after expiry`);
|
|
335
|
+
}
|
|
336
|
+
/**
|
|
337
|
+
* Assert that the requesting user is either the task owner or an admin.
|
|
338
|
+
*/
|
|
339
|
+
assertOwnerOrAdmin(req, taskOwnerId) {
|
|
340
|
+
const user = req.user;
|
|
341
|
+
if (user.role !== protocol_1.DeveloperRole.ADMIN && user.sub !== taskOwnerId) {
|
|
342
|
+
throw new common_1.ForbiddenException('Only the task owner or an admin can manage workspace tunnels');
|
|
343
|
+
}
|
|
344
|
+
}
|
|
345
|
+
};
|
|
346
|
+
exports.WorkspaceController = WorkspaceController;
|
|
347
|
+
__decorate([
|
|
348
|
+
(0, common_1.Get)('workspaces/:taskId'),
|
|
349
|
+
__param(0, (0, common_1.Param)('taskId', common_1.ParseIntPipe)),
|
|
350
|
+
__param(1, (0, common_1.Req)()),
|
|
351
|
+
__metadata("design:type", Function),
|
|
352
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
353
|
+
__metadata("design:returntype", void 0)
|
|
354
|
+
], WorkspaceController.prototype, "getWorkspace", null);
|
|
355
|
+
__decorate([
|
|
356
|
+
(0, common_1.Post)('workspace-tunnel/:taskId/start'),
|
|
357
|
+
__param(0, (0, common_1.Param)('taskId', common_1.ParseIntPipe)),
|
|
358
|
+
__param(1, (0, common_1.Req)()),
|
|
359
|
+
__metadata("design:type", Function),
|
|
360
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
361
|
+
__metadata("design:returntype", Promise)
|
|
362
|
+
], WorkspaceController.prototype, "startTunnel", null);
|
|
363
|
+
__decorate([
|
|
364
|
+
(0, common_1.Post)('workspace-tunnel/:taskId/stop'),
|
|
365
|
+
__param(0, (0, common_1.Param)('taskId', common_1.ParseIntPipe)),
|
|
366
|
+
__param(1, (0, common_1.Req)()),
|
|
367
|
+
__metadata("design:type", Function),
|
|
368
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
369
|
+
__metadata("design:returntype", Promise)
|
|
370
|
+
], WorkspaceController.prototype, "stopTunnel", null);
|
|
371
|
+
__decorate([
|
|
372
|
+
(0, common_1.Get)('workspace-tunnel/:taskId/status'),
|
|
373
|
+
__param(0, (0, common_1.Param)('taskId', common_1.ParseIntPipe)),
|
|
374
|
+
__param(1, (0, common_1.Req)()),
|
|
375
|
+
__metadata("design:type", Function),
|
|
376
|
+
__metadata("design:paramtypes", [Number, Object]),
|
|
377
|
+
__metadata("design:returntype", void 0)
|
|
378
|
+
], WorkspaceController.prototype, "getTunnelStatus", null);
|
|
379
|
+
exports.WorkspaceController = WorkspaceController = WorkspaceController_1 = __decorate([
|
|
380
|
+
(0, common_1.Controller)('api/web'),
|
|
381
|
+
(0, common_1.UseGuards)(jwt_auth_guard_1.JwtAuthGuard),
|
|
382
|
+
__metadata("design:paramtypes", [workspace_repository_1.WorkspaceRepository,
|
|
383
|
+
task_repository_1.TaskRepository,
|
|
384
|
+
worker_connection_manager_1.WorkerConnectionManager])
|
|
385
|
+
], WorkspaceController);
|
|
386
|
+
//# sourceMappingURL=workspace.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"workspace.controller.js","sourceRoot":"","sources":["../../src/web/workspace.controller.ts"],"names":[],"mappings":"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"}
|
package/package.json
ADDED
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@overlordai/server",
|
|
3
|
+
"version": "1.0.1",
|
|
4
|
+
"license": "MIT",
|
|
5
|
+
"files": [
|
|
6
|
+
"dist",
|
|
7
|
+
"database"
|
|
8
|
+
],
|
|
9
|
+
"bin": {
|
|
10
|
+
"overlord-server": "dist/main.js"
|
|
11
|
+
},
|
|
12
|
+
"dependencies": {
|
|
13
|
+
"@larksuiteoapi/node-sdk": "^1.59.0",
|
|
14
|
+
"@nestjs/common": "^10.4.0",
|
|
15
|
+
"@nestjs/core": "^10.4.0",
|
|
16
|
+
"@nestjs/jwt": "^10.2.0",
|
|
17
|
+
"@nestjs/passport": "^10.0.3",
|
|
18
|
+
"@nestjs/platform-express": "^10.4.0",
|
|
19
|
+
"@nestjs/platform-ws": "^10.4.0",
|
|
20
|
+
"@nestjs/websockets": "^10.4.0",
|
|
21
|
+
"bcrypt": "^6.0.0",
|
|
22
|
+
"better-sqlite3": "^11.0.0",
|
|
23
|
+
"bullmq": "^5.0.0",
|
|
24
|
+
"express": "^4.21.0",
|
|
25
|
+
"ioredis": "^5.4.0",
|
|
26
|
+
"otplib": "^12.0.1",
|
|
27
|
+
"passport": "^0.7.0",
|
|
28
|
+
"passport-jwt": "^4.0.1",
|
|
29
|
+
"pino": "^9.0.0",
|
|
30
|
+
"reflect-metadata": "^0.2.2",
|
|
31
|
+
"rxjs": "^7.8.0",
|
|
32
|
+
"uuid": "^11.1.0",
|
|
33
|
+
"@overlordai/protocol": "1.0.1"
|
|
34
|
+
},
|
|
35
|
+
"devDependencies": {
|
|
36
|
+
"@nestjs/testing": "^10.4.0",
|
|
37
|
+
"@swc/core": "^1.15.18",
|
|
38
|
+
"@testcontainers/redis": "^11.12.0",
|
|
39
|
+
"@types/bcrypt": "^5.0.2",
|
|
40
|
+
"@types/better-sqlite3": "^7.6.0",
|
|
41
|
+
"@types/express": "^5.0.6",
|
|
42
|
+
"@types/node": "^22.0.0",
|
|
43
|
+
"@types/passport-jwt": "^4.0.1",
|
|
44
|
+
"@types/supertest": "^7.2.0",
|
|
45
|
+
"@types/uuid": "^10.0.0",
|
|
46
|
+
"@types/ws": "^8.18.1",
|
|
47
|
+
"supertest": "^7.2.2",
|
|
48
|
+
"testcontainers": "^11.12.0",
|
|
49
|
+
"typescript": "^5.9.0",
|
|
50
|
+
"unplugin-swc": "^1.5.9",
|
|
51
|
+
"vitest": "^4.0.18",
|
|
52
|
+
"ws": "^8.18.0"
|
|
53
|
+
},
|
|
54
|
+
"scripts": {
|
|
55
|
+
"build": "tsc && node -e \"const f='dist/main.js',c=require('fs').readFileSync(f,'utf8');if(!c.startsWith('#!'))require('fs').writeFileSync(f,'#!/usr/bin/env node\\\\n'+c)\"",
|
|
56
|
+
"start": "node dist/main.js",
|
|
57
|
+
"seed": "npx tsx scripts/seed.ts",
|
|
58
|
+
"test": "vitest run",
|
|
59
|
+
"lint": "tsc --noEmit"
|
|
60
|
+
}
|
|
61
|
+
}
|