@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,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
14
|
+
var LarkController_1;
|
|
15
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
16
|
+
exports.LarkController = void 0;
|
|
17
|
+
const common_1 = require("@nestjs/common");
|
|
18
|
+
const lark_adapter_1 = require("./lark.adapter");
|
|
19
|
+
const dispatcher_service_1 = require("../../dispatcher/dispatcher.service");
|
|
20
|
+
const lark_card_builder_1 = require("./lark-card.builder");
|
|
21
|
+
/**
|
|
22
|
+
* POST /webhook/lark
|
|
23
|
+
*
|
|
24
|
+
* Single endpoint for all Lark webhook events:
|
|
25
|
+
* - URL verification (challenge)
|
|
26
|
+
* - im.message.receive_v1 (messages)
|
|
27
|
+
* - card.action.trigger (button callbacks)
|
|
28
|
+
*/
|
|
29
|
+
let LarkController = LarkController_1 = class LarkController {
|
|
30
|
+
larkAdapter;
|
|
31
|
+
dispatcher;
|
|
32
|
+
cardBuilder;
|
|
33
|
+
logger = new common_1.Logger(LarkController_1.name);
|
|
34
|
+
constructor(larkAdapter, dispatcher, cardBuilder) {
|
|
35
|
+
this.larkAdapter = larkAdapter;
|
|
36
|
+
this.dispatcher = dispatcher;
|
|
37
|
+
this.cardBuilder = cardBuilder;
|
|
38
|
+
}
|
|
39
|
+
async handleWebhook(req, res) {
|
|
40
|
+
const body = req.body;
|
|
41
|
+
// 1. Handle URL verification challenge
|
|
42
|
+
if (body.type === 'url_verification' && typeof body.challenge === 'string') {
|
|
43
|
+
res.status(common_1.HttpStatus.OK).json({ challenge: body.challenge });
|
|
44
|
+
return;
|
|
45
|
+
}
|
|
46
|
+
// 2. Handle card action callback — return updated card JSON
|
|
47
|
+
const header = body.header;
|
|
48
|
+
if (header?.event_type === 'card.action.trigger') {
|
|
49
|
+
// handleWebhook processes the card action internally
|
|
50
|
+
await this.larkAdapter.handleWebhook(req);
|
|
51
|
+
// Card action callbacks expect a card JSON response to update the card
|
|
52
|
+
const event = body.event;
|
|
53
|
+
const action = event?.action;
|
|
54
|
+
const value = action?.value;
|
|
55
|
+
if (value?.taskId !== undefined && value?.result !== undefined) {
|
|
56
|
+
const updatedCard = this.cardBuilder.buildSelectedCard(value.taskId, String(value.result));
|
|
57
|
+
const cardJson = this.cardBuilder.toLarkCardJson(updatedCard);
|
|
58
|
+
res.status(common_1.HttpStatus.OK).json(JSON.parse(cardJson));
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
res.status(common_1.HttpStatus.OK).json({});
|
|
62
|
+
return;
|
|
63
|
+
}
|
|
64
|
+
// 3. Handle regular message events
|
|
65
|
+
try {
|
|
66
|
+
const command = await this.larkAdapter.handleWebhook(req);
|
|
67
|
+
if (command) {
|
|
68
|
+
// Dispatch the command and handle the result
|
|
69
|
+
const result = await this.dispatcher.handleCommand(command);
|
|
70
|
+
// Send response back to chat
|
|
71
|
+
if (result.task) {
|
|
72
|
+
const card = this.cardBuilder.buildTaskCard(result.task);
|
|
73
|
+
await this.larkAdapter.sendMessage(command.chat.id, card);
|
|
74
|
+
}
|
|
75
|
+
else if (result.confirmRequired) {
|
|
76
|
+
const card = this.cardBuilder.buildDedupConfirmCard(result.confirmRequired.taskId ?? 0, result.confirmRequired.message, result.confirmRequired.confirmKey);
|
|
77
|
+
await this.larkAdapter.sendMessage(command.chat.id, card);
|
|
78
|
+
}
|
|
79
|
+
else if (result.tasks) {
|
|
80
|
+
// List command — send a summary text
|
|
81
|
+
const lines = result.tasks.map((t) => `#${t.id} [${t.status}] ${t.description.slice(0, 40)}`);
|
|
82
|
+
const text = lines.length > 0
|
|
83
|
+
? `Active tasks:\n${lines.join('\n')}`
|
|
84
|
+
: 'No active tasks.';
|
|
85
|
+
await this.larkAdapter.sendMessage(command.chat.id, {
|
|
86
|
+
type: 'text',
|
|
87
|
+
text,
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
else if (result.message) {
|
|
91
|
+
await this.larkAdapter.sendMessage(command.chat.id, {
|
|
92
|
+
type: 'text',
|
|
93
|
+
text: result.message,
|
|
94
|
+
});
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
res.status(common_1.HttpStatus.OK).json({});
|
|
98
|
+
}
|
|
99
|
+
catch (err) {
|
|
100
|
+
this.logger.error(`Webhook processing error: ${err instanceof Error ? err.message : String(err)}`);
|
|
101
|
+
res.status(common_1.HttpStatus.OK).json({});
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
exports.LarkController = LarkController;
|
|
106
|
+
__decorate([
|
|
107
|
+
(0, common_1.Post)('lark'),
|
|
108
|
+
__param(0, (0, common_1.Req)()),
|
|
109
|
+
__param(1, (0, common_1.Res)()),
|
|
110
|
+
__metadata("design:type", Function),
|
|
111
|
+
__metadata("design:paramtypes", [Object, Object]),
|
|
112
|
+
__metadata("design:returntype", Promise)
|
|
113
|
+
], LarkController.prototype, "handleWebhook", null);
|
|
114
|
+
exports.LarkController = LarkController = LarkController_1 = __decorate([
|
|
115
|
+
(0, common_1.Controller)('webhook'),
|
|
116
|
+
__metadata("design:paramtypes", [lark_adapter_1.LarkAdapter,
|
|
117
|
+
dispatcher_service_1.DispatcherService,
|
|
118
|
+
lark_card_builder_1.LarkCardBuilder])
|
|
119
|
+
], LarkController);
|
|
120
|
+
//# sourceMappingURL=lark.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lark.controller.js","sourceRoot":"","sources":["../../../src/adapters/lark/lark.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,2CAOwB;AAExB,iDAA6C;AAC7C,4EAAwE;AACxE,2DAAsD;AAEtD;;;;;;;GAOG;AAEI,IAAM,cAAc,sBAApB,MAAM,cAAc;IAIN;IACA;IACA;IALF,MAAM,GAAG,IAAI,eAAM,CAAC,gBAAc,CAAC,IAAI,CAAC,CAAC;IAE1D,YACmB,WAAwB,EACxB,UAA6B,EAC7B,WAA4B;QAF5B,gBAAW,GAAX,WAAW,CAAa;QACxB,eAAU,GAAV,UAAU,CAAmB;QAC7B,gBAAW,GAAX,WAAW,CAAiB;IAC5C,CAAC;IAGE,AAAN,KAAK,CAAC,aAAa,CACV,GAAY,EACZ,GAAa;QAEpB,MAAM,IAAI,GAAG,GAAG,CAAC,IAA+B,CAAC;QAEjD,uCAAuC;QACvC,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAkB,IAAI,OAAO,IAAI,CAAC,SAAS,KAAK,QAAQ,EAAE,CAAC;YAC3E,GAAG,CAAC,MAAM,CAAC,mBAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;YAC9D,OAAO;QACT,CAAC;QAED,4DAA4D;QAC5D,MAAM,MAAM,GAAG,IAAI,CAAC,MAA6C,CAAC;QAClE,IAAI,MAAM,EAAE,UAAU,KAAK,qBAAqB,EAAE,CAAC;YACjD,qDAAqD;YACrD,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAE1C,uEAAuE;YACvE,MAAM,KAAK,GAAG,IAAI,CAAC,KAA4C,CAAC;YAChE,MAAM,MAAM,GAAG,KAAK,EAAE,MAAyD,CAAC;YAChF,MAAM,KAAK,GAAG,MAAM,EAAE,KAGT,CAAC;YAEd,IAAI,KAAK,EAAE,MAAM,KAAK,SAAS,IAAI,KAAK,EAAE,MAAM,KAAK,SAAS,EAAE,CAAC;gBAC/D,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,iBAAiB,CACpD,KAAK,CAAC,MAAM,EACZ,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CACrB,CAAC;gBACF,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;gBAC9D,GAAG,CAAC,MAAM,CAAC,mBAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;gBACrD,OAAO;YACT,CAAC;YAED,GAAG,CAAC,MAAM,CAAC,mBAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;YACnC,OAAO;QACT,CAAC;QAED,mCAAmC;QACnC,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;YAE1D,IAAI,OAAO,EAAE,CAAC;gBACZ,6CAA6C;gBAC7C,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;gBAE5D,6BAA6B;gBAC7B,IAAI,MAAM,CAAC,IAAI,EAAE,CAAC;oBAChB,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;oBACzD,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;gBAC5D,CAAC;qBAAM,IAAI,MAAM,CAAC,eAAe,EAAE,CAAC;oBAClC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,CACjD,MAAM,CAAC,eAAe,CAAC,MAAM,IAAI,CAAC,EAClC,MAAM,CAAC,eAAe,CAAC,OAAO,EAC9B,MAAM,CAAC,eAAe,CAAC,UAAU,CAClC,CAAC;oBACF,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;gBAC5D,CAAC;qBAAM,IAAI,MAAM,CAAC,KAAK,EAAE,CAAC;oBACxB,qCAAqC;oBACrC,MAAM,KAAK,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAC5B,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAC9D,CAAC;oBACF,MAAM,IAAI,GAAG,KAAK,CAAC,MAAM,GAAG,CAAC;wBAC3B,CAAC,CAAC,kBAAkB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;wBACtC,CAAC,CAAC,kBAAkB,CAAC;oBACvB,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE;wBAClD,IAAI,EAAE,MAAM;wBACZ,IAAI;qBACL,CAAC,CAAC;gBACL,CAAC;qBAAM,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;oBAC1B,MAAM,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE;wBAClD,IAAI,EAAE,MAAM;wBACZ,IAAI,EAAE,MAAM,CAAC,OAAO;qBACrB,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;YAED,GAAG,CAAC,MAAM,CAAC,mBAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrC,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,6BAA6B,GAAG,YAAY,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAChF,CAAC;YACF,GAAG,CAAC,MAAM,CAAC,mBAAU,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACrC,CAAC;IACH,CAAC;CACF,CAAA;AAjGY,wCAAc;AAUnB;IADL,IAAA,aAAI,EAAC,MAAM,CAAC;IAEV,WAAA,IAAA,YAAG,GAAE,CAAA;IACL,WAAA,IAAA,YAAG,GAAE,CAAA;;;;mDAoFP;yBAhGU,cAAc;IAD1B,IAAA,mBAAU,EAAC,SAAS,CAAC;qCAKY,0BAAW;QACZ,sCAAiB;QAChB,mCAAe;GANpC,cAAc,CAiG1B"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import type { Request } from 'express';
|
|
2
|
+
import type { Command, DeveloperPublic } from '@overlordai/protocol';
|
|
3
|
+
import { Platform } from '@overlordai/protocol';
|
|
4
|
+
import type { IMessageAdapter, AdapterMessage } from '../adapter.interface';
|
|
5
|
+
/**
|
|
6
|
+
* Slack Adapter — V2 placeholder (stub implementation).
|
|
7
|
+
*
|
|
8
|
+
* This adapter satisfies the IMessageAdapter interface but does not implement
|
|
9
|
+
* any real Slack integration. It logs warnings for all method calls.
|
|
10
|
+
*/
|
|
11
|
+
export declare class SlackAdapter implements IMessageAdapter {
|
|
12
|
+
readonly platform = Platform.SLACK;
|
|
13
|
+
private readonly logger;
|
|
14
|
+
handleWebhook(_req: Request): Promise<Command | null>;
|
|
15
|
+
sendMessage(_chatId: string, _content: AdapterMessage): Promise<string>;
|
|
16
|
+
updateMessage(_msgId: string, _content: AdapterMessage): Promise<void>;
|
|
17
|
+
resolveUser(_platformUid: string): Promise<DeveloperPublic | null>;
|
|
18
|
+
}
|
|
19
|
+
//# sourceMappingURL=slack.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slack.adapter.d.ts","sourceRoot":"","sources":["../../../src/adapters/slack/slack.adapter.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAC;AACvC,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACrE,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAE5E;;;;;GAKG;AACH,qBACa,YAAa,YAAW,eAAe;IAClD,QAAQ,CAAC,QAAQ,kBAAkB;IACnC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiC;IAElD,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;IAKrD,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,MAAM,CAAC;IAKvE,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAItE,WAAW,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;CAIzE"}
|
|
@@ -0,0 +1,42 @@
|
|
|
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 SlackAdapter_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.SlackAdapter = void 0;
|
|
11
|
+
const common_1 = require("@nestjs/common");
|
|
12
|
+
const protocol_1 = require("@overlordai/protocol");
|
|
13
|
+
/**
|
|
14
|
+
* Slack Adapter — V2 placeholder (stub implementation).
|
|
15
|
+
*
|
|
16
|
+
* This adapter satisfies the IMessageAdapter interface but does not implement
|
|
17
|
+
* any real Slack integration. It logs warnings for all method calls.
|
|
18
|
+
*/
|
|
19
|
+
let SlackAdapter = SlackAdapter_1 = class SlackAdapter {
|
|
20
|
+
platform = protocol_1.Platform.SLACK;
|
|
21
|
+
logger = new common_1.Logger(SlackAdapter_1.name);
|
|
22
|
+
async handleWebhook(_req) {
|
|
23
|
+
this.logger.warn('Slack adapter is a stub — handleWebhook not implemented');
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
async sendMessage(_chatId, _content) {
|
|
27
|
+
this.logger.warn('Slack adapter is a stub — sendMessage not implemented');
|
|
28
|
+
return '';
|
|
29
|
+
}
|
|
30
|
+
async updateMessage(_msgId, _content) {
|
|
31
|
+
this.logger.warn('Slack adapter is a stub — updateMessage not implemented');
|
|
32
|
+
}
|
|
33
|
+
async resolveUser(_platformUid) {
|
|
34
|
+
this.logger.warn('Slack adapter is a stub — resolveUser not implemented');
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
};
|
|
38
|
+
exports.SlackAdapter = SlackAdapter;
|
|
39
|
+
exports.SlackAdapter = SlackAdapter = SlackAdapter_1 = __decorate([
|
|
40
|
+
(0, common_1.Injectable)()
|
|
41
|
+
], SlackAdapter);
|
|
42
|
+
//# sourceMappingURL=slack.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"slack.adapter.js","sourceRoot":"","sources":["../../../src/adapters/slack/slack.adapter.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,2CAAoD;AAGpD,mDAAgD;AAGhD;;;;;GAKG;AAEI,IAAM,YAAY,oBAAlB,MAAM,YAAY;IACd,QAAQ,GAAG,mBAAQ,CAAC,KAAK,CAAC;IAClB,MAAM,GAAG,IAAI,eAAM,CAAC,cAAY,CAAC,IAAI,CAAC,CAAC;IAExD,KAAK,CAAC,aAAa,CAAC,IAAa;QAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yDAAyD,CAAC,CAAC;QAC5E,OAAO,IAAI,CAAC;IACd,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,OAAe,EAAE,QAAwB;QACzD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uDAAuD,CAAC,CAAC;QAC1E,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,MAAc,EAAE,QAAwB;QAC1D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yDAAyD,CAAC,CAAC;IAC9E,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,YAAoB;QACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uDAAuD,CAAC,CAAC;QAC1E,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AAtBY,oCAAY;uBAAZ,YAAY;IADxB,IAAA,mBAAU,GAAE;GACA,YAAY,CAsBxB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app.module.d.ts","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,kBAAkB,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAYxE,qBAiBa,SAAU,YAAW,UAAU;IAC1C,SAAS,CAAC,QAAQ,EAAE,kBAAkB,GAAG,IAAI;CAK9C"}
|
|
@@ -0,0 +1,48 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AppModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const core_1 = require("@nestjs/core");
|
|
12
|
+
const database_module_1 = require("./database/database.module");
|
|
13
|
+
const redis_module_1 = require("./redis/redis.module");
|
|
14
|
+
const auth_module_1 = require("./auth/auth.module");
|
|
15
|
+
const dispatcher_module_1 = require("./dispatcher/dispatcher.module");
|
|
16
|
+
const web_module_1 = require("./web/web.module");
|
|
17
|
+
const adapter_module_1 = require("./adapters/adapter.module");
|
|
18
|
+
const notifier_module_1 = require("./notifier/notifier.module");
|
|
19
|
+
const rate_limit_guard_1 = require("./common/rate-limit.guard");
|
|
20
|
+
const extract_user_middleware_1 = require("./auth/extract-user.middleware");
|
|
21
|
+
let AppModule = class AppModule {
|
|
22
|
+
configure(consumer) {
|
|
23
|
+
// ExtractUserMiddleware runs BEFORE guards, populating request.user
|
|
24
|
+
// from JWT so RateLimitGuard can do per-user rate limiting.
|
|
25
|
+
consumer.apply(extract_user_middleware_1.ExtractUserMiddleware).forRoutes('*');
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
exports.AppModule = AppModule;
|
|
29
|
+
exports.AppModule = AppModule = __decorate([
|
|
30
|
+
(0, common_1.Module)({
|
|
31
|
+
imports: [
|
|
32
|
+
database_module_1.DatabaseModule,
|
|
33
|
+
redis_module_1.RedisModule,
|
|
34
|
+
auth_module_1.AuthModule,
|
|
35
|
+
dispatcher_module_1.DispatcherModule,
|
|
36
|
+
web_module_1.WebModule,
|
|
37
|
+
adapter_module_1.AdapterModule,
|
|
38
|
+
notifier_module_1.NotifierModule,
|
|
39
|
+
],
|
|
40
|
+
providers: [
|
|
41
|
+
{
|
|
42
|
+
provide: core_1.APP_GUARD,
|
|
43
|
+
useClass: rate_limit_guard_1.RateLimitGuard,
|
|
44
|
+
},
|
|
45
|
+
],
|
|
46
|
+
})
|
|
47
|
+
], AppModule);
|
|
48
|
+
//# sourceMappingURL=app.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app.module.js","sourceRoot":"","sources":["../src/app.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwE;AACxE,uCAAyC;AACzC,gEAA4D;AAC5D,uDAAmD;AACnD,oDAAgD;AAChD,sEAAkE;AAClE,iDAA6C;AAC7C,8DAA0D;AAC1D,gEAA4D;AAC5D,gEAA2D;AAC3D,4EAAuE;AAmBhE,IAAM,SAAS,GAAf,MAAM,SAAS;IACpB,SAAS,CAAC,QAA4B;QACpC,oEAAoE;QACpE,4DAA4D;QAC5D,QAAQ,CAAC,KAAK,CAAC,+CAAqB,CAAC,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IACvD,CAAC;CACF,CAAA;AANY,8BAAS;oBAAT,SAAS;IAjBrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,gCAAc;YACd,0BAAW;YACX,wBAAU;YACV,oCAAgB;YAChB,sBAAS;YACT,8BAAa;YACb,gCAAc;SACf;QACD,SAAS,EAAE;YACT;gBACE,OAAO,EAAE,gBAAS;gBAClB,QAAQ,EAAE,iCAAc;aACzB;SACF;KACF,CAAC;GACW,SAAS,CAMrB"}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { LoginRequest, LoginResponse, RefreshRequest, RefreshResponse } from '@overlordai/protocol';
|
|
2
|
+
import { AuthService } from './auth.service';
|
|
3
|
+
export declare class AuthController {
|
|
4
|
+
private readonly authService;
|
|
5
|
+
constructor(authService: AuthService);
|
|
6
|
+
login(body: LoginRequest): Promise<LoginResponse | {
|
|
7
|
+
accessToken: string;
|
|
8
|
+
totpSetup: true;
|
|
9
|
+
}>;
|
|
10
|
+
refresh(body: RefreshRequest): Promise<RefreshResponse>;
|
|
11
|
+
logout(body: {
|
|
12
|
+
refreshToken: string;
|
|
13
|
+
}): Promise<void>;
|
|
14
|
+
}
|
|
15
|
+
//# sourceMappingURL=auth.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.controller.d.ts","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,YAAY,EACZ,aAAa,EACb,cAAc,EACd,eAAe,EAChB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAG7C,qBACa,cAAc;IACb,OAAO,CAAC,QAAQ,CAAC,WAAW;gBAAX,WAAW,EAAE,WAAW;IAK/C,KAAK,CACD,IAAI,EAAE,YAAY,GACzB,OAAO,CAAC,aAAa,GAAG;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,IAAI,CAAA;KAAE,CAAC;IAM9D,OAAO,CAAS,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,eAAe,CAAC;IAO/D,MAAM,CAAS,IAAI,EAAE;QAAE,YAAY,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;CAKpE"}
|
|
@@ -0,0 +1,67 @@
|
|
|
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.AuthController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const auth_service_1 = require("./auth.service");
|
|
18
|
+
const rate_limit_guard_1 = require("../common/rate-limit.guard");
|
|
19
|
+
let AuthController = class AuthController {
|
|
20
|
+
authService;
|
|
21
|
+
constructor(authService) {
|
|
22
|
+
this.authService = authService;
|
|
23
|
+
}
|
|
24
|
+
async login(body) {
|
|
25
|
+
return this.authService.login(body.username, body.password, body.totpCode);
|
|
26
|
+
}
|
|
27
|
+
async refresh(body) {
|
|
28
|
+
return this.authService.refresh(body.refreshToken);
|
|
29
|
+
}
|
|
30
|
+
async logout(body) {
|
|
31
|
+
// No JwtAuthGuard — logout must work even when the access token is expired.
|
|
32
|
+
// The refresh token in the body is verified by authService.logout() itself.
|
|
33
|
+
await this.authService.logout(body.refreshToken);
|
|
34
|
+
}
|
|
35
|
+
};
|
|
36
|
+
exports.AuthController = AuthController;
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, common_1.Post)('login'),
|
|
39
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.OK),
|
|
40
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 5, windowMs: 60_000, byIp: true }),
|
|
41
|
+
__param(0, (0, common_1.Body)()),
|
|
42
|
+
__metadata("design:type", Function),
|
|
43
|
+
__metadata("design:paramtypes", [Object]),
|
|
44
|
+
__metadata("design:returntype", Promise)
|
|
45
|
+
], AuthController.prototype, "login", null);
|
|
46
|
+
__decorate([
|
|
47
|
+
(0, common_1.Post)('refresh'),
|
|
48
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.OK),
|
|
49
|
+
__param(0, (0, common_1.Body)()),
|
|
50
|
+
__metadata("design:type", Function),
|
|
51
|
+
__metadata("design:paramtypes", [Object]),
|
|
52
|
+
__metadata("design:returntype", Promise)
|
|
53
|
+
], AuthController.prototype, "refresh", null);
|
|
54
|
+
__decorate([
|
|
55
|
+
(0, common_1.Post)('logout'),
|
|
56
|
+
(0, common_1.HttpCode)(common_1.HttpStatus.NO_CONTENT),
|
|
57
|
+
(0, rate_limit_guard_1.RateLimit)({ limit: 10, windowMs: 60_000, byIp: true }),
|
|
58
|
+
__param(0, (0, common_1.Body)()),
|
|
59
|
+
__metadata("design:type", Function),
|
|
60
|
+
__metadata("design:paramtypes", [Object]),
|
|
61
|
+
__metadata("design:returntype", Promise)
|
|
62
|
+
], AuthController.prototype, "logout", null);
|
|
63
|
+
exports.AuthController = AuthController = __decorate([
|
|
64
|
+
(0, common_1.Controller)('api/auth'),
|
|
65
|
+
__metadata("design:paramtypes", [auth_service_1.AuthService])
|
|
66
|
+
], AuthController);
|
|
67
|
+
//# sourceMappingURL=auth.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.controller.js","sourceRoot":"","sources":["../../src/auth/auth.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAMwB;AAOxB,iDAA6C;AAC7C,iEAAuD;AAGhD,IAAM,cAAc,GAApB,MAAM,cAAc;IACI;IAA7B,YAA6B,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;IAAG,CAAC;IAKnD,AAAN,KAAK,CAAC,KAAK,CACD,IAAkB;QAE1B,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7E,CAAC;IAIK,AAAN,KAAK,CAAC,OAAO,CAAS,IAAoB;QACxC,OAAO,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACrD,CAAC;IAKK,AAAN,KAAK,CAAC,MAAM,CAAS,IAA8B;QACjD,4EAA4E;QAC5E,4EAA4E;QAC5E,MAAM,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACnD,CAAC;CACF,CAAA;AA1BY,wCAAc;AAMnB;IAHL,IAAA,aAAI,EAAC,OAAO,CAAC;IACb,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACvB,IAAA,4BAAS,EAAC,EAAE,KAAK,EAAE,CAAC,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IAEnD,WAAA,IAAA,aAAI,GAAE,CAAA;;;;2CAGR;AAIK;IAFL,IAAA,aAAI,EAAC,SAAS,CAAC;IACf,IAAA,iBAAQ,EAAC,mBAAU,CAAC,EAAE,CAAC;IACT,WAAA,IAAA,aAAI,GAAE,CAAA;;;;6CAEpB;AAKK;IAHL,IAAA,aAAI,EAAC,QAAQ,CAAC;IACd,IAAA,iBAAQ,EAAC,mBAAU,CAAC,UAAU,CAAC;IAC/B,IAAA,4BAAS,EAAC,EAAE,KAAK,EAAE,EAAE,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IACzC,WAAA,IAAA,aAAI,GAAE,CAAA;;;;4CAInB;yBAzBU,cAAc;IAD1B,IAAA,mBAAU,EAAC,UAAU,CAAC;qCAEqB,0BAAW;GAD1C,cAAc,CA0B1B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.module.d.ts","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":"AAYA,qBAoBa,UAAU;CAAG"}
|
|
@@ -0,0 +1,46 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
+
exports.AuthModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const jwt_1 = require("@nestjs/jwt");
|
|
12
|
+
const passport_1 = require("@nestjs/passport");
|
|
13
|
+
const developer_repository_1 = require("../database/repositories/developer.repository");
|
|
14
|
+
const developer_token_repository_1 = require("../database/repositories/developer-token.repository");
|
|
15
|
+
const auth_service_1 = require("./auth.service");
|
|
16
|
+
const auth_controller_1 = require("./auth.controller");
|
|
17
|
+
const jwt_strategy_1 = require("./jwt.strategy");
|
|
18
|
+
const jwt_auth_guard_1 = require("./guards/jwt-auth.guard");
|
|
19
|
+
const roles_guard_1 = require("./guards/roles.guard");
|
|
20
|
+
const project_role_guard_1 = require("./guards/project-role.guard");
|
|
21
|
+
let AuthModule = class AuthModule {
|
|
22
|
+
};
|
|
23
|
+
exports.AuthModule = AuthModule;
|
|
24
|
+
exports.AuthModule = AuthModule = __decorate([
|
|
25
|
+
(0, common_1.Module)({
|
|
26
|
+
imports: [
|
|
27
|
+
passport_1.PassportModule.register({ defaultStrategy: 'jwt' }),
|
|
28
|
+
jwt_1.JwtModule.register({
|
|
29
|
+
secret: process.env.JWT_SECRET || 'default-jwt-secret',
|
|
30
|
+
signOptions: { expiresIn: '15m' },
|
|
31
|
+
}),
|
|
32
|
+
],
|
|
33
|
+
controllers: [auth_controller_1.AuthController],
|
|
34
|
+
providers: [
|
|
35
|
+
auth_service_1.AuthService,
|
|
36
|
+
jwt_strategy_1.JwtStrategy,
|
|
37
|
+
jwt_auth_guard_1.JwtAuthGuard,
|
|
38
|
+
roles_guard_1.RolesGuard,
|
|
39
|
+
project_role_guard_1.ProjectRoleGuard,
|
|
40
|
+
developer_repository_1.DeveloperRepository,
|
|
41
|
+
developer_token_repository_1.DeveloperTokenRepository,
|
|
42
|
+
],
|
|
43
|
+
exports: [auth_service_1.AuthService, jwt_auth_guard_1.JwtAuthGuard, roles_guard_1.RolesGuard, project_role_guard_1.ProjectRoleGuard],
|
|
44
|
+
})
|
|
45
|
+
], AuthModule);
|
|
46
|
+
//# sourceMappingURL=auth.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.module.js","sourceRoot":"","sources":["../../src/auth/auth.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAwC;AACxC,qCAAwC;AACxC,+CAAkD;AAClD,wFAAoF;AACpF,oGAA+F;AAC/F,iDAA6C;AAC7C,uDAAmD;AACnD,iDAA6C;AAC7C,4DAAuD;AACvD,sDAAkD;AAClD,oEAA+D;AAsBxD,IAAM,UAAU,GAAhB,MAAM,UAAU;CAAG,CAAA;AAAb,gCAAU;qBAAV,UAAU;IApBtB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE;YACP,yBAAc,CAAC,QAAQ,CAAC,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC;YACnD,eAAS,CAAC,QAAQ,CAAC;gBACjB,MAAM,EAAE,OAAO,CAAC,GAAG,CAAC,UAAU,IAAI,oBAAoB;gBACtD,WAAW,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE;aAClC,CAAC;SACH;QACD,WAAW,EAAE,CAAC,gCAAc,CAAC;QAC7B,SAAS,EAAE;YACT,0BAAW;YACX,0BAAW;YACX,6BAAY;YACZ,wBAAU;YACV,qCAAgB;YAChB,0CAAmB;YACnB,qDAAwB;SACzB;QACD,OAAO,EAAE,CAAC,0BAAW,EAAE,6BAAY,EAAE,wBAAU,EAAE,qCAAgB,CAAC;KACnE,CAAC;GACW,UAAU,CAAG"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { OnModuleInit } from '@nestjs/common';
|
|
2
|
+
import { JwtService } from '@nestjs/jwt';
|
|
3
|
+
import { DeveloperRepository } from '../database/repositories/developer.repository';
|
|
4
|
+
import { RedisService } from '../redis/redis.service';
|
|
5
|
+
interface UserJwtPayload {
|
|
6
|
+
sub: number;
|
|
7
|
+
name: string;
|
|
8
|
+
role: string;
|
|
9
|
+
jti: string;
|
|
10
|
+
}
|
|
11
|
+
interface WorkerJwtPayload {
|
|
12
|
+
sub: string;
|
|
13
|
+
tokenId: number;
|
|
14
|
+
}
|
|
15
|
+
interface ChannelTokenPayload {
|
|
16
|
+
taskId: number;
|
|
17
|
+
aud: 'worker' | 'web';
|
|
18
|
+
jti: string;
|
|
19
|
+
}
|
|
20
|
+
export declare class AuthService implements OnModuleInit {
|
|
21
|
+
private readonly jwtService;
|
|
22
|
+
private readonly developerRepo;
|
|
23
|
+
private readonly redis;
|
|
24
|
+
private readonly logger;
|
|
25
|
+
constructor(jwtService: JwtService, developerRepo: DeveloperRepository, redis: RedisService);
|
|
26
|
+
onModuleInit(): void;
|
|
27
|
+
login(username: string, password: string, totpCode?: string): Promise<{
|
|
28
|
+
accessToken: string;
|
|
29
|
+
refreshToken: string;
|
|
30
|
+
} | {
|
|
31
|
+
accessToken: string;
|
|
32
|
+
totpSetup: true;
|
|
33
|
+
}>;
|
|
34
|
+
refresh(refreshToken: string): Promise<{
|
|
35
|
+
accessToken: string;
|
|
36
|
+
refreshToken: string;
|
|
37
|
+
}>;
|
|
38
|
+
logout(refreshToken: string): Promise<void>;
|
|
39
|
+
signUserJwt(developer: {
|
|
40
|
+
id: number;
|
|
41
|
+
name: string;
|
|
42
|
+
role: string;
|
|
43
|
+
}): string;
|
|
44
|
+
signRefreshToken(developer: {
|
|
45
|
+
id: number;
|
|
46
|
+
}): string;
|
|
47
|
+
signWorkerJwt(machineId: string, tokenId: number): string;
|
|
48
|
+
signChannelToken(taskId: number, aud: 'worker' | 'web'): string;
|
|
49
|
+
validateChannelToken(token: string, expectedAud: 'worker' | 'web'): Promise<ChannelTokenPayload>;
|
|
50
|
+
/**
|
|
51
|
+
* Verify a Worker JWT and return its payload.
|
|
52
|
+
* Throws UnauthorizedException on invalid/expired token.
|
|
53
|
+
*/
|
|
54
|
+
verifyWorkerJwt(token: string): WorkerJwtPayload;
|
|
55
|
+
/**
|
|
56
|
+
* Verify a User JWT and return its payload.
|
|
57
|
+
* Throws UnauthorizedException on invalid/expired token.
|
|
58
|
+
*/
|
|
59
|
+
verifyUserJwt(token: string): UserJwtPayload;
|
|
60
|
+
}
|
|
61
|
+
export {};
|
|
62
|
+
//# sourceMappingURL=auth.service.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"auth.service.d.ts","sourceRoot":"","sources":["../../src/auth/auth.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,YAAY,EAEb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAIzC,OAAO,EAAE,mBAAmB,EAAE,MAAM,+CAA+C,CAAC;AACpF,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEtD,UAAU,cAAc;IACtB,GAAG,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;IACb,GAAG,EAAE,MAAM,CAAC;CACb;AAUD,UAAU,gBAAgB;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,OAAO,EAAE,MAAM,CAAC;CACjB;AAED,UAAU,mBAAmB;IAC3B,MAAM,EAAE,MAAM,CAAC;IACf,GAAG,EAAE,QAAQ,GAAG,KAAK,CAAC;IACtB,GAAG,EAAE,MAAM,CAAC;CACb;AAED,qBACa,WAAY,YAAW,YAAY;IAI5C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,aAAa;IAC9B,OAAO,CAAC,QAAQ,CAAC,KAAK;IALxB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAgC;gBAGpC,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,mBAAmB,EAClC,KAAK,EAAE,YAAY;IAGtC,YAAY,IAAI,IAAI;IAmCd,KAAK,CACT,QAAQ,EAAE,MAAM,EAChB,QAAQ,EAAE,MAAM,EAChB,QAAQ,CAAC,EAAE,MAAM,GAChB,OAAO,CACN;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,GAC7C;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,IAAI,CAAA;KAAE,CAC3C;IAmEK,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC;QAAE,WAAW,EAAE,MAAM,CAAC;QAAC,YAAY,EAAE,MAAM,CAAA;KAAE,CAAC;IA+CrF,MAAM,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAsCjD,WAAW,CAAC,SAAS,EAAE;QACrB,EAAE,EAAE,MAAM,CAAC;QACX,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,EAAE,MAAM,CAAC;KACd,GAAG,MAAM;IAcV,gBAAgB,CAAC,SAAS,EAAE;QAAE,EAAE,EAAE,MAAM,CAAA;KAAE,GAAG,MAAM;IAanD,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,MAAM;IAYzD,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,QAAQ,GAAG,KAAK,GAAG,MAAM;IAazD,oBAAoB,CACxB,KAAK,EAAE,MAAM,EACb,WAAW,EAAE,QAAQ,GAAG,KAAK,GAC5B,OAAO,CAAC,mBAAmB,CAAC;IAoC/B;;;OAGG;IACH,eAAe,CAAC,KAAK,EAAE,MAAM,GAAG,gBAAgB;IAUhD;;;OAGG;IACH,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,cAAc;CAS7C"}
|