@tronsfey/ucli-server 0.5.0
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/README.md +423 -0
- package/README.zh.md +404 -0
- package/assets/logo.svg +138 -0
- package/dist/admin-ui/assets/index-BjdBylCY.css +1 -0
- package/dist/admin-ui/assets/index-CDwKIMTJ.js +117 -0
- package/dist/admin-ui/assets/remixicon-B25hvfAs.eot +0 -0
- package/dist/admin-ui/assets/remixicon-BTtOSOPh.svg +9709 -0
- package/dist/admin-ui/assets/remixicon-CZw4FkzQ.woff2 +0 -0
- package/dist/admin-ui/assets/remixicon-S6an_USy.woff +0 -0
- package/dist/admin-ui/assets/remixicon-sqouR8Ox.ttf +0 -0
- package/dist/admin-ui/dist/assets/index-BjdBylCY.css +1 -0
- package/dist/admin-ui/dist/assets/index-CDwKIMTJ.js +117 -0
- package/dist/admin-ui/dist/assets/index-CppEl63e.css +1 -0
- package/dist/admin-ui/dist/assets/index-DBkeGfMQ.js +117 -0
- package/dist/admin-ui/dist/assets/index-ss5EmsBH.js +117 -0
- package/dist/admin-ui/dist/assets/remixicon-B25hvfAs.eot +0 -0
- package/dist/admin-ui/dist/assets/remixicon-BTtOSOPh.svg +9709 -0
- package/dist/admin-ui/dist/assets/remixicon-CZw4FkzQ.woff2 +0 -0
- package/dist/admin-ui/dist/assets/remixicon-S6an_USy.woff +0 -0
- package/dist/admin-ui/dist/assets/remixicon-sqouR8Ox.ttf +0 -0
- package/dist/admin-ui/dist/index.html +14 -0
- package/dist/admin-ui/index.html +14 -0
- package/dist/app.module.d.ts +3 -0
- package/dist/app.module.d.ts.map +1 -0
- package/dist/app.module.js +65 -0
- package/dist/app.module.js.map +1 -0
- package/dist/auth/admin.guard.d.ts +8 -0
- package/dist/auth/admin.guard.d.ts.map +1 -0
- package/dist/auth/admin.guard.js +34 -0
- package/dist/auth/admin.guard.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 +24 -0
- package/dist/auth/auth.module.js.map +1 -0
- package/dist/auth/decorators/jwt-payload.decorator.d.ts +2 -0
- package/dist/auth/decorators/jwt-payload.decorator.d.ts.map +1 -0
- package/dist/auth/decorators/jwt-payload.decorator.js +10 -0
- package/dist/auth/decorators/jwt-payload.decorator.js.map +1 -0
- package/dist/auth/group-token.guard.d.ts +11 -0
- package/dist/auth/group-token.guard.d.ts.map +1 -0
- package/dist/auth/group-token.guard.js +53 -0
- package/dist/auth/group-token.guard.js.map +1 -0
- package/dist/cache/cache.interface.d.ts +8 -0
- package/dist/cache/cache.interface.d.ts.map +1 -0
- package/dist/cache/cache.interface.js +3 -0
- package/dist/cache/cache.interface.js.map +1 -0
- package/dist/cache/cache.module.d.ts +5 -0
- package/dist/cache/cache.module.d.ts.map +1 -0
- package/dist/cache/cache.module.js +56 -0
- package/dist/cache/cache.module.js.map +1 -0
- package/dist/cache/cache.token.d.ts +2 -0
- package/dist/cache/cache.token.d.ts.map +1 -0
- package/dist/cache/cache.token.js +5 -0
- package/dist/cache/cache.token.js.map +1 -0
- package/dist/cache/memory/memory-cache.adapter.d.ts +15 -0
- package/dist/cache/memory/memory-cache.adapter.d.ts.map +1 -0
- package/dist/cache/memory/memory-cache.adapter.js +52 -0
- package/dist/cache/memory/memory-cache.adapter.js.map +1 -0
- package/dist/cache/redis/redis-cache.adapter.d.ts +16 -0
- package/dist/cache/redis/redis-cache.adapter.d.ts.map +1 -0
- package/dist/cache/redis/redis-cache.adapter.js +63 -0
- package/dist/cache/redis/redis-cache.adapter.js.map +1 -0
- package/dist/config/app-config.module.d.ts +3 -0
- package/dist/config/app-config.module.d.ts.map +1 -0
- package/dist/config/app-config.module.js +100 -0
- package/dist/config/app-config.module.js.map +1 -0
- package/dist/config/app-config.service.d.ts +29 -0
- package/dist/config/app-config.service.d.ts.map +1 -0
- package/dist/config/app-config.service.js +66 -0
- package/dist/config/app-config.service.js.map +1 -0
- package/dist/crypto/crypto.module.d.ts +3 -0
- package/dist/crypto/crypto.module.d.ts.map +1 -0
- package/dist/crypto/crypto.module.js +22 -0
- package/dist/crypto/crypto.module.js.map +1 -0
- package/dist/crypto/encryption.service.d.ts +9 -0
- package/dist/crypto/encryption.service.d.ts.map +1 -0
- package/dist/crypto/encryption.service.js +59 -0
- package/dist/crypto/encryption.service.js.map +1 -0
- package/dist/crypto/jwt.service.d.ts +28 -0
- package/dist/crypto/jwt.service.d.ts.map +1 -0
- package/dist/crypto/jwt.service.js +72 -0
- package/dist/crypto/jwt.service.js.map +1 -0
- package/dist/groups/dto/create-group.dto.d.ts +5 -0
- package/dist/groups/dto/create-group.dto.d.ts.map +1 -0
- package/dist/groups/dto/create-group.dto.js +34 -0
- package/dist/groups/dto/create-group.dto.js.map +1 -0
- package/dist/groups/groups.controller.d.ts +9 -0
- package/dist/groups/groups.controller.d.ts.map +1 -0
- package/dist/groups/groups.controller.js +60 -0
- package/dist/groups/groups.controller.js.map +1 -0
- package/dist/groups/groups.module.d.ts +3 -0
- package/dist/groups/groups.module.d.ts.map +1 -0
- package/dist/groups/groups.module.js +25 -0
- package/dist/groups/groups.module.js.map +1 -0
- package/dist/groups/groups.service.d.ts +9 -0
- package/dist/groups/groups.service.d.ts.map +1 -0
- package/dist/groups/groups.service.js +45 -0
- package/dist/groups/groups.service.js.map +1 -0
- package/dist/health/health.controller.d.ts +13 -0
- package/dist/health/health.controller.d.ts.map +1 -0
- package/dist/health/health.controller.js +68 -0
- package/dist/health/health.controller.js.map +1 -0
- package/dist/health/health.module.d.ts +3 -0
- package/dist/health/health.module.d.ts.map +1 -0
- package/dist/health/health.module.js +22 -0
- package/dist/health/health.module.js.map +1 -0
- package/dist/main.d.ts +3 -0
- package/dist/main.d.ts.map +1 -0
- package/dist/main.js +109 -0
- package/dist/main.js.map +1 -0
- package/dist/mcp/admin-mcp.controller.d.ts +13 -0
- package/dist/mcp/admin-mcp.controller.d.ts.map +1 -0
- package/dist/mcp/admin-mcp.controller.js +105 -0
- package/dist/mcp/admin-mcp.controller.js.map +1 -0
- package/dist/mcp/client-mcp.controller.d.ts +9 -0
- package/dist/mcp/client-mcp.controller.d.ts.map +1 -0
- package/dist/mcp/client-mcp.controller.js +63 -0
- package/dist/mcp/client-mcp.controller.js.map +1 -0
- package/dist/mcp/dto/create-mcp.dto.d.ts +11 -0
- package/dist/mcp/dto/create-mcp.dto.d.ts.map +1 -0
- package/dist/mcp/dto/create-mcp.dto.js +74 -0
- package/dist/mcp/dto/create-mcp.dto.js.map +1 -0
- package/dist/mcp/dto/update-mcp.dto.d.ts +11 -0
- package/dist/mcp/dto/update-mcp.dto.d.ts.map +1 -0
- package/dist/mcp/dto/update-mcp.dto.js +71 -0
- package/dist/mcp/dto/update-mcp.dto.js.map +1 -0
- package/dist/mcp/mcp.module.d.ts +3 -0
- package/dist/mcp/mcp.module.d.ts.map +1 -0
- package/dist/mcp/mcp.module.js +26 -0
- package/dist/mcp/mcp.module.js.map +1 -0
- package/dist/mcp/mcp.service.d.ts +16 -0
- package/dist/mcp/mcp.service.d.ts.map +1 -0
- package/dist/mcp/mcp.service.js +78 -0
- package/dist/mcp/mcp.service.js.map +1 -0
- package/dist/metrics/metrics.controller.d.ts +12 -0
- package/dist/metrics/metrics.controller.d.ts.map +1 -0
- package/dist/metrics/metrics.controller.js +71 -0
- package/dist/metrics/metrics.controller.js.map +1 -0
- package/dist/metrics/metrics.module.d.ts +3 -0
- package/dist/metrics/metrics.module.d.ts.map +1 -0
- package/dist/metrics/metrics.module.js +20 -0
- package/dist/metrics/metrics.module.js.map +1 -0
- package/dist/oas/admin-oas.controller.d.ts +12 -0
- package/dist/oas/admin-oas.controller.d.ts.map +1 -0
- package/dist/oas/admin-oas.controller.js +96 -0
- package/dist/oas/admin-oas.controller.js.map +1 -0
- package/dist/oas/client-oas.controller.d.ts +9 -0
- package/dist/oas/client-oas.controller.d.ts.map +1 -0
- package/dist/oas/client-oas.controller.js +63 -0
- package/dist/oas/client-oas.controller.js.map +1 -0
- package/dist/oas/dto/create-oas.dto.d.ts +12 -0
- package/dist/oas/dto/create-oas.dto.d.ts.map +1 -0
- package/dist/oas/dto/create-oas.dto.js +82 -0
- package/dist/oas/dto/create-oas.dto.js.map +1 -0
- package/dist/oas/dto/update-oas.dto.d.ts +12 -0
- package/dist/oas/dto/update-oas.dto.d.ts.map +1 -0
- package/dist/oas/dto/update-oas.dto.js +77 -0
- package/dist/oas/dto/update-oas.dto.js.map +1 -0
- package/dist/oas/oas.module.d.ts +3 -0
- package/dist/oas/oas.module.d.ts.map +1 -0
- package/dist/oas/oas.module.js +26 -0
- package/dist/oas/oas.module.js.map +1 -0
- package/dist/oas/oas.service.d.ts +16 -0
- package/dist/oas/oas.service.d.ts.map +1 -0
- package/dist/oas/oas.service.js +79 -0
- package/dist/oas/oas.service.js.map +1 -0
- package/dist/otel/otel.d.ts +25 -0
- package/dist/otel/otel.d.ts.map +1 -0
- package/dist/otel/otel.js +61 -0
- package/dist/otel/otel.js.map +1 -0
- package/dist/storage/interfaces/repos.interface.d.ts +158 -0
- package/dist/storage/interfaces/repos.interface.d.ts.map +1 -0
- package/dist/storage/interfaces/repos.interface.js +4 -0
- package/dist/storage/interfaces/repos.interface.js.map +1 -0
- package/dist/storage/memory/memory-group.repo.d.ts +9 -0
- package/dist/storage/memory/memory-group.repo.d.ts.map +1 -0
- package/dist/storage/memory/memory-group.repo.js +33 -0
- package/dist/storage/memory/memory-group.repo.js.map +1 -0
- package/dist/storage/memory/memory-mcp.repo.d.ts +13 -0
- package/dist/storage/memory/memory-mcp.repo.d.ts.map +1 -0
- package/dist/storage/memory/memory-mcp.repo.js +65 -0
- package/dist/storage/memory/memory-mcp.repo.js.map +1 -0
- package/dist/storage/memory/memory-oas.repo.d.ts +13 -0
- package/dist/storage/memory/memory-oas.repo.d.ts.map +1 -0
- package/dist/storage/memory/memory-oas.repo.js +55 -0
- package/dist/storage/memory/memory-oas.repo.js.map +1 -0
- package/dist/storage/memory/memory-token.repo.d.ts +11 -0
- package/dist/storage/memory/memory-token.repo.d.ts.map +1 -0
- package/dist/storage/memory/memory-token.repo.js +39 -0
- package/dist/storage/memory/memory-token.repo.js.map +1 -0
- package/dist/storage/storage.module.d.ts +5 -0
- package/dist/storage/storage.module.d.ts.map +1 -0
- package/dist/storage/storage.module.js +84 -0
- package/dist/storage/storage.module.js.map +1 -0
- package/dist/storage/storage.tokens.d.ts +5 -0
- package/dist/storage/storage.tokens.d.ts.map +1 -0
- package/dist/storage/storage.tokens.js +8 -0
- package/dist/storage/storage.tokens.js.map +1 -0
- package/dist/storage/typeorm/entities/group.entity.d.ts +12 -0
- package/dist/storage/typeorm/entities/group.entity.d.ts.map +1 -0
- package/dist/storage/typeorm/entities/group.entity.js +57 -0
- package/dist/storage/typeorm/entities/group.entity.js.map +1 -0
- package/dist/storage/typeorm/entities/mcp-entry.entity.d.ts +16 -0
- package/dist/storage/typeorm/entities/mcp-entry.entity.d.ts.map +1 -0
- package/dist/storage/typeorm/entities/mcp-entry.entity.js +82 -0
- package/dist/storage/typeorm/entities/mcp-entry.entity.js.map +1 -0
- package/dist/storage/typeorm/entities/oas-entry.entity.d.ts +17 -0
- package/dist/storage/typeorm/entities/oas-entry.entity.d.ts.map +1 -0
- package/dist/storage/typeorm/entities/oas-entry.entity.js +87 -0
- package/dist/storage/typeorm/entities/oas-entry.entity.js.map +1 -0
- package/dist/storage/typeorm/entities/token.entity.d.ts +13 -0
- package/dist/storage/typeorm/entities/token.entity.d.ts.map +1 -0
- package/dist/storage/typeorm/entities/token.entity.js +68 -0
- package/dist/storage/typeorm/entities/token.entity.js.map +1 -0
- package/dist/storage/typeorm/typeorm-group.repo.d.ts +12 -0
- package/dist/storage/typeorm/typeorm-group.repo.d.ts.map +1 -0
- package/dist/storage/typeorm/typeorm-group.repo.js +50 -0
- package/dist/storage/typeorm/typeorm-group.repo.js.map +1 -0
- package/dist/storage/typeorm/typeorm-mcp.repo.d.ts +15 -0
- package/dist/storage/typeorm/typeorm-mcp.repo.d.ts.map +1 -0
- package/dist/storage/typeorm/typeorm-mcp.repo.js +88 -0
- package/dist/storage/typeorm/typeorm-mcp.repo.js.map +1 -0
- package/dist/storage/typeorm/typeorm-oas.repo.d.ts +15 -0
- package/dist/storage/typeorm/typeorm-oas.repo.d.ts.map +1 -0
- package/dist/storage/typeorm/typeorm-oas.repo.js +92 -0
- package/dist/storage/typeorm/typeorm-oas.repo.js.map +1 -0
- package/dist/storage/typeorm/typeorm-token.repo.d.ts +13 -0
- package/dist/storage/typeorm/typeorm-token.repo.d.ts.map +1 -0
- package/dist/storage/typeorm/typeorm-token.repo.js +56 -0
- package/dist/storage/typeorm/typeorm-token.repo.js.map +1 -0
- package/dist/tokens/dto/issue-token.dto.d.ts +6 -0
- package/dist/tokens/dto/issue-token.dto.d.ts.map +1 -0
- package/dist/tokens/dto/issue-token.dto.js +41 -0
- package/dist/tokens/dto/issue-token.dto.js.map +1 -0
- package/dist/tokens/tokens.controller.d.ts +12 -0
- package/dist/tokens/tokens.controller.d.ts.map +1 -0
- package/dist/tokens/tokens.controller.js +89 -0
- package/dist/tokens/tokens.controller.js.map +1 -0
- package/dist/tokens/tokens.module.d.ts +3 -0
- package/dist/tokens/tokens.module.d.ts.map +1 -0
- package/dist/tokens/tokens.module.js +27 -0
- package/dist/tokens/tokens.module.js.map +1 -0
- package/dist/tokens/tokens.service.d.ts +25 -0
- package/dist/tokens/tokens.service.d.ts.map +1 -0
- package/dist/tokens/tokens.service.js +69 -0
- package/dist/tokens/tokens.service.js.map +1 -0
- package/package.json +81 -0
|
@@ -0,0 +1,45 @@
|
|
|
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.GroupsService = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const storage_tokens_1 = require("../storage/storage.tokens");
|
|
18
|
+
let GroupsService = class GroupsService {
|
|
19
|
+
groupRepo;
|
|
20
|
+
constructor(groupRepo) {
|
|
21
|
+
this.groupRepo = groupRepo;
|
|
22
|
+
}
|
|
23
|
+
async create(data) {
|
|
24
|
+
const existing = await this.groupRepo.findByName(data.name);
|
|
25
|
+
if (existing)
|
|
26
|
+
throw new common_1.ConflictException(`Group name already exists: ${data.name}`);
|
|
27
|
+
return this.groupRepo.create(data);
|
|
28
|
+
}
|
|
29
|
+
async findAll() {
|
|
30
|
+
return this.groupRepo.findAll();
|
|
31
|
+
}
|
|
32
|
+
async findById(id) {
|
|
33
|
+
const group = await this.groupRepo.findById(id);
|
|
34
|
+
if (!group)
|
|
35
|
+
throw new common_1.NotFoundException(`Group not found: ${id}`);
|
|
36
|
+
return group;
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
exports.GroupsService = GroupsService;
|
|
40
|
+
exports.GroupsService = GroupsService = __decorate([
|
|
41
|
+
(0, common_1.Injectable)(),
|
|
42
|
+
__param(0, (0, common_1.Inject)(storage_tokens_1.GROUP_REPO)),
|
|
43
|
+
__metadata("design:paramtypes", [Object])
|
|
44
|
+
], GroupsService);
|
|
45
|
+
//# sourceMappingURL=groups.service.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"groups.service.js","sourceRoot":"","sources":["../../src/groups/groups.service.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAyF;AACzF,8DAAsD;AAI/C,IAAM,aAAa,GAAnB,MAAM,aAAa;IACyB;IAAjD,YAAiD,SAAqB;QAArB,cAAS,GAAT,SAAS,CAAY;IAAG,CAAC;IAE1E,KAAK,CAAC,MAAM,CAAC,IAAsB;QACjC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC3D,IAAI,QAAQ;YAAE,MAAM,IAAI,0BAAiB,CAAC,8BAA8B,IAAI,CAAC,IAAI,EAAE,CAAC,CAAA;QACpF,OAAO,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,IAAI,CAAC,CAAA;IACpC,CAAC;IAED,KAAK,CAAC,OAAO;QACX,OAAO,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAA;IACjC,CAAC;IAED,KAAK,CAAC,QAAQ,CAAC,EAAU;QACvB,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAC/C,IAAI,CAAC,KAAK;YAAE,MAAM,IAAI,0BAAiB,CAAC,oBAAoB,EAAE,EAAE,CAAC,CAAA;QACjE,OAAO,KAAK,CAAA;IACd,CAAC;CACF,CAAA;AAlBY,sCAAa;wBAAb,aAAa;IADzB,IAAA,mBAAU,GAAE;IAEE,WAAA,IAAA,eAAM,EAAC,2BAAU,CAAC,CAAA;;GADpB,aAAa,CAkBzB"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { HealthCheckService, HealthIndicatorResult } from '@nestjs/terminus';
|
|
2
|
+
import type { ICacheAdapter } from '../cache/cache.interface';
|
|
3
|
+
export declare class HealthController {
|
|
4
|
+
private readonly health;
|
|
5
|
+
private readonly cache;
|
|
6
|
+
constructor(health: HealthCheckService, cache: ICacheAdapter);
|
|
7
|
+
liveness(): {
|
|
8
|
+
status: string;
|
|
9
|
+
timestamp: string;
|
|
10
|
+
};
|
|
11
|
+
readiness(): Promise<import("@nestjs/terminus").HealthCheckResult<HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult, Partial<HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult> | undefined, Partial<HealthIndicatorResult<string, import("@nestjs/terminus").HealthIndicatorStatus, Record<string, any>> & HealthIndicatorResult> | undefined>>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=health.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.controller.d.ts","sourceRoot":"","sources":["../../src/health/health.controller.ts"],"names":[],"mappings":"AAEA,OAAO,EAAe,kBAAkB,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAEzF,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0BAA0B,CAAA;AAE7D,qBAEa,gBAAgB;IAEzB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACA,OAAO,CAAC,QAAQ,CAAC,KAAK;gBAD5B,MAAM,EAAE,kBAAkB,EACH,KAAK,EAAE,aAAa;IAM9D,QAAQ;;;;IAQR,SAAS;CAYV"}
|
|
@@ -0,0 +1,68 @@
|
|
|
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.HealthController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const terminus_1 = require("@nestjs/terminus");
|
|
19
|
+
const cache_token_1 = require("../cache/cache.token");
|
|
20
|
+
let HealthController = class HealthController {
|
|
21
|
+
health;
|
|
22
|
+
cache;
|
|
23
|
+
constructor(health, cache) {
|
|
24
|
+
this.health = health;
|
|
25
|
+
this.cache = cache;
|
|
26
|
+
}
|
|
27
|
+
liveness() {
|
|
28
|
+
return { status: 'ok', timestamp: new Date().toISOString() };
|
|
29
|
+
}
|
|
30
|
+
readiness() {
|
|
31
|
+
return this.health.check([
|
|
32
|
+
async () => {
|
|
33
|
+
try {
|
|
34
|
+
await this.cache.has('__readycheck__');
|
|
35
|
+
return { cache: { status: 'up' } };
|
|
36
|
+
}
|
|
37
|
+
catch (err) {
|
|
38
|
+
return { cache: { status: 'down', message: err.message } };
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
]);
|
|
42
|
+
}
|
|
43
|
+
};
|
|
44
|
+
exports.HealthController = HealthController;
|
|
45
|
+
__decorate([
|
|
46
|
+
(0, common_1.Get)('health'),
|
|
47
|
+
(0, swagger_1.ApiOperation)({ summary: 'Liveness probe' }),
|
|
48
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'Service is alive' }),
|
|
49
|
+
__metadata("design:type", Function),
|
|
50
|
+
__metadata("design:paramtypes", []),
|
|
51
|
+
__metadata("design:returntype", void 0)
|
|
52
|
+
], HealthController.prototype, "liveness", null);
|
|
53
|
+
__decorate([
|
|
54
|
+
(0, common_1.Get)('ready'),
|
|
55
|
+
(0, terminus_1.HealthCheck)(),
|
|
56
|
+
(0, swagger_1.ApiOperation)({ summary: 'Readiness probe' }),
|
|
57
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'Service is ready' }),
|
|
58
|
+
__metadata("design:type", Function),
|
|
59
|
+
__metadata("design:paramtypes", []),
|
|
60
|
+
__metadata("design:returntype", void 0)
|
|
61
|
+
], HealthController.prototype, "readiness", null);
|
|
62
|
+
exports.HealthController = HealthController = __decorate([
|
|
63
|
+
(0, swagger_1.ApiTags)('Health'),
|
|
64
|
+
(0, common_1.Controller)('api/v1'),
|
|
65
|
+
__param(1, (0, common_1.Inject)(cache_token_1.CACHE_ADAPTER)),
|
|
66
|
+
__metadata("design:paramtypes", [terminus_1.HealthCheckService, Object])
|
|
67
|
+
], HealthController);
|
|
68
|
+
//# sourceMappingURL=health.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.controller.js","sourceRoot":"","sources":["../../src/health/health.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAwD;AACxD,6CAAoE;AACpE,+CAAyF;AACzF,sDAAoD;AAK7C,IAAM,gBAAgB,GAAtB,MAAM,gBAAgB;IAER;IACuB;IAF1C,YACmB,MAA0B,EACH,KAAoB;QAD3C,WAAM,GAAN,MAAM,CAAoB;QACH,UAAK,GAAL,KAAK,CAAe;IAC3D,CAAC;IAKJ,QAAQ;QACN,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,EAAE,CAAA;IAC9D,CAAC;IAMD,SAAS;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;YACvB,KAAK,IAAoC,EAAE;gBACzC,IAAI,CAAC;oBACH,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAA;oBACtC,OAAO,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,CAAA;gBACpC,CAAC;gBAAC,OAAO,GAAG,EAAE,CAAC;oBACb,OAAO,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,EAAG,GAAa,CAAC,OAAO,EAAE,EAAE,CAAA;gBACvE,CAAC;YACH,CAAC;SACF,CAAC,CAAA;IACJ,CAAC;CACF,CAAA;AA7BY,4CAAgB;AAS3B;IAHC,IAAA,YAAG,EAAC,QAAQ,CAAC;IACb,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,gBAAgB,EAAE,CAAC;IAC3C,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC;;;;gDAG7D;AAMD;IAJC,IAAA,YAAG,EAAC,OAAO,CAAC;IACZ,IAAA,sBAAW,GAAE;IACb,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,iBAAiB,EAAE,CAAC;IAC5C,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,kBAAkB,EAAE,CAAC;;;;iDAY7D;2BA5BU,gBAAgB;IAF5B,IAAA,iBAAO,EAAC,QAAQ,CAAC;IACjB,IAAA,mBAAU,EAAC,QAAQ,CAAC;IAIhB,WAAA,IAAA,eAAM,EAAC,2BAAa,CAAC,CAAA;qCADG,6BAAkB;GAFlC,gBAAgB,CA6B5B"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.module.d.ts","sourceRoot":"","sources":["../../src/health/health.module.ts"],"names":[],"mappings":"AAIA,qBAIa,YAAY;CAAG"}
|
|
@@ -0,0 +1,22 @@
|
|
|
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.HealthModule = void 0;
|
|
10
|
+
const common_1 = require("@nestjs/common");
|
|
11
|
+
const terminus_1 = require("@nestjs/terminus");
|
|
12
|
+
const health_controller_1 = require("./health.controller");
|
|
13
|
+
let HealthModule = class HealthModule {
|
|
14
|
+
};
|
|
15
|
+
exports.HealthModule = HealthModule;
|
|
16
|
+
exports.HealthModule = HealthModule = __decorate([
|
|
17
|
+
(0, common_1.Module)({
|
|
18
|
+
imports: [terminus_1.TerminusModule],
|
|
19
|
+
controllers: [health_controller_1.HealthController],
|
|
20
|
+
})
|
|
21
|
+
], HealthModule);
|
|
22
|
+
//# sourceMappingURL=health.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"health.module.js","sourceRoot":"","sources":["../../src/health/health.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AACvC,+CAAiD;AACjD,2DAAsD;AAM/C,IAAM,YAAY,GAAlB,MAAM,YAAY;CAAG,CAAA;AAAf,oCAAY;uBAAZ,YAAY;IAJxB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,yBAAc,CAAC;QACzB,WAAW,EAAE,CAAC,oCAAgB,CAAC;KAChC,CAAC;GACW,YAAY,CAAG"}
|
package/dist/main.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.d.ts","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"AAEA,OAAO,aAAa,CAAA;AACpB,OAAO,kBAAkB,CAAA"}
|
package/dist/main.js
ADDED
|
@@ -0,0 +1,109 @@
|
|
|
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 __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
// OpenTelemetry MUST be initialized before any other imports so that
|
|
40
|
+
// auto-instrumentation can patch modules (http, express, pg, ioredis…)
|
|
41
|
+
require("./otel/otel");
|
|
42
|
+
require("reflect-metadata");
|
|
43
|
+
const node_fs_1 = require("node:fs");
|
|
44
|
+
const node_path_1 = require("node:path");
|
|
45
|
+
const core_1 = require("@nestjs/core");
|
|
46
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
47
|
+
const helmet_1 = __importDefault(require("helmet"));
|
|
48
|
+
const common_1 = require("@nestjs/common");
|
|
49
|
+
const nestjs_pino_1 = require("nestjs-pino");
|
|
50
|
+
const express = __importStar(require("express"));
|
|
51
|
+
const app_module_1 = require("./app.module");
|
|
52
|
+
const app_config_service_1 = require("./config/app-config.service");
|
|
53
|
+
async function bootstrap() {
|
|
54
|
+
const app = await core_1.NestFactory.create(app_module_1.AppModule, { bufferLogs: true });
|
|
55
|
+
app.useLogger(app.get(nestjs_pino_1.Logger));
|
|
56
|
+
const cfg = app.get(app_config_service_1.AppConfigService);
|
|
57
|
+
// Security — disable CSP when Swagger UI is enabled (it uses inline scripts/styles)
|
|
58
|
+
app.use((0, helmet_1.default)({
|
|
59
|
+
contentSecurityPolicy: cfg.swaggerEnabled ? false : undefined,
|
|
60
|
+
}));
|
|
61
|
+
app.enableCors({ origin: !cfg.isProd });
|
|
62
|
+
// Swagger / OpenAPI
|
|
63
|
+
if (cfg.swaggerEnabled) {
|
|
64
|
+
const swaggerConfig = new swagger_1.DocumentBuilder()
|
|
65
|
+
.setTitle('OAS Gateway API')
|
|
66
|
+
.setDescription('Centralized OpenAPI Specification management server.\n\n' +
|
|
67
|
+
'**Admin API** — requires `X-Admin-Secret` header.\n\n' +
|
|
68
|
+
'**Client API** — requires `Authorization: Bearer <group-jwt>` header.')
|
|
69
|
+
.setVersion('1.0')
|
|
70
|
+
.addBearerAuth({ type: 'http', scheme: 'bearer', bearerFormat: 'JWT', description: 'Group JWT issued by the admin' }, 'GroupJWT')
|
|
71
|
+
.addApiKey({ type: 'apiKey', name: 'x-admin-secret', in: 'header', description: 'Admin secret (ADMIN_SECRET env var)' }, 'AdminSecret')
|
|
72
|
+
.build();
|
|
73
|
+
const document = swagger_1.SwaggerModule.createDocument(app, swaggerConfig);
|
|
74
|
+
swagger_1.SwaggerModule.setup('api/docs', app, document, {
|
|
75
|
+
jsonDocumentUrl: 'api/openapi.json',
|
|
76
|
+
swaggerOptions: { persistAuthorization: true },
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
// Admin UI — serve the built Vite app as static files at /admin-ui
|
|
80
|
+
// Checks two locations: npm dist (dist/admin-ui/) and monorepo dev (packages/admin/dist/)
|
|
81
|
+
const adminUiPath = cfg.adminUiPath ?? [
|
|
82
|
+
(0, node_path_1.join)(__dirname, 'admin-ui'), // npm dist
|
|
83
|
+
(0, node_path_1.join)(__dirname, '..', '..', 'admin', 'dist'), // monorepo ts-node-dev
|
|
84
|
+
].find(node_fs_1.existsSync);
|
|
85
|
+
if (adminUiPath && (0, node_fs_1.existsSync)(adminUiPath)) {
|
|
86
|
+
const expressApp = app.getHttpAdapter().getInstance();
|
|
87
|
+
expressApp.use('/admin-ui', express.static(adminUiPath));
|
|
88
|
+
// SPA fallback — return index.html for all /admin-ui/* routes
|
|
89
|
+
expressApp.get('/admin-ui/*', (_req, res) => {
|
|
90
|
+
res.sendFile((0, node_path_1.join)(adminUiPath, 'index.html'));
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
// Graceful shutdown
|
|
94
|
+
app.enableShutdownHooks();
|
|
95
|
+
await app.listen(cfg.port, cfg.host);
|
|
96
|
+
const logger = new common_1.Logger('Bootstrap');
|
|
97
|
+
logger.log(`Server running on http://${cfg.host}:${cfg.port}`);
|
|
98
|
+
if (cfg.swaggerEnabled) {
|
|
99
|
+
logger.log(`Swagger UI: http://${cfg.host}:${cfg.port}/api/docs`);
|
|
100
|
+
logger.log(`OpenAPI JSON: http://${cfg.host}:${cfg.port}/api/openapi.json`);
|
|
101
|
+
}
|
|
102
|
+
if (adminUiPath && (0, node_fs_1.existsSync)(adminUiPath)) {
|
|
103
|
+
logger.log(`Admin UI: http://${cfg.host}:${cfg.port}/admin-ui`);
|
|
104
|
+
}
|
|
105
|
+
logger.log(`Storage: ${cfg.dbType} | Cache: ${cfg.cacheType} | Env: ${cfg.nodeEnv}`);
|
|
106
|
+
logger.log(`OTel: ${cfg.otelEnabled ? `enabled (endpoint=${cfg.otlpEndpoint ?? 'none (no-op)'})` : 'disabled'}`);
|
|
107
|
+
}
|
|
108
|
+
void bootstrap();
|
|
109
|
+
//# sourceMappingURL=main.js.map
|
package/dist/main.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"main.js","sourceRoot":"","sources":["../src/main.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { MCPService } from './mcp.service';
|
|
2
|
+
import { CreateMcpDto } from './dto/create-mcp.dto';
|
|
3
|
+
import { UpdateMcpDto } from './dto/update-mcp.dto';
|
|
4
|
+
export declare class AdminMCPController {
|
|
5
|
+
private readonly mcpService;
|
|
6
|
+
constructor(mcpService: MCPService);
|
|
7
|
+
create(dto: CreateMcpDto): Promise<import("../storage/interfaces/repos.interface").McpEntry>;
|
|
8
|
+
findAll(): Promise<import("../storage/interfaces/repos.interface").McpEntry[]>;
|
|
9
|
+
findById(id: string): Promise<import("../storage/interfaces/repos.interface").McpEntry>;
|
|
10
|
+
update(id: string, dto: UpdateMcpDto): Promise<import("../storage/interfaces/repos.interface").McpEntry>;
|
|
11
|
+
delete(id: string): Promise<void>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=admin-mcp.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-mcp.controller.d.ts","sourceRoot":"","sources":["../../src/mcp/admin-mcp.controller.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnD,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAEnD,qBAIa,kBAAkB;IACjB,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAAV,UAAU,EAAE,UAAU;IAOnD,MAAM,CAAS,GAAG,EAAE,YAAY;IAehC,OAAO;IAMP,QAAQ,CAAc,EAAE,EAAE,MAAM;IAMhC,MAAM,CAAc,EAAE,EAAE,MAAM,EAAU,GAAG,EAAE,YAAY;IAQnD,MAAM,CAAc,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGrD"}
|
|
@@ -0,0 +1,105 @@
|
|
|
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.AdminMCPController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const admin_guard_1 = require("../auth/admin.guard");
|
|
19
|
+
const mcp_service_1 = require("./mcp.service");
|
|
20
|
+
const create_mcp_dto_1 = require("./dto/create-mcp.dto");
|
|
21
|
+
const update_mcp_dto_1 = require("./dto/update-mcp.dto");
|
|
22
|
+
let AdminMCPController = class AdminMCPController {
|
|
23
|
+
mcpService;
|
|
24
|
+
constructor(mcpService) {
|
|
25
|
+
this.mcpService = mcpService;
|
|
26
|
+
}
|
|
27
|
+
create(dto) {
|
|
28
|
+
return this.mcpService.create({
|
|
29
|
+
groupId: dto.groupId,
|
|
30
|
+
name: dto.name,
|
|
31
|
+
description: dto.description ?? '',
|
|
32
|
+
transport: dto.transport,
|
|
33
|
+
serverUrl: dto.serverUrl,
|
|
34
|
+
command: dto.command,
|
|
35
|
+
authConfig: dto.authConfig,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
findAll() { return this.mcpService.findAll(); }
|
|
39
|
+
findById(id) { return this.mcpService.findById(id); }
|
|
40
|
+
update(id, dto) {
|
|
41
|
+
return this.mcpService.update(id, dto);
|
|
42
|
+
}
|
|
43
|
+
async delete(id) {
|
|
44
|
+
await this.mcpService.delete(id);
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
exports.AdminMCPController = AdminMCPController;
|
|
48
|
+
__decorate([
|
|
49
|
+
(0, common_1.Post)(),
|
|
50
|
+
(0, common_1.HttpCode)(201),
|
|
51
|
+
(0, swagger_1.ApiOperation)({ summary: 'Register a new MCP server' }),
|
|
52
|
+
(0, swagger_1.ApiResponse)({ status: 201, description: 'MCP server created' }),
|
|
53
|
+
(0, swagger_1.ApiResponse)({ status: 409, description: 'Server name already exists' }),
|
|
54
|
+
__param(0, (0, common_1.Body)()),
|
|
55
|
+
__metadata("design:type", Function),
|
|
56
|
+
__metadata("design:paramtypes", [create_mcp_dto_1.CreateMcpDto]),
|
|
57
|
+
__metadata("design:returntype", void 0)
|
|
58
|
+
], AdminMCPController.prototype, "create", null);
|
|
59
|
+
__decorate([
|
|
60
|
+
(0, common_1.Get)(),
|
|
61
|
+
(0, swagger_1.ApiOperation)({ summary: 'List all MCP servers' }),
|
|
62
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'List of MCP servers' }),
|
|
63
|
+
__metadata("design:type", Function),
|
|
64
|
+
__metadata("design:paramtypes", []),
|
|
65
|
+
__metadata("design:returntype", void 0)
|
|
66
|
+
], AdminMCPController.prototype, "findAll", null);
|
|
67
|
+
__decorate([
|
|
68
|
+
(0, common_1.Get)(':id'),
|
|
69
|
+
(0, swagger_1.ApiOperation)({ summary: 'Get a single MCP server by ID' }),
|
|
70
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'MCP server details' }),
|
|
71
|
+
(0, swagger_1.ApiResponse)({ status: 404, description: 'MCP server not found' }),
|
|
72
|
+
__param(0, (0, common_1.Param)('id')),
|
|
73
|
+
__metadata("design:type", Function),
|
|
74
|
+
__metadata("design:paramtypes", [String]),
|
|
75
|
+
__metadata("design:returntype", void 0)
|
|
76
|
+
], AdminMCPController.prototype, "findById", null);
|
|
77
|
+
__decorate([
|
|
78
|
+
(0, common_1.Put)(':id'),
|
|
79
|
+
(0, swagger_1.ApiOperation)({ summary: 'Update a MCP server' }),
|
|
80
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'MCP server updated' }),
|
|
81
|
+
(0, swagger_1.ApiResponse)({ status: 404, description: 'MCP server not found' }),
|
|
82
|
+
__param(0, (0, common_1.Param)('id')),
|
|
83
|
+
__param(1, (0, common_1.Body)()),
|
|
84
|
+
__metadata("design:type", Function),
|
|
85
|
+
__metadata("design:paramtypes", [String, update_mcp_dto_1.UpdateMcpDto]),
|
|
86
|
+
__metadata("design:returntype", void 0)
|
|
87
|
+
], AdminMCPController.prototype, "update", null);
|
|
88
|
+
__decorate([
|
|
89
|
+
(0, common_1.Delete)(':id'),
|
|
90
|
+
(0, common_1.HttpCode)(204),
|
|
91
|
+
(0, swagger_1.ApiOperation)({ summary: 'Delete a MCP server' }),
|
|
92
|
+
(0, swagger_1.ApiResponse)({ status: 204, description: 'MCP server deleted' }),
|
|
93
|
+
__param(0, (0, common_1.Param)('id')),
|
|
94
|
+
__metadata("design:type", Function),
|
|
95
|
+
__metadata("design:paramtypes", [String]),
|
|
96
|
+
__metadata("design:returntype", Promise)
|
|
97
|
+
], AdminMCPController.prototype, "delete", null);
|
|
98
|
+
exports.AdminMCPController = AdminMCPController = __decorate([
|
|
99
|
+
(0, swagger_1.ApiTags)('Admin / MCP'),
|
|
100
|
+
(0, swagger_1.ApiSecurity)('AdminSecret'),
|
|
101
|
+
(0, common_1.Controller)('admin/mcp'),
|
|
102
|
+
(0, common_1.UseGuards)(admin_guard_1.AdminGuard),
|
|
103
|
+
__metadata("design:paramtypes", [mcp_service_1.MCPService])
|
|
104
|
+
], AdminMCPController);
|
|
105
|
+
//# sourceMappingURL=admin-mcp.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"admin-mcp.controller.js","sourceRoot":"","sources":["../../src/mcp/admin-mcp.controller.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { JwtPayload } from '../crypto/jwt.service';
|
|
2
|
+
import { MCPService } from './mcp.service';
|
|
3
|
+
export declare class ClientMCPController {
|
|
4
|
+
private readonly mcpService;
|
|
5
|
+
constructor(mcpService: MCPService);
|
|
6
|
+
findByGroup(payload: JwtPayload): Promise<import("../storage/interfaces/repos.interface").McpEntry[]>;
|
|
7
|
+
findByName(name: string, payload: JwtPayload): Promise<import("../storage/interfaces/repos.interface").McpEntry>;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=client-mcp.controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-mcp.controller.d.ts","sourceRoot":"","sources":["../../src/mcp/client-mcp.controller.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAE1C,qBAIa,mBAAmB;IAClB,OAAO,CAAC,QAAQ,CAAC,UAAU;gBAAV,UAAU,EAAE,UAAU;IAMnD,WAAW,CAAoB,OAAO,EAAE,UAAU;IASlD,UAAU,CAAgB,IAAI,EAAE,MAAM,EAAqB,OAAO,EAAE,UAAU;CAG/E"}
|
|
@@ -0,0 +1,63 @@
|
|
|
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.ClientMCPController = void 0;
|
|
16
|
+
const common_1 = require("@nestjs/common");
|
|
17
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
18
|
+
const group_token_guard_1 = require("../auth/group-token.guard");
|
|
19
|
+
const jwt_payload_decorator_1 = require("../auth/decorators/jwt-payload.decorator");
|
|
20
|
+
const mcp_service_1 = require("./mcp.service");
|
|
21
|
+
let ClientMCPController = class ClientMCPController {
|
|
22
|
+
mcpService;
|
|
23
|
+
constructor(mcpService) {
|
|
24
|
+
this.mcpService = mcpService;
|
|
25
|
+
}
|
|
26
|
+
findByGroup(payload) {
|
|
27
|
+
return this.mcpService.findByGroup(payload.sub);
|
|
28
|
+
}
|
|
29
|
+
findByName(name, payload) {
|
|
30
|
+
return this.mcpService.findByName(name, payload.sub);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
exports.ClientMCPController = ClientMCPController;
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, common_1.Get)(),
|
|
36
|
+
(0, swagger_1.ApiOperation)({ summary: 'List MCP servers for the authenticated group' }),
|
|
37
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'List of MCP servers for the group (decrypted auth)' }),
|
|
38
|
+
(0, swagger_1.ApiResponse)({ status: 401, description: 'Invalid or expired token' }),
|
|
39
|
+
__param(0, (0, jwt_payload_decorator_1.JwtPayloadParam)()),
|
|
40
|
+
__metadata("design:type", Function),
|
|
41
|
+
__metadata("design:paramtypes", [Object]),
|
|
42
|
+
__metadata("design:returntype", void 0)
|
|
43
|
+
], ClientMCPController.prototype, "findByGroup", null);
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, common_1.Get)(':name'),
|
|
46
|
+
(0, swagger_1.ApiOperation)({ summary: 'Get a single MCP server by name (with decrypted auth)' }),
|
|
47
|
+
(0, swagger_1.ApiResponse)({ status: 200, description: 'MCP server with decrypted auth config' }),
|
|
48
|
+
(0, swagger_1.ApiResponse)({ status: 401, description: 'Invalid or expired token' }),
|
|
49
|
+
(0, swagger_1.ApiResponse)({ status: 404, description: 'MCP server not found' }),
|
|
50
|
+
__param(0, (0, common_1.Param)('name')),
|
|
51
|
+
__param(1, (0, jwt_payload_decorator_1.JwtPayloadParam)()),
|
|
52
|
+
__metadata("design:type", Function),
|
|
53
|
+
__metadata("design:paramtypes", [String, Object]),
|
|
54
|
+
__metadata("design:returntype", void 0)
|
|
55
|
+
], ClientMCPController.prototype, "findByName", null);
|
|
56
|
+
exports.ClientMCPController = ClientMCPController = __decorate([
|
|
57
|
+
(0, swagger_1.ApiTags)('Client / MCP'),
|
|
58
|
+
(0, swagger_1.ApiBearerAuth)('GroupJWT'),
|
|
59
|
+
(0, common_1.Controller)('api/v1/mcp'),
|
|
60
|
+
(0, common_1.UseGuards)(group_token_guard_1.GroupTokenGuard),
|
|
61
|
+
__metadata("design:paramtypes", [mcp_service_1.MCPService])
|
|
62
|
+
], ClientMCPController);
|
|
63
|
+
//# sourceMappingURL=client-mcp.controller.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"client-mcp.controller.js","sourceRoot":"","sources":["../../src/mcp/client-mcp.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAkE;AAClE,6CAAmF;AACnF,iEAA2D;AAC3D,oFAA0E;AAE1E,+CAA0C;AAMnC,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IACD;IAA7B,YAA6B,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;IAAG,CAAC;IAMvD,WAAW,CAAoB,OAAmB;QAChD,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,CAAC,CAAA;IACjD,CAAC;IAOD,UAAU,CAAgB,IAAY,EAAqB,OAAmB;QAC5E,OAAO,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,CAAC,CAAA;IACtD,CAAC;CACF,CAAA;AAnBY,kDAAmB;AAO9B;IAJC,IAAA,YAAG,GAAE;IACL,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,8CAA8C,EAAE,CAAC;IACzE,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,oDAAoD,EAAE,CAAC;IAC/F,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;IACzD,WAAA,IAAA,uCAAe,GAAE,CAAA;;;;sDAE7B;AAOD;IALC,IAAA,YAAG,EAAC,OAAO,CAAC;IACZ,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,uDAAuD,EAAE,CAAC;IAClF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,uCAAuC,EAAE,CAAC;IAClF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;IACrE,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtD,WAAA,IAAA,cAAK,EAAC,MAAM,CAAC,CAAA;IAAgB,WAAA,IAAA,uCAAe,GAAE,CAAA;;;;qDAEzD;8BAlBU,mBAAmB;IAJ/B,IAAA,iBAAO,EAAC,cAAc,CAAC;IACvB,IAAA,uBAAa,EAAC,UAAU,CAAC;IACzB,IAAA,mBAAU,EAAC,YAAY,CAAC;IACxB,IAAA,kBAAS,EAAC,mCAAe,CAAC;qCAEgB,wBAAU;GADxC,mBAAmB,CAmB/B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { McpAuthConfig } from '../../storage/interfaces/repos.interface';
|
|
2
|
+
export declare class CreateMcpDto {
|
|
3
|
+
groupId: string;
|
|
4
|
+
name: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
transport: 'http' | 'stdio';
|
|
7
|
+
serverUrl?: string;
|
|
8
|
+
command?: string;
|
|
9
|
+
authConfig: McpAuthConfig;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=create-mcp.dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-mcp.dto.d.ts","sourceRoot":"","sources":["../../../src/mcp/dto/create-mcp.dto.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAA;AAE7E,qBAAa,YAAY;IAGvB,OAAO,EAAG,MAAM,CAAA;IAMhB,IAAI,EAAG,MAAM,CAAA;IAMb,WAAW,CAAC,EAAE,MAAM,CAAA;IAIpB,SAAS,EAAG,MAAM,GAAG,OAAO,CAAA;IAK5B,SAAS,CAAC,EAAE,MAAM,CAAA;IAMlB,OAAO,CAAC,EAAE,MAAM,CAAA;IAWhB,UAAU,EAAG,aAAa,CAAA;CAC3B"}
|
|
@@ -0,0 +1,74 @@
|
|
|
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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.CreateMcpDto = void 0;
|
|
13
|
+
const class_validator_1 = require("class-validator");
|
|
14
|
+
const swagger_1 = require("@nestjs/swagger");
|
|
15
|
+
class CreateMcpDto {
|
|
16
|
+
groupId;
|
|
17
|
+
name;
|
|
18
|
+
description;
|
|
19
|
+
transport;
|
|
20
|
+
serverUrl;
|
|
21
|
+
command;
|
|
22
|
+
authConfig;
|
|
23
|
+
}
|
|
24
|
+
exports.CreateMcpDto = CreateMcpDto;
|
|
25
|
+
__decorate([
|
|
26
|
+
(0, swagger_1.ApiProperty)({ example: 'a1b2c3d4-...', description: 'ID of the group this MCP server belongs to', format: 'uuid' }),
|
|
27
|
+
(0, class_validator_1.IsUUID)(),
|
|
28
|
+
__metadata("design:type", String)
|
|
29
|
+
], CreateMcpDto.prototype, "groupId", void 0);
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, swagger_1.ApiProperty)({ example: 'my-mcp-server', description: 'Unique server name (lowercase alphanumeric, hyphens)' }),
|
|
32
|
+
(0, class_validator_1.IsString)(),
|
|
33
|
+
(0, class_validator_1.Length)(1, 100),
|
|
34
|
+
(0, class_validator_1.Matches)(/^[a-z0-9\-_]+$/, { message: 'name must be lowercase alphanumeric with hyphens/underscores' }),
|
|
35
|
+
__metadata("design:type", String)
|
|
36
|
+
], CreateMcpDto.prototype, "name", void 0);
|
|
37
|
+
__decorate([
|
|
38
|
+
(0, swagger_1.ApiPropertyOptional)({ example: 'My MCP server description' }),
|
|
39
|
+
(0, class_validator_1.IsOptional)(),
|
|
40
|
+
(0, class_validator_1.IsString)(),
|
|
41
|
+
(0, class_validator_1.Length)(0, 1000),
|
|
42
|
+
__metadata("design:type", String)
|
|
43
|
+
], CreateMcpDto.prototype, "description", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
(0, swagger_1.ApiProperty)({ example: 'http', enum: ['http', 'stdio'], description: 'Transport type' }),
|
|
46
|
+
(0, class_validator_1.IsEnum)(['http', 'stdio']),
|
|
47
|
+
__metadata("design:type", String)
|
|
48
|
+
], CreateMcpDto.prototype, "transport", void 0);
|
|
49
|
+
__decorate([
|
|
50
|
+
(0, swagger_1.ApiPropertyOptional)({ example: 'https://mcp.example.com/sse', description: 'Server URL (required for http transport)' }),
|
|
51
|
+
(0, class_validator_1.IsOptional)(),
|
|
52
|
+
(0, class_validator_1.IsUrl)(),
|
|
53
|
+
__metadata("design:type", String)
|
|
54
|
+
], CreateMcpDto.prototype, "serverUrl", void 0);
|
|
55
|
+
__decorate([
|
|
56
|
+
(0, swagger_1.ApiPropertyOptional)({ example: 'npx -y my-mcp-server', description: 'Command to run (required for stdio transport)' }),
|
|
57
|
+
(0, class_validator_1.IsOptional)(),
|
|
58
|
+
(0, class_validator_1.IsString)(),
|
|
59
|
+
(0, class_validator_1.Length)(1, 2048),
|
|
60
|
+
__metadata("design:type", String)
|
|
61
|
+
], CreateMcpDto.prototype, "command", void 0);
|
|
62
|
+
__decorate([
|
|
63
|
+
(0, swagger_1.ApiProperty)({
|
|
64
|
+
description: 'Auth config (shape varies by auth type)',
|
|
65
|
+
examples: {
|
|
66
|
+
none: { value: { type: 'none' } },
|
|
67
|
+
http_headers: { value: { type: 'http_headers', headers: { Authorization: 'Bearer my-token' } } },
|
|
68
|
+
env: { value: { type: 'env', env: { API_KEY: 'my-api-key' } } },
|
|
69
|
+
},
|
|
70
|
+
}),
|
|
71
|
+
(0, class_validator_1.IsObject)(),
|
|
72
|
+
__metadata("design:type", Object)
|
|
73
|
+
], CreateMcpDto.prototype, "authConfig", void 0);
|
|
74
|
+
//# sourceMappingURL=create-mcp.dto.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"create-mcp.dto.js","sourceRoot":"","sources":["../../../src/mcp/dto/create-mcp.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAAwG;AACxG,6CAAkE;AAGlE,MAAa,YAAY;IAGvB,OAAO,CAAS;IAMhB,IAAI,CAAS;IAMb,WAAW,CAAS;IAIpB,SAAS,CAAmB;IAK5B,SAAS,CAAS;IAMlB,OAAO,CAAS;IAWhB,UAAU,CAAgB;CAC3B;AA1CD,oCA0CC;AAvCC;IAFC,IAAA,qBAAW,EAAC,EAAE,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,4CAA4C,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC;IACnH,IAAA,wBAAM,GAAE;;6CACO;AAMhB;IAJC,IAAA,qBAAW,EAAC,EAAE,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,sDAAsD,EAAE,CAAC;IAC9G,IAAA,0BAAQ,GAAE;IACV,IAAA,wBAAM,EAAC,CAAC,EAAE,GAAG,CAAC;IACd,IAAA,yBAAO,EAAC,gBAAgB,EAAE,EAAE,OAAO,EAAE,8DAA8D,EAAE,CAAC;;0CAC1F;AAMb;IAJC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,2BAA2B,EAAE,CAAC;IAC7D,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,wBAAM,EAAC,CAAC,EAAE,IAAI,CAAC;;iDACI;AAIpB;IAFC,IAAA,qBAAW,EAAC,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;IACxF,IAAA,wBAAM,EAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;;+CACE;AAK5B;IAHC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,6BAA6B,EAAE,WAAW,EAAE,0CAA0C,EAAE,CAAC;IACxH,IAAA,4BAAU,GAAE;IACZ,IAAA,uBAAK,GAAE;;+CACU;AAMlB;IAJC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,WAAW,EAAE,+CAA+C,EAAE,CAAC;IACtH,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,wBAAM,EAAC,CAAC,EAAE,IAAI,CAAC;;6CACA;AAWhB;IATC,IAAA,qBAAW,EAAC;QACX,WAAW,EAAE,yCAAyC;QACtD,QAAQ,EAAE;YACR,IAAI,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,EAAE;YACjC,YAAY,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,cAAc,EAAE,OAAO,EAAE,EAAE,aAAa,EAAE,iBAAiB,EAAE,EAAE,EAAE;YAChG,GAAG,EAAE,EAAE,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,EAAE,EAAE;SAChE;KACF,CAAC;IACD,IAAA,0BAAQ,GAAE;;gDACe"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { McpAuthConfig } from '../../storage/interfaces/repos.interface';
|
|
2
|
+
export declare class UpdateMcpDto {
|
|
3
|
+
name?: string;
|
|
4
|
+
description?: string;
|
|
5
|
+
transport?: 'http' | 'stdio';
|
|
6
|
+
serverUrl?: string;
|
|
7
|
+
command?: string;
|
|
8
|
+
authConfig?: McpAuthConfig;
|
|
9
|
+
enabled?: boolean;
|
|
10
|
+
}
|
|
11
|
+
//# sourceMappingURL=update-mcp.dto.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"update-mcp.dto.d.ts","sourceRoot":"","sources":["../../../src/mcp/dto/update-mcp.dto.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,0CAA0C,CAAA;AAE7E,qBAAa,YAAY;IAMvB,IAAI,CAAC,EAAE,MAAM,CAAA;IAMb,WAAW,CAAC,EAAE,MAAM,CAAA;IAKpB,SAAS,CAAC,EAAE,MAAM,GAAG,OAAO,CAAA;IAK5B,SAAS,CAAC,EAAE,MAAM,CAAA;IAMlB,OAAO,CAAC,EAAE,MAAM,CAAA;IAKhB,UAAU,CAAC,EAAE,aAAa,CAAA;IAK1B,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB"}
|