@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.
Files changed (247) hide show
  1. package/README.md +423 -0
  2. package/README.zh.md +404 -0
  3. package/assets/logo.svg +138 -0
  4. package/dist/admin-ui/assets/index-BjdBylCY.css +1 -0
  5. package/dist/admin-ui/assets/index-CDwKIMTJ.js +117 -0
  6. package/dist/admin-ui/assets/remixicon-B25hvfAs.eot +0 -0
  7. package/dist/admin-ui/assets/remixicon-BTtOSOPh.svg +9709 -0
  8. package/dist/admin-ui/assets/remixicon-CZw4FkzQ.woff2 +0 -0
  9. package/dist/admin-ui/assets/remixicon-S6an_USy.woff +0 -0
  10. package/dist/admin-ui/assets/remixicon-sqouR8Ox.ttf +0 -0
  11. package/dist/admin-ui/dist/assets/index-BjdBylCY.css +1 -0
  12. package/dist/admin-ui/dist/assets/index-CDwKIMTJ.js +117 -0
  13. package/dist/admin-ui/dist/assets/index-CppEl63e.css +1 -0
  14. package/dist/admin-ui/dist/assets/index-DBkeGfMQ.js +117 -0
  15. package/dist/admin-ui/dist/assets/index-ss5EmsBH.js +117 -0
  16. package/dist/admin-ui/dist/assets/remixicon-B25hvfAs.eot +0 -0
  17. package/dist/admin-ui/dist/assets/remixicon-BTtOSOPh.svg +9709 -0
  18. package/dist/admin-ui/dist/assets/remixicon-CZw4FkzQ.woff2 +0 -0
  19. package/dist/admin-ui/dist/assets/remixicon-S6an_USy.woff +0 -0
  20. package/dist/admin-ui/dist/assets/remixicon-sqouR8Ox.ttf +0 -0
  21. package/dist/admin-ui/dist/index.html +14 -0
  22. package/dist/admin-ui/index.html +14 -0
  23. package/dist/app.module.d.ts +3 -0
  24. package/dist/app.module.d.ts.map +1 -0
  25. package/dist/app.module.js +65 -0
  26. package/dist/app.module.js.map +1 -0
  27. package/dist/auth/admin.guard.d.ts +8 -0
  28. package/dist/auth/admin.guard.d.ts.map +1 -0
  29. package/dist/auth/admin.guard.js +34 -0
  30. package/dist/auth/admin.guard.js.map +1 -0
  31. package/dist/auth/auth.module.d.ts +3 -0
  32. package/dist/auth/auth.module.d.ts.map +1 -0
  33. package/dist/auth/auth.module.js +24 -0
  34. package/dist/auth/auth.module.js.map +1 -0
  35. package/dist/auth/decorators/jwt-payload.decorator.d.ts +2 -0
  36. package/dist/auth/decorators/jwt-payload.decorator.d.ts.map +1 -0
  37. package/dist/auth/decorators/jwt-payload.decorator.js +10 -0
  38. package/dist/auth/decorators/jwt-payload.decorator.js.map +1 -0
  39. package/dist/auth/group-token.guard.d.ts +11 -0
  40. package/dist/auth/group-token.guard.d.ts.map +1 -0
  41. package/dist/auth/group-token.guard.js +53 -0
  42. package/dist/auth/group-token.guard.js.map +1 -0
  43. package/dist/cache/cache.interface.d.ts +8 -0
  44. package/dist/cache/cache.interface.d.ts.map +1 -0
  45. package/dist/cache/cache.interface.js +3 -0
  46. package/dist/cache/cache.interface.js.map +1 -0
  47. package/dist/cache/cache.module.d.ts +5 -0
  48. package/dist/cache/cache.module.d.ts.map +1 -0
  49. package/dist/cache/cache.module.js +56 -0
  50. package/dist/cache/cache.module.js.map +1 -0
  51. package/dist/cache/cache.token.d.ts +2 -0
  52. package/dist/cache/cache.token.d.ts.map +1 -0
  53. package/dist/cache/cache.token.js +5 -0
  54. package/dist/cache/cache.token.js.map +1 -0
  55. package/dist/cache/memory/memory-cache.adapter.d.ts +15 -0
  56. package/dist/cache/memory/memory-cache.adapter.d.ts.map +1 -0
  57. package/dist/cache/memory/memory-cache.adapter.js +52 -0
  58. package/dist/cache/memory/memory-cache.adapter.js.map +1 -0
  59. package/dist/cache/redis/redis-cache.adapter.d.ts +16 -0
  60. package/dist/cache/redis/redis-cache.adapter.d.ts.map +1 -0
  61. package/dist/cache/redis/redis-cache.adapter.js +63 -0
  62. package/dist/cache/redis/redis-cache.adapter.js.map +1 -0
  63. package/dist/config/app-config.module.d.ts +3 -0
  64. package/dist/config/app-config.module.d.ts.map +1 -0
  65. package/dist/config/app-config.module.js +100 -0
  66. package/dist/config/app-config.module.js.map +1 -0
  67. package/dist/config/app-config.service.d.ts +29 -0
  68. package/dist/config/app-config.service.d.ts.map +1 -0
  69. package/dist/config/app-config.service.js +66 -0
  70. package/dist/config/app-config.service.js.map +1 -0
  71. package/dist/crypto/crypto.module.d.ts +3 -0
  72. package/dist/crypto/crypto.module.d.ts.map +1 -0
  73. package/dist/crypto/crypto.module.js +22 -0
  74. package/dist/crypto/crypto.module.js.map +1 -0
  75. package/dist/crypto/encryption.service.d.ts +9 -0
  76. package/dist/crypto/encryption.service.d.ts.map +1 -0
  77. package/dist/crypto/encryption.service.js +59 -0
  78. package/dist/crypto/encryption.service.js.map +1 -0
  79. package/dist/crypto/jwt.service.d.ts +28 -0
  80. package/dist/crypto/jwt.service.d.ts.map +1 -0
  81. package/dist/crypto/jwt.service.js +72 -0
  82. package/dist/crypto/jwt.service.js.map +1 -0
  83. package/dist/groups/dto/create-group.dto.d.ts +5 -0
  84. package/dist/groups/dto/create-group.dto.d.ts.map +1 -0
  85. package/dist/groups/dto/create-group.dto.js +34 -0
  86. package/dist/groups/dto/create-group.dto.js.map +1 -0
  87. package/dist/groups/groups.controller.d.ts +9 -0
  88. package/dist/groups/groups.controller.d.ts.map +1 -0
  89. package/dist/groups/groups.controller.js +60 -0
  90. package/dist/groups/groups.controller.js.map +1 -0
  91. package/dist/groups/groups.module.d.ts +3 -0
  92. package/dist/groups/groups.module.d.ts.map +1 -0
  93. package/dist/groups/groups.module.js +25 -0
  94. package/dist/groups/groups.module.js.map +1 -0
  95. package/dist/groups/groups.service.d.ts +9 -0
  96. package/dist/groups/groups.service.d.ts.map +1 -0
  97. package/dist/groups/groups.service.js +45 -0
  98. package/dist/groups/groups.service.js.map +1 -0
  99. package/dist/health/health.controller.d.ts +13 -0
  100. package/dist/health/health.controller.d.ts.map +1 -0
  101. package/dist/health/health.controller.js +68 -0
  102. package/dist/health/health.controller.js.map +1 -0
  103. package/dist/health/health.module.d.ts +3 -0
  104. package/dist/health/health.module.d.ts.map +1 -0
  105. package/dist/health/health.module.js +22 -0
  106. package/dist/health/health.module.js.map +1 -0
  107. package/dist/main.d.ts +3 -0
  108. package/dist/main.d.ts.map +1 -0
  109. package/dist/main.js +109 -0
  110. package/dist/main.js.map +1 -0
  111. package/dist/mcp/admin-mcp.controller.d.ts +13 -0
  112. package/dist/mcp/admin-mcp.controller.d.ts.map +1 -0
  113. package/dist/mcp/admin-mcp.controller.js +105 -0
  114. package/dist/mcp/admin-mcp.controller.js.map +1 -0
  115. package/dist/mcp/client-mcp.controller.d.ts +9 -0
  116. package/dist/mcp/client-mcp.controller.d.ts.map +1 -0
  117. package/dist/mcp/client-mcp.controller.js +63 -0
  118. package/dist/mcp/client-mcp.controller.js.map +1 -0
  119. package/dist/mcp/dto/create-mcp.dto.d.ts +11 -0
  120. package/dist/mcp/dto/create-mcp.dto.d.ts.map +1 -0
  121. package/dist/mcp/dto/create-mcp.dto.js +74 -0
  122. package/dist/mcp/dto/create-mcp.dto.js.map +1 -0
  123. package/dist/mcp/dto/update-mcp.dto.d.ts +11 -0
  124. package/dist/mcp/dto/update-mcp.dto.d.ts.map +1 -0
  125. package/dist/mcp/dto/update-mcp.dto.js +71 -0
  126. package/dist/mcp/dto/update-mcp.dto.js.map +1 -0
  127. package/dist/mcp/mcp.module.d.ts +3 -0
  128. package/dist/mcp/mcp.module.d.ts.map +1 -0
  129. package/dist/mcp/mcp.module.js +26 -0
  130. package/dist/mcp/mcp.module.js.map +1 -0
  131. package/dist/mcp/mcp.service.d.ts +16 -0
  132. package/dist/mcp/mcp.service.d.ts.map +1 -0
  133. package/dist/mcp/mcp.service.js +78 -0
  134. package/dist/mcp/mcp.service.js.map +1 -0
  135. package/dist/metrics/metrics.controller.d.ts +12 -0
  136. package/dist/metrics/metrics.controller.d.ts.map +1 -0
  137. package/dist/metrics/metrics.controller.js +71 -0
  138. package/dist/metrics/metrics.controller.js.map +1 -0
  139. package/dist/metrics/metrics.module.d.ts +3 -0
  140. package/dist/metrics/metrics.module.d.ts.map +1 -0
  141. package/dist/metrics/metrics.module.js +20 -0
  142. package/dist/metrics/metrics.module.js.map +1 -0
  143. package/dist/oas/admin-oas.controller.d.ts +12 -0
  144. package/dist/oas/admin-oas.controller.d.ts.map +1 -0
  145. package/dist/oas/admin-oas.controller.js +96 -0
  146. package/dist/oas/admin-oas.controller.js.map +1 -0
  147. package/dist/oas/client-oas.controller.d.ts +9 -0
  148. package/dist/oas/client-oas.controller.d.ts.map +1 -0
  149. package/dist/oas/client-oas.controller.js +63 -0
  150. package/dist/oas/client-oas.controller.js.map +1 -0
  151. package/dist/oas/dto/create-oas.dto.d.ts +12 -0
  152. package/dist/oas/dto/create-oas.dto.d.ts.map +1 -0
  153. package/dist/oas/dto/create-oas.dto.js +82 -0
  154. package/dist/oas/dto/create-oas.dto.js.map +1 -0
  155. package/dist/oas/dto/update-oas.dto.d.ts +12 -0
  156. package/dist/oas/dto/update-oas.dto.d.ts.map +1 -0
  157. package/dist/oas/dto/update-oas.dto.js +77 -0
  158. package/dist/oas/dto/update-oas.dto.js.map +1 -0
  159. package/dist/oas/oas.module.d.ts +3 -0
  160. package/dist/oas/oas.module.d.ts.map +1 -0
  161. package/dist/oas/oas.module.js +26 -0
  162. package/dist/oas/oas.module.js.map +1 -0
  163. package/dist/oas/oas.service.d.ts +16 -0
  164. package/dist/oas/oas.service.d.ts.map +1 -0
  165. package/dist/oas/oas.service.js +79 -0
  166. package/dist/oas/oas.service.js.map +1 -0
  167. package/dist/otel/otel.d.ts +25 -0
  168. package/dist/otel/otel.d.ts.map +1 -0
  169. package/dist/otel/otel.js +61 -0
  170. package/dist/otel/otel.js.map +1 -0
  171. package/dist/storage/interfaces/repos.interface.d.ts +158 -0
  172. package/dist/storage/interfaces/repos.interface.d.ts.map +1 -0
  173. package/dist/storage/interfaces/repos.interface.js +4 -0
  174. package/dist/storage/interfaces/repos.interface.js.map +1 -0
  175. package/dist/storage/memory/memory-group.repo.d.ts +9 -0
  176. package/dist/storage/memory/memory-group.repo.d.ts.map +1 -0
  177. package/dist/storage/memory/memory-group.repo.js +33 -0
  178. package/dist/storage/memory/memory-group.repo.js.map +1 -0
  179. package/dist/storage/memory/memory-mcp.repo.d.ts +13 -0
  180. package/dist/storage/memory/memory-mcp.repo.d.ts.map +1 -0
  181. package/dist/storage/memory/memory-mcp.repo.js +65 -0
  182. package/dist/storage/memory/memory-mcp.repo.js.map +1 -0
  183. package/dist/storage/memory/memory-oas.repo.d.ts +13 -0
  184. package/dist/storage/memory/memory-oas.repo.d.ts.map +1 -0
  185. package/dist/storage/memory/memory-oas.repo.js +55 -0
  186. package/dist/storage/memory/memory-oas.repo.js.map +1 -0
  187. package/dist/storage/memory/memory-token.repo.d.ts +11 -0
  188. package/dist/storage/memory/memory-token.repo.d.ts.map +1 -0
  189. package/dist/storage/memory/memory-token.repo.js +39 -0
  190. package/dist/storage/memory/memory-token.repo.js.map +1 -0
  191. package/dist/storage/storage.module.d.ts +5 -0
  192. package/dist/storage/storage.module.d.ts.map +1 -0
  193. package/dist/storage/storage.module.js +84 -0
  194. package/dist/storage/storage.module.js.map +1 -0
  195. package/dist/storage/storage.tokens.d.ts +5 -0
  196. package/dist/storage/storage.tokens.d.ts.map +1 -0
  197. package/dist/storage/storage.tokens.js +8 -0
  198. package/dist/storage/storage.tokens.js.map +1 -0
  199. package/dist/storage/typeorm/entities/group.entity.d.ts +12 -0
  200. package/dist/storage/typeorm/entities/group.entity.d.ts.map +1 -0
  201. package/dist/storage/typeorm/entities/group.entity.js +57 -0
  202. package/dist/storage/typeorm/entities/group.entity.js.map +1 -0
  203. package/dist/storage/typeorm/entities/mcp-entry.entity.d.ts +16 -0
  204. package/dist/storage/typeorm/entities/mcp-entry.entity.d.ts.map +1 -0
  205. package/dist/storage/typeorm/entities/mcp-entry.entity.js +82 -0
  206. package/dist/storage/typeorm/entities/mcp-entry.entity.js.map +1 -0
  207. package/dist/storage/typeorm/entities/oas-entry.entity.d.ts +17 -0
  208. package/dist/storage/typeorm/entities/oas-entry.entity.d.ts.map +1 -0
  209. package/dist/storage/typeorm/entities/oas-entry.entity.js +87 -0
  210. package/dist/storage/typeorm/entities/oas-entry.entity.js.map +1 -0
  211. package/dist/storage/typeorm/entities/token.entity.d.ts +13 -0
  212. package/dist/storage/typeorm/entities/token.entity.d.ts.map +1 -0
  213. package/dist/storage/typeorm/entities/token.entity.js +68 -0
  214. package/dist/storage/typeorm/entities/token.entity.js.map +1 -0
  215. package/dist/storage/typeorm/typeorm-group.repo.d.ts +12 -0
  216. package/dist/storage/typeorm/typeorm-group.repo.d.ts.map +1 -0
  217. package/dist/storage/typeorm/typeorm-group.repo.js +50 -0
  218. package/dist/storage/typeorm/typeorm-group.repo.js.map +1 -0
  219. package/dist/storage/typeorm/typeorm-mcp.repo.d.ts +15 -0
  220. package/dist/storage/typeorm/typeorm-mcp.repo.d.ts.map +1 -0
  221. package/dist/storage/typeorm/typeorm-mcp.repo.js +88 -0
  222. package/dist/storage/typeorm/typeorm-mcp.repo.js.map +1 -0
  223. package/dist/storage/typeorm/typeorm-oas.repo.d.ts +15 -0
  224. package/dist/storage/typeorm/typeorm-oas.repo.d.ts.map +1 -0
  225. package/dist/storage/typeorm/typeorm-oas.repo.js +92 -0
  226. package/dist/storage/typeorm/typeorm-oas.repo.js.map +1 -0
  227. package/dist/storage/typeorm/typeorm-token.repo.d.ts +13 -0
  228. package/dist/storage/typeorm/typeorm-token.repo.d.ts.map +1 -0
  229. package/dist/storage/typeorm/typeorm-token.repo.js +56 -0
  230. package/dist/storage/typeorm/typeorm-token.repo.js.map +1 -0
  231. package/dist/tokens/dto/issue-token.dto.d.ts +6 -0
  232. package/dist/tokens/dto/issue-token.dto.d.ts.map +1 -0
  233. package/dist/tokens/dto/issue-token.dto.js +41 -0
  234. package/dist/tokens/dto/issue-token.dto.js.map +1 -0
  235. package/dist/tokens/tokens.controller.d.ts +12 -0
  236. package/dist/tokens/tokens.controller.d.ts.map +1 -0
  237. package/dist/tokens/tokens.controller.js +89 -0
  238. package/dist/tokens/tokens.controller.js.map +1 -0
  239. package/dist/tokens/tokens.module.d.ts +3 -0
  240. package/dist/tokens/tokens.module.d.ts.map +1 -0
  241. package/dist/tokens/tokens.module.js +27 -0
  242. package/dist/tokens/tokens.module.js.map +1 -0
  243. package/dist/tokens/tokens.service.d.ts +25 -0
  244. package/dist/tokens/tokens.service.d.ts.map +1 -0
  245. package/dist/tokens/tokens.service.js +69 -0
  246. package/dist/tokens/tokens.service.js.map +1 -0
  247. package/package.json +81 -0
@@ -0,0 +1,71 @@
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.UpdateMcpDto = void 0;
13
+ const class_validator_1 = require("class-validator");
14
+ const swagger_1 = require("@nestjs/swagger");
15
+ class UpdateMcpDto {
16
+ name;
17
+ description;
18
+ transport;
19
+ serverUrl;
20
+ command;
21
+ authConfig;
22
+ enabled;
23
+ }
24
+ exports.UpdateMcpDto = UpdateMcpDto;
25
+ __decorate([
26
+ (0, swagger_1.ApiPropertyOptional)({ example: 'my-mcp-server' }),
27
+ (0, class_validator_1.IsOptional)(),
28
+ (0, class_validator_1.IsString)(),
29
+ (0, class_validator_1.Length)(1, 100),
30
+ (0, class_validator_1.Matches)(/^[a-z0-9\-_]+$/, { message: 'name must be lowercase alphanumeric with hyphens/underscores' }),
31
+ __metadata("design:type", String)
32
+ ], UpdateMcpDto.prototype, "name", void 0);
33
+ __decorate([
34
+ (0, swagger_1.ApiPropertyOptional)({ example: 'Updated description' }),
35
+ (0, class_validator_1.IsOptional)(),
36
+ (0, class_validator_1.IsString)(),
37
+ (0, class_validator_1.Length)(0, 1000),
38
+ __metadata("design:type", String)
39
+ ], UpdateMcpDto.prototype, "description", void 0);
40
+ __decorate([
41
+ (0, swagger_1.ApiPropertyOptional)({ enum: ['http', 'stdio'] }),
42
+ (0, class_validator_1.IsOptional)(),
43
+ (0, class_validator_1.IsEnum)(['http', 'stdio']),
44
+ __metadata("design:type", String)
45
+ ], UpdateMcpDto.prototype, "transport", void 0);
46
+ __decorate([
47
+ (0, swagger_1.ApiPropertyOptional)({ example: 'https://mcp.example.com/sse' }),
48
+ (0, class_validator_1.IsOptional)(),
49
+ (0, class_validator_1.IsUrl)(),
50
+ __metadata("design:type", String)
51
+ ], UpdateMcpDto.prototype, "serverUrl", void 0);
52
+ __decorate([
53
+ (0, swagger_1.ApiPropertyOptional)({ example: 'npx -y my-mcp-server' }),
54
+ (0, class_validator_1.IsOptional)(),
55
+ (0, class_validator_1.IsString)(),
56
+ (0, class_validator_1.Length)(1, 2048),
57
+ __metadata("design:type", String)
58
+ ], UpdateMcpDto.prototype, "command", void 0);
59
+ __decorate([
60
+ (0, swagger_1.ApiPropertyOptional)({ description: 'Auth config' }),
61
+ (0, class_validator_1.IsOptional)(),
62
+ (0, class_validator_1.IsObject)(),
63
+ __metadata("design:type", Object)
64
+ ], UpdateMcpDto.prototype, "authConfig", void 0);
65
+ __decorate([
66
+ (0, swagger_1.ApiPropertyOptional)({ example: true }),
67
+ (0, class_validator_1.IsOptional)(),
68
+ (0, class_validator_1.IsBoolean)(),
69
+ __metadata("design:type", Boolean)
70
+ ], UpdateMcpDto.prototype, "enabled", void 0);
71
+ //# sourceMappingURL=update-mcp.dto.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-mcp.dto.js","sourceRoot":"","sources":["../../../src/mcp/dto/update-mcp.dto.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,qDAA2G;AAC3G,6CAAqD;AAGrD,MAAa,YAAY;IAMvB,IAAI,CAAS;IAMb,WAAW,CAAS;IAKpB,SAAS,CAAmB;IAK5B,SAAS,CAAS;IAMlB,OAAO,CAAS;IAKhB,UAAU,CAAgB;IAK1B,OAAO,CAAU;CAClB;AAvCD,oCAuCC;AAjCC;IALC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,eAAe,EAAE,CAAC;IACjD,IAAA,4BAAU,GAAE;IACZ,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,qBAAqB,EAAE,CAAC;IACvD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,wBAAM,EAAC,CAAC,EAAE,IAAI,CAAC;;iDACI;AAKpB;IAHC,IAAA,6BAAmB,EAAC,EAAE,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;IAChD,IAAA,4BAAU,GAAE;IACZ,IAAA,wBAAM,EAAC,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;;+CACE;AAK5B;IAHC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,6BAA6B,EAAE,CAAC;IAC/D,IAAA,4BAAU,GAAE;IACZ,IAAA,uBAAK,GAAE;;+CACU;AAMlB;IAJC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC;IACxD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;IACV,IAAA,wBAAM,EAAC,CAAC,EAAE,IAAI,CAAC;;6CACA;AAKhB;IAHC,IAAA,6BAAmB,EAAC,EAAE,WAAW,EAAE,aAAa,EAAE,CAAC;IACnD,IAAA,4BAAU,GAAE;IACZ,IAAA,0BAAQ,GAAE;;gDACe;AAK1B;IAHC,IAAA,6BAAmB,EAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;IACtC,IAAA,4BAAU,GAAE;IACZ,IAAA,2BAAS,GAAE;;6CACK"}
@@ -0,0 +1,3 @@
1
+ export declare class MCPModule {
2
+ }
3
+ //# sourceMappingURL=mcp.module.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.module.d.ts","sourceRoot":"","sources":["../../src/mcp/mcp.module.ts"],"names":[],"mappings":"AAOA,qBAKa,SAAS;CAAG"}
@@ -0,0 +1,26 @@
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.MCPModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const auth_module_1 = require("../auth/auth.module");
12
+ const crypto_module_1 = require("../crypto/crypto.module");
13
+ const admin_mcp_controller_1 = require("./admin-mcp.controller");
14
+ const client_mcp_controller_1 = require("./client-mcp.controller");
15
+ const mcp_service_1 = require("./mcp.service");
16
+ let MCPModule = class MCPModule {
17
+ };
18
+ exports.MCPModule = MCPModule;
19
+ exports.MCPModule = MCPModule = __decorate([
20
+ (0, common_1.Module)({
21
+ imports: [auth_module_1.AuthModule, crypto_module_1.CryptoModule],
22
+ controllers: [admin_mcp_controller_1.AdminMCPController, client_mcp_controller_1.ClientMCPController],
23
+ providers: [mcp_service_1.MCPService],
24
+ })
25
+ ], MCPModule);
26
+ //# sourceMappingURL=mcp.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.module.js","sourceRoot":"","sources":["../../src/mcp/mcp.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AACvC,qDAAgD;AAChD,2DAAsD;AACtD,iEAA2D;AAC3D,mEAA6D;AAC7D,+CAA0C;AAOnC,IAAM,SAAS,GAAf,MAAM,SAAS;CAAG,CAAA;AAAZ,8BAAS;oBAAT,SAAS;IALrB,IAAA,eAAM,EAAC;QACN,OAAO,EAAE,CAAC,wBAAU,EAAE,4BAAY,CAAC;QACnC,WAAW,EAAE,CAAC,yCAAkB,EAAE,2CAAmB,CAAC;QACtD,SAAS,EAAE,CAAC,wBAAU,CAAC;KACxB,CAAC;GACW,SAAS,CAAG"}
@@ -0,0 +1,16 @@
1
+ import { EncryptionService } from '../crypto/encryption.service';
2
+ import type { IMCPRepo, McpEntry, CreateMcpInput, UpdateMcpInput } from '../storage/interfaces/repos.interface';
3
+ export declare class MCPService {
4
+ private readonly mcpRepo;
5
+ private readonly encryption;
6
+ constructor(mcpRepo: IMCPRepo, encryption: EncryptionService);
7
+ create(data: CreateMcpInput): Promise<McpEntry>;
8
+ findAll(): Promise<McpEntry[]>;
9
+ findById(id: string): Promise<McpEntry>;
10
+ findByGroup(groupId: string): Promise<McpEntry[]>;
11
+ findByName(name: string, groupId?: string): Promise<McpEntry>;
12
+ update(id: string, data: UpdateMcpInput): Promise<McpEntry>;
13
+ delete(id: string): Promise<void>;
14
+ private decrypt;
15
+ }
16
+ //# sourceMappingURL=mcp.service.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.service.d.ts","sourceRoot":"","sources":["../../src/mcp/mcp.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAA;AAChE,OAAO,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,cAAc,EAAE,cAAc,EAAiB,MAAM,uCAAuC,CAAA;AAE9H,qBACa,UAAU;IAED,OAAO,CAAC,QAAQ,CAAC,OAAO;IAC1C,OAAO,CAAC,QAAQ,CAAC,UAAU;gBADQ,OAAO,EAAE,QAAQ,EACnC,UAAU,EAAE,iBAAiB;IAG1C,MAAM,CAAC,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC;IAU/C,OAAO,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;IAI9B,QAAQ,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAMvC,WAAW,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAKjD,UAAU,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC;IAO7D,MAAM,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,QAAQ,CAAC;IAW3D,MAAM,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvC,OAAO,CAAC,OAAO;CAGhB"}
@@ -0,0 +1,78 @@
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.MCPService = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const storage_tokens_1 = require("../storage/storage.tokens");
18
+ const encryption_service_1 = require("../crypto/encryption.service");
19
+ let MCPService = class MCPService {
20
+ mcpRepo;
21
+ encryption;
22
+ constructor(mcpRepo, encryption) {
23
+ this.mcpRepo = mcpRepo;
24
+ this.encryption = encryption;
25
+ }
26
+ async create(data) {
27
+ const existing = await this.mcpRepo.findByName(data.name);
28
+ if (existing)
29
+ throw new common_1.ConflictException(`MCP server name already exists: ${data.name}`);
30
+ const entry = await this.mcpRepo.create({
31
+ ...data,
32
+ authConfig: this.encryption.encrypt(data.authConfig),
33
+ });
34
+ return this.decrypt(entry);
35
+ }
36
+ async findAll() {
37
+ return (await this.mcpRepo.findAll()).map(e => this.decrypt(e));
38
+ }
39
+ async findById(id) {
40
+ const entry = await this.mcpRepo.findById(id);
41
+ if (!entry)
42
+ throw new common_1.NotFoundException(`MCP server not found: ${id}`);
43
+ return this.decrypt(entry);
44
+ }
45
+ async findByGroup(groupId) {
46
+ const entries = await this.mcpRepo.findByGroup(groupId);
47
+ return entries.filter(e => e.enabled).map(e => this.decrypt(e));
48
+ }
49
+ async findByName(name, groupId) {
50
+ const entry = await this.mcpRepo.findByName(name);
51
+ if (!entry)
52
+ throw new common_1.NotFoundException(`MCP server not found: ${name}`);
53
+ if (groupId && entry.groupId !== groupId)
54
+ throw new common_1.NotFoundException(`MCP server not found: ${name}`);
55
+ return this.decrypt(entry);
56
+ }
57
+ async update(id, data) {
58
+ const updateData = Object.fromEntries(Object.entries(data).filter(([, v]) => v !== undefined));
59
+ if (updateData.authConfig) {
60
+ updateData.authConfig = this.encryption.encrypt(updateData.authConfig);
61
+ }
62
+ const updated = await this.mcpRepo.update(id, updateData);
63
+ return this.decrypt(updated);
64
+ }
65
+ async delete(id) {
66
+ await this.mcpRepo.delete(id);
67
+ }
68
+ decrypt(entry) {
69
+ return { ...entry, authConfig: this.encryption.decrypt(entry.authConfig) };
70
+ }
71
+ };
72
+ exports.MCPService = MCPService;
73
+ exports.MCPService = MCPService = __decorate([
74
+ (0, common_1.Injectable)(),
75
+ __param(0, (0, common_1.Inject)(storage_tokens_1.MCP_REPO)),
76
+ __metadata("design:paramtypes", [Object, encryption_service_1.EncryptionService])
77
+ ], MCPService);
78
+ //# sourceMappingURL=mcp.service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mcp.service.js","sourceRoot":"","sources":["../../src/mcp/mcp.service.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { Request, Response } from 'express';
2
+ import { AppConfigService } from '../config/app-config.service';
3
+ export declare class MetricsController {
4
+ private readonly appConfig;
5
+ private readonly register;
6
+ private readonly httpRequests;
7
+ private readonly httpDuration;
8
+ constructor(appConfig: AppConfigService);
9
+ metrics(req: Request, res: Response): Promise<void>;
10
+ recordRequest(method: string, path: string, status: number, durationMs: number): void;
11
+ }
12
+ //# sourceMappingURL=metrics.controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics.controller.d.ts","sourceRoot":"","sources":["../../src/metrics/metrics.controller.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,SAAS,CAAA;AAE3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,8BAA8B,CAAA;AAE/D,qBACa,iBAAiB;IAKhB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAJtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAU;IACnC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAS;IACtC,OAAO,CAAC,QAAQ,CAAC,YAAY,CAAW;gBAEX,SAAS,EAAE,gBAAgB;IAsBlD,OAAO,CAAQ,GAAG,EAAE,OAAO,EAAS,GAAG,EAAE,QAAQ,GAAG,OAAO,CAAC,IAAI,CAAC;IAUvE,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,IAAI;CAItF"}
@@ -0,0 +1,71 @@
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.MetricsController = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const swagger_1 = require("@nestjs/swagger");
18
+ const prom_client_1 = require("prom-client");
19
+ const app_config_service_1 = require("../config/app-config.service");
20
+ let MetricsController = class MetricsController {
21
+ appConfig;
22
+ register;
23
+ httpRequests;
24
+ httpDuration;
25
+ constructor(appConfig) {
26
+ this.appConfig = appConfig;
27
+ this.register = new prom_client_1.Registry();
28
+ (0, prom_client_1.collectDefaultMetrics)({ register: this.register });
29
+ this.httpRequests = new prom_client_1.Counter({
30
+ name: 'http_requests_total',
31
+ help: 'Total HTTP requests',
32
+ labelNames: ['method', 'path', 'status'],
33
+ registers: [this.register],
34
+ });
35
+ this.httpDuration = new prom_client_1.Histogram({
36
+ name: 'http_request_duration_seconds',
37
+ help: 'HTTP request duration in seconds',
38
+ labelNames: ['method', 'path'],
39
+ buckets: [0.001, 0.005, 0.01, 0.05, 0.1, 0.5, 1, 5],
40
+ registers: [this.register],
41
+ });
42
+ }
43
+ async metrics(req, res) {
44
+ const allowedIPs = this.appConfig.metricsAllowedIPs;
45
+ if (allowedIPs.length > 0 && !allowedIPs.includes(req.ip ?? '')) {
46
+ throw new common_1.ForbiddenException('Metrics endpoint is restricted');
47
+ }
48
+ const output = await this.register.metrics();
49
+ res.setHeader('Content-Type', this.register.contentType);
50
+ res.send(output);
51
+ }
52
+ recordRequest(method, path, status, durationMs) {
53
+ this.httpRequests.labels(method, path, String(status)).inc();
54
+ this.httpDuration.labels(method, path).observe(durationMs / 1000);
55
+ }
56
+ };
57
+ exports.MetricsController = MetricsController;
58
+ __decorate([
59
+ (0, common_1.Get)('metrics'),
60
+ (0, swagger_1.ApiExcludeEndpoint)(),
61
+ __param(0, (0, common_1.Req)()),
62
+ __param(1, (0, common_1.Res)()),
63
+ __metadata("design:type", Function),
64
+ __metadata("design:paramtypes", [Object, Object]),
65
+ __metadata("design:returntype", Promise)
66
+ ], MetricsController.prototype, "metrics", null);
67
+ exports.MetricsController = MetricsController = __decorate([
68
+ (0, common_1.Controller)(),
69
+ __metadata("design:paramtypes", [app_config_service_1.AppConfigService])
70
+ ], MetricsController);
71
+ //# sourceMappingURL=metrics.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics.controller.js","sourceRoot":"","sources":["../../src/metrics/metrics.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAA8E;AAC9E,6CAAoD;AAEpD,6CAAiF;AACjF,qEAA+D;AAGxD,IAAM,iBAAiB,GAAvB,MAAM,iBAAiB;IAKC;IAJZ,QAAQ,CAAU;IAClB,YAAY,CAAS;IACrB,YAAY,CAAW;IAExC,YAA6B,SAA2B;QAA3B,cAAS,GAAT,SAAS,CAAkB;QACtD,IAAI,CAAC,QAAQ,GAAG,IAAI,sBAAQ,EAAE,CAAA;QAC9B,IAAA,mCAAqB,EAAC,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAA;QAElD,IAAI,CAAC,YAAY,GAAG,IAAI,qBAAO,CAAC;YAC9B,IAAI,EAAE,qBAAqB;YAC3B,IAAI,EAAE,qBAAqB;YAC3B,UAAU,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,QAAQ,CAAC;YACxC,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B,CAAC,CAAA;QAEF,IAAI,CAAC,YAAY,GAAG,IAAI,uBAAS,CAAC;YAChC,IAAI,EAAE,+BAA+B;YACrC,IAAI,EAAE,kCAAkC;YACxC,UAAU,EAAE,CAAC,QAAQ,EAAE,MAAM,CAAC;YAC9B,OAAO,EAAE,CAAC,KAAK,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,EAAE,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC;YACnD,SAAS,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC;SAC3B,CAAC,CAAA;IACJ,CAAC;IAIK,AAAN,KAAK,CAAC,OAAO,CAAQ,GAAY,EAAS,GAAa;QACrD,MAAM,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CAAA;QACnD,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC;YAChE,MAAM,IAAI,2BAAkB,CAAC,gCAAgC,CAAC,CAAA;QAChE,CAAC;QACD,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAA;QAC5C,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAA;QACxD,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAClB,CAAC;IAED,aAAa,CAAC,MAAc,EAAE,IAAY,EAAE,MAAc,EAAE,UAAkB;QAC5E,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAA;QAC5D,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,CAAA;IACnE,CAAC;CACF,CAAA;AAzCY,8CAAiB;AA2BtB;IAFL,IAAA,YAAG,EAAC,SAAS,CAAC;IACd,IAAA,4BAAkB,GAAE;IACN,WAAA,IAAA,YAAG,GAAE,CAAA;IAAgB,WAAA,IAAA,YAAG,GAAE,CAAA;;;;gDAQxC;4BAnCU,iBAAiB;IAD7B,IAAA,mBAAU,GAAE;qCAM6B,qCAAgB;GAL7C,iBAAiB,CAyC7B"}
@@ -0,0 +1,3 @@
1
+ export declare class MetricsModule {
2
+ }
3
+ //# sourceMappingURL=metrics.module.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics.module.d.ts","sourceRoot":"","sources":["../../src/metrics/metrics.module.ts"],"names":[],"mappings":"AAGA,qBAGa,aAAa;CAAG"}
@@ -0,0 +1,20 @@
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.MetricsModule = void 0;
10
+ const common_1 = require("@nestjs/common");
11
+ const metrics_controller_1 = require("./metrics.controller");
12
+ let MetricsModule = class MetricsModule {
13
+ };
14
+ exports.MetricsModule = MetricsModule;
15
+ exports.MetricsModule = MetricsModule = __decorate([
16
+ (0, common_1.Module)({
17
+ controllers: [metrics_controller_1.MetricsController],
18
+ })
19
+ ], MetricsModule);
20
+ //# sourceMappingURL=metrics.module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"metrics.module.js","sourceRoot":"","sources":["../../src/metrics/metrics.module.ts"],"names":[],"mappings":";;;;;;;;;AAAA,2CAAuC;AACvC,6DAAwD;AAKjD,IAAM,aAAa,GAAnB,MAAM,aAAa;CAAG,CAAA;AAAhB,sCAAa;wBAAb,aAAa;IAHzB,IAAA,eAAM,EAAC;QACN,WAAW,EAAE,CAAC,sCAAiB,CAAC;KACjC,CAAC;GACW,aAAa,CAAG"}
@@ -0,0 +1,12 @@
1
+ import { OASService } from './oas.service';
2
+ import { CreateOASDto } from './dto/create-oas.dto';
3
+ import { UpdateOASDto } from './dto/update-oas.dto';
4
+ export declare class AdminOASController {
5
+ private readonly oasService;
6
+ constructor(oasService: OASService);
7
+ create(dto: CreateOASDto): Promise<import("../storage/interfaces/repos.interface").OASEntry>;
8
+ findAll(): Promise<import("../storage/interfaces/repos.interface").OASEntry[]>;
9
+ update(id: string, dto: UpdateOASDto): Promise<import("../storage/interfaces/repos.interface").OASEntry>;
10
+ delete(id: string): Promise<void>;
11
+ }
12
+ //# sourceMappingURL=admin-oas.controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin-oas.controller.d.ts","sourceRoot":"","sources":["../../src/oas/admin-oas.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;IAgBhC,OAAO;IAMP,MAAM,CAAc,EAAE,EAAE,MAAM,EAAU,GAAG,EAAE,YAAY;IASnD,MAAM,CAAc,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAGrD"}
@@ -0,0 +1,96 @@
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.AdminOASController = 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 oas_service_1 = require("./oas.service");
20
+ const create_oas_dto_1 = require("./dto/create-oas.dto");
21
+ const update_oas_dto_1 = require("./dto/update-oas.dto");
22
+ let AdminOASController = class AdminOASController {
23
+ oasService;
24
+ constructor(oasService) {
25
+ this.oasService = oasService;
26
+ }
27
+ create(dto) {
28
+ return this.oasService.create({
29
+ groupId: dto.groupId,
30
+ name: dto.name,
31
+ description: dto.description ?? '',
32
+ remoteUrl: dto.remoteUrl,
33
+ baseEndpoint: dto.baseEndpoint,
34
+ authType: dto.authType,
35
+ authConfig: dto.authConfig,
36
+ cacheTtl: dto.cacheTtl,
37
+ });
38
+ }
39
+ findAll() { return this.oasService.findAll(); }
40
+ update(id, dto) {
41
+ return this.oasService.update(id, dto);
42
+ }
43
+ async delete(id) {
44
+ await this.oasService.delete(id);
45
+ }
46
+ };
47
+ exports.AdminOASController = AdminOASController;
48
+ __decorate([
49
+ (0, common_1.Post)(),
50
+ (0, common_1.HttpCode)(201),
51
+ (0, swagger_1.ApiOperation)({ summary: 'Register a new OAS entry' }),
52
+ (0, swagger_1.ApiResponse)({ status: 201, description: 'OAS entry created' }),
53
+ (0, swagger_1.ApiResponse)({ status: 409, description: 'Service name already exists in this group' }),
54
+ __param(0, (0, common_1.Body)()),
55
+ __metadata("design:type", Function),
56
+ __metadata("design:paramtypes", [create_oas_dto_1.CreateOASDto]),
57
+ __metadata("design:returntype", void 0)
58
+ ], AdminOASController.prototype, "create", null);
59
+ __decorate([
60
+ (0, common_1.Get)(),
61
+ (0, swagger_1.ApiOperation)({ summary: 'List all OAS entries' }),
62
+ (0, swagger_1.ApiResponse)({ status: 200, description: 'List of OAS entries' }),
63
+ __metadata("design:type", Function),
64
+ __metadata("design:paramtypes", []),
65
+ __metadata("design:returntype", void 0)
66
+ ], AdminOASController.prototype, "findAll", null);
67
+ __decorate([
68
+ (0, common_1.Put)(':id'),
69
+ (0, swagger_1.ApiOperation)({ summary: 'Update an OAS entry' }),
70
+ (0, swagger_1.ApiResponse)({ status: 200, description: 'OAS entry updated' }),
71
+ (0, swagger_1.ApiResponse)({ status: 404, description: 'OAS entry not found' }),
72
+ __param(0, (0, common_1.Param)('id')),
73
+ __param(1, (0, common_1.Body)()),
74
+ __metadata("design:type", Function),
75
+ __metadata("design:paramtypes", [String, update_oas_dto_1.UpdateOASDto]),
76
+ __metadata("design:returntype", void 0)
77
+ ], AdminOASController.prototype, "update", null);
78
+ __decorate([
79
+ (0, common_1.Delete)(':id'),
80
+ (0, common_1.HttpCode)(204),
81
+ (0, swagger_1.ApiOperation)({ summary: 'Delete an OAS entry' }),
82
+ (0, swagger_1.ApiResponse)({ status: 204, description: 'OAS entry deleted' }),
83
+ (0, swagger_1.ApiResponse)({ status: 404, description: 'OAS entry not found' }),
84
+ __param(0, (0, common_1.Param)('id')),
85
+ __metadata("design:type", Function),
86
+ __metadata("design:paramtypes", [String]),
87
+ __metadata("design:returntype", Promise)
88
+ ], AdminOASController.prototype, "delete", null);
89
+ exports.AdminOASController = AdminOASController = __decorate([
90
+ (0, swagger_1.ApiTags)('Admin / OAS'),
91
+ (0, swagger_1.ApiSecurity)('AdminSecret'),
92
+ (0, common_1.Controller)('admin/oas'),
93
+ (0, common_1.UseGuards)(admin_guard_1.AdminGuard),
94
+ __metadata("design:paramtypes", [oas_service_1.OASService])
95
+ ], AdminOASController);
96
+ //# sourceMappingURL=admin-oas.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"admin-oas.controller.js","sourceRoot":"","sources":["../../src/oas/admin-oas.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAAqG;AACrG,6CAAiF;AACjF,qDAAgD;AAChD,+CAA0C;AAC1C,yDAAmD;AACnD,yDAAmD;AAM5C,IAAM,kBAAkB,GAAxB,MAAM,kBAAkB;IACA;IAA7B,YAA6B,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;IAAG,CAAC;IAOvD,MAAM,CAAS,GAAiB;QAC9B,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;YAC5B,OAAO,EAAE,GAAG,CAAC,OAAO;YACpB,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,WAAW,EAAE,GAAG,CAAC,WAAW,IAAI,EAAE;YAClC,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,QAAQ,EAAE,GAAG,CAAC,QAAQ;SACvB,CAAC,CAAA;IACJ,CAAC;IAKD,OAAO,KAAK,OAAO,IAAI,CAAC,UAAU,CAAC,OAAO,EAAE,CAAA,CAAC,CAAC;IAM9C,MAAM,CAAc,EAAU,EAAU,GAAiB;QACvD,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,EAAE,GAAG,CAAC,CAAA;IACxC,CAAC;IAOK,AAAN,KAAK,CAAC,MAAM,CAAc,EAAU;QAClC,MAAM,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAClC,CAAC;CACF,CAAA;AA1CY,gDAAkB;AAQ7B;IALC,IAAA,aAAI,GAAE;IACN,IAAA,iBAAQ,EAAC,GAAG,CAAC;IACb,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,0BAA0B,EAAE,CAAC;IACrD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;IAC9D,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,2CAA2C,EAAE,CAAC;IAC/E,WAAA,IAAA,aAAI,GAAE,CAAA;;qCAAM,6BAAY;;gDAW/B;AAKD;IAHC,IAAA,YAAG,GAAE;IACL,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC;IACjD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC;;;;iDACnB;AAM9C;IAJC,IAAA,YAAG,EAAC,KAAK,CAAC;IACV,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,CAAC;IAChD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;IAC9D,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC;IACzD,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;IAAc,WAAA,IAAA,aAAI,GAAE,CAAA;;6CAAM,6BAAY;;gDAExD;AAOK;IALL,IAAA,eAAM,EAAC,KAAK,CAAC;IACb,IAAA,iBAAQ,EAAC,GAAG,CAAC;IACb,IAAA,sBAAY,EAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,CAAC;IAChD,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,mBAAmB,EAAE,CAAC;IAC9D,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC;IACnD,WAAA,IAAA,cAAK,EAAC,IAAI,CAAC,CAAA;;;;gDAExB;6BAzCU,kBAAkB;IAJ9B,IAAA,iBAAO,EAAC,aAAa,CAAC;IACtB,IAAA,qBAAW,EAAC,aAAa,CAAC;IAC1B,IAAA,mBAAU,EAAC,WAAW,CAAC;IACvB,IAAA,kBAAS,EAAC,wBAAU,CAAC;qCAEqB,wBAAU;GADxC,kBAAkB,CA0C9B"}
@@ -0,0 +1,9 @@
1
+ import type { JwtPayload } from '../crypto/jwt.service';
2
+ import { OASService } from './oas.service';
3
+ export declare class ClientOASController {
4
+ private readonly oasService;
5
+ constructor(oasService: OASService);
6
+ findByGroup(payload: JwtPayload): Promise<import("../storage/interfaces/repos.interface").OASEntry[]>;
7
+ findByName(name: string, payload: JwtPayload): Promise<import("../storage/interfaces/repos.interface").OASEntry>;
8
+ }
9
+ //# sourceMappingURL=client-oas.controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client-oas.controller.d.ts","sourceRoot":"","sources":["../../src/oas/client-oas.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.ClientOASController = 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 oas_service_1 = require("./oas.service");
21
+ let ClientOASController = class ClientOASController {
22
+ oasService;
23
+ constructor(oasService) {
24
+ this.oasService = oasService;
25
+ }
26
+ findByGroup(payload) {
27
+ return this.oasService.findByGroup(payload.sub);
28
+ }
29
+ findByName(name, payload) {
30
+ return this.oasService.findByName(name, payload.sub);
31
+ }
32
+ };
33
+ exports.ClientOASController = ClientOASController;
34
+ __decorate([
35
+ (0, common_1.Get)(),
36
+ (0, swagger_1.ApiOperation)({ summary: 'List OAS entries for the authenticated group' }),
37
+ (0, swagger_1.ApiResponse)({ status: 200, description: 'List of OAS entries for the group' }),
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
+ ], ClientOASController.prototype, "findByGroup", null);
44
+ __decorate([
45
+ (0, common_1.Get)(':name'),
46
+ (0, swagger_1.ApiOperation)({ summary: 'Get a single OAS entry by service name (with decrypted auth)' }),
47
+ (0, swagger_1.ApiResponse)({ status: 200, description: 'OAS entry with decrypted auth config' }),
48
+ (0, swagger_1.ApiResponse)({ status: 401, description: 'Invalid or expired token' }),
49
+ (0, swagger_1.ApiResponse)({ status: 404, description: 'OAS entry 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
+ ], ClientOASController.prototype, "findByName", null);
56
+ exports.ClientOASController = ClientOASController = __decorate([
57
+ (0, swagger_1.ApiTags)('Client / OAS'),
58
+ (0, swagger_1.ApiBearerAuth)('GroupJWT'),
59
+ (0, common_1.Controller)('api/v1/oas'),
60
+ (0, common_1.UseGuards)(group_token_guard_1.GroupTokenGuard),
61
+ __metadata("design:paramtypes", [oas_service_1.OASService])
62
+ ], ClientOASController);
63
+ //# sourceMappingURL=client-oas.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"client-oas.controller.js","sourceRoot":"","sources":["../../src/oas/client-oas.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,mCAAmC,EAAE,CAAC;IAC9E,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,8DAA8D,EAAE,CAAC;IACzF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,sCAAsC,EAAE,CAAC;IACjF,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,0BAA0B,EAAE,CAAC;IACrE,IAAA,qBAAW,EAAC,EAAE,MAAM,EAAE,GAAG,EAAE,WAAW,EAAE,qBAAqB,EAAE,CAAC;IACrD,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,12 @@
1
+ import type { AuthType, AuthConfig } from '../../storage/interfaces/repos.interface';
2
+ export declare class CreateOASDto {
3
+ groupId: string;
4
+ name: string;
5
+ description?: string;
6
+ remoteUrl: string;
7
+ baseEndpoint?: string;
8
+ authType: AuthType;
9
+ authConfig: AuthConfig;
10
+ cacheTtl?: number;
11
+ }
12
+ //# sourceMappingURL=create-oas.dto.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create-oas.dto.d.ts","sourceRoot":"","sources":["../../../src/oas/dto/create-oas.dto.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,0CAA0C,CAAA;AAEpF,qBAAa,YAAY;IAGvB,OAAO,EAAG,MAAM,CAAA;IAMhB,IAAI,EAAG,MAAM,CAAA;IAMb,WAAW,CAAC,EAAE,MAAM,CAAA;IAIpB,SAAS,EAAG,MAAM,CAAA;IAKlB,YAAY,CAAC,EAAE,MAAM,CAAA;IAIrB,QAAQ,EAAG,QAAQ,CAAA;IAanB,UAAU,EAAG,UAAU,CAAA;IAMvB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB"}