@rockster/core 0.0.2 → 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 (501) hide show
  1. package/access/access.module.d.ts +11 -0
  2. package/access/access.module.js +56 -0
  3. package/access/access.module.js.map +1 -0
  4. package/access/constants.d.ts +2 -0
  5. package/access/constants.js +6 -0
  6. package/access/constants.js.map +1 -0
  7. package/access/controllers/controllers.d.ts +7 -0
  8. package/access/controllers/controllers.js +18 -0
  9. package/access/controllers/controllers.js.map +1 -0
  10. package/access/controllers/scope-access-profile.controller.d.ts +17 -0
  11. package/access/controllers/scope-access-profile.controller.js +111 -0
  12. package/access/controllers/scope-access-profile.controller.js.map +1 -0
  13. package/access/controllers/scope-group-user.controller.d.ts +20 -0
  14. package/access/controllers/scope-group-user.controller.js +132 -0
  15. package/access/controllers/scope-group-user.controller.js.map +1 -0
  16. package/access/controllers/scope-group.controller.d.ts +22 -0
  17. package/access/controllers/scope-group.controller.js +177 -0
  18. package/access/controllers/scope-group.controller.js.map +1 -0
  19. package/access/controllers/scope-key.controller.d.ts +7 -0
  20. package/access/controllers/scope-key.controller.js +45 -0
  21. package/access/controllers/scope-key.controller.js.map +1 -0
  22. package/access/controllers/scope-owner.controller.d.ts +9 -0
  23. package/access/controllers/scope-owner.controller.js +80 -0
  24. package/access/controllers/scope-owner.controller.js.map +1 -0
  25. package/access/controllers/scope-user.controller.d.ts +14 -0
  26. package/access/controllers/scope-user.controller.js +109 -0
  27. package/access/controllers/scope-user.controller.js.map +1 -0
  28. package/access/decorators/context-params.decorator.d.ts +2 -0
  29. package/access/decorators/context-params.decorator.js +13 -0
  30. package/access/decorators/context-params.decorator.js.map +1 -0
  31. package/access/decorators/index.d.ts +2 -0
  32. package/access/decorators/index.js +19 -0
  33. package/access/decorators/index.js.map +1 -0
  34. package/access/decorators/scope-context-id-resolver.decorator.d.ts +10 -0
  35. package/access/decorators/scope-context-id-resolver.decorator.js +22 -0
  36. package/access/decorators/scope-context-id-resolver.decorator.js.map +1 -0
  37. package/access/entities/entities.d.ts +8 -0
  38. package/access/entities/entities.js +22 -0
  39. package/access/entities/entities.js.map +1 -0
  40. package/access/entities/index.d.ts +7 -0
  41. package/access/entities/index.js +24 -0
  42. package/access/entities/index.js.map +1 -0
  43. package/access/entities/scope-access-profile-key.d.ts +6 -0
  44. package/access/entities/scope-access-profile-key.js +40 -0
  45. package/access/entities/scope-access-profile-key.js.map +1 -0
  46. package/access/entities/scope-access-profile.d.ts +6 -0
  47. package/access/entities/scope-access-profile.js +37 -0
  48. package/access/entities/scope-access-profile.js.map +1 -0
  49. package/access/entities/scope-access.d.ts +9 -0
  50. package/access/entities/scope-access.js +58 -0
  51. package/access/entities/scope-access.js.map +1 -0
  52. package/access/entities/scope-group-user.d.ts +7 -0
  53. package/access/entities/scope-group-user.js +47 -0
  54. package/access/entities/scope-group-user.js.map +1 -0
  55. package/access/entities/scope-group.d.ts +12 -0
  56. package/access/entities/scope-group.js +72 -0
  57. package/access/entities/scope-group.js.map +1 -0
  58. package/access/entities/scope-key.d.ts +5 -0
  59. package/access/entities/scope-key.js +35 -0
  60. package/access/entities/scope-key.js.map +1 -0
  61. package/access/entities/scope-owner.d.ts +7 -0
  62. package/access/entities/scope-owner.js +45 -0
  63. package/access/entities/scope-owner.js.map +1 -0
  64. package/access/env.d.ts +10 -0
  65. package/access/env.js +10 -0
  66. package/access/env.js.map +1 -0
  67. package/access/functions/assert-context-admin-access.d.ts +15 -0
  68. package/access/functions/assert-context-admin-access.js +62 -0
  69. package/access/functions/assert-context-admin-access.js.map +1 -0
  70. package/access/functions/assert-master-or-owner.d.ts +9 -0
  71. package/access/functions/assert-master-or-owner.js +40 -0
  72. package/access/functions/assert-master-or-owner.js.map +1 -0
  73. package/access/functions/assert-scope-action-access.d.ts +32 -0
  74. package/access/functions/assert-scope-action-access.js +189 -0
  75. package/access/functions/assert-scope-action-access.js.map +1 -0
  76. package/access/functions/build-scope-resolver-initial-data.d.ts +4 -0
  77. package/access/functions/build-scope-resolver-initial-data.js +17 -0
  78. package/access/functions/build-scope-resolver-initial-data.js.map +1 -0
  79. package/access/functions/describe-action-scope.d.ts +9 -0
  80. package/access/functions/describe-action-scope.js +27 -0
  81. package/access/functions/describe-action-scope.js.map +1 -0
  82. package/access/functions/get-context-id-service.d.ts +1 -0
  83. package/access/functions/get-context-id-service.js +8 -0
  84. package/access/functions/get-context-id-service.js.map +1 -0
  85. package/access/functions/get-is-owner.d.ts +1 -0
  86. package/access/functions/get-is-owner.js +8 -0
  87. package/access/functions/get-is-owner.js.map +1 -0
  88. package/access/functions/get-user-keys.d.ts +2 -0
  89. package/access/functions/get-user-keys.js +10 -0
  90. package/access/functions/get-user-keys.js.map +1 -0
  91. package/access/functions/index.d.ts +8 -0
  92. package/access/functions/index.js +25 -0
  93. package/access/functions/index.js.map +1 -0
  94. package/access/functions/init-scope-service-executors.d.ts +3 -0
  95. package/access/functions/init-scope-service-executors.js +38 -0
  96. package/access/functions/init-scope-service-executors.js.map +1 -0
  97. package/access/functions/normalize-scope-keys.d.ts +4 -0
  98. package/access/functions/normalize-scope-keys.js +17 -0
  99. package/access/functions/normalize-scope-keys.js.map +1 -0
  100. package/access/functions/register-scope.d.ts +19 -0
  101. package/access/functions/register-scope.js +94 -0
  102. package/access/functions/register-scope.js.map +1 -0
  103. package/access/functions/resolve-scope-context-id.d.ts +9 -0
  104. package/access/functions/resolve-scope-context-id.js +71 -0
  105. package/access/functions/resolve-scope-context-id.js.map +1 -0
  106. package/access/functions/warn-if-public.d.ts +12 -0
  107. package/access/functions/warn-if-public.js +20 -0
  108. package/access/functions/warn-if-public.js.map +1 -0
  109. package/access/index.d.ts +7 -0
  110. package/access/index.js +24 -0
  111. package/access/index.js.map +1 -0
  112. package/access/interfaces/index.d.ts +3 -0
  113. package/access/interfaces/index.js +20 -0
  114. package/access/interfaces/index.js.map +1 -0
  115. package/access/interfaces/resolve-scope-context-id.d.ts +21 -0
  116. package/access/interfaces/resolve-scope-context-id.js +3 -0
  117. package/access/interfaces/resolve-scope-context-id.js.map +1 -0
  118. package/access/interfaces/scope-service-registry.d.ts +21 -0
  119. package/access/interfaces/scope-service-registry.js +3 -0
  120. package/access/interfaces/scope-service-registry.js.map +1 -0
  121. package/access/interfaces/scope-service.d.ts +11 -0
  122. package/{database/interfaces/protector.js → access/interfaces/scope-service.js} +1 -1
  123. package/access/interfaces/scope-service.js.map +1 -0
  124. package/access/models/scope-access-profile-keys-update.d.ts +5 -0
  125. package/access/models/scope-access-profile-keys-update.js +27 -0
  126. package/access/models/scope-access-profile-keys-update.js.map +1 -0
  127. package/access/models/scope-context.d.ts +4 -0
  128. package/access/models/scope-context.js +27 -0
  129. package/access/models/scope-context.js.map +1 -0
  130. package/access/models/scope-group-apply-access-profile.d.ts +6 -0
  131. package/access/models/scope-group-apply-access-profile.js +32 -0
  132. package/access/models/scope-group-apply-access-profile.js.map +1 -0
  133. package/access/models/scope-keys-update.d.ts +7 -0
  134. package/access/models/scope-keys-update.js +38 -0
  135. package/access/models/scope-keys-update.js.map +1 -0
  136. package/access/models/scope-owner.d.ts +5 -0
  137. package/access/models/scope-owner.js +32 -0
  138. package/access/models/scope-owner.js.map +1 -0
  139. package/access/models/scope-user-mapped.d.ts +9 -0
  140. package/access/models/scope-user-mapped.js +48 -0
  141. package/access/models/scope-user-mapped.js.map +1 -0
  142. package/access/models/scope-user.d.ts +9 -0
  143. package/access/models/scope-user.js +51 -0
  144. package/access/models/scope-user.js.map +1 -0
  145. package/access/queries/scope-access-profile.query.d.ts +1 -0
  146. package/access/queries/scope-access-profile.query.js +10 -0
  147. package/access/queries/scope-access-profile.query.js.map +1 -0
  148. package/access/queries/scope-group-user.query.d.ts +1 -0
  149. package/access/queries/scope-group-user.query.js +26 -0
  150. package/access/queries/scope-group-user.query.js.map +1 -0
  151. package/access/queries/scope-group.query.d.ts +1 -0
  152. package/access/queries/scope-group.query.js +19 -0
  153. package/access/queries/scope-group.query.js.map +1 -0
  154. package/access/services/index.d.ts +7 -0
  155. package/access/services/index.js +24 -0
  156. package/access/services/index.js.map +1 -0
  157. package/access/services/scope-access-profile.service.d.ts +13 -0
  158. package/access/services/scope-access-profile.service.js +75 -0
  159. package/access/services/scope-access-profile.service.js.map +1 -0
  160. package/access/services/scope-access.service.d.ts +11 -0
  161. package/access/services/scope-access.service.js +89 -0
  162. package/access/services/scope-access.service.js.map +1 -0
  163. package/access/services/scope-group-user.service.d.ts +8 -0
  164. package/access/services/scope-group-user.service.js +49 -0
  165. package/access/services/scope-group-user.service.js.map +1 -0
  166. package/access/services/scope-group.service.d.ts +17 -0
  167. package/access/services/scope-group.service.js +75 -0
  168. package/access/services/scope-group.service.js.map +1 -0
  169. package/access/services/scope-key.service.d.ts +9 -0
  170. package/access/services/scope-key.service.js +52 -0
  171. package/access/services/scope-key.service.js.map +1 -0
  172. package/access/services/scope-owner.service.d.ts +10 -0
  173. package/access/services/scope-owner.service.js +60 -0
  174. package/access/services/scope-owner.service.js.map +1 -0
  175. package/access/services/scope-service.d.ts +10 -0
  176. package/access/services/scope-service.js +52 -0
  177. package/access/services/scope-service.js.map +1 -0
  178. package/command/functions/execute-post.js +5 -7
  179. package/command/functions/execute-post.js.map +1 -1
  180. package/command/services/post-action-builder.js +21 -17
  181. package/command/services/post-action-builder.js.map +1 -1
  182. package/command/services/remove-action-builder.js +32 -22
  183. package/command/services/remove-action-builder.js.map +1 -1
  184. package/common/entities/base-entity.js +2 -0
  185. package/common/entities/base-entity.js.map +1 -1
  186. package/common/interfaces/enum/object-type.d.ts +2 -1
  187. package/common/interfaces/enum/object-type.js +1 -0
  188. package/common/interfaces/enum/object-type.js.map +1 -1
  189. package/controllers/constants/controller-transaction.d.ts +2 -0
  190. package/controllers/constants/controller-transaction.js +6 -0
  191. package/controllers/constants/controller-transaction.js.map +1 -0
  192. package/controllers/controller.controller.d.ts +1 -1
  193. package/controllers/controller.controller.js +4 -4
  194. package/controllers/controller.controller.js.map +1 -1
  195. package/controllers/decorators/controller.decorator.js +8 -0
  196. package/controllers/decorators/controller.decorator.js.map +1 -1
  197. package/controllers/decorators/index.d.ts +1 -0
  198. package/controllers/decorators/index.js +1 -0
  199. package/controllers/decorators/index.js.map +1 -1
  200. package/controllers/decorators/transaction.decorator.d.ts +7 -0
  201. package/controllers/decorators/transaction.decorator.js +23 -0
  202. package/controllers/decorators/transaction.decorator.js.map +1 -0
  203. package/controllers/interfaces/controller-object.d.ts +1 -0
  204. package/controllers/interfaces/controller-options.d.ts +1 -0
  205. package/controllers/interfaces/controller-property.d.ts +9 -0
  206. package/controllers/services/default-action-builder.js +14 -0
  207. package/controllers/services/default-action-builder.js.map +1 -1
  208. package/controllers/services/restful-action-builder.js +25 -1
  209. package/controllers/services/restful-action-builder.js.map +1 -1
  210. package/core/contexts/request-context.d.ts +5 -0
  211. package/core/contexts/request-context.js +6 -0
  212. package/core/contexts/request-context.js.map +1 -0
  213. package/core/core.controller.d.ts +1 -0
  214. package/core/core.controller.js +15 -2
  215. package/core/core.controller.js.map +1 -1
  216. package/core/functions/create-interceptor.js +2 -2
  217. package/core/functions/create-interceptor.js.map +1 -1
  218. package/core/functions/resolve-action-transactional.d.ts +3 -0
  219. package/core/functions/resolve-action-transactional.js +10 -0
  220. package/core/functions/resolve-action-transactional.js.map +1 -0
  221. package/core/interfaces/action-def.d.ts +2 -5
  222. package/core/interfaces/action-docs.d.ts +15 -0
  223. package/core/interfaces/action-handle.d.ts +5 -0
  224. package/core/interfaces/action-handle.js +3 -0
  225. package/core/interfaces/action-handle.js.map +1 -0
  226. package/core/interfaces/core-options.d.ts +1 -0
  227. package/core/interfaces/interceptor.d.ts +1 -1
  228. package/core/interfaces/object.d.ts +3 -2
  229. package/core/interfaces/request-context.d.ts +7 -2
  230. package/core/services/request-executor.d.ts +8 -0
  231. package/core/services/request-executor.js +88 -0
  232. package/core/services/request-executor.js.map +1 -1
  233. package/core/services/request-router.js +5 -4
  234. package/core/services/request-router.js.map +1 -1
  235. package/database/database.controller.d.ts +1 -3
  236. package/database/database.controller.js +1 -5
  237. package/database/database.controller.js.map +1 -1
  238. package/database/decorators/entity.decorator.d.ts +3 -1
  239. package/database/decorators/entity.decorator.js +14 -5
  240. package/database/decorators/entity.decorator.js.map +1 -1
  241. package/database/decorators/external-column.decorator.d.ts +17 -0
  242. package/database/decorators/external-column.decorator.js +30 -0
  243. package/database/decorators/external-column.decorator.js.map +1 -0
  244. package/database/decorators/index.d.ts +1 -0
  245. package/database/decorators/index.js +1 -0
  246. package/database/decorators/index.js.map +1 -1
  247. package/database/decorators/protect-entity.decorator.d.ts +1 -0
  248. package/database/decorators/protect-entity.decorator.js +2 -3
  249. package/database/decorators/protect-entity.decorator.js.map +1 -1
  250. package/database/decorators/protected-entity.decorator.d.ts +1 -0
  251. package/database/decorators/protected-entity.decorator.js +2 -16
  252. package/database/decorators/protected-entity.decorator.js.map +1 -1
  253. package/database/decorators/relation.decorator.d.ts +2 -2
  254. package/database/decorators/relation.decorator.js.map +1 -1
  255. package/database/extensions/select-query-builder.d.ts +1 -5
  256. package/database/extensions/select-query-builder.js.map +1 -1
  257. package/database/functions/find-relation.d.ts +2 -1
  258. package/database/functions/find-relation.js +3 -3
  259. package/database/functions/find-relation.js.map +1 -1
  260. package/database/functions/generate-entity-id.d.ts +2 -0
  261. package/database/functions/{generate-id.js → generate-entity-id.js} +3 -3
  262. package/database/functions/generate-entity-id.js.map +1 -0
  263. package/database/functions/get-relations.d.ts +1 -1
  264. package/database/functions/inject-repository-handle.js +4 -3
  265. package/database/functions/inject-repository-handle.js.map +1 -1
  266. package/database/functions/use-transaction.d.ts +1 -0
  267. package/database/functions/use-transaction.js +2 -6
  268. package/database/functions/use-transaction.js.map +1 -1
  269. package/database/interfaces/entity-dto-object.d.ts +7 -0
  270. package/database/interfaces/entity-dto-object.js +3 -0
  271. package/database/interfaces/entity-dto-object.js.map +1 -0
  272. package/database/interfaces/entity-object.d.ts +0 -6
  273. package/database/interfaces/entity-property.d.ts +12 -0
  274. package/database/interfaces/index.d.ts +0 -1
  275. package/database/interfaces/index.js +0 -1
  276. package/database/interfaces/index.js.map +1 -1
  277. package/database/interfaces/path.d.ts +6 -2
  278. package/database/interfaces/repository.d.ts +8 -8
  279. package/database/interfaces/virtual-select.d.ts +4 -0
  280. package/database/interfaces/virtual-select.js +3 -0
  281. package/database/interfaces/virtual-select.js.map +1 -0
  282. package/database/services/repository.service.d.ts +1 -1
  283. package/database/services/repository.service.js +3 -6
  284. package/database/services/repository.service.js.map +1 -1
  285. package/docs/docs.module.js +3 -1
  286. package/docs/docs.module.js.map +1 -1
  287. package/docs/migrations/1747584000000-CreateDocsTables.d.ts +5 -0
  288. package/docs/migrations/1747584000000-CreateDocsTables.js +90 -0
  289. package/docs/migrations/1747584000000-CreateDocsTables.js.map +1 -0
  290. package/docs/migrations/migrations.d.ts +2 -0
  291. package/docs/migrations/migrations.js +8 -0
  292. package/docs/migrations/migrations.js.map +1 -0
  293. package/docs/queries/docs-controller-action.query.d.ts +1 -1
  294. package/docs/queries/docs-controller.query.d.ts +1 -1
  295. package/docs/queries/docs-model.query.d.ts +1 -1
  296. package/docs/queries/docs-model.query.js +1 -1
  297. package/docs/queries/docs-model.query.js.map +1 -1
  298. package/docs/queries/docs-version.query.d.ts +1 -1
  299. package/docs/services/docs-version.service.js +6 -3
  300. package/docs/services/docs-version.service.js.map +1 -1
  301. package/forms/queries/form.query.d.ts +1 -1
  302. package/forms/queries/property.query.d.ts +1 -1
  303. package/global.d.ts +2 -0
  304. package/global.js +2 -1
  305. package/global.js.map +1 -1
  306. package/http/http.controller.d.ts +2 -0
  307. package/http/http.controller.js +3 -2
  308. package/http/http.controller.js.map +1 -1
  309. package/index.d.ts +5 -2
  310. package/index.js +4 -7
  311. package/index.js.map +1 -1
  312. package/jobs/jobs.controller.d.ts +2 -0
  313. package/jobs/jobs.controller.js +22 -16
  314. package/jobs/jobs.controller.js.map +1 -1
  315. package/package.json +70 -69
  316. package/query/functions/add-join.js +8 -16
  317. package/query/functions/add-join.js.map +1 -1
  318. package/query/functions/collect-external-column-owners.d.ts +10 -0
  319. package/query/functions/collect-external-column-owners.js +100 -0
  320. package/query/functions/collect-external-column-owners.js.map +1 -0
  321. package/query/functions/create-query-builder.js +47 -28
  322. package/query/functions/create-query-builder.js.map +1 -1
  323. package/query/functions/create-query-cache-hash.d.ts +16 -0
  324. package/query/functions/create-query-cache-hash.js +70 -0
  325. package/query/functions/create-query-cache-hash.js.map +1 -0
  326. package/query/functions/create-query.d.ts +8 -3
  327. package/query/functions/create-query.js +12 -9
  328. package/query/functions/create-query.js.map +1 -1
  329. package/query/functions/describe-query-filter.js +3 -2
  330. package/query/functions/describe-query-filter.js.map +1 -1
  331. package/query/functions/execute-query.js +89 -9
  332. package/query/functions/execute-query.js.map +1 -1
  333. package/query/functions/expand-select-with-external-dependencies.d.ts +9 -0
  334. package/query/functions/expand-select-with-external-dependencies.js +34 -0
  335. package/query/functions/expand-select-with-external-dependencies.js.map +1 -0
  336. package/query/functions/external-column-owner-path.d.ts +5 -0
  337. package/query/functions/external-column-owner-path.js +18 -0
  338. package/query/functions/external-column-owner-path.js.map +1 -0
  339. package/query/functions/get-entity-object-class.d.ts +2 -0
  340. package/query/functions/get-entity-object-class.js +12 -0
  341. package/query/functions/get-entity-object-class.js.map +1 -0
  342. package/query/functions/get-native-select.js +3 -0
  343. package/query/functions/get-native-select.js.map +1 -1
  344. package/query/functions/load-properties.d.ts +20 -2
  345. package/query/functions/load-properties.js +190 -40
  346. package/query/functions/load-properties.js.map +1 -1
  347. package/query/functions/map-query-property-to-column-name.js +1 -1
  348. package/query/functions/map-query-property-to-column-name.js.map +1 -1
  349. package/query/functions/query-structure-cache.d.ts +24 -0
  350. package/query/functions/query-structure-cache.js +66 -0
  351. package/query/functions/query-structure-cache.js.map +1 -0
  352. package/query/interfaces/query.d.ts +44 -1
  353. package/query/services/query-action-builder.d.ts +4 -1
  354. package/query/services/query-action-builder.js +26 -12
  355. package/query/services/query-action-builder.js.map +1 -1
  356. package/remote-logs/dtos/index.d.ts +2 -0
  357. package/remote-logs/dtos/index.js +19 -0
  358. package/remote-logs/dtos/index.js.map +1 -0
  359. package/remote-logs/dtos/remote-log-hooks.dto.d.ts +72 -0
  360. package/remote-logs/dtos/remote-log-hooks.dto.js +280 -0
  361. package/remote-logs/dtos/remote-log-hooks.dto.js.map +1 -0
  362. package/remote-logs/dtos/remote-log-search.dto.d.ts +34 -0
  363. package/remote-logs/dtos/remote-log-search.dto.js +146 -0
  364. package/remote-logs/dtos/remote-log-search.dto.js.map +1 -0
  365. package/remote-logs/environment.d.ts +4 -0
  366. package/remote-logs/environment.js +5 -0
  367. package/remote-logs/environment.js.map +1 -0
  368. package/remote-logs/index.d.ts +3 -0
  369. package/remote-logs/index.js +20 -0
  370. package/remote-logs/index.js.map +1 -0
  371. package/remote-logs/interfaces/index.d.ts +1 -0
  372. package/remote-logs/interfaces/index.js +18 -0
  373. package/remote-logs/interfaces/index.js.map +1 -0
  374. package/remote-logs/interfaces/remote-logs-module-options.d.ts +8 -0
  375. package/remote-logs/interfaces/remote-logs-module-options.js +3 -0
  376. package/remote-logs/interfaces/remote-logs-module-options.js.map +1 -0
  377. package/remote-logs/remote-logs-hooks.controller.d.ts +60 -0
  378. package/remote-logs/remote-logs-hooks.controller.js +331 -0
  379. package/remote-logs/remote-logs-hooks.controller.js.map +1 -0
  380. package/remote-logs/remote-logs.controller.d.ts +8 -0
  381. package/remote-logs/remote-logs.controller.js +41 -0
  382. package/remote-logs/remote-logs.controller.js.map +1 -0
  383. package/remote-logs/remote-logs.module.d.ts +12 -0
  384. package/remote-logs/remote-logs.module.js +107 -0
  385. package/remote-logs/remote-logs.module.js.map +1 -0
  386. package/remote-logs/services/opensearch.service.d.ts +13 -0
  387. package/remote-logs/services/opensearch.service.js +167 -0
  388. package/remote-logs/services/opensearch.service.js.map +1 -0
  389. package/security/auth.controller.js +4 -4
  390. package/security/auth.controller.js.map +1 -1
  391. package/security/env.js.map +1 -1
  392. package/security/functions/add-protected.d.ts +2 -2
  393. package/security/functions/add-protected.js +8 -5
  394. package/security/functions/add-protected.js.map +1 -1
  395. package/security/functions/create-authentication-interceptor.d.ts +44 -0
  396. package/security/functions/create-authentication-interceptor.js +114 -0
  397. package/security/functions/create-authentication-interceptor.js.map +1 -0
  398. package/security/functions/find-auth-context.d.ts +1 -2
  399. package/security/functions/find-auth-context.js +6 -11
  400. package/security/functions/find-auth-context.js.map +1 -1
  401. package/security/index.d.ts +1 -0
  402. package/security/index.js +1 -0
  403. package/security/index.js.map +1 -1
  404. package/security/interfaces/authorization-schema.d.ts +3 -1
  405. package/security/requests/security.request.js +1 -1
  406. package/security/requests/security.request.js.map +1 -1
  407. package/security/services/authorization.service.d.ts +5 -3
  408. package/security/services/authorization.service.js +56 -37
  409. package/security/services/authorization.service.js.map +1 -1
  410. package/storage/services/routes.service.js +1 -1
  411. package/storage/services/routes.service.js.map +1 -1
  412. package/tasks/constants.d.ts +3 -0
  413. package/tasks/constants.js +2 -1
  414. package/tasks/constants.js.map +1 -1
  415. package/tasks/controllers/task.controller.d.ts +3 -2
  416. package/tasks/controllers/task.controller.js +11 -40
  417. package/tasks/controllers/task.controller.js.map +1 -1
  418. package/tasks/decorators/index.d.ts +1 -0
  419. package/tasks/decorators/index.js +1 -0
  420. package/tasks/decorators/index.js.map +1 -1
  421. package/tasks/decorators/task-payload.decorator.d.ts +1 -0
  422. package/tasks/decorators/task-payload.decorator.js +12 -0
  423. package/tasks/decorators/task-payload.decorator.js.map +1 -0
  424. package/tasks/decorators/task.decorator.js +6 -2
  425. package/tasks/decorators/task.decorator.js.map +1 -1
  426. package/tasks/functions/compile-all-task-post-hooks.d.ts +1 -0
  427. package/tasks/functions/compile-all-task-post-hooks.js +27 -0
  428. package/tasks/functions/compile-all-task-post-hooks.js.map +1 -0
  429. package/tasks/functions/compile-task-hook-handle.d.ts +6 -0
  430. package/tasks/functions/compile-task-hook-handle.js +67 -0
  431. package/tasks/functions/compile-task-hook-handle.js.map +1 -0
  432. package/tasks/functions/create-task-hook.d.ts +9 -0
  433. package/tasks/functions/create-task-hook.js +13 -0
  434. package/tasks/functions/create-task-hook.js.map +1 -0
  435. package/tasks/functions/{create-task-message-receptor.d.ts → create-task-message-post.d.ts} +1 -1
  436. package/tasks/functions/{create-task-message-receptor.js → create-task-message-post.js} +10 -3
  437. package/tasks/functions/create-task-message-post.js.map +1 -0
  438. package/tasks/functions/register-task-post-hook-interceptors.d.ts +3 -0
  439. package/tasks/functions/register-task-post-hook-interceptors.js +86 -0
  440. package/tasks/functions/register-task-post-hook-interceptors.js.map +1 -0
  441. package/tasks/functions/run-task-post-hooks.d.ts +11 -0
  442. package/tasks/functions/run-task-post-hooks.js +18 -0
  443. package/tasks/functions/run-task-post-hooks.js.map +1 -0
  444. package/tasks/functions/task-message-operations.d.ts +18 -0
  445. package/tasks/functions/task-message-operations.js +100 -0
  446. package/tasks/functions/task-message-operations.js.map +1 -0
  447. package/tasks/functions/validate-task-payload.d.ts +2 -0
  448. package/tasks/functions/validate-task-payload.js +19 -0
  449. package/tasks/functions/validate-task-payload.js.map +1 -0
  450. package/tasks/hook-constants.d.ts +2 -0
  451. package/tasks/hook-constants.js +6 -0
  452. package/tasks/hook-constants.js.map +1 -0
  453. package/tasks/index.d.ts +3 -0
  454. package/tasks/index.js +3 -0
  455. package/tasks/index.js.map +1 -1
  456. package/tasks/interfaces/compiled-task-post-hooks.d.ts +17 -0
  457. package/tasks/interfaces/compiled-task-post-hooks.js +3 -0
  458. package/tasks/interfaces/compiled-task-post-hooks.js.map +1 -0
  459. package/tasks/interfaces/index.d.ts +3 -0
  460. package/tasks/interfaces/index.js +3 -0
  461. package/tasks/interfaces/index.js.map +1 -1
  462. package/tasks/interfaces/task-hook.d.ts +16 -0
  463. package/tasks/interfaces/task-hook.js +8 -0
  464. package/tasks/interfaces/task-hook.js.map +1 -0
  465. package/tasks/interfaces/task-object.d.ts +6 -2
  466. package/tasks/interfaces/task-post-hook.d.ts +2 -0
  467. package/tasks/interfaces/task-post-hook.js +3 -0
  468. package/tasks/interfaces/task-post-hook.js.map +1 -0
  469. package/tasks/interfaces/task-post-intercept.d.ts +1 -8
  470. package/tasks/interfaces/task-runner.d.ts +2 -1
  471. package/tasks/interfaces/task-settings.d.ts +7 -0
  472. package/tasks/services/task-runner.service.d.ts +24 -3
  473. package/tasks/services/task-runner.service.js +68 -28
  474. package/tasks/services/task-runner.service.js.map +1 -1
  475. package/translations/controllers/translation.controller.js +12 -9
  476. package/translations/controllers/translation.controller.js.map +1 -1
  477. package/translations/functions/create-translation-values.js +2 -5
  478. package/translations/functions/create-translation-values.js.map +1 -1
  479. package/translations/migrations/1723760669185-CreateTranslationTables.js +3 -3
  480. package/translations/migrations/1723760669185-CreateTranslationTables.js.map +1 -1
  481. package/translations/queries/translation-config.query.d.ts +1 -1
  482. package/translations/queries/translation-values.query.d.ts +1 -1
  483. package/translations/queries/translation-values.query.js +1 -1
  484. package/translations/queries/translation-values.query.js.map +1 -1
  485. package/translations/translations.controller.d.ts +1 -1
  486. package/translations/translations.controller.js +4 -4
  487. package/translations/translations.controller.js.map +1 -1
  488. package/database/functions/generate-id.d.ts +0 -2
  489. package/database/functions/generate-id.js.map +0 -1
  490. package/database/functions/use-protector.d.ts +0 -2
  491. package/database/functions/use-protector.js +0 -11
  492. package/database/functions/use-protector.js.map +0 -1
  493. package/database/interfaces/protector.d.ts +0 -51
  494. package/database/interfaces/protector.js.map +0 -1
  495. package/database/services/protect-builder.d.ts +0 -59
  496. package/database/services/protect-builder.js +0 -524
  497. package/database/services/protect-builder.js.map +0 -1
  498. package/security/functions/add-protect.d.ts +0 -2
  499. package/security/functions/add-protect.js +0 -11
  500. package/security/functions/add-protect.js.map +0 -1
  501. package/tasks/functions/create-task-message-receptor.js.map +0 -1
@@ -0,0 +1,11 @@
1
+ import { ScopeAccessService } from "./services/scope-access.service";
2
+ import { ScopeKeyService } from "./services/scope-key.service";
3
+ import { ScopeOwnerService } from "./services/scope-owner.service";
4
+ export declare class AccessModule {
5
+ protected readonly scopeKeyService: ScopeKeyService;
6
+ protected readonly scopeAccessService: ScopeAccessService;
7
+ protected readonly scopeOwnerService: ScopeOwnerService;
8
+ constructor(scopeKeyService: ScopeKeyService, scopeAccessService: ScopeAccessService, scopeOwnerService: ScopeOwnerService);
9
+ init(): Promise<void>;
10
+ protected initGetContextIdServices(): Promise<void>;
11
+ }
@@ -0,0 +1,56 @@
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.AccessModule = void 0;
13
+ const env_1 = require("./env");
14
+ const module_decorator_1 = require("../module/decorators/module.decorator");
15
+ const on_after_database_init_1 = require("../module/decorators/on-after-database-init");
16
+ const entities_1 = require("./entities/entities");
17
+ const scope_access_service_1 = require("./services/scope-access.service");
18
+ const scope_key_service_1 = require("./services/scope-key.service");
19
+ const scope_owner_service_1 = require("./services/scope-owner.service");
20
+ const controllers_1 = require("./controllers/controllers");
21
+ const init_scope_service_executors_1 = require("./functions/init-scope-service-executors");
22
+ let AccessModule = class AccessModule {
23
+ constructor(scopeKeyService, scopeAccessService, scopeOwnerService) {
24
+ this.scopeKeyService = scopeKeyService;
25
+ this.scopeAccessService = scopeAccessService;
26
+ this.scopeOwnerService = scopeOwnerService;
27
+ }
28
+ async init() {
29
+ await this.scopeKeyService.updateAll();
30
+ env_1.env.scopeAccessService = this.scopeAccessService;
31
+ env_1.env.scopeOwnerService = this.scopeOwnerService;
32
+ await this.initGetContextIdServices();
33
+ }
34
+ async initGetContextIdServices() {
35
+ for (const [contextName, data] of env_1.env.scopeServiceRegistry.entries()) {
36
+ await (0, init_scope_service_executors_1.initScopeServiceExecutors)(contextName, data.Service);
37
+ }
38
+ }
39
+ };
40
+ exports.AccessModule = AccessModule;
41
+ __decorate([
42
+ (0, on_after_database_init_1.OnAfterDatabaseInit)(),
43
+ __metadata("design:type", Function),
44
+ __metadata("design:paramtypes", []),
45
+ __metadata("design:returntype", Promise)
46
+ ], AccessModule.prototype, "init", null);
47
+ exports.AccessModule = AccessModule = __decorate([
48
+ (0, module_decorator_1.Module)({
49
+ entities: entities_1.entities,
50
+ controllers: controllers_1.controllers
51
+ }),
52
+ __metadata("design:paramtypes", [scope_key_service_1.ScopeKeyService,
53
+ scope_access_service_1.ScopeAccessService,
54
+ scope_owner_service_1.ScopeOwnerService])
55
+ ], AccessModule);
56
+ //# sourceMappingURL=access.module.js.map
@@ -0,0 +1 @@
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"}
@@ -0,0 +1,7 @@
1
+ import { ScopeAccessProfileController } from "./scope-access-profile.controller";
2
+ import { ScopeGroupUserController } from "./scope-group-user.controller";
3
+ import { ScopeGroupController } from "./scope-group.controller";
4
+ import { ScopeKeyController } from "./scope-key.controller";
5
+ import { ScopeOwnerController } from "./scope-owner.controller";
6
+ import { ScopeUserController } from "./scope-user.controller";
7
+ export declare const controllers: (typeof ScopeAccessProfileController | typeof ScopeGroupUserController | typeof ScopeGroupController | typeof ScopeKeyController | typeof ScopeOwnerController | typeof ScopeUserController)[];
@@ -0,0 +1,18 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.controllers = void 0;
4
+ const scope_access_profile_controller_1 = require("./scope-access-profile.controller");
5
+ const scope_group_user_controller_1 = require("./scope-group-user.controller");
6
+ const scope_group_controller_1 = require("./scope-group.controller");
7
+ const scope_key_controller_1 = require("./scope-key.controller");
8
+ const scope_owner_controller_1 = require("./scope-owner.controller");
9
+ const scope_user_controller_1 = require("./scope-user.controller");
10
+ exports.controllers = [
11
+ scope_key_controller_1.ScopeKeyController,
12
+ scope_user_controller_1.ScopeUserController,
13
+ scope_owner_controller_1.ScopeOwnerController,
14
+ scope_group_controller_1.ScopeGroupController,
15
+ scope_group_user_controller_1.ScopeGroupUserController,
16
+ scope_access_profile_controller_1.ScopeAccessProfileController,
17
+ ];
18
+ //# sourceMappingURL=controllers.js.map
@@ -0,0 +1 @@
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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"}
@@ -0,0 +1,20 @@
1
+ import { IScopeGroupUser } from "@rockster/common/access";
2
+ import { IQueryContent } from "../../query/interfaces/query";
3
+ import { ScopeGroupUser } from "../entities/scope-group-user";
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";
7
+ import { IPostContent } from "../../command/interfaces/post-content";
8
+ import { IRequestContext } from "../../core/interfaces/request-context";
9
+ import { ScopeContext } from "../models/scope-context";
10
+ export declare class ScopeGroupUserController {
11
+ protected readonly scopeGroupUserService: ScopeGroupUserService;
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>;
20
+ }
@@ -0,0 +1,132 @@
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.ScopeGroupUserController = void 0;
16
+ const controller_decorator_1 = require("../../controllers/decorators/controller.decorator");
17
+ const query_content_decorator_1 = require("../../query/decorators/query-content.decorator");
18
+ const scope_group_user_query_1 = require("../queries/scope-group-user.query");
19
+ const execute_query_1 = require("../../query/functions/execute-query");
20
+ const post_action_decorator_1 = require("../../command/decorators/post-action.decorator");
21
+ const scope_group_user_1 = require("../entities/scope-group-user");
22
+ const post_content_decorator_1 = require("../../command/decorators/post-content.decorator");
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");
26
+ const action_decorator_1 = require("../../controllers/decorators/actions/action.decorator");
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");
29
+ const scope_group_1 = require("../entities/scope-group");
30
+ const assert_context_admin_access_1 = require("../functions/assert-context-admin-access");
31
+ let ScopeGroupUserController = class ScopeGroupUserController {
32
+ constructor(scopeGroupUserService, scopeGroupService, scopeOwnerService) {
33
+ this.scopeGroupUserService = scopeGroupUserService;
34
+ this.scopeGroupService = scopeGroupService;
35
+ this.scopeOwnerService = scopeOwnerService;
36
+ }
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) {
49
+ const contextName = content.context.$contextName;
50
+ const contextId = content.context.$contextId;
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)({
57
+ content,
58
+ intercept: (queryBuilder) => {
59
+ queryBuilder.leftJoin(scope_group_1.ScopeGroup, 'scopeGroup', '"scopeGroup".id = "scopeGroupUser".group_id');
60
+ return queryBuilder;
61
+ },
62
+ preFilter: `"scopeGroup".context_name = '${contextName}'
63
+ ${contextId ? `AND "scopeGroup".context_id = '${contextId}'` : ''}`
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;
84
+ }
85
+ async post(content, requestContext) {
86
+ await this.assertGroupAdmin(content.data.groupId, requestContext.session?.userId);
87
+ return this
88
+ .scopeGroupUserService
89
+ .addIfNotExists(content.data.groupId, content.data.userId);
90
+ }
91
+ async remove(content, requestContext) {
92
+ await this.assertGroupAdmin(content.groupId, requestContext.session?.userId);
93
+ return this.scopeGroupUserService.removeBy({
94
+ groupId: content.groupId,
95
+ userId: content.userId
96
+ });
97
+ }
98
+ };
99
+ exports.ScopeGroupUserController = ScopeGroupUserController;
100
+ __decorate([
101
+ (0, scope_group_user_query_1.ScopeGroupUserQuery)(),
102
+ __param(0, (0, query_content_decorator_1.QueryContent)()),
103
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
104
+ __metadata("design:type", Function),
105
+ __metadata("design:paramtypes", [Object, Object]),
106
+ __metadata("design:returntype", Promise)
107
+ ], ScopeGroupUserController.prototype, "query", null);
108
+ __decorate([
109
+ (0, post_action_decorator_1.PostAction)({
110
+ type: () => scope_group_user_1.ScopeGroupUser
111
+ }),
112
+ __param(0, (0, post_content_decorator_1.PostContent)()),
113
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
114
+ __metadata("design:type", Function),
115
+ __metadata("design:paramtypes", [Object, Object]),
116
+ __metadata("design:returntype", Promise)
117
+ ], ScopeGroupUserController.prototype, "post", null);
118
+ __decorate([
119
+ (0, action_decorator_1.Action)(),
120
+ __param(0, (0, action_content_decorator_1.ActionContent)()),
121
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
122
+ __metadata("design:type", Function),
123
+ __metadata("design:paramtypes", [scope_group_user_1.ScopeGroupUser, Object]),
124
+ __metadata("design:returntype", Promise)
125
+ ], ScopeGroupUserController.prototype, "remove", null);
126
+ exports.ScopeGroupUserController = ScopeGroupUserController = __decorate([
127
+ (0, controller_decorator_1.Controller)(),
128
+ __metadata("design:paramtypes", [scope_group_user_service_1.ScopeGroupUserService,
129
+ scope_group_service_1.ScopeGroupService,
130
+ scope_owner_service_1.ScopeOwnerService])
131
+ ], ScopeGroupUserController);
132
+ //# sourceMappingURL=scope-group-user.controller.js.map
@@ -0,0 +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;AAC7E,yEAAoE;AACpE,yEAAoE;AAEpE,4FAA+E;AAC/E,4GAA8F;AAC9F,sGAAwF;AAGxF,yDAAqD;AACrD,0FAAoF;AAG7E,IAAM,wBAAwB,GAA9B,MAAM,wBAAwB;IAElC,YACsB,qBAA4C,EAC5C,iBAAoC,EACpC,iBAAoC;QAFpC,0BAAqB,GAArB,qBAAqB,CAAuB;QAC5C,sBAAiB,GAAjB,iBAAiB,CAAmB;QACpC,sBAAiB,GAAjB,iBAAiB,CAAmB;IACvD,CAAC;IAEJ,kFAAkF;IACxE,KAAK,CAAC,gBAAgB,CAAC,OAAe,EAAE,MAAe;QAC9D,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,EAAE,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;QACrE,IAAI,KAAK,EAAE,CAAC;YACT,MAAM,IAAA,sDAAwB,EAAC;gBAC5B,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,SAAS,EAAE,KAAK,CAAC,SAAS;gBAC1B,MAAM;aACR,CAAC,CAAC;QACN,CAAC;IACJ,CAAC;IAGK,AAAN,KAAK,CAAC,KAAK,CACQ,OAAqD,EACnD,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,MAAM,MAAM,GAAG,MAAM,IAAA,4BAAY,EAAC;YAC/B,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;QAEH,IAAI,SAAS,EAAE,CAAC;YACb,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAC3D,WAAW,EACX,SAAS,EACT,MAAM,CAAC,IAAI;iBACP,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC;iBACxC,MAAM,CAAC,CAAC,EAAE,EAAgB,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAC/C,CAAC;YAEF,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;gBACnC,MAAM,MAAM,GAAG,GAAG,CAAC,IAAI,EAAE,EAAE,IAAI,GAAG,CAAC,MAAM,CAAC;gBAC1C,IAAI,CAAC,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;oBACxB,OAAO,GAAG,CAAC;gBACd,CAAC;gBACD,OAAO;oBACJ,GAAG,GAAG;oBACN,IAAI,EAAE;wBACH,GAAG,GAAG,CAAC,IAAI;wBACX,YAAY,EAAE,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC;qBACpC;iBACH,CAAC;YACL,CAAC,CAAC,CAAC;QACN,CAAC;QAED,OAAO,MAAM,CAAC;IACjB,CAAC;IAKK,AAAN,KAAK,CAAC,IAAI,CACQ,OAAqC,EAClC,cAA+B;QAEjD,MAAM,IAAI,CAAC,gBAAgB,CACxB,OAAO,CAAC,IAAI,CAAC,OAAO,EACpB,cAAc,CAAC,OAAO,EAAE,MAAM,CAChC,CAAC;QACF,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,CACQ,OAAuB,EACtB,cAA+B;QAEjD,MAAM,IAAI,CAAC,gBAAgB,CACxB,OAAO,CAAC,OAAO,EACf,cAAc,CAAC,OAAO,EAAE,MAAM,CAChC,CAAC;QACF,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;AA5GY,4DAAwB;AAqB5B;IADL,IAAA,4CAAmB,GAAE;IAElB,WAAA,IAAA,sCAAY,GAAE,CAAA;IACd,WAAA,IAAA,0CAAc,GAAE,CAAA;;;;qDAkDnB;AAKK;IAHL,IAAA,kCAAU,EAAC;QACT,IAAI,EAAE,GAAG,EAAE,CAAC,iCAAc;KAC5B,CAAC;IAEE,WAAA,IAAA,oCAAW,GAAE,CAAA;IACb,WAAA,IAAA,0CAAc,GAAE,CAAA;;;;oDAYnB;AAGK;IADL,IAAA,yBAAM,GAAE;IAEL,WAAA,IAAA,wCAAa,GAAE,CAAA;IACf,WAAA,IAAA,0CAAc,GAAE,CAAA;;qCADS,iCAAc;;sDAW1C;mCA3GS,wBAAwB;IADpC,IAAA,iCAAU,GAAE;qCAImC,gDAAqB;QACzB,uCAAiB;QACjB,uCAAiB;GALhD,wBAAwB,CA4GpC"}
@@ -0,0 +1,22 @@
1
+ import { IScopeGroup } 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 { ScopeGroup } from "../entities/scope-group";
6
+ import { ScopeKeysUpdate } from "../models/scope-keys-update";
7
+ import { ScopeAccessService } from "../services/scope-access.service";
8
+ import { ScopeGroupService } from "../services/scope-group.service";
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";
12
+ export declare class ScopeGroupController {
13
+ protected readonly scopeAccessService: ScopeAccessService;
14
+ protected readonly scopeGroupService: ScopeGroupService;
15
+ constructor(scopeAccessService: ScopeAccessService, scopeGroupService: ScopeGroupService);
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>;
22
+ }
@@ -0,0 +1,177 @@
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.ScopeGroupController = 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_group_1 = require("../entities/scope-group");
26
+ const scope_group_query_1 = require("../queries/scope-group.query");
27
+ const action_content_decorator_1 = require("../../controllers/decorators/actions/action-content.decorator");
28
+ const scope_keys_update_1 = require("../models/scope-keys-update");
29
+ const action_decorator_1 = require("../../controllers/decorators/actions/action.decorator");
30
+ const scope_access_service_1 = require("../services/scope-access.service");
31
+ const response_type_decorator_1 = require("../../controllers/decorators/http-methods/response-type.decorator");
32
+ const from_params_decorator_1 = require("../../controllers/decorators/http-methods/from-params.decorator");
33
+ const from_query_decorator_1 = require("../../controllers/decorators/http-methods/from-query.decorator");
34
+ const scope_group_service_1 = require("../services/scope-group.service");
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");
41
+ let ScopeGroupController = class ScopeGroupController {
42
+ constructor(scopeAccessService, scopeGroupService) {
43
+ this.scopeAccessService = scopeAccessService;
44
+ this.scopeGroupService = scopeGroupService;
45
+ }
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));
61
+ }
62
+ async query(content, requestContext) {
63
+ const contextName = content.context.$contextName;
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
+ });
70
+ return (0, execute_query_1.executeQuery)({
71
+ content,
72
+ preFilter: `"scopeGroup".context_name = '${contextName}'
73
+ ${contextId ? `AND "scopeGroup".context_id = '${contextId}'` : ''}`
74
+ });
75
+ }
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
+ });
82
+ return (0, execute_post_1.executePost)(content);
83
+ }
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
+ }
93
+ return (0, execute_remove_1.executeRemove)(content);
94
+ }
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
+ });
101
+ const group = await this
102
+ .scopeGroupService
103
+ .getOneBy({ id: groupId });
104
+ const keys = await this
105
+ .scopeAccessService
106
+ .getMany({
107
+ where: {
108
+ contextName: contextName,
109
+ groupId: group.id
110
+ }
111
+ });
112
+ return {
113
+ contextName: contextName,
114
+ contextId: contextId,
115
+ name: group.name,
116
+ keys: (0, normalize_scope_keys_1.filterScopeAccessRows)(keys),
117
+ };
118
+ }
119
+ };
120
+ exports.ScopeGroupController = ScopeGroupController;
121
+ __decorate([
122
+ (0, action_decorator_1.Action)(),
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)()),
133
+ __metadata("design:type", Function),
134
+ __metadata("design:paramtypes", [scope_keys_update_1.ScopeKeysUpdate, Object]),
135
+ __metadata("design:returntype", Promise)
136
+ ], ScopeGroupController.prototype, "updateKeys", null);
137
+ __decorate([
138
+ (0, scope_group_query_1.ScopeGroupQuery)(),
139
+ __param(0, (0, query_content_decorator_1.QueryContent)()),
140
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
141
+ __metadata("design:type", Function),
142
+ __metadata("design:paramtypes", [Object, Object]),
143
+ __metadata("design:returntype", Promise)
144
+ ], ScopeGroupController.prototype, "query", null);
145
+ __decorate([
146
+ (0, post_action_decorator_1.PostAction)({ type: () => scope_group_1.ScopeGroup }),
147
+ __param(0, (0, post_content_decorator_1.PostContent)()),
148
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
149
+ __metadata("design:type", Function),
150
+ __metadata("design:paramtypes", [Object, Object]),
151
+ __metadata("design:returntype", Promise)
152
+ ], ScopeGroupController.prototype, "post", null);
153
+ __decorate([
154
+ (0, remove_action_decorator_1.RemoveAction)({ type: () => scope_group_1.ScopeGroup }),
155
+ __param(0, (0, remove_content_decorator_1.RemoveContent)()),
156
+ __param(1, (0, request_context_decorator_1.RequestContext)()),
157
+ __metadata("design:type", Function),
158
+ __metadata("design:paramtypes", [Object, Object]),
159
+ __metadata("design:returntype", Promise)
160
+ ], ScopeGroupController.prototype, "remove", null);
161
+ __decorate([
162
+ (0, response_type_decorator_1.ResponseType)(() => scope_group_1.ScopeGroup),
163
+ (0, get_decorator_1.Get)(':groupId/context/:contextName'),
164
+ __param(0, (0, from_params_decorator_1.FromParams)('groupId')),
165
+ __param(1, (0, from_params_decorator_1.FromParams)('contextName')),
166
+ __param(2, (0, from_query_decorator_1.FromQuery)('contextId')),
167
+ __param(3, (0, session_decorator_1.Session)()),
168
+ __metadata("design:type", Function),
169
+ __metadata("design:paramtypes", [String, String, String, Object]),
170
+ __metadata("design:returntype", Promise)
171
+ ], ScopeGroupController.prototype, "get", null);
172
+ exports.ScopeGroupController = ScopeGroupController = __decorate([
173
+ (0, controller_decorator_1.Controller)(),
174
+ __metadata("design:paramtypes", [scope_access_service_1.ScopeAccessService,
175
+ scope_group_service_1.ScopeGroupService])
176
+ ], ScopeGroupController);
177
+ //# sourceMappingURL=scope-group.controller.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"scope-group.controller.js","sourceRoot":"./","sources":["access/controllers/scope-group.controller.ts"],"names":[],"mappings":"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"}