@rockster/core 0.0.4 → 0.1.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 (309) hide show
  1. package/access/access.module.js +3 -7
  2. package/access/access.module.js.map +1 -1
  3. package/access/constants.d.ts +2 -0
  4. package/access/constants.js +6 -0
  5. package/access/constants.js.map +1 -0
  6. package/access/controllers/controllers.d.ts +2 -1
  7. package/access/controllers/controllers.js +3 -1
  8. package/access/controllers/controllers.js.map +1 -1
  9. package/access/controllers/scope-access-profile.controller.d.ts +17 -0
  10. package/access/controllers/scope-access-profile.controller.js +111 -0
  11. package/access/controllers/scope-access-profile.controller.js.map +1 -0
  12. package/access/controllers/scope-group-user.controller.d.ts +11 -4
  13. package/access/controllers/scope-group-user.controller.js +57 -9
  14. package/access/controllers/scope-group-user.controller.js.map +1 -1
  15. package/access/controllers/scope-group.controller.d.ts +8 -5
  16. package/access/controllers/scope-group.controller.js +66 -12
  17. package/access/controllers/scope-group.controller.js.map +1 -1
  18. package/access/controllers/scope-owner.controller.d.ts +3 -2
  19. package/access/controllers/scope-owner.controller.js +18 -4
  20. package/access/controllers/scope-owner.controller.js.map +1 -1
  21. package/access/controllers/scope-user.controller.d.ts +2 -2
  22. package/access/controllers/scope-user.controller.js +19 -5
  23. package/access/controllers/scope-user.controller.js.map +1 -1
  24. package/access/decorators/context-params.decorator.d.ts +2 -0
  25. package/access/decorators/context-params.decorator.js +13 -0
  26. package/access/decorators/context-params.decorator.js.map +1 -0
  27. package/access/decorators/index.d.ts +2 -0
  28. package/access/decorators/index.js +19 -0
  29. package/access/decorators/index.js.map +1 -0
  30. package/access/decorators/scope-context-id-resolver.decorator.d.ts +10 -0
  31. package/access/decorators/scope-context-id-resolver.decorator.js +22 -0
  32. package/access/decorators/scope-context-id-resolver.decorator.js.map +1 -0
  33. package/access/entities/entities.d.ts +3 -1
  34. package/access/entities/entities.js +4 -0
  35. package/access/entities/entities.js.map +1 -1
  36. package/access/entities/index.d.ts +2 -0
  37. package/access/entities/index.js +2 -0
  38. package/access/entities/index.js.map +1 -1
  39. package/access/entities/scope-access-profile-key.d.ts +6 -0
  40. package/access/entities/scope-access-profile-key.js +40 -0
  41. package/access/entities/scope-access-profile-key.js.map +1 -0
  42. package/access/entities/scope-access-profile.d.ts +6 -0
  43. package/access/entities/scope-access-profile.js +37 -0
  44. package/access/entities/scope-access-profile.js.map +1 -0
  45. package/access/entities/scope-group.d.ts +3 -0
  46. package/access/entities/scope-group.js +16 -0
  47. package/access/entities/scope-group.js.map +1 -1
  48. package/access/functions/assert-context-admin-access.d.ts +15 -0
  49. package/access/functions/assert-context-admin-access.js +62 -0
  50. package/access/functions/assert-context-admin-access.js.map +1 -0
  51. package/access/functions/assert-master-or-owner.d.ts +9 -0
  52. package/access/functions/assert-master-or-owner.js +40 -0
  53. package/access/functions/assert-master-or-owner.js.map +1 -0
  54. package/access/functions/assert-scope-action-access.d.ts +32 -0
  55. package/access/functions/assert-scope-action-access.js +189 -0
  56. package/access/functions/assert-scope-action-access.js.map +1 -0
  57. package/access/functions/build-scope-resolver-initial-data.d.ts +4 -0
  58. package/access/functions/build-scope-resolver-initial-data.js +17 -0
  59. package/access/functions/build-scope-resolver-initial-data.js.map +1 -0
  60. package/access/functions/describe-action-scope.d.ts +9 -0
  61. package/access/functions/describe-action-scope.js +27 -0
  62. package/access/functions/describe-action-scope.js.map +1 -0
  63. package/access/functions/index.d.ts +5 -0
  64. package/access/functions/index.js +5 -0
  65. package/access/functions/index.js.map +1 -1
  66. package/access/functions/init-scope-service-executors.d.ts +3 -0
  67. package/access/functions/init-scope-service-executors.js +38 -0
  68. package/access/functions/init-scope-service-executors.js.map +1 -0
  69. package/access/functions/normalize-scope-keys.d.ts +4 -0
  70. package/access/functions/normalize-scope-keys.js +17 -0
  71. package/access/functions/normalize-scope-keys.js.map +1 -0
  72. package/access/functions/register-scope.d.ts +16 -5
  73. package/access/functions/register-scope.js +57 -45
  74. package/access/functions/register-scope.js.map +1 -1
  75. package/access/functions/resolve-scope-context-id.d.ts +9 -0
  76. package/access/functions/resolve-scope-context-id.js +71 -0
  77. package/access/functions/resolve-scope-context-id.js.map +1 -0
  78. package/access/functions/warn-if-public.d.ts +12 -0
  79. package/access/functions/warn-if-public.js +20 -0
  80. package/access/functions/warn-if-public.js.map +1 -0
  81. package/access/index.d.ts +2 -0
  82. package/access/index.js +2 -0
  83. package/access/index.js.map +1 -1
  84. package/access/interfaces/index.d.ts +1 -0
  85. package/access/interfaces/index.js +1 -0
  86. package/access/interfaces/index.js.map +1 -1
  87. package/access/interfaces/resolve-scope-context-id.d.ts +21 -0
  88. package/access/interfaces/resolve-scope-context-id.js +3 -0
  89. package/access/interfaces/resolve-scope-context-id.js.map +1 -0
  90. package/access/interfaces/scope-service-registry.d.ts +16 -1
  91. package/access/interfaces/scope-service.d.ts +6 -7
  92. package/access/models/scope-access-profile-keys-update.d.ts +5 -0
  93. package/access/models/scope-access-profile-keys-update.js +27 -0
  94. package/access/models/scope-access-profile-keys-update.js.map +1 -0
  95. package/access/models/scope-group-apply-access-profile.d.ts +6 -0
  96. package/access/models/scope-group-apply-access-profile.js +32 -0
  97. package/access/models/scope-group-apply-access-profile.js.map +1 -0
  98. package/access/models/scope-user-mapped.d.ts +1 -0
  99. package/access/models/scope-user-mapped.js +6 -0
  100. package/access/models/scope-user-mapped.js.map +1 -1
  101. package/access/models/scope-user.js +4 -2
  102. package/access/models/scope-user.js.map +1 -1
  103. package/access/queries/scope-access-profile.query.d.ts +1 -0
  104. package/access/queries/scope-access-profile.query.js +10 -0
  105. package/access/queries/scope-access-profile.query.js.map +1 -0
  106. package/access/queries/scope-group.query.js +9 -2
  107. package/access/queries/scope-group.query.js.map +1 -1
  108. package/access/services/index.d.ts +1 -0
  109. package/access/services/index.js +1 -0
  110. package/access/services/index.js.map +1 -1
  111. package/access/services/scope-access-profile.service.d.ts +13 -0
  112. package/access/services/scope-access-profile.service.js +75 -0
  113. package/access/services/scope-access-profile.service.js.map +1 -0
  114. package/access/services/scope-access.service.js +4 -2
  115. package/access/services/scope-access.service.js.map +1 -1
  116. package/access/services/scope-group-user.service.js +2 -2
  117. package/access/services/scope-group-user.service.js.map +1 -1
  118. package/access/services/scope-group.service.d.ts +10 -0
  119. package/access/services/scope-group.service.js +38 -1
  120. package/access/services/scope-group.service.js.map +1 -1
  121. package/access/services/scope-owner.service.d.ts +3 -0
  122. package/access/services/scope-owner.service.js +26 -1
  123. package/access/services/scope-owner.service.js.map +1 -1
  124. package/command/services/post-action-builder.js +19 -17
  125. package/command/services/post-action-builder.js.map +1 -1
  126. package/command/services/remove-action-builder.js +30 -22
  127. package/command/services/remove-action-builder.js.map +1 -1
  128. package/controllers/interfaces/controller-property.d.ts +7 -1
  129. package/controllers/services/default-action-builder.js +12 -30
  130. package/controllers/services/default-action-builder.js.map +1 -1
  131. package/controllers/services/restful-action-builder.js +25 -1
  132. package/controllers/services/restful-action-builder.js.map +1 -1
  133. package/core/contexts/request-context.d.ts +5 -0
  134. package/core/contexts/request-context.js +6 -0
  135. package/core/contexts/request-context.js.map +1 -0
  136. package/core/core.controller.js +6 -1
  137. package/core/core.controller.js.map +1 -1
  138. package/core/interfaces/action-docs.d.ts +15 -0
  139. package/core/interfaces/request-context.d.ts +5 -0
  140. package/core/services/request-router.js +2 -1
  141. package/core/services/request-router.js.map +1 -1
  142. package/database/database.controller.d.ts +1 -3
  143. package/database/database.controller.js +1 -5
  144. package/database/database.controller.js.map +1 -1
  145. package/database/decorators/protect-entity.decorator.d.ts +1 -0
  146. package/database/decorators/protect-entity.decorator.js +2 -3
  147. package/database/decorators/protect-entity.decorator.js.map +1 -1
  148. package/database/decorators/protected-entity.decorator.d.ts +1 -0
  149. package/database/decorators/protected-entity.decorator.js +2 -16
  150. package/database/decorators/protected-entity.decorator.js.map +1 -1
  151. package/database/functions/inject-repository-handle.js +4 -3
  152. package/database/functions/inject-repository-handle.js.map +1 -1
  153. package/database/interfaces/entity-object.d.ts +0 -6
  154. package/database/interfaces/index.d.ts +0 -1
  155. package/database/interfaces/index.js +0 -1
  156. package/database/interfaces/index.js.map +1 -1
  157. package/database/interfaces/repository.d.ts +8 -8
  158. package/docs/docs.module.js +3 -1
  159. package/docs/docs.module.js.map +1 -1
  160. package/docs/migrations/1747584000000-CreateDocsTables.d.ts +5 -0
  161. package/docs/migrations/1747584000000-CreateDocsTables.js +90 -0
  162. package/docs/migrations/1747584000000-CreateDocsTables.js.map +1 -0
  163. package/docs/migrations/migrations.d.ts +2 -0
  164. package/docs/migrations/migrations.js +8 -0
  165. package/docs/migrations/migrations.js.map +1 -0
  166. package/global.d.ts +2 -0
  167. package/global.js +1 -0
  168. package/global.js.map +1 -1
  169. package/index.d.ts +2 -1
  170. package/index.js +2 -1
  171. package/index.js.map +1 -1
  172. package/jobs/jobs.controller.d.ts +2 -0
  173. package/jobs/jobs.controller.js +20 -16
  174. package/jobs/jobs.controller.js.map +1 -1
  175. package/package.json +70 -70
  176. package/query/functions/add-join.js +2 -13
  177. package/query/functions/add-join.js.map +1 -1
  178. package/query/functions/create-query-builder.js +0 -10
  179. package/query/functions/create-query-builder.js.map +1 -1
  180. package/query/functions/execute-query.js +34 -0
  181. package/query/functions/execute-query.js.map +1 -1
  182. package/query/functions/load-properties.js +73 -5
  183. package/query/functions/load-properties.js.map +1 -1
  184. package/query/services/query-action-builder.js +12 -18
  185. package/query/services/query-action-builder.js.map +1 -1
  186. package/remote-logs/dtos/index.d.ts +2 -0
  187. package/remote-logs/dtos/index.js +19 -0
  188. package/remote-logs/dtos/index.js.map +1 -0
  189. package/remote-logs/dtos/remote-log-hooks.dto.d.ts +72 -0
  190. package/remote-logs/dtos/remote-log-hooks.dto.js +280 -0
  191. package/remote-logs/dtos/remote-log-hooks.dto.js.map +1 -0
  192. package/remote-logs/dtos/remote-log-search.dto.d.ts +34 -0
  193. package/remote-logs/dtos/remote-log-search.dto.js +146 -0
  194. package/remote-logs/dtos/remote-log-search.dto.js.map +1 -0
  195. package/remote-logs/environment.d.ts +4 -0
  196. package/remote-logs/environment.js +5 -0
  197. package/remote-logs/environment.js.map +1 -0
  198. package/remote-logs/index.d.ts +3 -0
  199. package/remote-logs/index.js +20 -0
  200. package/remote-logs/index.js.map +1 -0
  201. package/remote-logs/interfaces/index.d.ts +1 -0
  202. package/remote-logs/interfaces/index.js +18 -0
  203. package/remote-logs/interfaces/index.js.map +1 -0
  204. package/remote-logs/interfaces/remote-logs-module-options.d.ts +8 -0
  205. package/remote-logs/interfaces/remote-logs-module-options.js +3 -0
  206. package/remote-logs/interfaces/remote-logs-module-options.js.map +1 -0
  207. package/remote-logs/remote-logs-hooks.controller.d.ts +60 -0
  208. package/remote-logs/remote-logs-hooks.controller.js +331 -0
  209. package/remote-logs/remote-logs-hooks.controller.js.map +1 -0
  210. package/remote-logs/remote-logs.controller.d.ts +8 -0
  211. package/remote-logs/remote-logs.controller.js +41 -0
  212. package/remote-logs/remote-logs.controller.js.map +1 -0
  213. package/remote-logs/remote-logs.module.d.ts +12 -0
  214. package/remote-logs/remote-logs.module.js +107 -0
  215. package/remote-logs/remote-logs.module.js.map +1 -0
  216. package/remote-logs/services/opensearch.service.d.ts +13 -0
  217. package/remote-logs/services/opensearch.service.js +167 -0
  218. package/remote-logs/services/opensearch.service.js.map +1 -0
  219. package/security/auth.controller.js +4 -4
  220. package/security/auth.controller.js.map +1 -1
  221. package/security/functions/add-protected.d.ts +2 -2
  222. package/security/functions/add-protected.js +8 -5
  223. package/security/functions/add-protected.js.map +1 -1
  224. package/security/functions/create-authentication-interceptor.d.ts +44 -0
  225. package/security/functions/create-authentication-interceptor.js +114 -0
  226. package/security/functions/create-authentication-interceptor.js.map +1 -0
  227. package/security/functions/find-auth-context.d.ts +1 -2
  228. package/security/functions/find-auth-context.js +6 -11
  229. package/security/functions/find-auth-context.js.map +1 -1
  230. package/security/index.d.ts +1 -0
  231. package/security/index.js +1 -0
  232. package/security/index.js.map +1 -1
  233. package/security/interfaces/authorization-schema.d.ts +3 -1
  234. package/security/services/authorization.service.d.ts +5 -3
  235. package/security/services/authorization.service.js +56 -37
  236. package/security/services/authorization.service.js.map +1 -1
  237. package/storage/services/routes.service.js +1 -1
  238. package/storage/services/routes.service.js.map +1 -1
  239. package/tasks/constants.d.ts +3 -0
  240. package/tasks/constants.js +2 -1
  241. package/tasks/constants.js.map +1 -1
  242. package/tasks/controllers/task.controller.d.ts +3 -2
  243. package/tasks/controllers/task.controller.js +11 -40
  244. package/tasks/controllers/task.controller.js.map +1 -1
  245. package/tasks/decorators/index.d.ts +1 -0
  246. package/tasks/decorators/index.js +1 -0
  247. package/tasks/decorators/index.js.map +1 -1
  248. package/tasks/decorators/task-payload.decorator.d.ts +1 -0
  249. package/tasks/decorators/task-payload.decorator.js +12 -0
  250. package/tasks/decorators/task-payload.decorator.js.map +1 -0
  251. package/tasks/decorators/task.decorator.js +3 -0
  252. package/tasks/decorators/task.decorator.js.map +1 -1
  253. package/tasks/functions/compile-all-task-post-hooks.d.ts +1 -0
  254. package/tasks/functions/compile-all-task-post-hooks.js +27 -0
  255. package/tasks/functions/compile-all-task-post-hooks.js.map +1 -0
  256. package/tasks/functions/compile-task-hook-handle.d.ts +6 -0
  257. package/tasks/functions/compile-task-hook-handle.js +67 -0
  258. package/tasks/functions/compile-task-hook-handle.js.map +1 -0
  259. package/tasks/functions/create-task-hook.d.ts +9 -0
  260. package/tasks/functions/create-task-hook.js +13 -0
  261. package/tasks/functions/create-task-hook.js.map +1 -0
  262. package/tasks/functions/create-task-message-post.js +2 -0
  263. package/tasks/functions/create-task-message-post.js.map +1 -1
  264. package/tasks/functions/register-task-post-hook-interceptors.d.ts +3 -0
  265. package/tasks/functions/register-task-post-hook-interceptors.js +86 -0
  266. package/tasks/functions/register-task-post-hook-interceptors.js.map +1 -0
  267. package/tasks/functions/run-task-post-hooks.d.ts +11 -0
  268. package/tasks/functions/run-task-post-hooks.js +18 -0
  269. package/tasks/functions/run-task-post-hooks.js.map +1 -0
  270. package/tasks/functions/task-message-operations.d.ts +18 -0
  271. package/tasks/functions/task-message-operations.js +100 -0
  272. package/tasks/functions/task-message-operations.js.map +1 -0
  273. package/tasks/functions/validate-task-payload.d.ts +2 -0
  274. package/tasks/functions/validate-task-payload.js +19 -0
  275. package/tasks/functions/validate-task-payload.js.map +1 -0
  276. package/tasks/hook-constants.d.ts +2 -0
  277. package/tasks/hook-constants.js +6 -0
  278. package/tasks/hook-constants.js.map +1 -0
  279. package/tasks/index.d.ts +3 -0
  280. package/tasks/index.js +3 -0
  281. package/tasks/index.js.map +1 -1
  282. package/tasks/interfaces/compiled-task-post-hooks.d.ts +17 -0
  283. package/tasks/interfaces/compiled-task-post-hooks.js +3 -0
  284. package/tasks/interfaces/compiled-task-post-hooks.js.map +1 -0
  285. package/tasks/interfaces/index.d.ts +3 -0
  286. package/tasks/interfaces/index.js +3 -0
  287. package/tasks/interfaces/index.js.map +1 -1
  288. package/tasks/interfaces/task-hook.d.ts +16 -0
  289. package/tasks/interfaces/task-hook.js +8 -0
  290. package/tasks/interfaces/task-hook.js.map +1 -0
  291. package/tasks/interfaces/task-object.d.ts +4 -0
  292. package/tasks/interfaces/task-post-hook.d.ts +2 -0
  293. package/{database/interfaces/protector.js → tasks/interfaces/task-post-hook.js} +1 -1
  294. package/tasks/interfaces/task-post-hook.js.map +1 -0
  295. package/tasks/interfaces/task-settings.d.ts +5 -0
  296. package/tasks/services/task-runner.service.d.ts +24 -3
  297. package/tasks/services/task-runner.service.js +66 -28
  298. package/tasks/services/task-runner.service.js.map +1 -1
  299. package/database/functions/use-protector.d.ts +0 -2
  300. package/database/functions/use-protector.js +0 -11
  301. package/database/functions/use-protector.js.map +0 -1
  302. package/database/interfaces/protector.d.ts +0 -51
  303. package/database/interfaces/protector.js.map +0 -1
  304. package/database/services/protect-builder.d.ts +0 -60
  305. package/database/services/protect-builder.js +0 -524
  306. package/database/services/protect-builder.js.map +0 -1
  307. package/security/functions/add-protect.d.ts +0 -2
  308. package/security/functions/add-protect.js +0 -11
  309. package/security/functions/add-protect.js.map +0 -1
@@ -11,7 +11,6 @@ var __metadata = (this && this.__metadata) || function (k, v) {
11
11
  Object.defineProperty(exports, "__esModule", { value: true });
12
12
  exports.AccessModule = void 0;
13
13
  const env_1 = require("./env");
14
- const class_injector_1 = require("@rockster/class-injector");
15
14
  const module_decorator_1 = require("../module/decorators/module.decorator");
16
15
  const on_after_database_init_1 = require("../module/decorators/on-after-database-init");
17
16
  const entities_1 = require("./entities/entities");
@@ -19,7 +18,7 @@ const scope_access_service_1 = require("./services/scope-access.service");
19
18
  const scope_key_service_1 = require("./services/scope-key.service");
20
19
  const scope_owner_service_1 = require("./services/scope-owner.service");
21
20
  const controllers_1 = require("./controllers/controllers");
22
- const logger_1 = require("@rockster/logger");
21
+ const init_scope_service_executors_1 = require("./functions/init-scope-service-executors");
23
22
  let AccessModule = class AccessModule {
24
23
  constructor(scopeKeyService, scopeAccessService, scopeOwnerService) {
25
24
  this.scopeKeyService = scopeKeyService;
@@ -33,11 +32,8 @@ let AccessModule = class AccessModule {
33
32
  await this.initGetContextIdServices();
34
33
  }
35
34
  async initGetContextIdServices() {
36
- const services = env_1.env.scopeServiceRegistry.entries();
37
- const logger = new logger_1.Logger('Access');
38
- for (const [_, data] of services) {
39
- data.instance = await (0, class_injector_1.createInstance)(data.Service);
40
- logger.log(`[${data.Service.name}] initialized`);
35
+ for (const [contextName, data] of env_1.env.scopeServiceRegistry.entries()) {
36
+ await (0, init_scope_service_executors_1.initScopeServiceExecutors)(contextName, data.Service);
41
37
  }
42
38
  }
43
39
  };
@@ -1 +1 @@
1
- {"version":3,"file":"access.module.js","sourceRoot":"./","sources":["access/access.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+BAA4B;AAC5B,6DAA0D;AAC1D,4EAA+D;AAC/D,wFAAkF;AAClF,kDAA+C;AAC/C,0EAAqE;AACrE,oEAA+D;AAC/D,wEAAmE;AACnE,2DAAwD;AACxD,6CAA0C;AAMnC,IAAM,YAAY,GAAlB,MAAM,YAAY;IAEtB,YACsB,eAAgC,EAChC,kBAAsC,EACtC,iBAAoC;QAFpC,oBAAe,GAAf,eAAe,CAAiB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAmB;IACvD,CAAC;IAGE,AAAN,KAAK,CAAC,IAAI;QACP,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;QACvC,SAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QACjD,SAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;QAC/C,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAC;IACzC,CAAC;IAES,KAAK,CAAC,wBAAwB;QACrC,MAAM,QAAQ,GAAG,SAAG,CAAC,oBAAoB,CAAC,OAAO,EAAE,CAAC;QACpD,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,QAAQ,CAAC,CAAC;QAEpC,KAAK,MAAM,CAAC,CAAC,EAAE,IAAI,CAAC,IAAI,QAAQ,EAAE,CAAC;YAChC,IAAI,CAAC,QAAQ,GAAG,MAAM,IAAA,+BAAc,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YACnD,MAAM,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,IAAI,eAAe,CAAC,CAAC;QACpD,CAAC;IACJ,CAAC;CACH,CAAA;AAzBY,oCAAY;AAShB;IADL,IAAA,4CAAmB,GAAE;;;;wCAMrB;uBAdS,YAAY;IAJxB,IAAA,yBAAM,EAAC;QACL,QAAQ,EAAE,mBAAQ;QAClB,WAAW,EAAE,yBAAW;KAC1B,CAAC;qCAIwC,mCAAe;QACZ,yCAAkB;QACnB,uCAAiB;GALhD,YAAY,CAyBxB"}
1
+ {"version":3,"file":"access.module.js","sourceRoot":"./","sources":["access/access.module.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,+BAA4B;AAC5B,4EAA+D;AAC/D,wFAAkF;AAClF,kDAA+C;AAC/C,0EAAqE;AACrE,oEAA+D;AAC/D,wEAAmE;AACnE,2DAAwD;AACxD,2FAAqF;AAM9E,IAAM,YAAY,GAAlB,MAAM,YAAY;IAEtB,YACsB,eAAgC,EAChC,kBAAsC,EACtC,iBAAoC;QAFpC,oBAAe,GAAf,eAAe,CAAiB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAmB;IACvD,CAAC;IAGE,AAAN,KAAK,CAAC,IAAI;QACP,MAAM,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,CAAC;QACvC,SAAG,CAAC,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC;QACjD,SAAG,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC;QAC/C,MAAM,IAAI,CAAC,wBAAwB,EAAE,CAAC;IACzC,CAAC;IAES,KAAK,CAAC,wBAAwB;QACrC,KAAK,MAAM,CAAC,WAAW,EAAE,IAAI,CAAC,IAAI,SAAG,CAAC,oBAAoB,CAAC,OAAO,EAAE,EAAE,CAAC;YACpE,MAAM,IAAA,wDAAyB,EAAC,WAAW,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QAC9D,CAAC;IACJ,CAAC;CACH,CAAA;AArBY,oCAAY;AAShB;IADL,IAAA,4CAAmB,GAAE;;;;wCAMrB;uBAdS,YAAY;IAJxB,IAAA,yBAAM,EAAC;QACL,QAAQ,EAAE,mBAAQ;QAClB,WAAW,EAAE,yBAAW;KAC1B,CAAC;qCAIwC,mCAAe;QACZ,yCAAkB;QACnB,uCAAiB;GALhD,YAAY,CAqBxB"}
@@ -0,0 +1,2 @@
1
+ /** Injected into @ScopeContextIdResolver methods via @ContextParams(). */
2
+ export declare const SCOPE_CONTEXT_PARAMS_KEY = "SCOPE_CONTEXT_PARAMS";
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SCOPE_CONTEXT_PARAMS_KEY = void 0;
4
+ /** Injected into @ScopeContextIdResolver methods via @ContextParams(). */
5
+ exports.SCOPE_CONTEXT_PARAMS_KEY = "SCOPE_CONTEXT_PARAMS";
6
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"constants.js","sourceRoot":"./","sources":["access/constants.ts"],"names":[],"mappings":";;;AAAA,0EAA0E;AAC7D,QAAA,wBAAwB,GAAG,sBAAsB,CAAC"}
@@ -1,6 +1,7 @@
1
+ import { ScopeAccessProfileController } from "./scope-access-profile.controller";
1
2
  import { ScopeGroupUserController } from "./scope-group-user.controller";
2
3
  import { ScopeGroupController } from "./scope-group.controller";
3
4
  import { ScopeKeyController } from "./scope-key.controller";
4
5
  import { ScopeOwnerController } from "./scope-owner.controller";
5
6
  import { ScopeUserController } from "./scope-user.controller";
6
- export declare const controllers: (typeof ScopeGroupUserController | typeof ScopeGroupController | typeof ScopeKeyController | typeof ScopeOwnerController | typeof ScopeUserController)[];
7
+ export declare const controllers: (typeof ScopeAccessProfileController | typeof ScopeGroupUserController | typeof ScopeGroupController | typeof ScopeKeyController | typeof ScopeOwnerController | typeof ScopeUserController)[];
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.controllers = void 0;
4
+ const scope_access_profile_controller_1 = require("./scope-access-profile.controller");
4
5
  const scope_group_user_controller_1 = require("./scope-group-user.controller");
5
6
  const scope_group_controller_1 = require("./scope-group.controller");
6
7
  const scope_key_controller_1 = require("./scope-key.controller");
@@ -11,6 +12,7 @@ exports.controllers = [
11
12
  scope_user_controller_1.ScopeUserController,
12
13
  scope_owner_controller_1.ScopeOwnerController,
13
14
  scope_group_controller_1.ScopeGroupController,
14
- scope_group_user_controller_1.ScopeGroupUserController
15
+ scope_group_user_controller_1.ScopeGroupUserController,
16
+ scope_access_profile_controller_1.ScopeAccessProfileController,
15
17
  ];
16
18
  //# sourceMappingURL=controllers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"controllers.js","sourceRoot":"./","sources":["access/controllers/controllers.ts"],"names":[],"mappings":";;;AAAA,+EAAyE;AACzE,qEAAgE;AAChE,iEAA4D;AAC5D,qEAAgE;AAChE,mEAA8D;AAEjD,QAAA,WAAW,GAAG;IACxB,yCAAkB;IAClB,2CAAmB;IACnB,6CAAoB;IACpB,6CAAoB;IACpB,sDAAwB;CAC1B,CAAC"}
1
+ {"version":3,"file":"controllers.js","sourceRoot":"./","sources":["access/controllers/controllers.ts"],"names":[],"mappings":";;;AAAA,uFAAiF;AACjF,+EAAyE;AACzE,qEAAgE;AAChE,iEAA4D;AAC5D,qEAAgE;AAChE,mEAA8D;AAEjD,QAAA,WAAW,GAAG;IACxB,yCAAkB;IAClB,2CAAmB;IACnB,6CAAoB;IACpB,6CAAoB;IACpB,sDAAwB;IACxB,8DAA4B;CAC9B,CAAC"}
@@ -0,0 +1,17 @@
1
+ import { IScopeAccessProfile } from "@rockster/common/access";
2
+ import { IPostContent } from "../../command/interfaces/post-content";
3
+ import { IRemoveContent } from "../../command/interfaces/remove-content";
4
+ import { IQueryContent } from "../../query/interfaces/query";
5
+ import { ScopeAccessProfile } from "../entities/scope-access-profile";
6
+ import { ScopeAccessProfileService } from "../services/scope-access-profile.service";
7
+ import { ScopeAccessProfileKeysUpdate } from "../models/scope-access-profile-keys-update";
8
+ import { IRequestContext } from "../../core/interfaces/request-context";
9
+ export declare class ScopeAccessProfileController {
10
+ protected readonly scopeAccessProfileService: ScopeAccessProfileService;
11
+ constructor(scopeAccessProfileService: ScopeAccessProfileService);
12
+ updateKeys(content: ScopeAccessProfileKeysUpdate, requestContext: IRequestContext): Promise<import("@rockster/common/access").IScopeAccessProfileKey[]>;
13
+ query(content: IQueryContent<IScopeAccessProfile>): Promise<import("../../query/interfaces/query").Query<IScopeAccessProfile>>;
14
+ post(content: IPostContent<IScopeAccessProfile>, requestContext: IRequestContext): Promise<IScopeAccessProfile>;
15
+ remove(content: IRemoveContent, requestContext: IRequestContext): Promise<void>;
16
+ get(profileId: string): Promise<ScopeAccessProfile>;
17
+ }
@@ -0,0 +1,111 @@
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.ScopeAccessProfileController = void 0;
16
+ const post_action_decorator_1 = require("../../command/decorators/post-action.decorator");
17
+ const post_content_decorator_1 = require("../../command/decorators/post-content.decorator");
18
+ const controller_decorator_1 = require("../../controllers/decorators/controller.decorator");
19
+ const remove_action_decorator_1 = require("../../command/decorators/remove-action.decorator");
20
+ const execute_remove_1 = require("../../command/functions/execute-remove");
21
+ const remove_content_decorator_1 = require("../../command/decorators/remove-content.decorator");
22
+ const execute_post_1 = require("../../command/functions/execute-post");
23
+ const query_content_decorator_1 = require("../../query/decorators/query-content.decorator");
24
+ const execute_query_1 = require("../../query/functions/execute-query");
25
+ const scope_access_profile_1 = require("../entities/scope-access-profile");
26
+ const scope_access_profile_query_1 = require("../queries/scope-access-profile.query");
27
+ const action_content_decorator_1 = require("../../controllers/decorators/actions/action-content.decorator");
28
+ const action_decorator_1 = require("../../controllers/decorators/actions/action.decorator");
29
+ const response_type_decorator_1 = require("../../controllers/decorators/http-methods/response-type.decorator");
30
+ const from_params_decorator_1 = require("../../controllers/decorators/http-methods/from-params.decorator");
31
+ const get_decorator_1 = require("../../controllers/decorators/http-methods/get.decorator");
32
+ const scope_access_profile_service_1 = require("../services/scope-access-profile.service");
33
+ const scope_access_profile_keys_update_1 = require("../models/scope-access-profile-keys-update");
34
+ const normalize_scope_keys_1 = require("../functions/normalize-scope-keys");
35
+ const request_context_decorator_1 = require("../../controllers/decorators/request-context.decorator");
36
+ const assert_master_or_owner_1 = require("../functions/assert-master-or-owner");
37
+ let ScopeAccessProfileController = class ScopeAccessProfileController {
38
+ constructor(scopeAccessProfileService) {
39
+ this.scopeAccessProfileService = scopeAccessProfileService;
40
+ }
41
+ async updateKeys(content, requestContext) {
42
+ await (0, assert_master_or_owner_1.assertMasterOrOwner)(requestContext.session?.userId);
43
+ return this.scopeAccessProfileService.updateKeys(content.scopeAccessProfileId, (0, normalize_scope_keys_1.normalizeScopeKeys)(content.keys));
44
+ }
45
+ async query(content) {
46
+ return (0, execute_query_1.executeQuery)({ content });
47
+ }
48
+ async post(content, requestContext) {
49
+ await (0, assert_master_or_owner_1.assertMasterOrOwner)(requestContext.session?.userId);
50
+ return (0, execute_post_1.executePost)(content);
51
+ }
52
+ async remove(content, requestContext) {
53
+ await (0, assert_master_or_owner_1.assertMasterOrOwner)(requestContext.session?.userId);
54
+ return (0, execute_remove_1.executeRemove)(content);
55
+ }
56
+ async get(profileId) {
57
+ const profile = await this.scopeAccessProfileService.getOneBy({
58
+ id: profileId,
59
+ });
60
+ const keys = await this.scopeAccessProfileService.getProfileKeys(profileId);
61
+ return {
62
+ ...profile,
63
+ keys,
64
+ };
65
+ }
66
+ };
67
+ exports.ScopeAccessProfileController = ScopeAccessProfileController;
68
+ __decorate([
69
+ (0, action_decorator_1.Action)(),
70
+ __param(0, (0, action_content_decorator_1.ActionContent)()),
71
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
72
+ __metadata("design:type", Function),
73
+ __metadata("design:paramtypes", [scope_access_profile_keys_update_1.ScopeAccessProfileKeysUpdate, Object]),
74
+ __metadata("design:returntype", Promise)
75
+ ], ScopeAccessProfileController.prototype, "updateKeys", null);
76
+ __decorate([
77
+ (0, scope_access_profile_query_1.ScopeAccessProfileQuery)(),
78
+ __param(0, (0, query_content_decorator_1.QueryContent)()),
79
+ __metadata("design:type", Function),
80
+ __metadata("design:paramtypes", [Object]),
81
+ __metadata("design:returntype", Promise)
82
+ ], ScopeAccessProfileController.prototype, "query", null);
83
+ __decorate([
84
+ (0, post_action_decorator_1.PostAction)({ type: () => scope_access_profile_1.ScopeAccessProfile }),
85
+ __param(0, (0, post_content_decorator_1.PostContent)()),
86
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
87
+ __metadata("design:type", Function),
88
+ __metadata("design:paramtypes", [Object, Object]),
89
+ __metadata("design:returntype", Promise)
90
+ ], ScopeAccessProfileController.prototype, "post", null);
91
+ __decorate([
92
+ (0, remove_action_decorator_1.RemoveAction)({ type: () => scope_access_profile_1.ScopeAccessProfile }),
93
+ __param(0, (0, remove_content_decorator_1.RemoveContent)()),
94
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
95
+ __metadata("design:type", Function),
96
+ __metadata("design:paramtypes", [Object, Object]),
97
+ __metadata("design:returntype", Promise)
98
+ ], ScopeAccessProfileController.prototype, "remove", null);
99
+ __decorate([
100
+ (0, response_type_decorator_1.ResponseType)(() => scope_access_profile_1.ScopeAccessProfile),
101
+ (0, get_decorator_1.Get)(":profileId"),
102
+ __param(0, (0, from_params_decorator_1.FromParams)("profileId")),
103
+ __metadata("design:type", Function),
104
+ __metadata("design:paramtypes", [String]),
105
+ __metadata("design:returntype", Promise)
106
+ ], ScopeAccessProfileController.prototype, "get", null);
107
+ exports.ScopeAccessProfileController = ScopeAccessProfileController = __decorate([
108
+ (0, controller_decorator_1.Controller)(),
109
+ __metadata("design:paramtypes", [scope_access_profile_service_1.ScopeAccessProfileService])
110
+ ], ScopeAccessProfileController);
111
+ //# sourceMappingURL=scope-access-profile.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scope-access-profile.controller.js","sourceRoot":"./","sources":["access/controllers/scope-access-profile.controller.ts"],"names":[],"mappings":"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"}
@@ -2,12 +2,19 @@ import { IScopeGroupUser } from "@rockster/common/access";
2
2
  import { IQueryContent } from "../../query/interfaces/query";
3
3
  import { ScopeGroupUser } from "../entities/scope-group-user";
4
4
  import { ScopeGroupUserService } from "../services/scope-group-user.service";
5
+ import { ScopeGroupService } from "../services/scope-group.service";
6
+ import { ScopeOwnerService } from "../services/scope-owner.service";
5
7
  import { IPostContent } from "../../command/interfaces/post-content";
8
+ import { IRequestContext } from "../../core/interfaces/request-context";
6
9
  import { ScopeContext } from "../models/scope-context";
7
10
  export declare class ScopeGroupUserController {
8
11
  protected readonly scopeGroupUserService: ScopeGroupUserService;
9
- constructor(scopeGroupUserService: ScopeGroupUserService);
10
- query(content: IQueryContent<IScopeGroupUser, ScopeContext>): Promise<import("../../query/interfaces/query").Query<IScopeGroupUser>>;
11
- post(content: IPostContent<ScopeGroupUser>): Promise<IScopeGroupUser>;
12
- remove(content: ScopeGroupUser): Promise<import("typeorm").DeleteResult>;
12
+ protected readonly scopeGroupService: ScopeGroupService;
13
+ protected readonly scopeOwnerService: ScopeOwnerService;
14
+ constructor(scopeGroupUserService: ScopeGroupUserService, scopeGroupService: ScopeGroupService, scopeOwnerService: ScopeOwnerService);
15
+ /** Loads a group's context and asserts the caller is owner/admin/master of it. */
16
+ protected assertGroupAdmin(groupId: string, userId?: string): Promise<void>;
17
+ query(content: IQueryContent<IScopeGroupUser, ScopeContext>, requestContext: IRequestContext): Promise<import("../../query/interfaces/query").Query<IScopeGroupUser>>;
18
+ post(content: IPostContent<ScopeGroupUser>, requestContext: IRequestContext): Promise<IScopeGroupUser>;
19
+ remove(content: ScopeGroupUser, requestContext: IRequestContext): Promise<import("typeorm").DeleteResult>;
13
20
  }
@@ -21,17 +21,39 @@ const post_action_decorator_1 = require("../../command/decorators/post-action.de
21
21
  const scope_group_user_1 = require("../entities/scope-group-user");
22
22
  const post_content_decorator_1 = require("../../command/decorators/post-content.decorator");
23
23
  const scope_group_user_service_1 = require("../services/scope-group-user.service");
24
+ const scope_group_service_1 = require("../services/scope-group.service");
25
+ const scope_owner_service_1 = require("../services/scope-owner.service");
24
26
  const action_decorator_1 = require("../../controllers/decorators/actions/action.decorator");
25
27
  const action_content_decorator_1 = require("../../controllers/decorators/actions/action-content.decorator");
28
+ const request_context_decorator_1 = require("../../controllers/decorators/request-context.decorator");
26
29
  const scope_group_1 = require("../entities/scope-group");
30
+ const assert_context_admin_access_1 = require("../functions/assert-context-admin-access");
27
31
  let ScopeGroupUserController = class ScopeGroupUserController {
28
- constructor(scopeGroupUserService) {
32
+ constructor(scopeGroupUserService, scopeGroupService, scopeOwnerService) {
29
33
  this.scopeGroupUserService = scopeGroupUserService;
34
+ this.scopeGroupService = scopeGroupService;
35
+ this.scopeOwnerService = scopeOwnerService;
30
36
  }
31
- async query(content) {
37
+ /** Loads a group's context and asserts the caller is owner/admin/master of it. */
38
+ async assertGroupAdmin(groupId, userId) {
39
+ const group = await this.scopeGroupService.getOneBy({ id: groupId });
40
+ if (group) {
41
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
42
+ contextName: group.contextName,
43
+ contextId: group.contextId,
44
+ userId,
45
+ });
46
+ }
47
+ }
48
+ async query(content, requestContext) {
32
49
  const contextName = content.context.$contextName;
33
50
  const contextId = content.context.$contextId;
34
- return (0, execute_query_1.executeQuery)({
51
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
52
+ contextName,
53
+ contextId,
54
+ userId: requestContext.session?.userId,
55
+ });
56
+ const result = await (0, execute_query_1.executeQuery)({
35
57
  content,
36
58
  intercept: (queryBuilder) => {
37
59
  queryBuilder.leftJoin(scope_group_1.ScopeGroup, 'scopeGroup', '"scopeGroup".id = "scopeGroupUser".group_id');
@@ -40,13 +62,34 @@ let ScopeGroupUserController = class ScopeGroupUserController {
40
62
  preFilter: `"scopeGroup".context_name = '${contextName}'
41
63
  ${contextId ? `AND "scopeGroup".context_id = '${contextId}'` : ''}`
42
64
  });
65
+ if (contextId) {
66
+ const ownerIds = await this.scopeOwnerService.findOwnerUserIds(contextName, contextId, result.data
67
+ .map((row) => row.user?.id ?? row.userId)
68
+ .filter((id) => Boolean(id)));
69
+ result.data = result.data.map((row) => {
70
+ const userId = row.user?.id ?? row.userId;
71
+ if (!row.user || !userId) {
72
+ return row;
73
+ }
74
+ return {
75
+ ...row,
76
+ user: {
77
+ ...row.user,
78
+ isScopeOwner: ownerIds.has(userId),
79
+ },
80
+ };
81
+ });
82
+ }
83
+ return result;
43
84
  }
44
- async post(content) {
85
+ async post(content, requestContext) {
86
+ await this.assertGroupAdmin(content.data.groupId, requestContext.session?.userId);
45
87
  return this
46
88
  .scopeGroupUserService
47
89
  .addIfNotExists(content.data.groupId, content.data.userId);
48
90
  }
49
- async remove(content) {
91
+ async remove(content, requestContext) {
92
+ await this.assertGroupAdmin(content.groupId, requestContext.session?.userId);
50
93
  return this.scopeGroupUserService.removeBy({
51
94
  groupId: content.groupId,
52
95
  userId: content.userId
@@ -57,8 +100,9 @@ exports.ScopeGroupUserController = ScopeGroupUserController;
57
100
  __decorate([
58
101
  (0, scope_group_user_query_1.ScopeGroupUserQuery)(),
59
102
  __param(0, (0, query_content_decorator_1.QueryContent)()),
103
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
60
104
  __metadata("design:type", Function),
61
- __metadata("design:paramtypes", [Object]),
105
+ __metadata("design:paramtypes", [Object, Object]),
62
106
  __metadata("design:returntype", Promise)
63
107
  ], ScopeGroupUserController.prototype, "query", null);
64
108
  __decorate([
@@ -66,19 +110,23 @@ __decorate([
66
110
  type: () => scope_group_user_1.ScopeGroupUser
67
111
  }),
68
112
  __param(0, (0, post_content_decorator_1.PostContent)()),
113
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
69
114
  __metadata("design:type", Function),
70
- __metadata("design:paramtypes", [Object]),
115
+ __metadata("design:paramtypes", [Object, Object]),
71
116
  __metadata("design:returntype", Promise)
72
117
  ], ScopeGroupUserController.prototype, "post", null);
73
118
  __decorate([
74
119
  (0, action_decorator_1.Action)(),
75
120
  __param(0, (0, action_content_decorator_1.ActionContent)()),
121
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
76
122
  __metadata("design:type", Function),
77
- __metadata("design:paramtypes", [scope_group_user_1.ScopeGroupUser]),
123
+ __metadata("design:paramtypes", [scope_group_user_1.ScopeGroupUser, Object]),
78
124
  __metadata("design:returntype", Promise)
79
125
  ], ScopeGroupUserController.prototype, "remove", null);
80
126
  exports.ScopeGroupUserController = ScopeGroupUserController = __decorate([
81
127
  (0, controller_decorator_1.Controller)(),
82
- __metadata("design:paramtypes", [scope_group_user_service_1.ScopeGroupUserService])
128
+ __metadata("design:paramtypes", [scope_group_user_service_1.ScopeGroupUserService,
129
+ scope_group_service_1.ScopeGroupService,
130
+ scope_owner_service_1.ScopeOwnerService])
83
131
  ], ScopeGroupUserController);
84
132
  //# sourceMappingURL=scope-group-user.controller.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"scope-group-user.controller.js","sourceRoot":"./","sources":["access/controllers/scope-group-user.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,4FAA+E;AAC/E,4FAA8E;AAE9E,8EAAwE;AACxE,uEAAmE;AACnE,0FAA4E;AAC5E,mEAA8D;AAC9D,4FAA8E;AAC9E,mFAA6E;AAE7E,4FAA+E;AAC/E,4GAA8F;AAE9F,yDAAqD;AAG9C,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAElC,YACsB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAC/D,CAAC;IAGE,AAAN,KAAK,CAAC,KAAK,CACQ,OAAqD;QAErE,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC;QACjD,MAAM,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC;QAC7C,OAAO,IAAA,4BAAY,EAAC;YACjB,OAAO;YACP,SAAS,EAAE,CAAC,YAAY,EAAE,EAAE;gBACzB,YAAY,CAAC,QAAQ,CAClB,wBAAU,EACV,YAAY,EACZ,6CAA6C,CAC/C,CAAC;gBACF,OAAO,YAAY,CAAC;YACvB,CAAC;YACD,SAAS,EAAE,gCAAgC,WAAW;cACjD,SAAS,CAAC,CAAC,CAAC,kCAAkC,SAAS,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;SACxE,CAAC,CAAC;IACN,CAAC;IAKK,AAAN,KAAK,CAAC,IAAI,CAAgB,OAAqC;QAC5D,OAAO,IAAI;aACP,qBAAqB;aACrB,cAAc,CACZ,OAAO,CAAC,IAAI,CAAC,OAAO,EACpB,OAAO,CAAC,IAAI,CAAC,MAAM,CACrB,CAAC;IACR,CAAC;IAGK,AAAN,KAAK,CAAC,MAAM,CAAkB,OAAuB;QAClD,OAAO,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC;YACxC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,MAAM,EAAE,OAAO,CAAC,MAAM;SACxB,CAAC,CAAA;IACL,CAAC;CACH,CAAA;AA9CY,4DAAwB;AAO5B;IADL,IAAA,4CAAmB,GAAE;IAElB,WAAA,IAAA,sCAAY,GAAE,CAAA;;;;qDAiBjB;AAKK;IAHL,IAAA,kCAAU,EAAC;QACT,IAAI,EAAE,GAAG,EAAE,CAAC,iCAAc;KAC5B,CAAC;IACU,WAAA,IAAA,oCAAW,GAAE,CAAA;;;;oDAOxB;AAGK;IADL,IAAA,yBAAM,GAAE;IACK,WAAA,IAAA,wCAAa,GAAE,CAAA;;qCAAU,iCAAc;;sDAKpD;mCA7CS,wBAAwB;IADpC,IAAA,iCAAU,GAAE;qCAImC,gDAAqB;GAHxD,wBAAwB,CA8CpC"}
1
+ {"version":3,"file":"scope-group-user.controller.js","sourceRoot":"./","sources":["access/controllers/scope-group-user.controller.ts"],"names":[],"mappings":"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"}
@@ -7,13 +7,16 @@ import { ScopeKeysUpdate } from "../models/scope-keys-update";
7
7
  import { ScopeAccessService } from "../services/scope-access.service";
8
8
  import { ScopeGroupService } from "../services/scope-group.service";
9
9
  import { ScopeContext } from "../models/scope-context";
10
+ import { ScopeGroupApplyAccessProfile } from "../models/scope-group-apply-access-profile";
11
+ import { CurrentSession, IRequestContext } from "../../core/interfaces/request-context";
10
12
  export declare class ScopeGroupController {
11
13
  protected readonly scopeAccessService: ScopeAccessService;
12
14
  protected readonly scopeGroupService: ScopeGroupService;
13
15
  constructor(scopeAccessService: ScopeAccessService, scopeGroupService: ScopeGroupService);
14
- updateKeys(content: ScopeKeysUpdate): Promise<void>;
15
- query(content: IQueryContent<IScopeGroup, ScopeContext>): Promise<import("../../query/interfaces/query").Query<IScopeGroup>>;
16
- post(content: IPostContent<IScopeGroup>): Promise<IScopeGroup>;
17
- remove(content: IRemoveContent): Promise<void>;
18
- get(groupId: string, contextName: string, contextId: string): Promise<ScopeGroup>;
16
+ applyAccessProfile(content: ScopeGroupApplyAccessProfile, requestContext: IRequestContext): Promise<string[]>;
17
+ updateKeys(content: ScopeKeysUpdate, requestContext: IRequestContext): Promise<void>;
18
+ query(content: IQueryContent<IScopeGroup, ScopeContext>, requestContext: IRequestContext): Promise<import("../../query/interfaces/query").Query<IScopeGroup>>;
19
+ post(content: IPostContent<IScopeGroup>, requestContext: IRequestContext): Promise<IScopeGroup>;
20
+ remove(content: IRemoveContent, requestContext: IRequestContext): Promise<void>;
21
+ get(groupId: string, contextName: string, contextId: string, session: CurrentSession): Promise<ScopeGroup>;
19
22
  }
@@ -33,30 +33,71 @@ const from_params_decorator_1 = require("../../controllers/decorators/http-metho
33
33
  const from_query_decorator_1 = require("../../controllers/decorators/http-methods/from-query.decorator");
34
34
  const scope_group_service_1 = require("../services/scope-group.service");
35
35
  const get_decorator_1 = require("../../controllers/decorators/http-methods/get.decorator");
36
+ const normalize_scope_keys_1 = require("../functions/normalize-scope-keys");
37
+ const scope_group_apply_access_profile_1 = require("../models/scope-group-apply-access-profile");
38
+ const request_context_decorator_1 = require("../../controllers/decorators/request-context.decorator");
39
+ const session_decorator_1 = require("../../controllers/decorators/session.decorator");
40
+ const assert_context_admin_access_1 = require("../functions/assert-context-admin-access");
36
41
  let ScopeGroupController = class ScopeGroupController {
37
42
  constructor(scopeAccessService, scopeGroupService) {
38
43
  this.scopeAccessService = scopeAccessService;
39
44
  this.scopeGroupService = scopeGroupService;
40
45
  }
41
- async updateKeys(content) {
42
- return this.scopeAccessService.updateKeys('group', content.contextName, content.contextId, content.targetId, content.keys);
46
+ async applyAccessProfile(content, requestContext) {
47
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
48
+ contextName: content.contextName,
49
+ contextId: content.contextId,
50
+ userId: requestContext.session?.userId,
51
+ });
52
+ return this.scopeGroupService.applyAccessProfileToGroupContext(content.groupId, content.contextName, content.contextId);
53
+ }
54
+ async updateKeys(content, requestContext) {
55
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
56
+ contextName: content.contextName,
57
+ contextId: content.contextId,
58
+ userId: requestContext.session?.userId,
59
+ });
60
+ return this.scopeAccessService.updateKeys('group', content.contextName, content.contextId, content.targetId, (0, normalize_scope_keys_1.normalizeScopeKeys)(content.keys));
43
61
  }
44
- async query(content) {
62
+ async query(content, requestContext) {
45
63
  const contextName = content.context.$contextName;
46
64
  const contextId = content.context.$contextId;
65
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
66
+ contextName,
67
+ contextId,
68
+ userId: requestContext.session?.userId,
69
+ });
47
70
  return (0, execute_query_1.executeQuery)({
48
71
  content,
49
72
  preFilter: `"scopeGroup".context_name = '${contextName}'
50
73
  ${contextId ? `AND "scopeGroup".context_id = '${contextId}'` : ''}`
51
74
  });
52
75
  }
53
- async post(content) {
76
+ async post(content, requestContext) {
77
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
78
+ contextName: content.data.contextName,
79
+ contextId: content.data.contextId,
80
+ userId: requestContext.session?.userId,
81
+ });
54
82
  return (0, execute_post_1.executePost)(content);
55
83
  }
56
- async remove(content) {
84
+ async remove(content, requestContext) {
85
+ const group = await this.scopeGroupService.getOneBy({ id: content.idValue });
86
+ if (group) {
87
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
88
+ contextName: group.contextName,
89
+ contextId: group.contextId,
90
+ userId: requestContext.session?.userId,
91
+ });
92
+ }
57
93
  return (0, execute_remove_1.executeRemove)(content);
58
94
  }
59
- async get(groupId, contextName, contextId) {
95
+ async get(groupId, contextName, contextId, session) {
96
+ await (0, assert_context_admin_access_1.assertContextAdminAccess)({
97
+ contextName,
98
+ contextId,
99
+ userId: session?.userId,
100
+ });
60
101
  const group = await this
61
102
  .scopeGroupService
62
103
  .getOneBy({ id: groupId });
@@ -72,7 +113,7 @@ let ScopeGroupController = class ScopeGroupController {
72
113
  contextName: contextName,
73
114
  contextId: contextId,
74
115
  name: group.name,
75
- keys: keys
116
+ keys: (0, normalize_scope_keys_1.filterScopeAccessRows)(keys),
76
117
  };
77
118
  }
78
119
  };
@@ -80,29 +121,41 @@ exports.ScopeGroupController = ScopeGroupController;
80
121
  __decorate([
81
122
  (0, action_decorator_1.Action)(),
82
123
  __param(0, (0, action_content_decorator_1.ActionContent)()),
124
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
125
+ __metadata("design:type", Function),
126
+ __metadata("design:paramtypes", [scope_group_apply_access_profile_1.ScopeGroupApplyAccessProfile, Object]),
127
+ __metadata("design:returntype", Promise)
128
+ ], ScopeGroupController.prototype, "applyAccessProfile", null);
129
+ __decorate([
130
+ (0, action_decorator_1.Action)(),
131
+ __param(0, (0, action_content_decorator_1.ActionContent)()),
132
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
83
133
  __metadata("design:type", Function),
84
- __metadata("design:paramtypes", [scope_keys_update_1.ScopeKeysUpdate]),
134
+ __metadata("design:paramtypes", [scope_keys_update_1.ScopeKeysUpdate, Object]),
85
135
  __metadata("design:returntype", Promise)
86
136
  ], ScopeGroupController.prototype, "updateKeys", null);
87
137
  __decorate([
88
138
  (0, scope_group_query_1.ScopeGroupQuery)(),
89
139
  __param(0, (0, query_content_decorator_1.QueryContent)()),
140
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
90
141
  __metadata("design:type", Function),
91
- __metadata("design:paramtypes", [Object]),
142
+ __metadata("design:paramtypes", [Object, Object]),
92
143
  __metadata("design:returntype", Promise)
93
144
  ], ScopeGroupController.prototype, "query", null);
94
145
  __decorate([
95
146
  (0, post_action_decorator_1.PostAction)({ type: () => scope_group_1.ScopeGroup }),
96
147
  __param(0, (0, post_content_decorator_1.PostContent)()),
148
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
97
149
  __metadata("design:type", Function),
98
- __metadata("design:paramtypes", [Object]),
150
+ __metadata("design:paramtypes", [Object, Object]),
99
151
  __metadata("design:returntype", Promise)
100
152
  ], ScopeGroupController.prototype, "post", null);
101
153
  __decorate([
102
154
  (0, remove_action_decorator_1.RemoveAction)({ type: () => scope_group_1.ScopeGroup }),
103
155
  __param(0, (0, remove_content_decorator_1.RemoveContent)()),
156
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
104
157
  __metadata("design:type", Function),
105
- __metadata("design:paramtypes", [Object]),
158
+ __metadata("design:paramtypes", [Object, Object]),
106
159
  __metadata("design:returntype", Promise)
107
160
  ], ScopeGroupController.prototype, "remove", null);
108
161
  __decorate([
@@ -111,8 +164,9 @@ __decorate([
111
164
  __param(0, (0, from_params_decorator_1.FromParams)('groupId')),
112
165
  __param(1, (0, from_params_decorator_1.FromParams)('contextName')),
113
166
  __param(2, (0, from_query_decorator_1.FromQuery)('contextId')),
167
+ __param(3, (0, session_decorator_1.Session)()),
114
168
  __metadata("design:type", Function),
115
- __metadata("design:paramtypes", [String, String, String]),
169
+ __metadata("design:paramtypes", [String, String, String, Object]),
116
170
  __metadata("design:returntype", Promise)
117
171
  ], ScopeGroupController.prototype, "get", null);
118
172
  exports.ScopeGroupController = ScopeGroupController = __decorate([
@@ -1 +1 @@
1
- {"version":3,"file":"scope-group.controller.js","sourceRoot":"./","sources":["access/controllers/scope-group.controller.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"scope-group.controller.js","sourceRoot":"./","sources":["access/controllers/scope-group.controller.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,0FAA4E;AAC5E,4FAA8E;AAE9E,4FAA+E;AAC/E,8FAAgF;AAChF,2EAAuE;AACvE,gGAAkF;AAElF,uEAAmE;AAEnE,4FAA8E;AAC9E,uEAAmE;AACnE,yDAAqD;AACrD,oEAA+D;AAC/D,4GAA8F;AAC9F,mEAA8D;AAC9D,4FAA+E;AAC/E,2EAAsE;AACtE,+GAAiG;AACjG,2GAA6F;AAC7F,yGAA2F;AAC3F,yEAAoE;AACpE,2FAA8E;AAE9E,4EAG2C;AAC3C,iGAA0F;AAC1F,sGAAwF;AACxF,sFAAyE;AAEzE,0FAAoF;AAG7E,IAAM,oBAAoB,GAA1B,MAAM,oBAAoB;IAE9B,YACsB,kBAAsC,EACtC,iBAAoC;QADpC,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAmB;IACtD,CAAC;IAGC,AAAN,KAAK,CAAC,kBAAkB,CACJ,OAAqC,EACpC,cAA+B;QAEjD,MAAM,IAAA,sDAAwB,EAAC;YAC5B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,MAAM,EAAE,cAAc,CAAC,OAAO,EAAE,MAAM;SACxC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,iBAAiB,CAAC,gCAAgC,CAC3D,OAAO,CAAC,OAAO,EACf,OAAO,CAAC,WAAW,EACnB,OAAO,CAAC,SAAS,CACnB,CAAC;IACL,CAAC;IAGK,AAAN,KAAK,CAAC,UAAU,CACI,OAAwB,EACvB,cAA+B;QAEjD,MAAM,IAAA,sDAAwB,EAAC;YAC5B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,SAAS,EAAE,OAAO,CAAC,SAAS;YAC5B,MAAM,EAAE,cAAc,CAAC,OAAO,EAAE,MAAM;SACxC,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC,kBAAkB,CAAC,UAAU,CACtC,OAAO,EACP,OAAO,CAAC,WAAW,EACnB,OAAO,CAAC,SAAS,EACjB,OAAO,CAAC,QAAQ,EAChB,IAAA,yCAAkB,EAAC,OAAO,CAAC,IAAI,CAAC,CAClC,CAAC;IACL,CAAC;IAGK,AAAN,KAAK,CAAC,KAAK,CACQ,OAAiD,EAC/C,cAA+B;QAEjD,MAAM,WAAW,GAAG,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC;QACjD,MAAM,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC;QAE7C,MAAM,IAAA,sDAAwB,EAAC;YAC5B,WAAW;YACX,SAAS;YACT,MAAM,EAAE,cAAc,CAAC,OAAO,EAAE,MAAM;SACxC,CAAC,CAAC;QAEH,OAAO,IAAA,4BAAY,EAAC;YACjB,OAAO;YACP,SAAS,EAAE,gCAAgC,WAAW;cACjD,SAAS,CAAC,CAAC,CAAC,kCAAkC,SAAS,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE;SACxE,CAAC,CAAC;IACN,CAAC;IAGK,AAAN,KAAK,CAAC,IAAI,CACQ,OAAkC,EAC/B,cAA+B;QAEjD,MAAM,IAAA,sDAAwB,EAAC;YAC5B,WAAW,EAAE,OAAO,CAAC,IAAI,CAAC,WAAW;YACrC,SAAS,EAAE,OAAO,CAAC,IAAI,CAAC,SAAS;YACjC,MAAM,EAAE,cAAc,CAAC,OAAO,EAAE,MAAM;SACxC,CAAC,CAAC;QACH,OAAO,IAAA,0BAAW,EAAC,OAAO,CAAC,CAAC;IAC/B,CAAC;IAGK,AAAN,KAAK,CAAC,MAAM,CACQ,OAAuB,EACtB,cAA+B;QAEjD,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,OAAO,CAAC,OAAO,EAAE,CAAC,CAAC;QAC7E,IAAI,KAAK,EAAE,CAAC;YACT,MAAM,IAAA,sDAAwB,EAAC;gBAC5B,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,MAAM,EAAE,cAAc,CAAC,OAAO,EAAE,MAAM;aACxC,CAAC,CAAC;QACN,CAAC;QACD,OAAO,IAAA,8BAAa,EAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAIK,AAAN,KAAK,CAAC,GAAG,CACiB,OAAe,EACX,WAAmB,EACtB,SAAiB,EAC9B,OAAuB;QAElC,MAAM,IAAA,sDAAwB,EAAC;YAC5B,WAAW;YACX,SAAS;YACT,MAAM,EAAE,OAAO,EAAE,MAAM;SACzB,CAAC,CAAC;QAEH,MAAM,KAAK,GAAG,MAAM,IAAI;aACpB,iBAAiB;aACjB,QAAQ,CAAC,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QAE9B,MAAM,IAAI,GAAG,MAAM,IAAI;aACnB,kBAAkB;aAClB,OAAO,CAAC;YACN,KAAK,EAAE;gBACJ,WAAW,EAAE,WAAW;gBACxB,OAAO,EAAE,KAAK,CAAC,EAAE;aACnB;SACH,CAAC,CAAC;QAEN,OAAO;YACJ,WAAW,EAAE,WAAW;YACxB,SAAS,EAAE,SAAS;YACpB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,IAAI,EAAE,IAAA,4CAAqB,EAAC,IAAI,CAAC;SACrB,CAAC;IACnB,CAAC;CACH,CAAA;AAjIY,oDAAoB;AAQxB;IADL,IAAA,yBAAM,GAAE;IAEL,WAAA,IAAA,wCAAa,GAAE,CAAA;IACf,WAAA,IAAA,0CAAc,GAAE,CAAA;;qCADS,+DAA4B;;8DAcxD;AAGK;IADL,IAAA,yBAAM,GAAE;IAEL,WAAA,IAAA,wCAAa,GAAE,CAAA;IACf,WAAA,IAAA,0CAAc,GAAE,CAAA;;qCADS,mCAAe;;sDAgB3C;AAGK;IADL,IAAA,mCAAe,GAAE;IAEd,WAAA,IAAA,sCAAY,GAAE,CAAA;IACd,WAAA,IAAA,0CAAc,GAAE,CAAA;;;;iDAgBnB;AAGK;IADL,IAAA,kCAAU,EAAC,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,wBAAU,EAAE,CAAC;IAEnC,WAAA,IAAA,oCAAW,GAAE,CAAA;IACb,WAAA,IAAA,0CAAc,GAAE,CAAA;;;;gDAQnB;AAGK;IADL,IAAA,sCAAY,EAAC,EAAE,IAAI,EAAE,GAAG,EAAE,CAAC,wBAAU,EAAE,CAAC;IAErC,WAAA,IAAA,wCAAa,GAAE,CAAA;IACf,WAAA,IAAA,0CAAc,GAAE,CAAA;;;;kDAWnB;AAIK;IAFL,IAAA,sCAAY,EAAC,GAAG,EAAE,CAAC,wBAAU,CAAC;IAC9B,IAAA,mBAAG,EAAC,+BAA+B,CAAC;IAEjC,WAAA,IAAA,kCAAU,EAAC,SAAS,CAAC,CAAA;IACrB,WAAA,IAAA,kCAAU,EAAC,aAAa,CAAC,CAAA;IACzB,WAAA,IAAA,gCAAS,EAAC,WAAW,CAAC,CAAA;IACtB,WAAA,IAAA,2BAAO,GAAE,CAAA;;;;+CA2BZ;+BAhIS,oBAAoB;IADhC,IAAA,iCAAU,GAAE;qCAIgC,yCAAkB;QACnB,uCAAiB;GAJhD,oBAAoB,CAiIhC"}
@@ -1,8 +1,9 @@
1
+ import { IRequestContext } from "../../core/interfaces/request-context";
1
2
  import { ScopeOwner } from "../models/scope-owner";
2
3
  import { ScopeOwnerService } from "../services/scope-owner.service";
3
4
  export declare class ScopeOwnerController {
4
5
  protected readonly scopeOwnerService: ScopeOwnerService;
5
6
  constructor(scopeOwnerService: ScopeOwnerService);
6
- add(content: ScopeOwner): Promise<void>;
7
- remove(content: ScopeOwner): Promise<void>;
7
+ add(content: ScopeOwner, requestContext: IRequestContext): Promise<void>;
8
+ remove(content: ScopeOwner, requestContext: IRequestContext): Promise<void>;
8
9
  }