@kalisio/kdk 2.6.2 → 2.6.3

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 (299) hide show
  1. package/client/css/core.variables.scss +72 -0
  2. package/client/i18n/core_en.json +744 -0
  3. package/client/i18n/core_fr.json +744 -0
  4. package/client/i18n/map_en.json +800 -0
  5. package/client/i18n/map_fr.json +800 -0
  6. package/client/kdk.client.css +47 -0
  7. package/client/kdk.client.js +41097 -0
  8. package/client/kdk.client.map.css +47 -0
  9. package/client/kdk.client.map.js +38182 -0
  10. package/client/kdk.client.map.min.css +1 -0
  11. package/client/kdk.client.map.min.js +27032 -0
  12. package/client/kdk.client.min.css +1 -0
  13. package/client/kdk.client.min.js +29074 -0
  14. package/client/schemas/capture.create.json +132 -0
  15. package/client/schemas/catalog.update.json +44 -0
  16. package/client/schemas/messages.update.json +16 -0
  17. package/client/schemas/projects.create.json +52 -0
  18. package/client/schemas/projects.update.json +52 -0
  19. package/client/schemas/settings.update.json +286 -0
  20. package/client/schemas/tags.update.json +35 -0
  21. package/client/schemas/users.update-profile.json +34 -0
  22. package/core/api/authentication.js +13 -1
  23. package/core/api/hooks/hooks.query.js +9 -0
  24. package/core/client/capabilities.js +6 -1
  25. package/core/client/components/KChip.vue +27 -6
  26. package/core/client/components/collection/KCard.vue +2 -2
  27. package/core/client/utils/utils.session.js +5 -1
  28. package/coverage/core/api/application.js.html +392 -398
  29. package/coverage/core/api/authentication.js.html +352 -187
  30. package/coverage/core/api/db.js.html +165 -126
  31. package/coverage/core/api/hooks/hooks.authentication.js.html +22 -196
  32. package/coverage/core/api/hooks/hooks.authorisations.js.html +383 -662
  33. package/coverage/core/api/hooks/hooks.logger.js.html +41 -41
  34. package/coverage/core/api/hooks/hooks.model.js.html +113 -101
  35. package/coverage/core/api/hooks/hooks.push.js.html +112 -97
  36. package/coverage/core/api/hooks/hooks.query.js.html +270 -222
  37. package/coverage/core/api/hooks/hooks.schemas.js.html +123 -123
  38. package/coverage/core/api/hooks/hooks.service.js.html +1 -1
  39. package/coverage/core/api/hooks/hooks.storage.js.html +1 -1
  40. package/coverage/core/api/hooks/{hooks.groups.js.html → hooks.tags.js.html} +100 -76
  41. package/coverage/core/api/hooks/hooks.users.js.html +255 -447
  42. package/coverage/core/api/hooks/index.html +107 -122
  43. package/coverage/core/api/hooks/index.js.html +4 -10
  44. package/coverage/core/api/index.html +46 -61
  45. package/coverage/core/api/index.js.html +9 -9
  46. package/coverage/core/api/marshall.js.html +9 -9
  47. package/coverage/core/api/models/{organisations.model.mongodb.js.html → configurations.model.mongodb.js.html} +10 -7
  48. package/coverage/core/api/models/index.html +35 -50
  49. package/coverage/core/api/models/messages.model.mongodb.js.html +39 -27
  50. package/coverage/core/api/models/tags.model.mongodb.js.html +26 -32
  51. package/coverage/core/api/models/users.model.mongodb.js.html +10 -10
  52. package/coverage/core/api/services/account/account.hooks.js.html +5 -5
  53. package/coverage/core/api/services/account/account.service.js.html +127 -127
  54. package/coverage/core/api/services/account/index.html +22 -22
  55. package/coverage/core/api/services/authorisations/authorisations.hooks.js.html +1 -1
  56. package/coverage/core/api/services/authorisations/authorisations.service.js.html +213 -222
  57. package/coverage/core/api/services/authorisations/index.html +21 -21
  58. package/coverage/core/api/services/{groups/groups.hooks.js.html → configurations/configurations.hooks.js.html} +16 -10
  59. package/coverage/{lcov-report/core/api/services/groups → core/api/services/configurations}/index.html +8 -8
  60. package/coverage/core/api/services/databases/databases.hooks.js.html +1 -1
  61. package/coverage/core/api/services/databases/databases.service.js.html +1 -1
  62. package/coverage/core/api/services/databases/index.html +1 -1
  63. package/coverage/core/api/services/import-export/import-export.hooks.js.html +76 -76
  64. package/coverage/core/api/services/import-export/import-export.service.js.html +32 -32
  65. package/coverage/core/api/services/import-export/index.html +32 -32
  66. package/coverage/core/api/services/index.html +21 -21
  67. package/coverage/core/api/services/index.js.html +313 -142
  68. package/coverage/core/api/services/mailer/index.html +32 -32
  69. package/coverage/core/api/services/mailer/mailer.hooks.js.html +80 -80
  70. package/coverage/core/api/services/mailer/mailer.service.js.html +32 -32
  71. package/coverage/core/api/services/messages/index.html +21 -21
  72. package/coverage/core/api/services/messages/messages.hooks.js.html +112 -76
  73. package/coverage/core/api/services/push/index.html +32 -32
  74. package/coverage/core/api/services/push/push.hooks.js.html +80 -80
  75. package/coverage/core/api/services/push/push.service.js.html +34 -34
  76. package/coverage/core/api/services/storage/index.html +29 -29
  77. package/coverage/core/api/services/storage/storage.hooks.js.html +80 -80
  78. package/coverage/core/api/services/storage/storage.service.js.html +29 -29
  79. package/coverage/core/api/services/tags/index.html +21 -21
  80. package/coverage/core/api/services/tags/tags.hooks.js.html +119 -71
  81. package/coverage/core/api/services/users/index.html +27 -12
  82. package/coverage/core/api/services/users/users.hooks.js.html +14 -11
  83. package/coverage/core/api/services/users/users.service.js.html +100 -0
  84. package/coverage/core/common/errors.js.html +1 -1
  85. package/coverage/core/common/index.html +42 -27
  86. package/coverage/core/common/index.js.html +1 -1
  87. package/coverage/core/common/permissions.js.html +166 -472
  88. package/coverage/core/common/schema.js.html +4 -4
  89. package/coverage/core/common/utils.js.html +31 -25
  90. package/coverage/core/common/utils.offline.js.html +199 -0
  91. package/coverage/index.html +192 -192
  92. package/coverage/lcov-report/core/api/application.js.html +392 -398
  93. package/coverage/lcov-report/core/api/authentication.js.html +352 -187
  94. package/coverage/lcov-report/core/api/db.js.html +165 -126
  95. package/coverage/lcov-report/core/api/hooks/hooks.authentication.js.html +22 -196
  96. package/coverage/lcov-report/core/api/hooks/hooks.authorisations.js.html +383 -662
  97. package/coverage/lcov-report/core/api/hooks/hooks.logger.js.html +41 -41
  98. package/coverage/lcov-report/core/api/hooks/hooks.model.js.html +113 -101
  99. package/coverage/lcov-report/core/api/hooks/hooks.push.js.html +112 -97
  100. package/coverage/lcov-report/core/api/hooks/hooks.query.js.html +270 -222
  101. package/coverage/lcov-report/core/api/hooks/hooks.schemas.js.html +123 -123
  102. package/coverage/lcov-report/core/api/hooks/hooks.service.js.html +1 -1
  103. package/coverage/lcov-report/core/api/hooks/hooks.storage.js.html +1 -1
  104. package/coverage/lcov-report/core/api/hooks/{hooks.groups.js.html → hooks.tags.js.html} +100 -76
  105. package/coverage/lcov-report/core/api/hooks/hooks.users.js.html +255 -447
  106. package/coverage/lcov-report/core/api/hooks/index.html +107 -122
  107. package/coverage/lcov-report/core/api/hooks/index.js.html +4 -10
  108. package/coverage/lcov-report/core/api/index.html +46 -61
  109. package/coverage/lcov-report/core/api/index.js.html +9 -9
  110. package/coverage/lcov-report/core/api/marshall.js.html +9 -9
  111. package/coverage/lcov-report/core/api/models/{organisations.model.mongodb.js.html → configurations.model.mongodb.js.html} +10 -7
  112. package/coverage/lcov-report/core/api/models/index.html +35 -50
  113. package/coverage/lcov-report/core/api/models/messages.model.mongodb.js.html +39 -27
  114. package/coverage/lcov-report/core/api/models/tags.model.mongodb.js.html +26 -32
  115. package/coverage/lcov-report/core/api/models/users.model.mongodb.js.html +10 -10
  116. package/coverage/lcov-report/core/api/services/account/account.hooks.js.html +5 -5
  117. package/coverage/lcov-report/core/api/services/account/account.service.js.html +127 -127
  118. package/coverage/lcov-report/core/api/services/account/index.html +22 -22
  119. package/coverage/lcov-report/core/api/services/authorisations/authorisations.hooks.js.html +1 -1
  120. package/coverage/lcov-report/core/api/services/authorisations/authorisations.service.js.html +213 -222
  121. package/coverage/lcov-report/core/api/services/authorisations/index.html +21 -21
  122. package/coverage/lcov-report/core/api/services/{groups/groups.hooks.js.html → configurations/configurations.hooks.js.html} +16 -10
  123. package/coverage/{core/api/services/groups → lcov-report/core/api/services/configurations}/index.html +8 -8
  124. package/coverage/lcov-report/core/api/services/databases/databases.hooks.js.html +1 -1
  125. package/coverage/lcov-report/core/api/services/databases/databases.service.js.html +1 -1
  126. package/coverage/lcov-report/core/api/services/databases/index.html +1 -1
  127. package/coverage/lcov-report/core/api/services/import-export/import-export.hooks.js.html +76 -76
  128. package/coverage/lcov-report/core/api/services/import-export/import-export.service.js.html +32 -32
  129. package/coverage/lcov-report/core/api/services/import-export/index.html +32 -32
  130. package/coverage/lcov-report/core/api/services/index.html +21 -21
  131. package/coverage/lcov-report/core/api/services/index.js.html +313 -142
  132. package/coverage/lcov-report/core/api/services/mailer/index.html +32 -32
  133. package/coverage/lcov-report/core/api/services/mailer/mailer.hooks.js.html +80 -80
  134. package/coverage/lcov-report/core/api/services/mailer/mailer.service.js.html +32 -32
  135. package/coverage/lcov-report/core/api/services/messages/index.html +21 -21
  136. package/coverage/lcov-report/core/api/services/messages/messages.hooks.js.html +112 -76
  137. package/coverage/lcov-report/core/api/services/push/index.html +32 -32
  138. package/coverage/lcov-report/core/api/services/push/push.hooks.js.html +80 -80
  139. package/coverage/lcov-report/core/api/services/push/push.service.js.html +34 -34
  140. package/coverage/lcov-report/core/api/services/storage/index.html +29 -29
  141. package/coverage/lcov-report/core/api/services/storage/storage.hooks.js.html +80 -80
  142. package/coverage/lcov-report/core/api/services/storage/storage.service.js.html +29 -29
  143. package/coverage/lcov-report/core/api/services/tags/index.html +21 -21
  144. package/coverage/lcov-report/core/api/services/tags/tags.hooks.js.html +119 -71
  145. package/coverage/lcov-report/core/api/services/users/index.html +27 -12
  146. package/coverage/lcov-report/core/api/services/users/users.hooks.js.html +14 -11
  147. package/coverage/lcov-report/core/api/services/users/users.service.js.html +100 -0
  148. package/coverage/lcov-report/core/common/errors.js.html +1 -1
  149. package/coverage/lcov-report/core/common/index.html +42 -27
  150. package/coverage/lcov-report/core/common/index.js.html +1 -1
  151. package/coverage/lcov-report/core/common/permissions.js.html +166 -472
  152. package/coverage/lcov-report/core/common/schema.js.html +4 -4
  153. package/coverage/lcov-report/core/common/utils.js.html +31 -25
  154. package/coverage/lcov-report/core/common/utils.offline.js.html +199 -0
  155. package/coverage/lcov-report/index.html +192 -192
  156. package/coverage/lcov-report/map/api/hooks/hooks.catalog.js.html +169 -31
  157. package/coverage/lcov-report/map/api/hooks/hooks.features.js.html +1 -1
  158. package/coverage/lcov-report/map/api/hooks/hooks.query.js.html +32 -32
  159. package/coverage/lcov-report/map/api/hooks/index.html +5 -5
  160. package/coverage/lcov-report/map/api/hooks/index.js.html +1 -1
  161. package/coverage/lcov-report/map/api/index.html +1 -1
  162. package/coverage/lcov-report/map/api/index.js.html +1 -1
  163. package/coverage/lcov-report/map/api/marshall.js.html +1 -1
  164. package/coverage/lcov-report/map/api/models/alerts.model.mongodb.js.html +1 -1
  165. package/coverage/lcov-report/map/api/models/catalog.model.mongodb.js.html +82 -7
  166. package/coverage/lcov-report/map/api/models/features.model.mongodb.js.html +1 -1
  167. package/coverage/lcov-report/map/api/models/index.html +22 -7
  168. package/coverage/lcov-report/map/api/models/projects.model.mongodb.js.html +1 -1
  169. package/coverage/lcov-report/{core/api/models/groups.model.mongodb.js.html → map/api/models/styles.model.mongodb.js.html} +10 -7
  170. package/coverage/lcov-report/map/api/services/alerts/alerts.hooks.js.html +1 -1
  171. package/coverage/lcov-report/map/api/services/alerts/alerts.service.js.html +1 -1
  172. package/coverage/lcov-report/map/api/services/alerts/index.html +1 -1
  173. package/coverage/lcov-report/map/api/services/catalog/catalog.hooks.js.html +39 -12
  174. package/coverage/lcov-report/map/api/services/catalog/index.html +5 -5
  175. package/coverage/lcov-report/map/api/services/daptiles/daptiles.service.js.html +1 -1
  176. package/coverage/lcov-report/map/api/services/daptiles/index.html +1 -1
  177. package/coverage/lcov-report/map/api/services/features/features.hooks.js.html +86 -11
  178. package/coverage/lcov-report/map/api/services/features/features.service.js.html +307 -4
  179. package/coverage/lcov-report/map/api/services/features/index.html +7 -7
  180. package/coverage/lcov-report/map/api/services/index.html +5 -5
  181. package/coverage/lcov-report/map/api/services/index.js.html +326 -50
  182. package/coverage/lcov-report/map/api/services/projects/index.html +1 -1
  183. package/coverage/lcov-report/map/api/services/projects/projects.hooks.js.html +1 -1
  184. package/coverage/{core/api/services/organisations → lcov-report/map/api/services/styles}/index.html +10 -25
  185. package/coverage/{core/api/services/organisations/organisations.hooks.js.html → lcov-report/map/api/services/styles/styles.hooks.js.html} +45 -12
  186. package/coverage/lcov-report/map/common/dynamic-grid-source.js.html +1 -1
  187. package/coverage/lcov-report/map/common/errors.js.html +1 -1
  188. package/coverage/lcov-report/map/common/geotiff-grid-source.js.html +7 -10
  189. package/coverage/lcov-report/map/common/grid.js.html +1 -1
  190. package/coverage/lcov-report/map/common/index.html +19 -19
  191. package/coverage/lcov-report/map/common/index.js.html +1 -1
  192. package/coverage/lcov-report/map/common/meteo-model-grid-source.js.html +1 -1
  193. package/coverage/lcov-report/map/common/moment-utils.js.html +1 -1
  194. package/coverage/lcov-report/map/common/opendap-grid-source.js.html +1 -1
  195. package/coverage/lcov-report/map/common/opendap-utils.js.html +4 -7
  196. package/coverage/lcov-report/map/common/permissions.js.html +10 -4
  197. package/coverage/lcov-report/map/common/time-based-grid-source.js.html +1 -1
  198. package/coverage/lcov-report/map/common/tms-utils.js.html +9 -12
  199. package/coverage/lcov-report/map/common/wcs-grid-source.js.html +3 -3
  200. package/coverage/lcov-report/map/common/wcs-utils.js.html +12 -15
  201. package/coverage/lcov-report/map/common/weacast-grid-source.js.html +2 -2
  202. package/coverage/lcov-report/map/common/wfs-utils.js.html +14 -17
  203. package/coverage/lcov-report/map/common/wms-utils.js.html +30 -12
  204. package/coverage/lcov-report/map/common/wmts-utils.js.html +10 -13
  205. package/coverage/lcov.info +4172 -3909
  206. package/coverage/map/api/hooks/hooks.catalog.js.html +169 -31
  207. package/coverage/map/api/hooks/hooks.features.js.html +1 -1
  208. package/coverage/map/api/hooks/hooks.query.js.html +32 -32
  209. package/coverage/map/api/hooks/index.html +5 -5
  210. package/coverage/map/api/hooks/index.js.html +1 -1
  211. package/coverage/map/api/index.html +1 -1
  212. package/coverage/map/api/index.js.html +1 -1
  213. package/coverage/map/api/marshall.js.html +1 -1
  214. package/coverage/map/api/models/alerts.model.mongodb.js.html +1 -1
  215. package/coverage/map/api/models/catalog.model.mongodb.js.html +82 -7
  216. package/coverage/map/api/models/features.model.mongodb.js.html +1 -1
  217. package/coverage/map/api/models/index.html +22 -7
  218. package/coverage/map/api/models/projects.model.mongodb.js.html +1 -1
  219. package/coverage/{core/api/models/groups.model.mongodb.js.html → map/api/models/styles.model.mongodb.js.html} +10 -7
  220. package/coverage/map/api/services/alerts/alerts.hooks.js.html +1 -1
  221. package/coverage/map/api/services/alerts/alerts.service.js.html +1 -1
  222. package/coverage/map/api/services/alerts/index.html +1 -1
  223. package/coverage/map/api/services/catalog/catalog.hooks.js.html +39 -12
  224. package/coverage/map/api/services/catalog/index.html +5 -5
  225. package/coverage/map/api/services/daptiles/daptiles.service.js.html +1 -1
  226. package/coverage/map/api/services/daptiles/index.html +1 -1
  227. package/coverage/map/api/services/features/features.hooks.js.html +86 -11
  228. package/coverage/map/api/services/features/features.service.js.html +307 -4
  229. package/coverage/map/api/services/features/index.html +7 -7
  230. package/coverage/map/api/services/index.html +5 -5
  231. package/coverage/map/api/services/index.js.html +326 -50
  232. package/coverage/map/api/services/projects/index.html +1 -1
  233. package/coverage/map/api/services/projects/projects.hooks.js.html +1 -1
  234. package/coverage/{lcov-report/core/api/services/organisations → map/api/services/styles}/index.html +10 -25
  235. package/coverage/{lcov-report/core/api/services/organisations/organisations.hooks.js.html → map/api/services/styles/styles.hooks.js.html} +45 -12
  236. package/coverage/map/common/dynamic-grid-source.js.html +1 -1
  237. package/coverage/map/common/errors.js.html +1 -1
  238. package/coverage/map/common/geotiff-grid-source.js.html +7 -10
  239. package/coverage/map/common/grid.js.html +1 -1
  240. package/coverage/map/common/index.html +19 -19
  241. package/coverage/map/common/index.js.html +1 -1
  242. package/coverage/map/common/meteo-model-grid-source.js.html +1 -1
  243. package/coverage/map/common/moment-utils.js.html +1 -1
  244. package/coverage/map/common/opendap-grid-source.js.html +1 -1
  245. package/coverage/map/common/opendap-utils.js.html +4 -7
  246. package/coverage/map/common/permissions.js.html +10 -4
  247. package/coverage/map/common/time-based-grid-source.js.html +1 -1
  248. package/coverage/map/common/tms-utils.js.html +9 -12
  249. package/coverage/map/common/wcs-grid-source.js.html +3 -3
  250. package/coverage/map/common/wcs-utils.js.html +12 -15
  251. package/coverage/map/common/weacast-grid-source.js.html +2 -2
  252. package/coverage/map/common/wfs-utils.js.html +14 -17
  253. package/coverage/map/common/wms-utils.js.html +30 -12
  254. package/coverage/map/common/wmts-utils.js.html +10 -13
  255. package/coverage/tmp/coverage-222524-1765963609350-0.json +1 -0
  256. package/coverage/tmp/coverage-222536-1765963609335-0.json +1 -0
  257. package/coverage/tmp/coverage-222547-1765963609324-0.json +1 -0
  258. package/coverage/tmp/coverage-222559-1765963609309-0.json +1 -0
  259. package/coverage/tmp/coverage-222566-1765963609278-0.json +1 -0
  260. package/map/api/hooks/hooks.query.js +60 -0
  261. package/map/client/components/stickies/KZoomControl.vue +17 -9
  262. package/map/client/i18n/map_en.json +6 -0
  263. package/map/client/i18n/map_fr.json +6 -0
  264. package/map/client/mixins/map/mixin.base-map.js +19 -1
  265. package/package.json +2 -2
  266. package/scripts/kash/CHANGELOG.md +4 -0
  267. package/scripts/kash/LICENSE +21 -0
  268. package/scripts/kash/README.md +9 -0
  269. package/scripts/kash/kash.sh +40 -45
  270. package/scripts/kash/scripts/run_tests.sh +4 -1
  271. package/test/api/core/config/default.cjs +1 -0
  272. package/test/api/core/test-log-2025-07-31.log +15 -0
  273. package/test/api/core/{test-log-2024-04-23.log → test-log-2025-10-03.log} +4 -9
  274. package/test/api/core/test-log-2025-11-12.log +117 -0
  275. package/test/api/core/test-log-2025-11-27.log +0 -0
  276. package/test/api/core/test-log-2025-11-28.log +17 -0
  277. package/test/api/core/test-log-2025-12-09.log +148 -0
  278. package/test/api/core/test-log-2025-12-17.log +58 -0
  279. package/test/api/core/test-log-2026-01-29.log +17 -0
  280. package/test/api/map/index.test.js +21 -0
  281. package/test/api/map/test-log-2025-07-23.log +1 -0
  282. package/test/api/map/test-log-2025-11-28.log +33 -0
  283. package/test/api/map/test-log-2025-12-10.log +2 -0
  284. package/test/api/map/test-log-2026-01-06.log +26 -0
  285. package/.vscode/settings.json +0 -5
  286. package/coverage/core/api/hooks/hooks.organisations.js.html +0 -541
  287. package/coverage/core/api/services/organisations/organisations.service.js.html +0 -343
  288. package/coverage/core/api/utils.js.html +0 -118
  289. package/coverage/lcov-report/core/api/hooks/hooks.organisations.js.html +0 -541
  290. package/coverage/lcov-report/core/api/services/organisations/organisations.service.js.html +0 -343
  291. package/coverage/lcov-report/core/api/utils.js.html +0 -118
  292. package/coverage/tmp/coverage-151166-1723543324307-0.json +0 -1
  293. package/coverage/tmp/coverage-151178-1723543324283-0.json +0 -1
  294. package/coverage/tmp/coverage-151189-1723543324271-0.json +0 -1
  295. package/coverage/tmp/coverage-151201-1723543324248-0.json +0 -1
  296. package/coverage/tmp/coverage-151208-1723543324227-0.json +0 -1
  297. package/test/api/core/test-log-2024-04-22.log +0 -84
  298. package/test/api/core/test-log-2024-08-13.log +0 -3
  299. /package/test/api/{map/test-log-2025-03-08.log → core/test-log-2025-11-10.log} +0 -0
@@ -1,541 +0,0 @@
1
-
2
- <!doctype html>
3
- <html lang="en">
4
-
5
- <head>
6
- <title>Code coverage report for core/api/hooks/hooks.organisations.js</title>
7
- <meta charset="utf-8" />
8
- <link rel="stylesheet" href="../../../prettify.css" />
9
- <link rel="stylesheet" href="../../../base.css" />
10
- <link rel="shortcut icon" type="image/x-icon" href="../../../favicon.png" />
11
- <meta name="viewport" content="width=device-width, initial-scale=1" />
12
- <style type='text/css'>
13
- .coverage-summary .sorter {
14
- background-image: url(../../../sort-arrow-sprite.png);
15
- }
16
- </style>
17
- </head>
18
-
19
- <body>
20
- <div class='wrapper'>
21
- <div class='pad1'>
22
- <h1><a href="../../../index.html">All files</a> / <a href="index.html">core/api/hooks</a> hooks.organisations.js</h1>
23
- <div class='clearfix'>
24
-
25
- <div class='fl pad1y space-right2'>
26
- <span class="strong">9.86% </span>
27
- <span class="quiet">Statements</span>
28
- <span class='fraction'>15/152</span>
29
- </div>
30
-
31
-
32
- <div class='fl pad1y space-right2'>
33
- <span class="strong">100% </span>
34
- <span class="quiet">Branches</span>
35
- <span class='fraction'>1/1</span>
36
- </div>
37
-
38
-
39
- <div class='fl pad1y space-right2'>
40
- <span class="strong">0% </span>
41
- <span class="quiet">Functions</span>
42
- <span class='fraction'>0/6</span>
43
- </div>
44
-
45
-
46
- <div class='fl pad1y space-right2'>
47
- <span class="strong">9.86% </span>
48
- <span class="quiet">Lines</span>
49
- <span class='fraction'>15/152</span>
50
- </div>
51
-
52
-
53
- </div>
54
- <p class="quiet">
55
- Press <em>n</em> or <em>j</em> to go to the next uncovered block, <em>b</em>, <em>p</em> or <em>k</em> for the previous block.
56
- </p>
57
- <template id="filterTemplate">
58
- <div class="quiet">
59
- Filter:
60
- <input oninput="onInput()" type="search" id="fileSearch">
61
- </div>
62
- </template>
63
- </div>
64
- <div class='status-line low'></div>
65
- <pre><table class="coverage">
66
- <tr><td class="line-count quiet"><a name='L1'></a><a href='#L1'>1</a>
67
- <a name='L2'></a><a href='#L2'>2</a>
68
- <a name='L3'></a><a href='#L3'>3</a>
69
- <a name='L4'></a><a href='#L4'>4</a>
70
- <a name='L5'></a><a href='#L5'>5</a>
71
- <a name='L6'></a><a href='#L6'>6</a>
72
- <a name='L7'></a><a href='#L7'>7</a>
73
- <a name='L8'></a><a href='#L8'>8</a>
74
- <a name='L9'></a><a href='#L9'>9</a>
75
- <a name='L10'></a><a href='#L10'>10</a>
76
- <a name='L11'></a><a href='#L11'>11</a>
77
- <a name='L12'></a><a href='#L12'>12</a>
78
- <a name='L13'></a><a href='#L13'>13</a>
79
- <a name='L14'></a><a href='#L14'>14</a>
80
- <a name='L15'></a><a href='#L15'>15</a>
81
- <a name='L16'></a><a href='#L16'>16</a>
82
- <a name='L17'></a><a href='#L17'>17</a>
83
- <a name='L18'></a><a href='#L18'>18</a>
84
- <a name='L19'></a><a href='#L19'>19</a>
85
- <a name='L20'></a><a href='#L20'>20</a>
86
- <a name='L21'></a><a href='#L21'>21</a>
87
- <a name='L22'></a><a href='#L22'>22</a>
88
- <a name='L23'></a><a href='#L23'>23</a>
89
- <a name='L24'></a><a href='#L24'>24</a>
90
- <a name='L25'></a><a href='#L25'>25</a>
91
- <a name='L26'></a><a href='#L26'>26</a>
92
- <a name='L27'></a><a href='#L27'>27</a>
93
- <a name='L28'></a><a href='#L28'>28</a>
94
- <a name='L29'></a><a href='#L29'>29</a>
95
- <a name='L30'></a><a href='#L30'>30</a>
96
- <a name='L31'></a><a href='#L31'>31</a>
97
- <a name='L32'></a><a href='#L32'>32</a>
98
- <a name='L33'></a><a href='#L33'>33</a>
99
- <a name='L34'></a><a href='#L34'>34</a>
100
- <a name='L35'></a><a href='#L35'>35</a>
101
- <a name='L36'></a><a href='#L36'>36</a>
102
- <a name='L37'></a><a href='#L37'>37</a>
103
- <a name='L38'></a><a href='#L38'>38</a>
104
- <a name='L39'></a><a href='#L39'>39</a>
105
- <a name='L40'></a><a href='#L40'>40</a>
106
- <a name='L41'></a><a href='#L41'>41</a>
107
- <a name='L42'></a><a href='#L42'>42</a>
108
- <a name='L43'></a><a href='#L43'>43</a>
109
- <a name='L44'></a><a href='#L44'>44</a>
110
- <a name='L45'></a><a href='#L45'>45</a>
111
- <a name='L46'></a><a href='#L46'>46</a>
112
- <a name='L47'></a><a href='#L47'>47</a>
113
- <a name='L48'></a><a href='#L48'>48</a>
114
- <a name='L49'></a><a href='#L49'>49</a>
115
- <a name='L50'></a><a href='#L50'>50</a>
116
- <a name='L51'></a><a href='#L51'>51</a>
117
- <a name='L52'></a><a href='#L52'>52</a>
118
- <a name='L53'></a><a href='#L53'>53</a>
119
- <a name='L54'></a><a href='#L54'>54</a>
120
- <a name='L55'></a><a href='#L55'>55</a>
121
- <a name='L56'></a><a href='#L56'>56</a>
122
- <a name='L57'></a><a href='#L57'>57</a>
123
- <a name='L58'></a><a href='#L58'>58</a>
124
- <a name='L59'></a><a href='#L59'>59</a>
125
- <a name='L60'></a><a href='#L60'>60</a>
126
- <a name='L61'></a><a href='#L61'>61</a>
127
- <a name='L62'></a><a href='#L62'>62</a>
128
- <a name='L63'></a><a href='#L63'>63</a>
129
- <a name='L64'></a><a href='#L64'>64</a>
130
- <a name='L65'></a><a href='#L65'>65</a>
131
- <a name='L66'></a><a href='#L66'>66</a>
132
- <a name='L67'></a><a href='#L67'>67</a>
133
- <a name='L68'></a><a href='#L68'>68</a>
134
- <a name='L69'></a><a href='#L69'>69</a>
135
- <a name='L70'></a><a href='#L70'>70</a>
136
- <a name='L71'></a><a href='#L71'>71</a>
137
- <a name='L72'></a><a href='#L72'>72</a>
138
- <a name='L73'></a><a href='#L73'>73</a>
139
- <a name='L74'></a><a href='#L74'>74</a>
140
- <a name='L75'></a><a href='#L75'>75</a>
141
- <a name='L76'></a><a href='#L76'>76</a>
142
- <a name='L77'></a><a href='#L77'>77</a>
143
- <a name='L78'></a><a href='#L78'>78</a>
144
- <a name='L79'></a><a href='#L79'>79</a>
145
- <a name='L80'></a><a href='#L80'>80</a>
146
- <a name='L81'></a><a href='#L81'>81</a>
147
- <a name='L82'></a><a href='#L82'>82</a>
148
- <a name='L83'></a><a href='#L83'>83</a>
149
- <a name='L84'></a><a href='#L84'>84</a>
150
- <a name='L85'></a><a href='#L85'>85</a>
151
- <a name='L86'></a><a href='#L86'>86</a>
152
- <a name='L87'></a><a href='#L87'>87</a>
153
- <a name='L88'></a><a href='#L88'>88</a>
154
- <a name='L89'></a><a href='#L89'>89</a>
155
- <a name='L90'></a><a href='#L90'>90</a>
156
- <a name='L91'></a><a href='#L91'>91</a>
157
- <a name='L92'></a><a href='#L92'>92</a>
158
- <a name='L93'></a><a href='#L93'>93</a>
159
- <a name='L94'></a><a href='#L94'>94</a>
160
- <a name='L95'></a><a href='#L95'>95</a>
161
- <a name='L96'></a><a href='#L96'>96</a>
162
- <a name='L97'></a><a href='#L97'>97</a>
163
- <a name='L98'></a><a href='#L98'>98</a>
164
- <a name='L99'></a><a href='#L99'>99</a>
165
- <a name='L100'></a><a href='#L100'>100</a>
166
- <a name='L101'></a><a href='#L101'>101</a>
167
- <a name='L102'></a><a href='#L102'>102</a>
168
- <a name='L103'></a><a href='#L103'>103</a>
169
- <a name='L104'></a><a href='#L104'>104</a>
170
- <a name='L105'></a><a href='#L105'>105</a>
171
- <a name='L106'></a><a href='#L106'>106</a>
172
- <a name='L107'></a><a href='#L107'>107</a>
173
- <a name='L108'></a><a href='#L108'>108</a>
174
- <a name='L109'></a><a href='#L109'>109</a>
175
- <a name='L110'></a><a href='#L110'>110</a>
176
- <a name='L111'></a><a href='#L111'>111</a>
177
- <a name='L112'></a><a href='#L112'>112</a>
178
- <a name='L113'></a><a href='#L113'>113</a>
179
- <a name='L114'></a><a href='#L114'>114</a>
180
- <a name='L115'></a><a href='#L115'>115</a>
181
- <a name='L116'></a><a href='#L116'>116</a>
182
- <a name='L117'></a><a href='#L117'>117</a>
183
- <a name='L118'></a><a href='#L118'>118</a>
184
- <a name='L119'></a><a href='#L119'>119</a>
185
- <a name='L120'></a><a href='#L120'>120</a>
186
- <a name='L121'></a><a href='#L121'>121</a>
187
- <a name='L122'></a><a href='#L122'>122</a>
188
- <a name='L123'></a><a href='#L123'>123</a>
189
- <a name='L124'></a><a href='#L124'>124</a>
190
- <a name='L125'></a><a href='#L125'>125</a>
191
- <a name='L126'></a><a href='#L126'>126</a>
192
- <a name='L127'></a><a href='#L127'>127</a>
193
- <a name='L128'></a><a href='#L128'>128</a>
194
- <a name='L129'></a><a href='#L129'>129</a>
195
- <a name='L130'></a><a href='#L130'>130</a>
196
- <a name='L131'></a><a href='#L131'>131</a>
197
- <a name='L132'></a><a href='#L132'>132</a>
198
- <a name='L133'></a><a href='#L133'>133</a>
199
- <a name='L134'></a><a href='#L134'>134</a>
200
- <a name='L135'></a><a href='#L135'>135</a>
201
- <a name='L136'></a><a href='#L136'>136</a>
202
- <a name='L137'></a><a href='#L137'>137</a>
203
- <a name='L138'></a><a href='#L138'>138</a>
204
- <a name='L139'></a><a href='#L139'>139</a>
205
- <a name='L140'></a><a href='#L140'>140</a>
206
- <a name='L141'></a><a href='#L141'>141</a>
207
- <a name='L142'></a><a href='#L142'>142</a>
208
- <a name='L143'></a><a href='#L143'>143</a>
209
- <a name='L144'></a><a href='#L144'>144</a>
210
- <a name='L145'></a><a href='#L145'>145</a>
211
- <a name='L146'></a><a href='#L146'>146</a>
212
- <a name='L147'></a><a href='#L147'>147</a>
213
- <a name='L148'></a><a href='#L148'>148</a>
214
- <a name='L149'></a><a href='#L149'>149</a>
215
- <a name='L150'></a><a href='#L150'>150</a>
216
- <a name='L151'></a><a href='#L151'>151</a>
217
- <a name='L152'></a><a href='#L152'>152</a>
218
- <a name='L153'></a><a href='#L153'>153</a></td><td class="line-coverage quiet"><span class="cline-any cline-yes">1x</span>
219
- <span class="cline-any cline-yes">1x</span>
220
- <span class="cline-any cline-yes">1x</span>
221
- <span class="cline-any cline-yes">1x</span>
222
- <span class="cline-any cline-yes">1x</span>
223
- <span class="cline-any cline-no">&nbsp;</span>
224
- <span class="cline-any cline-no">&nbsp;</span>
225
- <span class="cline-any cline-no">&nbsp;</span>
226
- <span class="cline-any cline-no">&nbsp;</span>
227
- <span class="cline-any cline-no">&nbsp;</span>
228
- <span class="cline-any cline-no">&nbsp;</span>
229
- <span class="cline-any cline-no">&nbsp;</span>
230
- <span class="cline-any cline-no">&nbsp;</span>
231
- <span class="cline-any cline-no">&nbsp;</span>
232
- <span class="cline-any cline-no">&nbsp;</span>
233
- <span class="cline-any cline-no">&nbsp;</span>
234
- <span class="cline-any cline-no">&nbsp;</span>
235
- <span class="cline-any cline-no">&nbsp;</span>
236
- <span class="cline-any cline-no">&nbsp;</span>
237
- <span class="cline-any cline-no">&nbsp;</span>
238
- <span class="cline-any cline-no">&nbsp;</span>
239
- <span class="cline-any cline-no">&nbsp;</span>
240
- <span class="cline-any cline-no">&nbsp;</span>
241
- <span class="cline-any cline-no">&nbsp;</span>
242
- <span class="cline-any cline-no">&nbsp;</span>
243
- <span class="cline-any cline-no">&nbsp;</span>
244
- <span class="cline-any cline-no">&nbsp;</span>
245
- <span class="cline-any cline-no">&nbsp;</span>
246
- <span class="cline-any cline-no">&nbsp;</span>
247
- <span class="cline-any cline-yes">1x</span>
248
- <span class="cline-any cline-yes">1x</span>
249
- <span class="cline-any cline-no">&nbsp;</span>
250
- <span class="cline-any cline-no">&nbsp;</span>
251
- <span class="cline-any cline-no">&nbsp;</span>
252
- <span class="cline-any cline-no">&nbsp;</span>
253
- <span class="cline-any cline-no">&nbsp;</span>
254
- <span class="cline-any cline-no">&nbsp;</span>
255
- <span class="cline-any cline-no">&nbsp;</span>
256
- <span class="cline-any cline-no">&nbsp;</span>
257
- <span class="cline-any cline-no">&nbsp;</span>
258
- <span class="cline-any cline-no">&nbsp;</span>
259
- <span class="cline-any cline-no">&nbsp;</span>
260
- <span class="cline-any cline-no">&nbsp;</span>
261
- <span class="cline-any cline-no">&nbsp;</span>
262
- <span class="cline-any cline-no">&nbsp;</span>
263
- <span class="cline-any cline-no">&nbsp;</span>
264
- <span class="cline-any cline-no">&nbsp;</span>
265
- <span class="cline-any cline-no">&nbsp;</span>
266
- <span class="cline-any cline-yes">1x</span>
267
- <span class="cline-any cline-yes">1x</span>
268
- <span class="cline-any cline-no">&nbsp;</span>
269
- <span class="cline-any cline-no">&nbsp;</span>
270
- <span class="cline-any cline-no">&nbsp;</span>
271
- <span class="cline-any cline-no">&nbsp;</span>
272
- <span class="cline-any cline-no">&nbsp;</span>
273
- <span class="cline-any cline-no">&nbsp;</span>
274
- <span class="cline-any cline-no">&nbsp;</span>
275
- <span class="cline-any cline-no">&nbsp;</span>
276
- <span class="cline-any cline-no">&nbsp;</span>
277
- <span class="cline-any cline-no">&nbsp;</span>
278
- <span class="cline-any cline-no">&nbsp;</span>
279
- <span class="cline-any cline-no">&nbsp;</span>
280
- <span class="cline-any cline-no">&nbsp;</span>
281
- <span class="cline-any cline-no">&nbsp;</span>
282
- <span class="cline-any cline-no">&nbsp;</span>
283
- <span class="cline-any cline-no">&nbsp;</span>
284
- <span class="cline-any cline-no">&nbsp;</span>
285
- <span class="cline-any cline-no">&nbsp;</span>
286
- <span class="cline-any cline-no">&nbsp;</span>
287
- <span class="cline-any cline-no">&nbsp;</span>
288
- <span class="cline-any cline-no">&nbsp;</span>
289
- <span class="cline-any cline-no">&nbsp;</span>
290
- <span class="cline-any cline-no">&nbsp;</span>
291
- <span class="cline-any cline-yes">1x</span>
292
- <span class="cline-any cline-yes">1x</span>
293
- <span class="cline-any cline-no">&nbsp;</span>
294
- <span class="cline-any cline-no">&nbsp;</span>
295
- <span class="cline-any cline-no">&nbsp;</span>
296
- <span class="cline-any cline-no">&nbsp;</span>
297
- <span class="cline-any cline-no">&nbsp;</span>
298
- <span class="cline-any cline-no">&nbsp;</span>
299
- <span class="cline-any cline-no">&nbsp;</span>
300
- <span class="cline-any cline-no">&nbsp;</span>
301
- <span class="cline-any cline-no">&nbsp;</span>
302
- <span class="cline-any cline-no">&nbsp;</span>
303
- <span class="cline-any cline-no">&nbsp;</span>
304
- <span class="cline-any cline-no">&nbsp;</span>
305
- <span class="cline-any cline-no">&nbsp;</span>
306
- <span class="cline-any cline-no">&nbsp;</span>
307
- <span class="cline-any cline-no">&nbsp;</span>
308
- <span class="cline-any cline-no">&nbsp;</span>
309
- <span class="cline-any cline-no">&nbsp;</span>
310
- <span class="cline-any cline-no">&nbsp;</span>
311
- <span class="cline-any cline-no">&nbsp;</span>
312
- <span class="cline-any cline-no">&nbsp;</span>
313
- <span class="cline-any cline-no">&nbsp;</span>
314
- <span class="cline-any cline-no">&nbsp;</span>
315
- <span class="cline-any cline-yes">1x</span>
316
- <span class="cline-any cline-yes">1x</span>
317
- <span class="cline-any cline-no">&nbsp;</span>
318
- <span class="cline-any cline-no">&nbsp;</span>
319
- <span class="cline-any cline-no">&nbsp;</span>
320
- <span class="cline-any cline-no">&nbsp;</span>
321
- <span class="cline-any cline-no">&nbsp;</span>
322
- <span class="cline-any cline-no">&nbsp;</span>
323
- <span class="cline-any cline-no">&nbsp;</span>
324
- <span class="cline-any cline-no">&nbsp;</span>
325
- <span class="cline-any cline-no">&nbsp;</span>
326
- <span class="cline-any cline-no">&nbsp;</span>
327
- <span class="cline-any cline-no">&nbsp;</span>
328
- <span class="cline-any cline-no">&nbsp;</span>
329
- <span class="cline-any cline-no">&nbsp;</span>
330
- <span class="cline-any cline-no">&nbsp;</span>
331
- <span class="cline-any cline-no">&nbsp;</span>
332
- <span class="cline-any cline-no">&nbsp;</span>
333
- <span class="cline-any cline-no">&nbsp;</span>
334
- <span class="cline-any cline-no">&nbsp;</span>
335
- <span class="cline-any cline-no">&nbsp;</span>
336
- <span class="cline-any cline-no">&nbsp;</span>
337
- <span class="cline-any cline-no">&nbsp;</span>
338
- <span class="cline-any cline-no">&nbsp;</span>
339
- <span class="cline-any cline-no">&nbsp;</span>
340
- <span class="cline-any cline-no">&nbsp;</span>
341
- <span class="cline-any cline-no">&nbsp;</span>
342
- <span class="cline-any cline-no">&nbsp;</span>
343
- <span class="cline-any cline-no">&nbsp;</span>
344
- <span class="cline-any cline-no">&nbsp;</span>
345
- <span class="cline-any cline-no">&nbsp;</span>
346
- <span class="cline-any cline-no">&nbsp;</span>
347
- <span class="cline-any cline-no">&nbsp;</span>
348
- <span class="cline-any cline-no">&nbsp;</span>
349
- <span class="cline-any cline-no">&nbsp;</span>
350
- <span class="cline-any cline-no">&nbsp;</span>
351
- <span class="cline-any cline-yes">1x</span>
352
- <span class="cline-any cline-yes">1x</span>
353
- <span class="cline-any cline-no">&nbsp;</span>
354
- <span class="cline-any cline-no">&nbsp;</span>
355
- <span class="cline-any cline-no">&nbsp;</span>
356
- <span class="cline-any cline-no">&nbsp;</span>
357
- <span class="cline-any cline-no">&nbsp;</span>
358
- <span class="cline-any cline-no">&nbsp;</span>
359
- <span class="cline-any cline-no">&nbsp;</span>
360
- <span class="cline-any cline-no">&nbsp;</span>
361
- <span class="cline-any cline-no">&nbsp;</span>
362
- <span class="cline-any cline-no">&nbsp;</span>
363
- <span class="cline-any cline-no">&nbsp;</span>
364
- <span class="cline-any cline-no">&nbsp;</span>
365
- <span class="cline-any cline-no">&nbsp;</span>
366
- <span class="cline-any cline-no">&nbsp;</span>
367
- <span class="cline-any cline-no">&nbsp;</span>
368
- <span class="cline-any cline-no">&nbsp;</span>
369
- <span class="cline-any cline-no">&nbsp;</span>
370
- <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import _ from 'lodash'
371
- import makeDebug from 'debug'
372
- const debug = makeDebug('kdk:core:organisations:hooks')
373
- &nbsp;
374
- export <span class="fstat-no" title="function not covered" >async function createOrganisationServices (hook) {</span>
375
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
376
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'createOrganisationServices\' hook should only be used as a \'after\' hook.')</span>
377
- <span class="cstat-no" title="statement not covered" > }</span>
378
- <span class="cstat-no" title="statement not covered" ></span>
379
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
380
- <span class="cstat-no" title="statement not covered" > const organisationService = hook.service</span>
381
- <span class="cstat-no" title="statement not covered" > const databaseService = app.getService('databases')</span>
382
- <span class="cstat-no" title="statement not covered" > const name = hook.result._id.toString()</span>
383
- <span class="cstat-no" title="statement not covered" ></span>
384
- <span class="cstat-no" title="statement not covered" > // First we create the organisation DB</span>
385
- <span class="cstat-no" title="statement not covered" > await databaseService.create({</span>
386
- <span class="cstat-no" title="statement not covered" > name</span>
387
- <span class="cstat-no" title="statement not covered" > }, {</span>
388
- <span class="cstat-no" title="statement not covered" > user: hook.params.user</span>
389
- <span class="cstat-no" title="statement not covered" > })</span>
390
- <span class="cstat-no" title="statement not covered" ></span>
391
- <span class="cstat-no" title="statement not covered" > debug('DB created for organisation ' + hook.result.name)</span>
392
- <span class="cstat-no" title="statement not covered" ></span>
393
- <span class="cstat-no" title="statement not covered" > // Jump from infos/stats to real DB object</span>
394
- <span class="cstat-no" title="statement not covered" > const db = app.db.client.db(name)</span>
395
- <span class="cstat-no" title="statement not covered" > await organisationService.createOrganisationServices(hook.result, db)</span>
396
- <span class="cstat-no" title="statement not covered" ></span>
397
- <span class="cstat-no" title="statement not covered" > return hook</span>
398
- <span class="cstat-no" title="statement not covered" >}</span>
399
- &nbsp;
400
- export <span class="fstat-no" title="function not covered" >async function removeOrganisationServices (hook) {</span>
401
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
402
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'removeOrganisationServices\' hook should only be used as a \'after\' hook.')</span>
403
- <span class="cstat-no" title="statement not covered" > }</span>
404
- <span class="cstat-no" title="statement not covered" ></span>
405
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
406
- <span class="cstat-no" title="statement not covered" > const organisationService = hook.service</span>
407
- <span class="cstat-no" title="statement not covered" > const databaseService = app.getService('databases')</span>
408
- <span class="cstat-no" title="statement not covered" ></span>
409
- <span class="cstat-no" title="statement not covered" > // Then we remove the organisation DB</span>
410
- <span class="cstat-no" title="statement not covered" > await databaseService.remove(hook.result._id.toString(), {</span>
411
- <span class="cstat-no" title="statement not covered" > user: hook.params.user</span>
412
- <span class="cstat-no" title="statement not covered" > })</span>
413
- <span class="cstat-no" title="statement not covered" ></span>
414
- <span class="cstat-no" title="statement not covered" > debug('DB removed for organisation ' + hook.result.name)</span>
415
- <span class="cstat-no" title="statement not covered" > await organisationService.removeOrganisationServices(hook.result)</span>
416
- <span class="cstat-no" title="statement not covered" > return hook</span>
417
- <span class="cstat-no" title="statement not covered" >}</span>
418
- &nbsp;
419
- export <span class="fstat-no" title="function not covered" >async function createOrganisationAuthorisations (hook) {</span>
420
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
421
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'createOrganisationAuthorisations\' hook should only be used as a \'after\' hook.')</span>
422
- <span class="cstat-no" title="statement not covered" > }</span>
423
- <span class="cstat-no" title="statement not covered" ></span>
424
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
425
- <span class="cstat-no" title="statement not covered" > const authorisationService = app.getService('authorisations')</span>
426
- <span class="cstat-no" title="statement not covered" > const userService = app.getService('users')</span>
427
- <span class="cstat-no" title="statement not covered" > // Set membership for the owner</span>
428
- <span class="cstat-no" title="statement not covered" > await authorisationService.create({</span>
429
- <span class="cstat-no" title="statement not covered" > scope: 'organisations',</span>
430
- <span class="cstat-no" title="statement not covered" > permissions: 'owner' // Owner by default</span>
431
- <span class="cstat-no" title="statement not covered" > }, {</span>
432
- <span class="cstat-no" title="statement not covered" > user: hook.params.user,</span>
433
- <span class="cstat-no" title="statement not covered" > // Because we already have subject/resource set it as objects to avoid populating</span>
434
- <span class="cstat-no" title="statement not covered" > subjects: [hook.params.user],</span>
435
- <span class="cstat-no" title="statement not covered" > subjectsService: userService,</span>
436
- <span class="cstat-no" title="statement not covered" > resource: hook.result,</span>
437
- <span class="cstat-no" title="statement not covered" > resourcesService: hook.service</span>
438
- <span class="cstat-no" title="statement not covered" > })</span>
439
- <span class="cstat-no" title="statement not covered" ></span>
440
- <span class="cstat-no" title="statement not covered" > debug('Organisation ownership set for user ' + hook.result._id)</span>
441
- <span class="cstat-no" title="statement not covered" > return hook</span>
442
- <span class="cstat-no" title="statement not covered" >}</span>
443
- &nbsp;
444
- export <span class="fstat-no" title="function not covered" >async function removeOrganisationAuthorisations (hook) {</span>
445
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
446
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'removeOrganisationAuthorisations\' hook should only be used as a \'after\' hook.')</span>
447
- <span class="cstat-no" title="statement not covered" > }</span>
448
- <span class="cstat-no" title="statement not covered" ></span>
449
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
450
- <span class="cstat-no" title="statement not covered" > const authorisationService = app.getService('authorisations')</span>
451
- <span class="cstat-no" title="statement not covered" ></span>
452
- <span class="cstat-no" title="statement not covered" > // Unset membership for the all org users</span>
453
- <span class="cstat-no" title="statement not covered" > await authorisationService.remove(hook.result._id.toString(), {</span>
454
- <span class="cstat-no" title="statement not covered" > query: {</span>
455
- <span class="cstat-no" title="statement not covered" > subjectsService: hook.result._id.toString() + '/members',</span>
456
- <span class="cstat-no" title="statement not covered" > scope: 'organisations'</span>
457
- <span class="cstat-no" title="statement not covered" > },</span>
458
- <span class="cstat-no" title="statement not covered" > user: hook.params.user,</span>
459
- <span class="cstat-no" title="statement not covered" > // Because we already have resource set it as objects to avoid populating</span>
460
- <span class="cstat-no" title="statement not covered" > // Moreover used as an after hook the resource might not already exist anymore</span>
461
- <span class="cstat-no" title="statement not covered" > resource: hook.result,</span>
462
- <span class="cstat-no" title="statement not covered" > resourcesService: hook.service</span>
463
- <span class="cstat-no" title="statement not covered" > })</span>
464
- <span class="cstat-no" title="statement not covered" > debug('Authorisations unset for organisation ' + hook.result._id)</span>
465
- <span class="cstat-no" title="statement not covered" > return hook</span>
466
- <span class="cstat-no" title="statement not covered" >}</span>
467
- &nbsp;
468
- export <span class="fstat-no" title="function not covered" >function updateOrganisationResource (resourceScope) {</span>
469
- <span class="cstat-no" title="statement not covered" > return async function (hook) {</span>
470
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
471
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'updateOrganisationResource\' hook should only be used as a \'after\' hook.')</span>
472
- <span class="cstat-no" title="statement not covered" > }</span>
473
- <span class="cstat-no" title="statement not covered" > // Only applicable to update/remove operations</span>
474
- <span class="cstat-no" title="statement not covered" > if ((hook.method === 'get' || hook.method === 'find' || hook.method === 'create')) return hook</span>
475
- <span class="cstat-no" title="statement not covered" ></span>
476
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
477
- <span class="cstat-no" title="statement not covered" > // Retrieve the list of members</span>
478
- <span class="cstat-no" title="statement not covered" > const context = hook.service.getContextId()</span>
479
- <span class="cstat-no" title="statement not covered" > // Use members service if any or global users service</span>
480
- <span class="cstat-no" title="statement not covered" > const orgMembersService = (context ? app.getService('members', context) : app.getService('users'))</span>
481
- <span class="cstat-no" title="statement not covered" > const members = await orgMembersService.find({</span>
482
- <span class="cstat-no" title="statement not covered" > query: { [resourceScope]: { $elemMatch: { _id: hook.result._id } } },</span>
483
- <span class="cstat-no" title="statement not covered" > paginate: false</span>
484
- <span class="cstat-no" title="statement not covered" > })</span>
485
- <span class="cstat-no" title="statement not covered" > // Update each members</span>
486
- <span class="cstat-no" title="statement not covered" > await Promise.all(members.map(member =&gt; {</span>
487
- <span class="cstat-no" title="statement not covered" > const resources = _.get(member, resourceScope, [])</span>
488
- <span class="cstat-no" title="statement not covered" > const resource = _.find(resources, item =&gt; item._id.toString() === hook.result._id.toString())</span>
489
- <span class="cstat-no" title="statement not covered" > if (!resource) return Promise.resolve()</span>
490
- <span class="cstat-no" title="statement not covered" > // Check for removal or update</span>
491
- <span class="cstat-no" title="statement not covered" > if (hook.method === 'remove') {</span>
492
- <span class="cstat-no" title="statement not covered" > _.remove(resources, item =&gt; resource._id.toString() === item._id.toString())</span>
493
- <span class="cstat-no" title="statement not covered" > } else {</span>
494
- <span class="cstat-no" title="statement not covered" > Object.assign(resource, hook.result)</span>
495
- <span class="cstat-no" title="statement not covered" > }</span>
496
- <span class="cstat-no" title="statement not covered" > return orgMembersService.patch(member._id, { [resourceScope]: resources })</span>
497
- <span class="cstat-no" title="statement not covered" > }))</span>
498
- <span class="cstat-no" title="statement not covered" ></span>
499
- <span class="cstat-no" title="statement not covered" > debug(`Updated resource ${hook.result._id} on scope ${resourceScope} for members of organisation ` + hook.result._id)</span>
500
- <span class="cstat-no" title="statement not covered" > return hook</span>
501
- <span class="cstat-no" title="statement not covered" > }</span>
502
- <span class="cstat-no" title="statement not covered" >}</span>
503
- &nbsp;
504
- export <span class="fstat-no" title="function not covered" >function removeOrganisationResources (resourceScope) {</span>
505
- <span class="cstat-no" title="statement not covered" > return async function (hook) {</span>
506
- <span class="cstat-no" title="statement not covered" > if (hook.type !== 'after') {</span>
507
- <span class="cstat-no" title="statement not covered" > throw new Error('The \'removeOrganisationResources\' hook should only be used as a \'after\' hook.')</span>
508
- <span class="cstat-no" title="statement not covered" > }</span>
509
- <span class="cstat-no" title="statement not covered" ></span>
510
- <span class="cstat-no" title="statement not covered" > const app = hook.app</span>
511
- <span class="cstat-no" title="statement not covered" > const orgResourceService = app.getService(resourceScope, hook.result)</span>
512
- <span class="cstat-no" title="statement not covered" > const resources = await orgResourceService.find({ paginate: false })</span>
513
- <span class="cstat-no" title="statement not covered" > await Promise.all(resources.map(resource =&gt; {</span>
514
- <span class="cstat-no" title="statement not covered" > return orgResourceService.remove(resource._id.toString(), {</span>
515
- <span class="cstat-no" title="statement not covered" > user: hook.params.user</span>
516
- <span class="cstat-no" title="statement not covered" > })</span>
517
- <span class="cstat-no" title="statement not covered" > }))</span>
518
- <span class="cstat-no" title="statement not covered" > debug(`Removed ${resourceScope} for organisation ` + hook.result._id)</span>
519
- <span class="cstat-no" title="statement not covered" > return hook</span>
520
- <span class="cstat-no" title="statement not covered" > }</span>
521
- <span class="cstat-no" title="statement not covered" >}</span>
522
- &nbsp;</pre></td></tr></table></pre>
523
-
524
- <div class='push'></div><!-- for sticky footer -->
525
- </div><!-- /wrapper -->
526
- <div class='footer quiet pad2 space-top1 center small'>
527
- Code coverage generated by
528
- <a href="https://istanbul.js.org/" target="_blank" rel="noopener noreferrer">istanbul</a>
529
- at 2024-08-13T10:02:04.872Z
530
- </div>
531
- <script src="../../../prettify.js"></script>
532
- <script>
533
- window.onload = function () {
534
- prettyPrint();
535
- };
536
- </script>
537
- <script src="../../../sorter.js"></script>
538
- <script src="../../../block-navigation.js"></script>
539
- </body>
540
- </html>
541
-