@esri/hub-common 15.31.3 → 15.31.4

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 (389) hide show
  1. package/dist/esm/channels/HubChannel.js +173 -0
  2. package/dist/esm/channels/HubChannel.js.map +1 -0
  3. package/dist/esm/channels/_internal/ChannelBusinessRules.js +39 -0
  4. package/dist/esm/channels/_internal/ChannelBusinessRules.js.map +1 -0
  5. package/dist/esm/channels/_internal/ChannelSchema.js +198 -0
  6. package/dist/esm/channels/_internal/ChannelSchema.js.map +1 -0
  7. package/dist/esm/channels/_internal/ChannelUiSchemaCreate.js +288 -0
  8. package/dist/esm/channels/_internal/ChannelUiSchemaCreate.js.map +1 -0
  9. package/dist/esm/channels/_internal/ChannelUiSchemaEdit.js +20 -0
  10. package/dist/esm/channels/_internal/ChannelUiSchemaEdit.js.map +1 -0
  11. package/dist/esm/channels/_internal/buildDefaultChannel.js +26 -0
  12. package/dist/esm/channels/_internal/buildDefaultChannel.js.map +1 -0
  13. package/dist/esm/channels/_internal/transformAclPermissionToEntityPermissionPolicy.js +49 -0
  14. package/dist/esm/channels/_internal/transformAclPermissionToEntityPermissionPolicy.js.map +1 -0
  15. package/dist/esm/channels/_internal/transformChannelToEntity.js +61 -0
  16. package/dist/esm/channels/_internal/transformChannelToEntity.js.map +1 -0
  17. package/dist/esm/channels/_internal/transformEditorToEntity.js +22 -0
  18. package/dist/esm/channels/_internal/transformEditorToEntity.js.map +1 -0
  19. package/dist/esm/channels/_internal/transformEntityPermissionPoliciesToFormValues.js +150 -0
  20. package/dist/esm/channels/_internal/transformEntityPermissionPoliciesToFormValues.js.map +1 -0
  21. package/dist/esm/channels/_internal/transformEntityToChannelData.js +69 -0
  22. package/dist/esm/channels/_internal/transformEntityToChannelData.js.map +1 -0
  23. package/dist/esm/channels/_internal/transformEntityToEditor.js +20 -0
  24. package/dist/esm/channels/_internal/transformEntityToEditor.js.map +1 -0
  25. package/dist/esm/channels/_internal/transformFormValuesToEntityPermissionPolicies.js +55 -0
  26. package/dist/esm/channels/_internal/transformFormValuesToEntityPermissionPolicies.js.map +1 -0
  27. package/dist/esm/channels/edit.js +35 -0
  28. package/dist/esm/channels/edit.js.map +1 -0
  29. package/dist/esm/channels/fetch.js +14 -0
  30. package/dist/esm/channels/fetch.js.map +1 -0
  31. package/dist/esm/channels/index.js +4 -0
  32. package/dist/esm/channels/index.js.map +1 -0
  33. package/dist/esm/core/schemas/internal/discussions/EntityUiSchemaDiscussionsSettings.js +141 -0
  34. package/dist/esm/core/schemas/internal/discussions/EntityUiSchemaDiscussionsSettings.js.map +1 -0
  35. package/dist/esm/core/types/IHubChannel.js +1 -0
  36. package/dist/esm/core/types/IHubChannel.js.map +1 -0
  37. package/dist/esm/core/types/IHubOrganization.js +1 -0
  38. package/dist/esm/core/types/IHubOrganization.js.map +1 -0
  39. package/dist/esm/discussions/api/posts/index.js +2 -0
  40. package/dist/esm/discussions/api/posts/index.js.map +1 -0
  41. package/dist/esm/discussions/api/posts/posts.js +225 -0
  42. package/dist/esm/discussions/api/posts/posts.js.map +1 -0
  43. package/dist/esm/discussions/api/reactions/index.js +2 -0
  44. package/dist/esm/discussions/api/reactions/index.js.map +1 -0
  45. package/dist/esm/discussions/api/reactions/reactions.js +53 -0
  46. package/dist/esm/discussions/api/reactions/reactions.js.map +1 -0
  47. package/dist/esm/discussions/api/utils/channel-permission.js +377 -0
  48. package/dist/esm/discussions/api/utils/channel-permission.js.map +1 -0
  49. package/dist/esm/discussions/api/utils/channels/can-create-channel-v2.js +13 -0
  50. package/dist/esm/discussions/api/utils/channels/can-create-channel-v2.js.map +1 -0
  51. package/dist/esm/discussions/api/utils/channels/can-create-channel.js +54 -0
  52. package/dist/esm/discussions/api/utils/channels/can-create-channel.js.map +1 -0
  53. package/dist/esm/discussions/api/utils/channels/can-delete-channel-v2.js +17 -0
  54. package/dist/esm/discussions/api/utils/channels/can-delete-channel-v2.js.map +1 -0
  55. package/dist/esm/discussions/api/utils/channels/can-delete-channel.js +17 -0
  56. package/dist/esm/discussions/api/utils/channels/can-delete-channel.js.map +1 -0
  57. package/dist/esm/discussions/api/utils/channels/can-edit-channel-v2.js +19 -0
  58. package/dist/esm/discussions/api/utils/channels/can-edit-channel-v2.js.map +1 -0
  59. package/dist/esm/discussions/api/utils/channels/can-edit-channel.js +17 -0
  60. package/dist/esm/discussions/api/utils/channels/can-edit-channel.js.map +1 -0
  61. package/dist/esm/discussions/api/utils/channels/can-modify-channel.js +18 -0
  62. package/dist/esm/discussions/api/utils/channels/can-modify-channel.js.map +1 -0
  63. package/dist/esm/discussions/api/utils/channels/can-post-to-channel.js +57 -0
  64. package/dist/esm/discussions/api/utils/channels/can-post-to-channel.js.map +1 -0
  65. package/dist/esm/discussions/api/utils/channels/can-read-channel-v2.js +18 -0
  66. package/dist/esm/discussions/api/utils/channels/can-read-channel-v2.js.map +1 -0
  67. package/dist/esm/discussions/api/utils/channels/can-read-channel.js +52 -0
  68. package/dist/esm/discussions/api/utils/channels/can-read-channel.js.map +1 -0
  69. package/dist/esm/discussions/api/utils/channels/channel-to-dto-map.js +11 -0
  70. package/dist/esm/discussions/api/utils/channels/channel-to-dto-map.js.map +1 -0
  71. package/dist/esm/discussions/api/utils/channels/index.js +13 -0
  72. package/dist/esm/discussions/api/utils/channels/index.js.map +1 -0
  73. package/dist/esm/discussions/api/utils/channels/is-authorized-to-modify-channel-by-legacy-permissions.js +44 -0
  74. package/dist/esm/discussions/api/utils/channels/is-authorized-to-modify-channel-by-legacy-permissions.js.map +1 -0
  75. package/dist/esm/discussions/api/utils/platform.js +44 -0
  76. package/dist/esm/discussions/api/utils/platform.js.map +1 -0
  77. package/dist/esm/discussions/api/utils/portal-privilege.js +35 -0
  78. package/dist/esm/discussions/api/utils/portal-privilege.js.map +1 -0
  79. package/dist/esm/discussions/api/utils/posts/can-create-post-v2.js +20 -0
  80. package/dist/esm/discussions/api/utils/posts/can-create-post-v2.js.map +1 -0
  81. package/dist/esm/discussions/api/utils/posts/can-create-post.js +52 -0
  82. package/dist/esm/discussions/api/utils/posts/can-create-post.js.map +1 -0
  83. package/dist/esm/discussions/api/utils/posts/can-create-reply-v2.js +19 -0
  84. package/dist/esm/discussions/api/utils/posts/can-create-reply-v2.js.map +1 -0
  85. package/dist/esm/discussions/api/utils/posts/can-create-reply.js +52 -0
  86. package/dist/esm/discussions/api/utils/posts/can-create-reply.js.map +1 -0
  87. package/dist/esm/discussions/api/utils/posts/can-delete-post-v2.js +24 -0
  88. package/dist/esm/discussions/api/utils/posts/can-delete-post-v2.js.map +1 -0
  89. package/dist/esm/discussions/api/utils/posts/can-delete-post.js +28 -0
  90. package/dist/esm/discussions/api/utils/posts/can-delete-post.js.map +1 -0
  91. package/dist/esm/discussions/api/utils/posts/can-edit-post-status-v2.js +16 -0
  92. package/dist/esm/discussions/api/utils/posts/can-edit-post-status-v2.js.map +1 -0
  93. package/dist/esm/discussions/api/utils/posts/can-edit-post-status.js +61 -0
  94. package/dist/esm/discussions/api/utils/posts/can-edit-post-status.js.map +1 -0
  95. package/dist/esm/discussions/api/utils/posts/can-edit-post-v2.js +19 -0
  96. package/dist/esm/discussions/api/utils/posts/can-edit-post-v2.js.map +1 -0
  97. package/dist/esm/discussions/api/utils/posts/can-edit-post.js +62 -0
  98. package/dist/esm/discussions/api/utils/posts/can-edit-post.js.map +1 -0
  99. package/dist/esm/discussions/api/utils/posts/index.js +15 -0
  100. package/dist/esm/discussions/api/utils/posts/index.js.map +1 -0
  101. package/dist/esm/discussions/api/utils/posts/parse-discussion-uri.js +38 -0
  102. package/dist/esm/discussions/api/utils/posts/parse-discussion-uri.js.map +1 -0
  103. package/dist/esm/discussions/api/utils/posts/parse-mentioned-users.js +19 -0
  104. package/dist/esm/discussions/api/utils/posts/parse-mentioned-users.js.map +1 -0
  105. package/dist/esm/discussions/api/utils/reactions/can-create-reaction-v2.js +27 -0
  106. package/dist/esm/discussions/api/utils/reactions/can-create-reaction-v2.js.map +1 -0
  107. package/dist/esm/discussions/api/utils/reactions/can-create-reaction.js +28 -0
  108. package/dist/esm/discussions/api/utils/reactions/can-create-reaction.js.map +1 -0
  109. package/dist/esm/discussions/api/utils/reactions/index.js +3 -0
  110. package/dist/esm/discussions/api/utils/reactions/index.js.map +1 -0
  111. package/dist/esm/hub-types.js +916 -0
  112. package/dist/esm/hub-types.js.map +1 -0
  113. package/dist/esm/org/fetch-org.js +5 -1
  114. package/dist/esm/org/fetch-org.js.map +1 -1
  115. package/dist/esm/org/fetch.js +83 -0
  116. package/dist/esm/org/fetch.js.map +1 -0
  117. package/dist/esm/search/_internal/hubDiscussionsHelpers/channelResultsToSearchResults.js +33 -0
  118. package/dist/esm/search/_internal/hubDiscussionsHelpers/channelResultsToSearchResults.js.map +1 -0
  119. package/dist/esm/search/_internal/hubDiscussionsHelpers/processChannelFilters.js +67 -0
  120. package/dist/esm/search/_internal/hubDiscussionsHelpers/processChannelFilters.js.map +1 -0
  121. package/dist/esm/search/_internal/hubDiscussionsHelpers/processChannelOptions.js +35 -0
  122. package/dist/esm/search/_internal/hubDiscussionsHelpers/processChannelOptions.js.map +1 -0
  123. package/dist/esm/search/_internal/hubSearchItemsHelpers/getFieldsQueryParam.js +15 -0
  124. package/dist/esm/search/_internal/hubSearchItemsHelpers/getFieldsQueryParam.js.map +1 -0
  125. package/dist/esm/search/_internal/hubSearchItemsHelpers/getFlattenQueryParam.js +15 -0
  126. package/dist/esm/search/_internal/hubSearchItemsHelpers/getFlattenQueryParam.js.map +1 -0
  127. package/dist/esm/search/_internal/portalFetchOrgs.js +33 -0
  128. package/dist/esm/search/_internal/portalFetchOrgs.js.map +1 -0
  129. package/dist/esm/sites/_internal/_migrate-to-v2-catalog.js +24 -0
  130. package/dist/esm/sites/_internal/_migrate-to-v2-catalog.js.map +1 -0
  131. package/dist/esm/sites/defaultSiteCollectionKeys.js +7 -0
  132. package/dist/esm/sites/defaultSiteCollectionKeys.js.map +1 -0
  133. package/dist/esm/sites/searchCategoriesToCollections.js +75 -0
  134. package/dist/esm/sites/searchCategoriesToCollections.js.map +1 -0
  135. package/dist/esm/types/IArcGISContext.js +1 -0
  136. package/dist/esm/types/IArcGISContext.js.map +1 -0
  137. package/dist/esm/types/IArcGISContextManagerOptions.js +1 -0
  138. package/dist/esm/types/IArcGISContextManagerOptions.js.map +1 -0
  139. package/dist/esm/types/IArcGISContextOptions.js +1 -0
  140. package/dist/esm/types/IArcGISContextOptions.js.map +1 -0
  141. package/dist/esm/types/IUserResourceConfig.js +1 -0
  142. package/dist/esm/types/IUserResourceConfig.js.map +1 -0
  143. package/dist/esm/types/IUserResourceToken.js +1 -0
  144. package/dist/esm/types/IUserResourceToken.js.map +1 -0
  145. package/dist/esm/urls/getPortalBaseFromOrgUrl.js +3 -1
  146. package/dist/esm/urls/getPortalBaseFromOrgUrl.js.map +1 -1
  147. package/dist/esm/utils/IHubConfig.js +1 -0
  148. package/dist/esm/utils/IHubConfig.js.map +1 -0
  149. package/dist/esm/utils/IUserHubSettings.js +1 -0
  150. package/dist/esm/utils/IUserHubSettings.js.map +1 -0
  151. package/dist/esm/utils/IUserSiteSettings.js +4 -0
  152. package/dist/esm/utils/IUserSiteSettings.js.map +1 -0
  153. package/dist/esm/utils/LogLevel.js +1 -0
  154. package/dist/esm/utils/LogLevel.js.map +1 -0
  155. package/dist/esm/utils/internal/config.js +11 -0
  156. package/dist/esm/utils/internal/config.js.map +1 -0
  157. package/dist/node/channels/HubChannel.js +177 -0
  158. package/dist/node/channels/HubChannel.js.map +1 -0
  159. package/dist/node/channels/_internal/ChannelBusinessRules.js +42 -0
  160. package/dist/node/channels/_internal/ChannelBusinessRules.js.map +1 -0
  161. package/dist/node/channels/_internal/ChannelSchema.js +201 -0
  162. package/dist/node/channels/_internal/ChannelSchema.js.map +1 -0
  163. package/dist/node/channels/_internal/ChannelUiSchemaCreate.js +291 -0
  164. package/dist/node/channels/_internal/ChannelUiSchemaCreate.js.map +1 -0
  165. package/dist/node/channels/_internal/ChannelUiSchemaEdit.js +23 -0
  166. package/dist/node/channels/_internal/ChannelUiSchemaEdit.js.map +1 -0
  167. package/dist/node/channels/_internal/buildDefaultChannel.js +30 -0
  168. package/dist/node/channels/_internal/buildDefaultChannel.js.map +1 -0
  169. package/dist/node/channels/_internal/transformAclPermissionToEntityPermissionPolicy.js +52 -0
  170. package/dist/node/channels/_internal/transformAclPermissionToEntityPermissionPolicy.js.map +1 -0
  171. package/dist/node/channels/_internal/transformChannelToEntity.js +65 -0
  172. package/dist/node/channels/_internal/transformChannelToEntity.js.map +1 -0
  173. package/dist/node/channels/_internal/transformEditorToEntity.js +26 -0
  174. package/dist/node/channels/_internal/transformEditorToEntity.js.map +1 -0
  175. package/dist/node/channels/_internal/transformEntityPermissionPoliciesToFormValues.js +153 -0
  176. package/dist/node/channels/_internal/transformEntityPermissionPoliciesToFormValues.js.map +1 -0
  177. package/dist/node/channels/_internal/transformEntityToChannelData.js +73 -0
  178. package/dist/node/channels/_internal/transformEntityToChannelData.js.map +1 -0
  179. package/dist/node/channels/_internal/transformEntityToEditor.js +24 -0
  180. package/dist/node/channels/_internal/transformEntityToEditor.js.map +1 -0
  181. package/dist/node/channels/_internal/transformFormValuesToEntityPermissionPolicies.js +59 -0
  182. package/dist/node/channels/_internal/transformFormValuesToEntityPermissionPolicies.js.map +1 -0
  183. package/dist/node/channels/edit.js +41 -0
  184. package/dist/node/channels/edit.js.map +1 -0
  185. package/dist/node/channels/fetch.js +18 -0
  186. package/dist/node/channels/fetch.js.map +1 -0
  187. package/dist/node/channels/index.js +7 -0
  188. package/dist/node/channels/index.js.map +1 -0
  189. package/dist/node/core/schemas/internal/discussions/EntityUiSchemaDiscussionsSettings.js +144 -0
  190. package/dist/node/core/schemas/internal/discussions/EntityUiSchemaDiscussionsSettings.js.map +1 -0
  191. package/dist/node/core/types/IHubChannel.js +3 -0
  192. package/dist/node/core/types/IHubChannel.js.map +1 -0
  193. package/dist/node/core/types/IHubOrganization.js +3 -0
  194. package/dist/node/core/types/IHubOrganization.js.map +1 -0
  195. package/dist/node/discussions/api/posts/index.js +5 -0
  196. package/dist/node/discussions/api/posts/index.js.map +1 -0
  197. package/dist/node/discussions/api/posts/posts.js +244 -0
  198. package/dist/node/discussions/api/posts/posts.js.map +1 -0
  199. package/dist/node/discussions/api/reactions/index.js +5 -0
  200. package/dist/node/discussions/api/reactions/index.js.map +1 -0
  201. package/dist/node/discussions/api/reactions/reactions.js +60 -0
  202. package/dist/node/discussions/api/reactions/reactions.js.map +1 -0
  203. package/dist/node/discussions/api/utils/channel-permission.js +381 -0
  204. package/dist/node/discussions/api/utils/channel-permission.js.map +1 -0
  205. package/dist/node/discussions/api/utils/channels/can-create-channel-v2.js +17 -0
  206. package/dist/node/discussions/api/utils/channels/can-create-channel-v2.js.map +1 -0
  207. package/dist/node/discussions/api/utils/channels/can-create-channel.js +58 -0
  208. package/dist/node/discussions/api/utils/channels/can-create-channel.js.map +1 -0
  209. package/dist/node/discussions/api/utils/channels/can-delete-channel-v2.js +21 -0
  210. package/dist/node/discussions/api/utils/channels/can-delete-channel-v2.js.map +1 -0
  211. package/dist/node/discussions/api/utils/channels/can-delete-channel.js +21 -0
  212. package/dist/node/discussions/api/utils/channels/can-delete-channel.js.map +1 -0
  213. package/dist/node/discussions/api/utils/channels/can-edit-channel-v2.js +23 -0
  214. package/dist/node/discussions/api/utils/channels/can-edit-channel-v2.js.map +1 -0
  215. package/dist/node/discussions/api/utils/channels/can-edit-channel.js +21 -0
  216. package/dist/node/discussions/api/utils/channels/can-edit-channel.js.map +1 -0
  217. package/dist/node/discussions/api/utils/channels/can-modify-channel.js +22 -0
  218. package/dist/node/discussions/api/utils/channels/can-modify-channel.js.map +1 -0
  219. package/dist/node/discussions/api/utils/channels/can-post-to-channel.js +61 -0
  220. package/dist/node/discussions/api/utils/channels/can-post-to-channel.js.map +1 -0
  221. package/dist/node/discussions/api/utils/channels/can-read-channel-v2.js +22 -0
  222. package/dist/node/discussions/api/utils/channels/can-read-channel-v2.js.map +1 -0
  223. package/dist/node/discussions/api/utils/channels/can-read-channel.js +57 -0
  224. package/dist/node/discussions/api/utils/channels/can-read-channel.js.map +1 -0
  225. package/dist/node/discussions/api/utils/channels/channel-to-dto-map.js +15 -0
  226. package/dist/node/discussions/api/utils/channels/channel-to-dto-map.js.map +1 -0
  227. package/dist/node/discussions/api/utils/channels/index.js +26 -0
  228. package/dist/node/discussions/api/utils/channels/index.js.map +1 -0
  229. package/dist/node/discussions/api/utils/channels/is-authorized-to-modify-channel-by-legacy-permissions.js +48 -0
  230. package/dist/node/discussions/api/utils/channels/is-authorized-to-modify-channel-by-legacy-permissions.js.map +1 -0
  231. package/dist/node/discussions/api/utils/platform.js +53 -0
  232. package/dist/node/discussions/api/utils/platform.js.map +1 -0
  233. package/dist/node/discussions/api/utils/portal-privilege.js +41 -0
  234. package/dist/node/discussions/api/utils/portal-privilege.js.map +1 -0
  235. package/dist/node/discussions/api/utils/posts/can-create-post-v2.js +24 -0
  236. package/dist/node/discussions/api/utils/posts/can-create-post-v2.js.map +1 -0
  237. package/dist/node/discussions/api/utils/posts/can-create-post.js +56 -0
  238. package/dist/node/discussions/api/utils/posts/can-create-post.js.map +1 -0
  239. package/dist/node/discussions/api/utils/posts/can-create-reply-v2.js +23 -0
  240. package/dist/node/discussions/api/utils/posts/can-create-reply-v2.js.map +1 -0
  241. package/dist/node/discussions/api/utils/posts/can-create-reply.js +56 -0
  242. package/dist/node/discussions/api/utils/posts/can-create-reply.js.map +1 -0
  243. package/dist/node/discussions/api/utils/posts/can-delete-post-v2.js +28 -0
  244. package/dist/node/discussions/api/utils/posts/can-delete-post-v2.js.map +1 -0
  245. package/dist/node/discussions/api/utils/posts/can-delete-post.js +32 -0
  246. package/dist/node/discussions/api/utils/posts/can-delete-post.js.map +1 -0
  247. package/dist/node/discussions/api/utils/posts/can-edit-post-status-v2.js +20 -0
  248. package/dist/node/discussions/api/utils/posts/can-edit-post-status-v2.js.map +1 -0
  249. package/dist/node/discussions/api/utils/posts/can-edit-post-status.js +66 -0
  250. package/dist/node/discussions/api/utils/posts/can-edit-post-status.js.map +1 -0
  251. package/dist/node/discussions/api/utils/posts/can-edit-post-v2.js +23 -0
  252. package/dist/node/discussions/api/utils/posts/can-edit-post-v2.js.map +1 -0
  253. package/dist/node/discussions/api/utils/posts/can-edit-post.js +67 -0
  254. package/dist/node/discussions/api/utils/posts/can-edit-post.js.map +1 -0
  255. package/dist/node/discussions/api/utils/posts/index.js +31 -0
  256. package/dist/node/discussions/api/utils/posts/index.js.map +1 -0
  257. package/dist/node/discussions/api/utils/posts/parse-discussion-uri.js +42 -0
  258. package/dist/node/discussions/api/utils/posts/parse-discussion-uri.js.map +1 -0
  259. package/dist/node/discussions/api/utils/posts/parse-mentioned-users.js +23 -0
  260. package/dist/node/discussions/api/utils/posts/parse-mentioned-users.js.map +1 -0
  261. package/dist/node/discussions/api/utils/reactions/can-create-reaction-v2.js +31 -0
  262. package/dist/node/discussions/api/utils/reactions/can-create-reaction-v2.js.map +1 -0
  263. package/dist/node/discussions/api/utils/reactions/can-create-reaction.js +32 -0
  264. package/dist/node/discussions/api/utils/reactions/can-create-reaction.js.map +1 -0
  265. package/dist/node/discussions/api/utils/reactions/index.js +7 -0
  266. package/dist/node/discussions/api/utils/reactions/index.js.map +1 -0
  267. package/dist/node/hub-types.js +919 -0
  268. package/dist/node/hub-types.js.map +1 -0
  269. package/dist/node/org/fetch-org.js +5 -1
  270. package/dist/node/org/fetch-org.js.map +1 -1
  271. package/dist/node/org/fetch.js +89 -0
  272. package/dist/node/org/fetch.js.map +1 -0
  273. package/dist/node/search/_internal/hubDiscussionsHelpers/channelResultsToSearchResults.js +37 -0
  274. package/dist/node/search/_internal/hubDiscussionsHelpers/channelResultsToSearchResults.js.map +1 -0
  275. package/dist/node/search/_internal/hubDiscussionsHelpers/processChannelFilters.js +72 -0
  276. package/dist/node/search/_internal/hubDiscussionsHelpers/processChannelFilters.js.map +1 -0
  277. package/dist/node/search/_internal/hubDiscussionsHelpers/processChannelOptions.js +39 -0
  278. package/dist/node/search/_internal/hubDiscussionsHelpers/processChannelOptions.js.map +1 -0
  279. package/dist/node/search/_internal/hubSearchItemsHelpers/getFieldsQueryParam.js +19 -0
  280. package/dist/node/search/_internal/hubSearchItemsHelpers/getFieldsQueryParam.js.map +1 -0
  281. package/dist/node/search/_internal/hubSearchItemsHelpers/getFlattenQueryParam.js +19 -0
  282. package/dist/node/search/_internal/hubSearchItemsHelpers/getFlattenQueryParam.js.map +1 -0
  283. package/dist/node/search/_internal/portalFetchOrgs.js +37 -0
  284. package/dist/node/search/_internal/portalFetchOrgs.js.map +1 -0
  285. package/dist/node/sites/_internal/_migrate-to-v2-catalog.js +28 -0
  286. package/dist/node/sites/_internal/_migrate-to-v2-catalog.js.map +1 -0
  287. package/dist/node/sites/defaultSiteCollectionKeys.js +10 -0
  288. package/dist/node/sites/defaultSiteCollectionKeys.js.map +1 -0
  289. package/dist/node/sites/searchCategoriesToCollections.js +79 -0
  290. package/dist/node/sites/searchCategoriesToCollections.js.map +1 -0
  291. package/dist/node/types/IArcGISContext.js +3 -0
  292. package/dist/node/types/IArcGISContext.js.map +1 -0
  293. package/dist/node/types/IArcGISContextManagerOptions.js +3 -0
  294. package/dist/node/types/IArcGISContextManagerOptions.js.map +1 -0
  295. package/dist/node/types/IArcGISContextOptions.js +3 -0
  296. package/dist/node/types/IArcGISContextOptions.js.map +1 -0
  297. package/dist/node/types/IUserResourceConfig.js +3 -0
  298. package/dist/node/types/IUserResourceConfig.js.map +1 -0
  299. package/dist/node/types/IUserResourceToken.js +3 -0
  300. package/dist/node/types/IUserResourceToken.js.map +1 -0
  301. package/dist/node/urls/getPortalBaseFromOrgUrl.js +3 -1
  302. package/dist/node/urls/getPortalBaseFromOrgUrl.js.map +1 -1
  303. package/dist/node/utils/IHubConfig.js +3 -0
  304. package/dist/node/utils/IHubConfig.js.map +1 -0
  305. package/dist/node/utils/IUserHubSettings.js +3 -0
  306. package/dist/node/utils/IUserHubSettings.js.map +1 -0
  307. package/dist/node/utils/IUserSiteSettings.js +6 -0
  308. package/dist/node/utils/IUserSiteSettings.js.map +1 -0
  309. package/dist/node/utils/LogLevel.js +3 -0
  310. package/dist/node/utils/LogLevel.js.map +1 -0
  311. package/dist/node/utils/internal/config.js +14 -0
  312. package/dist/node/utils/internal/config.js.map +1 -0
  313. package/dist/types/channels/HubChannel.d.ts +105 -0
  314. package/dist/types/channels/_internal/ChannelBusinessRules.d.ts +19 -0
  315. package/dist/types/channels/_internal/ChannelSchema.d.ts +16 -0
  316. package/dist/types/channels/_internal/ChannelUiSchemaCreate.d.ts +10 -0
  317. package/dist/types/channels/_internal/ChannelUiSchemaEdit.d.ts +10 -0
  318. package/dist/types/channels/_internal/buildDefaultChannel.d.ts +8 -0
  319. package/dist/types/channels/_internal/transformAclPermissionToEntityPermissionPolicy.d.ts +11 -0
  320. package/dist/types/channels/_internal/transformChannelToEntity.d.ts +11 -0
  321. package/dist/types/channels/_internal/transformEditorToEntity.d.ts +8 -0
  322. package/dist/types/channels/_internal/transformEntityPermissionPoliciesToFormValues.d.ts +44 -0
  323. package/dist/types/channels/_internal/transformEntityToChannelData.d.ts +9 -0
  324. package/dist/types/channels/_internal/transformEntityToEditor.d.ts +9 -0
  325. package/dist/types/channels/_internal/transformFormValuesToEntityPermissionPolicies.d.ts +9 -0
  326. package/dist/types/channels/edit.d.ts +23 -0
  327. package/dist/types/channels/fetch.d.ts +9 -0
  328. package/dist/types/channels/index.d.ts +3 -0
  329. package/dist/types/core/schemas/internal/discussions/EntityUiSchemaDiscussionsSettings.d.ts +11 -0
  330. package/dist/types/core/types/IHubChannel.d.ts +91 -0
  331. package/dist/types/core/types/IHubOrganization.d.ts +61 -0
  332. package/dist/types/discussions/api/posts/index.d.ts +1 -0
  333. package/dist/types/discussions/api/posts/posts.d.ts +146 -0
  334. package/dist/types/discussions/api/reactions/index.d.ts +1 -0
  335. package/dist/types/discussions/api/reactions/reactions.d.ts +38 -0
  336. package/dist/types/discussions/api/utils/channel-permission.d.ts +44 -0
  337. package/dist/types/discussions/api/utils/channels/can-create-channel-v2.d.ts +10 -0
  338. package/dist/types/discussions/api/utils/channels/can-create-channel.d.ts +11 -0
  339. package/dist/types/discussions/api/utils/channels/can-delete-channel-v2.d.ts +10 -0
  340. package/dist/types/discussions/api/utils/channels/can-delete-channel.d.ts +11 -0
  341. package/dist/types/discussions/api/utils/channels/can-edit-channel-v2.d.ts +11 -0
  342. package/dist/types/discussions/api/utils/channels/can-edit-channel.d.ts +11 -0
  343. package/dist/types/discussions/api/utils/channels/can-modify-channel.d.ts +11 -0
  344. package/dist/types/discussions/api/utils/channels/can-post-to-channel.d.ts +11 -0
  345. package/dist/types/discussions/api/utils/channels/can-read-channel-v2.d.ts +11 -0
  346. package/dist/types/discussions/api/utils/channels/can-read-channel.d.ts +22 -0
  347. package/dist/types/discussions/api/utils/channels/channel-to-dto-map.d.ts +6 -0
  348. package/dist/types/discussions/api/utils/channels/index.d.ts +10 -0
  349. package/dist/types/discussions/api/utils/channels/is-authorized-to-modify-channel-by-legacy-permissions.d.ts +11 -0
  350. package/dist/types/discussions/api/utils/platform.d.ts +26 -0
  351. package/dist/types/discussions/api/utils/portal-privilege.d.ts +17 -0
  352. package/dist/types/discussions/api/utils/posts/can-create-post-v2.d.ts +10 -0
  353. package/dist/types/discussions/api/utils/posts/can-create-post.d.ts +12 -0
  354. package/dist/types/discussions/api/utils/posts/can-create-reply-v2.d.ts +9 -0
  355. package/dist/types/discussions/api/utils/posts/can-create-reply.d.ts +12 -0
  356. package/dist/types/discussions/api/utils/posts/can-delete-post-v2.d.ts +11 -0
  357. package/dist/types/discussions/api/utils/posts/can-delete-post.d.ts +12 -0
  358. package/dist/types/discussions/api/utils/posts/can-edit-post-status-v2.d.ts +9 -0
  359. package/dist/types/discussions/api/utils/posts/can-edit-post-status.d.ts +20 -0
  360. package/dist/types/discussions/api/utils/posts/can-edit-post-v2.d.ts +10 -0
  361. package/dist/types/discussions/api/utils/posts/can-edit-post.d.ts +22 -0
  362. package/dist/types/discussions/api/utils/posts/index.d.ts +12 -0
  363. package/dist/types/discussions/api/utils/posts/parse-discussion-uri.d.ts +9 -0
  364. package/dist/types/discussions/api/utils/posts/parse-mentioned-users.d.ts +6 -0
  365. package/dist/types/discussions/api/utils/reactions/can-create-reaction-v2.d.ts +12 -0
  366. package/dist/types/discussions/api/utils/reactions/can-create-reaction.d.ts +13 -0
  367. package/dist/types/discussions/api/utils/reactions/index.d.ts +2 -0
  368. package/dist/types/hub-types.d.ts +547 -0
  369. package/dist/types/org/fetch.d.ts +26 -0
  370. package/dist/types/search/_internal/hubDiscussionsHelpers/channelResultsToSearchResults.d.ts +11 -0
  371. package/dist/types/search/_internal/hubDiscussionsHelpers/processChannelFilters.d.ts +32 -0
  372. package/dist/types/search/_internal/hubDiscussionsHelpers/processChannelOptions.d.ts +10 -0
  373. package/dist/types/search/_internal/hubSearchItemsHelpers/getFieldsQueryParam.d.ts +11 -0
  374. package/dist/types/search/_internal/hubSearchItemsHelpers/getFlattenQueryParam.d.ts +11 -0
  375. package/dist/types/search/_internal/portalFetchOrgs.d.ts +9 -0
  376. package/dist/types/sites/_internal/_migrate-to-v2-catalog.d.ts +8 -0
  377. package/dist/types/sites/defaultSiteCollectionKeys.d.ts +2 -0
  378. package/dist/types/sites/searchCategoriesToCollections.d.ts +10 -0
  379. package/dist/types/types/IArcGISContext.d.ts +258 -0
  380. package/dist/types/types/IArcGISContextManagerOptions.d.ts +79 -0
  381. package/dist/types/types/IArcGISContextOptions.d.ts +78 -0
  382. package/dist/types/types/IUserResourceConfig.d.ts +5 -0
  383. package/dist/types/types/IUserResourceToken.d.ts +4 -0
  384. package/dist/types/utils/IHubConfig.d.ts +24 -0
  385. package/dist/types/utils/IUserHubSettings.d.ts +32 -0
  386. package/dist/types/utils/IUserSiteSettings.d.ts +8 -0
  387. package/dist/types/utils/LogLevel.d.ts +2 -0
  388. package/dist/types/utils/internal/config.d.ts +1 -0
  389. package/package.json +1 -1
@@ -0,0 +1,381 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ChannelPermission = void 0;
4
+ const types_1 = require("../types");
5
+ const platform_1 = require("./platform");
6
+ const channel_to_dto_map_1 = require("./channels/channel-to-dto-map");
7
+ const constants_1 = require("../../constants");
8
+ var ChannelAction;
9
+ (function (ChannelAction) {
10
+ ChannelAction["READ_POSTS"] = "readPosts";
11
+ ChannelAction["WRITE_POSTS"] = "writePosts";
12
+ ChannelAction["MODERATE_CHANNEL"] = "moderateChannel";
13
+ ChannelAction["DELETE_CHANNEL"] = "deleteChannel";
14
+ ChannelAction["IS_MODERATOR"] = "isModerator";
15
+ ChannelAction["IS_MANAGER"] = "isManager";
16
+ ChannelAction["IS_OWNER"] = "isOwner";
17
+ })(ChannelAction || (ChannelAction = {}));
18
+ // See confluence for privs documentation: https://confluencewikidev.esri.com/pages/viewpage.action?pageId=153747776#Roles&Privileges-ApplicationtoChannels
19
+ const CHANNEL_ACTION_PRIVS = {
20
+ // permissions
21
+ UPDATE_OWNERS: [types_1.Role.OWNER],
22
+ UPDATE_MANAGERS: [types_1.Role.OWNER, types_1.Role.MANAGE],
23
+ UPDATE_MODERATORS: [types_1.Role.OWNER, types_1.Role.MANAGE],
24
+ UPDATE_ORGS: [types_1.Role.OWNER, types_1.Role.MANAGE],
25
+ UPDATE_GROUPS: [types_1.Role.OWNER, types_1.Role.MANAGE],
26
+ UPDATE_USERS: [types_1.Role.OWNER, types_1.Role.MANAGE],
27
+ UPDATE_AUTHENTICATED_USERS: [types_1.Role.OWNER, types_1.Role.MANAGE],
28
+ UPDATE_ANONYMOUS_USERS: [types_1.Role.OWNER, types_1.Role.MANAGE],
29
+ // settings
30
+ UPDATE_POST_REPLIES: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
31
+ UPDATE_POST_REACTIONS: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
32
+ UPDATE_POST_AS_ANONYMOUS: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
33
+ UPDATE_ALLOWED_REACTIONS: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
34
+ UPDATE_DEFAULT_POST_STATUS: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
35
+ UPDATE_BLOCKED_WORDS: [types_1.Role.OWNER, types_1.Role.MANAGE, types_1.Role.MODERATE],
36
+ UPDATE_CHANNEL_NAME: [types_1.Role.OWNER, types_1.Role.MANAGE],
37
+ UPDATE_SOFT_DELETE_SETTING: [types_1.Role.OWNER, types_1.Role.MANAGE],
38
+ };
39
+ /**
40
+ * @internal
41
+ * @hidden
42
+ */
43
+ class ChannelPermission {
44
+ constructor(channel) {
45
+ this.ALLOWED_GROUP_MEMBER_TYPES = ["owner", "admin", "member"];
46
+ if (channel.channelAcl === undefined) {
47
+ throw new Error("channel.channelAcl is required for ChannelPermission checks");
48
+ }
49
+ this.existingChannel = channel;
50
+ this.isChannelAclEmpty = channel.channelAcl.length === 0;
51
+ this.permissionsByCategory = {};
52
+ channel.channelAcl.forEach((permission) => {
53
+ var _c;
54
+ const { category } = permission;
55
+ ((_c = this.permissionsByCategory[category]) === null || _c === void 0 ? void 0 : _c.push(permission)) ||
56
+ (this.permissionsByCategory[category] = [permission]);
57
+ });
58
+ }
59
+ canPostToChannel(user) {
60
+ if (this.canAnyUser(ChannelAction.WRITE_POSTS)) {
61
+ return true;
62
+ }
63
+ if (this.isUserUnAuthenticated(user)) {
64
+ return false;
65
+ }
66
+ return (this.canAnyAuthenticatedUser(ChannelAction.WRITE_POSTS) ||
67
+ this.canSomeUser(ChannelAction.WRITE_POSTS, user) ||
68
+ this.canSomeUserGroup(ChannelAction.WRITE_POSTS, user) ||
69
+ this.canSomeUserOrg(ChannelAction.WRITE_POSTS, user));
70
+ }
71
+ canCreateChannel(user) {
72
+ if (this.isUserUnAuthenticated(user) || this.isChannelAclEmpty) {
73
+ return false;
74
+ }
75
+ return (this.userCanAddAnonymousToAcl(user) &&
76
+ this.userCanAddUnauthenticatedToAcl(user) &&
77
+ this.userCanAddAllGroupsToAcl(user) &&
78
+ this.userCanAddAllOrgsToAcl(user) &&
79
+ this.userCanAddUsersToAcl(user));
80
+ }
81
+ canModerateChannel(user) {
82
+ if (this.isUserUnAuthenticated(user)) {
83
+ return false;
84
+ }
85
+ return (this.canSomeUser(ChannelAction.MODERATE_CHANNEL, user) ||
86
+ this.canSomeUserGroup(ChannelAction.MODERATE_CHANNEL, user) ||
87
+ this.canSomeUserOrg(ChannelAction.MODERATE_CHANNEL, user));
88
+ }
89
+ canReadChannel(user) {
90
+ if (this.canAnyUser(ChannelAction.READ_POSTS)) {
91
+ return true;
92
+ }
93
+ if (this.isUserUnAuthenticated(user)) {
94
+ return false;
95
+ }
96
+ return (this.canAnyAuthenticatedUser(ChannelAction.READ_POSTS) ||
97
+ this.canSomeUser(ChannelAction.READ_POSTS, user) ||
98
+ this.canSomeUserGroup(ChannelAction.READ_POSTS, user) ||
99
+ this.canSomeUserOrg(ChannelAction.READ_POSTS, user));
100
+ }
101
+ canDeleteChannel(user) {
102
+ if (this.isUserUnAuthenticated(user)) {
103
+ return false;
104
+ }
105
+ return (this.canSomeUser(ChannelAction.DELETE_CHANNEL, user) ||
106
+ this.canSomeUserGroup(ChannelAction.DELETE_CHANNEL, user) ||
107
+ this.canSomeUserOrg(ChannelAction.DELETE_CHANNEL, user));
108
+ }
109
+ /**
110
+ * Ensure the user has rights to update the channel before calling this method
111
+ * Ex: canModerateChannel
112
+ */
113
+ canUpdateProperties(user, updateData = {}) {
114
+ if (Object.keys(updateData).length === 0) {
115
+ return true;
116
+ }
117
+ const userRole = this.determineUserRole(user);
118
+ const updates = channel_to_dto_map_1.dtoToChannel(updateData);
119
+ if (
120
+ // settings
121
+ (this.isChanged(updates.allowReply, this.existingChannel.allowReply) &&
122
+ !CHANNEL_ACTION_PRIVS.UPDATE_POST_REPLIES.includes(userRole)) ||
123
+ (this.isChanged(updates.allowReaction, this.existingChannel.allowReaction) &&
124
+ !CHANNEL_ACTION_PRIVS.UPDATE_POST_REACTIONS.includes(userRole)) ||
125
+ (this.isChanged(updates.allowAsAnonymous, this.existingChannel.allowAsAnonymous) &&
126
+ !CHANNEL_ACTION_PRIVS.UPDATE_POST_AS_ANONYMOUS.includes(userRole)) ||
127
+ (this.isStringArrayChanged(updates.allowedReactions, this.existingChannel.allowedReactions) &&
128
+ !CHANNEL_ACTION_PRIVS.UPDATE_ALLOWED_REACTIONS.includes(userRole)) ||
129
+ (this.isChanged(updates.defaultPostStatus, this.existingChannel.defaultPostStatus) &&
130
+ !CHANNEL_ACTION_PRIVS.UPDATE_DEFAULT_POST_STATUS.includes(userRole)) ||
131
+ (this.isStringArrayChanged(updates.blockWords, this.existingChannel.blockWords) &&
132
+ !CHANNEL_ACTION_PRIVS.UPDATE_BLOCKED_WORDS.includes(userRole)) ||
133
+ (this.isChanged(updates.name, this.existingChannel.name) &&
134
+ !CHANNEL_ACTION_PRIVS.UPDATE_CHANNEL_NAME.includes(userRole)) ||
135
+ (this.isChanged(updates.softDelete, this.existingChannel.softDelete) &&
136
+ !CHANNEL_ACTION_PRIVS.UPDATE_SOFT_DELETE_SETTING.includes(userRole)) ||
137
+ // permissions
138
+ (this.isRoleChanged(types_1.Role.OWNER, updates.channelAcl) &&
139
+ !CHANNEL_ACTION_PRIVS.UPDATE_OWNERS.includes(userRole)) ||
140
+ (this.isRoleChanged(types_1.Role.MANAGE, updates.channelAcl) &&
141
+ !CHANNEL_ACTION_PRIVS.UPDATE_MANAGERS.includes(userRole)) ||
142
+ (this.isRoleChanged(types_1.Role.MODERATE, updates.channelAcl) &&
143
+ !CHANNEL_ACTION_PRIVS.UPDATE_MODERATORS.includes(userRole)) ||
144
+ (this.isCategoryChanged(types_1.AclCategory.ORG, updates.channelAcl) &&
145
+ !CHANNEL_ACTION_PRIVS.UPDATE_ORGS.includes(userRole)) ||
146
+ (this.isCategoryChanged(types_1.AclCategory.GROUP, updates.channelAcl) &&
147
+ !CHANNEL_ACTION_PRIVS.UPDATE_GROUPS.includes(userRole)) ||
148
+ (this.isCategoryChanged(types_1.AclCategory.USER, updates.channelAcl) &&
149
+ !CHANNEL_ACTION_PRIVS.UPDATE_USERS.includes(userRole)) ||
150
+ (this.isCategoryChanged(types_1.AclCategory.AUTHENTICATED_USER, updates.channelAcl) &&
151
+ !CHANNEL_ACTION_PRIVS.UPDATE_AUTHENTICATED_USERS.includes(userRole)) ||
152
+ (this.isCategoryChanged(types_1.AclCategory.ANONYMOUS_USER, updates.channelAcl) &&
153
+ !CHANNEL_ACTION_PRIVS.UPDATE_ANONYMOUS_USERS.includes(userRole))) {
154
+ return false;
155
+ }
156
+ return true;
157
+ }
158
+ isChanged(updateValue, existingValue) {
159
+ return updateValue !== undefined && updateValue !== existingValue;
160
+ }
161
+ isStringArrayChanged(_a, _b) {
162
+ const a = _a !== null && _a !== void 0 ? _a : [];
163
+ const b = _b !== null && _b !== void 0 ? _b : [];
164
+ return (a.filter((x) => !b.includes(x)).length !== 0 ||
165
+ b.filter((x) => !a.includes(x)).length !== 0);
166
+ }
167
+ isRoleChanged(role, aclUpdates) {
168
+ if (!aclUpdates) {
169
+ return false;
170
+ }
171
+ // ex: ['org_admin_1111_owner', 'group_admin_222_owner', 'user_undefined_333_owner]
172
+ const existing = this.existingChannel.channelAcl
173
+ .filter((acl) => acl.role === role)
174
+ .map((acl) => `${acl.category}_${acl.subCategory}_${acl.key}_${role}`);
175
+ const changed = aclUpdates
176
+ .filter((acl) => acl.role === role)
177
+ .map((acl) => `${acl.category}_${acl.subCategory}_${acl.key}_${role}`);
178
+ return this.isStringArrayChanged(existing, changed);
179
+ }
180
+ isCategoryChanged(category, aclUpdates) {
181
+ var _c;
182
+ if (!aclUpdates) {
183
+ return false;
184
+ }
185
+ // ex: ['org_admin_111_OWNER', 'org_member_111_readWrite', 'group_member_2222_read']
186
+ const existing = ((_c = this.permissionsByCategory[category]) !== null && _c !== void 0 ? _c : []).map((acl) => `${category}_${acl.subCategory}_${acl.key}_${acl.role}`);
187
+ const changed = aclUpdates
188
+ .filter((acl) => acl.category === category)
189
+ .map((acl) => `${category}_${acl.subCategory}_${acl.key}_${acl.role}`);
190
+ return this.isStringArrayChanged(existing, changed);
191
+ }
192
+ canAnyUser(action) {
193
+ var _c;
194
+ const anonymousUserRole = (_c = this.permissionsByCategory[types_1.AclCategory.ANONYMOUS_USER]) === null || _c === void 0 ? void 0 : _c[0].role;
195
+ return channelActionLookup(action).includes(anonymousUserRole);
196
+ }
197
+ canAnyAuthenticatedUser(action) {
198
+ var _c;
199
+ const role = (_c = this.permissionsByCategory[types_1.AclCategory.AUTHENTICATED_USER]) === null || _c === void 0 ? void 0 : _c[0].role;
200
+ return channelActionLookup(action).includes(role);
201
+ }
202
+ canSomeUser(action, user) {
203
+ var _c;
204
+ const userPermissions = (_c = this.permissionsByCategory[types_1.AclCategory.USER]) !== null && _c !== void 0 ? _c : [];
205
+ const username = user.username;
206
+ return userPermissions.some((permission) => {
207
+ const { role, key } = permission;
208
+ return key === username && channelActionLookup(action).includes(role);
209
+ });
210
+ }
211
+ canSomeUserGroup(action, user) {
212
+ var _c;
213
+ const groupAccessControls = (_c = this.permissionsByCategory[types_1.AclCategory.GROUP]) !== null && _c !== void 0 ? _c : [];
214
+ const userGroupsById = this.mapUserGroupsById(user.groups);
215
+ return groupAccessControls.some((permission) => {
216
+ const group = userGroupsById[permission.key];
217
+ if (action === ChannelAction.READ_POSTS) {
218
+ if (!group) {
219
+ return false;
220
+ }
221
+ }
222
+ else {
223
+ if (!group || !isGroupDiscussable(group)) {
224
+ return false;
225
+ }
226
+ }
227
+ return (doesPermissionAllowGroupMemberType(permission, group) &&
228
+ channelActionLookup(action).includes(permission.role));
229
+ });
230
+ }
231
+ canSomeUserOrg(action, user) {
232
+ var _c;
233
+ const orgPermissions = (_c = this.permissionsByCategory[types_1.AclCategory.ORG]) !== null && _c !== void 0 ? _c : [];
234
+ return orgPermissions.some((permission) => {
235
+ if (permission.key !== user.orgId) {
236
+ return false;
237
+ }
238
+ return (doesPermissionAllowOrgRole(permission, user) &&
239
+ channelActionLookup(action).includes(permission.role));
240
+ });
241
+ }
242
+ userCanAddAnonymousToAcl(user) {
243
+ if (!this.permissionsByCategory[types_1.AclCategory.ANONYMOUS_USER]) {
244
+ return true;
245
+ }
246
+ return (platform_1.isOrgAdmin(user) ||
247
+ platform_1.userHasPrivilege(user, "portal:admin:shareToPublic") ||
248
+ platform_1.userHasPrivilege(user, "portal:user:shareToPublic"));
249
+ }
250
+ userCanAddUnauthenticatedToAcl(user) {
251
+ if (!this.permissionsByCategory[types_1.AclCategory.AUTHENTICATED_USER]) {
252
+ return true;
253
+ }
254
+ return (platform_1.isOrgAdmin(user) ||
255
+ platform_1.userHasPrivilege(user, "portal:admin:shareToPublic") ||
256
+ platform_1.userHasPrivilege(user, "portal:user:shareToPublic"));
257
+ }
258
+ userCanAddAllGroupsToAcl(user) {
259
+ const groupPermissions = this.permissionsByCategory[types_1.AclCategory.GROUP];
260
+ const userGroupsById = this.mapUserGroupsById(user.groups);
261
+ if (!groupPermissions) {
262
+ return true;
263
+ }
264
+ return groupPermissions.every((permission) => {
265
+ const userGroup = userGroupsById[permission.key];
266
+ return (userGroup &&
267
+ this.isMemberTypeAuthorized(userGroup) &&
268
+ isGroupDiscussable(userGroup));
269
+ });
270
+ }
271
+ userCanAddAllOrgsToAcl(user) {
272
+ const orgPermissions = this.permissionsByCategory[types_1.AclCategory.ORG];
273
+ if (!orgPermissions) {
274
+ return true;
275
+ }
276
+ return ((platform_1.isOrgAdmin(user) ||
277
+ platform_1.userHasPrivilege(user, "portal:admin:shareToOrg") ||
278
+ platform_1.userHasPrivilege(user, "portal:user:shareToOrg")) &&
279
+ this.isEveryPermissionForUserOrg(user.orgId, orgPermissions));
280
+ }
281
+ isEveryPermissionForUserOrg(userOrgId, orgPermissions) {
282
+ return orgPermissions.every((permission) => {
283
+ const { key: orgId } = permission;
284
+ return userOrgId === orgId;
285
+ });
286
+ }
287
+ // for now user permissions are disabled on channel create
288
+ // since users are not notified and cannot opt out
289
+ userCanAddUsersToAcl(user) {
290
+ const userPermissions = this.permissionsByCategory[types_1.AclCategory.USER];
291
+ return !userPermissions;
292
+ }
293
+ isUserUnAuthenticated(user) {
294
+ return user.username === null || user.username === undefined;
295
+ }
296
+ mapUserGroupsById(groups) {
297
+ return groups.reduce((accum, userGroup) => {
298
+ accum[userGroup.id] = userGroup;
299
+ return accum;
300
+ }, {});
301
+ }
302
+ isMemberTypeAuthorized(userGroup) {
303
+ const { userMembership: { memberType }, } = userGroup;
304
+ return this.ALLOWED_GROUP_MEMBER_TYPES.includes(memberType);
305
+ }
306
+ determineUserRole(user) {
307
+ if (this.isOwner(user)) {
308
+ return types_1.Role.OWNER;
309
+ }
310
+ else if (this.isManager(user)) {
311
+ return types_1.Role.MANAGE;
312
+ }
313
+ else if (this.isModerator(user)) {
314
+ return types_1.Role.MODERATE;
315
+ }
316
+ else {
317
+ return types_1.Role.READ;
318
+ }
319
+ }
320
+ isOwner(user) {
321
+ return (this.canSomeUser(ChannelAction.IS_OWNER, user) ||
322
+ this.canSomeUserGroup(ChannelAction.IS_OWNER, user) ||
323
+ this.canSomeUserOrg(ChannelAction.IS_OWNER, user));
324
+ }
325
+ isManager(user) {
326
+ return (this.canSomeUser(ChannelAction.IS_MANAGER, user) ||
327
+ this.canSomeUserGroup(ChannelAction.IS_MANAGER, user) ||
328
+ this.canSomeUserOrg(ChannelAction.IS_MANAGER, user));
329
+ }
330
+ isModerator(user) {
331
+ return (this.canSomeUser(ChannelAction.IS_MODERATOR, user) ||
332
+ this.canSomeUserGroup(ChannelAction.IS_MODERATOR, user) ||
333
+ this.canSomeUserOrg(ChannelAction.IS_MODERATOR, user));
334
+ }
335
+ }
336
+ exports.ChannelPermission = ChannelPermission;
337
+ function isGroupDiscussable(userGroup) {
338
+ const { typeKeywords = [] } = userGroup;
339
+ return !typeKeywords.includes(constants_1.CANNOT_DISCUSS);
340
+ }
341
+ function doesPermissionAllowGroupMemberType(permission, group) {
342
+ if (permission.category !== types_1.AclCategory.GROUP ||
343
+ group.userMembership.memberType === "none") {
344
+ return false;
345
+ }
346
+ return (
347
+ // group owners and admins can do anything permissioned with SubCategory "member"
348
+ group.userMembership.memberType === "owner" ||
349
+ group.userMembership.memberType === "admin" ||
350
+ permission.subCategory === types_1.AclSubCategory.MEMBER);
351
+ }
352
+ function doesPermissionAllowOrgRole(permission, user) {
353
+ return (permission.category === types_1.AclCategory.ORG &&
354
+ (permission.subCategory === types_1.AclSubCategory.MEMBER ||
355
+ (permission.subCategory === types_1.AclSubCategory.ADMIN && platform_1.isOrgAdmin(user))));
356
+ }
357
+ function channelActionLookup(action) {
358
+ // channel actions
359
+ if (action === ChannelAction.WRITE_POSTS) {
360
+ return [types_1.Role.WRITE, types_1.Role.READWRITE, types_1.Role.MODERATE, types_1.Role.MANAGE, types_1.Role.OWNER];
361
+ }
362
+ if (action === ChannelAction.MODERATE_CHANNEL) {
363
+ return [types_1.Role.MODERATE, types_1.Role.MANAGE, types_1.Role.OWNER];
364
+ }
365
+ if (action === ChannelAction.DELETE_CHANNEL) {
366
+ return [types_1.Role.OWNER];
367
+ }
368
+ // channel update actions
369
+ if (action === ChannelAction.IS_MODERATOR) {
370
+ return [types_1.Role.MODERATE];
371
+ }
372
+ if (action === ChannelAction.IS_MANAGER) {
373
+ return [types_1.Role.MANAGE];
374
+ }
375
+ if (action === ChannelAction.IS_OWNER) {
376
+ return [types_1.Role.OWNER];
377
+ }
378
+ // default to read action
379
+ return [types_1.Role.READ, types_1.Role.READWRITE, types_1.Role.MODERATE, types_1.Role.MANAGE, types_1.Role.OWNER];
380
+ }
381
+ //# sourceMappingURL=channel-permission.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"channel-permission.js","sourceRoot":"","sources":["../../../../../src/discussions/api/utils/channel-permission.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canCreateChannelV2 = void 0;
4
+ const channel_permission_1 = require("../channel-permission");
5
+ /**
6
+ * Utility to determine if User has privileges to create a channel with the defined permissions
7
+ * @export
8
+ * @param channel
9
+ * @param user
10
+ * @returns {boolean}
11
+ */
12
+ function canCreateChannelV2(channel, user = {}) {
13
+ const channelPermission = new channel_permission_1.ChannelPermission(channel);
14
+ return channelPermission.canCreateChannel(user);
15
+ }
16
+ exports.canCreateChannelV2 = canCreateChannelV2;
17
+ //# sourceMappingURL=can-create-channel-v2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-create-channel-v2.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-create-channel-v2.ts"],"names":[],"mappings":";;;AAEA,8DAA0D;AAE1D;;;;;;GAMG;AACH,SAAgB,kBAAkB,CAChC,OAAiB,EACjB,OAAiC,EAAE;IAEnC,MAAM,iBAAiB,GAAG,IAAI,sCAAiB,CAAC,OAAO,CAAC,CAAC;IACzD,OAAO,iBAAiB,CAAC,gBAAgB,CAAC,IAAwB,CAAC,CAAC;AACtE,CAAC;AAND,gDAMC"}
@@ -0,0 +1,58 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canCreateChannel = void 0;
4
+ const types_1 = require("../../types");
5
+ const platform_1 = require("../platform");
6
+ const constants_1 = require("../../../constants");
7
+ /**
8
+ * Utility to determine if User has privileges to create a channel with the defined permissions
9
+ * @deprecated replace with canCreateChannelV2 for v2 discussions
10
+ * @export
11
+ * @param channel
12
+ * @param user
13
+ * @returns {boolean}
14
+ */
15
+ function canCreateChannel(channel, user = {}) {
16
+ const { access, groups, orgs } = channel;
17
+ return isAuthorizedToCreateByLegacyPermissions(user, {
18
+ access,
19
+ groups,
20
+ orgs,
21
+ });
22
+ }
23
+ exports.canCreateChannel = canCreateChannel;
24
+ // Once ACL usage is enforced, we will remove authorization by legacy permissions
25
+ function isAuthorizedToCreateByLegacyPermissions(user, channelParams) {
26
+ const { username, groups: userGroups = [] } = user;
27
+ const { access, groups: channelGroupIds = [], orgs: channelOrgs, } = channelParams;
28
+ // ensure authenticated
29
+ if (!username) {
30
+ return false;
31
+ }
32
+ if (access === types_1.SharingAccess.PRIVATE) {
33
+ return canAllowGroupsLegacy(userGroups, channelGroupIds);
34
+ }
35
+ // public or org access
36
+ return (canAllowGroupsLegacy(userGroups, channelGroupIds) &&
37
+ isLegacyChannelOrgAdmin(user, channelOrgs));
38
+ }
39
+ function canAllowGroupsLegacy(userGroups, channelGroupIds) {
40
+ return channelGroupIds.every((channelGroupId) => {
41
+ const userGroup = userGroups.find((group) => group.id === channelGroupId);
42
+ return (userGroup &&
43
+ isMemberTypeAuthorized(userGroup) &&
44
+ isGroupDiscussable(userGroup));
45
+ });
46
+ }
47
+ function isMemberTypeAuthorized(userGroup) {
48
+ const { userMembership: { memberType }, } = userGroup;
49
+ return ["owner", "admin", "member"].includes(memberType);
50
+ }
51
+ function isGroupDiscussable(userGroup) {
52
+ const { typeKeywords = [] } = userGroup;
53
+ return !typeKeywords.includes(constants_1.CANNOT_DISCUSS);
54
+ }
55
+ function isLegacyChannelOrgAdmin(user, channelOrgs) {
56
+ return platform_1.isOrgAdmin(user) && channelOrgs.includes(user.orgId);
57
+ }
58
+ //# sourceMappingURL=can-create-channel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-create-channel.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-create-channel.ts"],"names":[],"mappings":";;;AACA,uCAAwE;AACxE,0CAAyC;AACzC,kDAAoD;AAIpD;;;;;;;GAOG;AACH,SAAgB,gBAAgB,CAC9B,OAAiB,EACjB,OAAiC,EAAE;IAEnC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,OAAO,CAAC;IAEzC,OAAO,uCAAuC,CAAC,IAAI,EAAE;QACnD,MAAM;QACN,MAAM;QACN,IAAI;KACL,CAAC,CAAC;AACL,CAAC;AAXD,4CAWC;AAED,iFAAiF;AACjF,SAAS,uCAAuC,CAC9C,IAA8B,EAC9B,aAAwC;IAExC,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,UAAU,GAAG,EAAE,EAAE,GAAG,IAAI,CAAC;IACnD,MAAM,EACJ,MAAM,EACN,MAAM,EAAE,eAAe,GAAG,EAAE,EAC5B,IAAI,EAAE,WAAW,GAClB,GAAG,aAAa,CAAC;IAElB,uBAAuB;IACvB,IAAI,CAAC,QAAQ,EAAE;QACb,OAAO,KAAK,CAAC;KACd;IAED,IAAI,MAAM,KAAK,qBAAa,CAAC,OAAO,EAAE;QACpC,OAAO,oBAAoB,CAAC,UAAU,EAAE,eAAe,CAAC,CAAC;KAC1D;IAED,uBAAuB;IACvB,OAAO,CACL,oBAAoB,CAAC,UAAU,EAAE,eAAe,CAAC;QACjD,uBAAuB,CAAC,IAAI,EAAE,WAAW,CAAC,CAC3C,CAAC;AACJ,CAAC;AAED,SAAS,oBAAoB,CAC3B,UAAoB,EACpB,eAAyB;IAEzB,OAAO,eAAe,CAAC,KAAK,CAAC,CAAC,cAAc,EAAE,EAAE;QAC9C,MAAM,SAAS,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,EAAE,KAAK,cAAc,CAAC,CAAC;QAE1E,OAAO,CACL,SAAS;YACT,sBAAsB,CAAC,SAAS,CAAC;YACjC,kBAAkB,CAAC,SAAS,CAAC,CAC9B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,sBAAsB,CAAC,SAAiB;IAC/C,MAAM,EACJ,cAAc,EAAE,EAAE,UAAU,EAAE,GAC/B,GAAG,SAAS,CAAC;IACd,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;AAC3D,CAAC;AAED,SAAS,kBAAkB,CAAC,SAAiB;IAC3C,MAAM,EAAE,YAAY,GAAG,EAAE,EAAE,GAAG,SAAS,CAAC;IACxC,OAAO,CAAC,YAAY,CAAC,QAAQ,CAAC,0BAAc,CAAC,CAAC;AAChD,CAAC;AAED,SAAS,uBAAuB,CAC9B,IAA8B,EAC9B,WAAqB;IAErB,OAAO,qBAAU,CAAC,IAAI,CAAC,IAAI,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;AAC9D,CAAC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canDeleteChannelV2 = void 0;
4
+ const channel_permission_1 = require("../channel-permission");
5
+ const portal_privilege_1 = require("../portal-privilege");
6
+ /**
7
+ * Utility to determine if User has privileges to delete a channel
8
+ * @export
9
+ * @param channel
10
+ * @param user
11
+ * @returns {boolean}
12
+ */
13
+ function canDeleteChannelV2(channel, user = {}) {
14
+ if (portal_privilege_1.hasOrgAdminDeleteRights(user, channel.orgId)) {
15
+ return true;
16
+ }
17
+ const channelPermission = new channel_permission_1.ChannelPermission(channel);
18
+ return channelPermission.canDeleteChannel(user);
19
+ }
20
+ exports.canDeleteChannelV2 = canDeleteChannelV2;
21
+ //# sourceMappingURL=can-delete-channel-v2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-delete-channel-v2.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-delete-channel-v2.ts"],"names":[],"mappings":";;;AAEA,8DAA0D;AAC1D,0DAA8D;AAE9D;;;;;;GAMG;AACH,SAAgB,kBAAkB,CAChC,OAAiB,EACjB,OAAiC,EAAE;IAEnC,IAAI,0CAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE;QAChD,OAAO,IAAI,CAAC;KACb;IAED,MAAM,iBAAiB,GAAG,IAAI,sCAAiB,CAAC,OAAO,CAAC,CAAC;IACzD,OAAO,iBAAiB,CAAC,gBAAgB,CAAC,IAAwB,CAAC,CAAC;AACtE,CAAC;AAVD,gDAUC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canDeleteChannel = void 0;
4
+ const is_authorized_to_modify_channel_by_legacy_permissions_1 = require("./is-authorized-to-modify-channel-by-legacy-permissions");
5
+ const portal_privilege_1 = require("../portal-privilege");
6
+ /**
7
+ * Utility to determine if User has privileges to delete a channel
8
+ * @deprecated replace with canDeleteChannelV2 for v2 discussions
9
+ * @export
10
+ * @param channel
11
+ * @param user
12
+ * @returns {boolean}
13
+ */
14
+ function canDeleteChannel(channel, user = {}) {
15
+ if (portal_privilege_1.hasOrgAdminDeleteRights(user, channel.orgId)) {
16
+ return true;
17
+ }
18
+ return is_authorized_to_modify_channel_by_legacy_permissions_1.isAuthorizedToModifyChannelByLegacyPermissions(user, channel);
19
+ }
20
+ exports.canDeleteChannel = canDeleteChannel;
21
+ //# sourceMappingURL=can-delete-channel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-delete-channel.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-delete-channel.ts"],"names":[],"mappings":";;;AAEA,mIAAyH;AACzH,0DAA8D;AAE9D;;;;;;;GAOG;AACH,SAAgB,gBAAgB,CAC9B,OAAiB,EACjB,OAAiC,EAAE;IAEnC,IAAI,0CAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE;QAChD,OAAO,IAAI,CAAC;KACb;IAED,OAAO,sGAA8C,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACvE,CAAC;AATD,4CASC"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canEditChannelV2 = void 0;
4
+ const channel_permission_1 = require("../channel-permission");
5
+ const portal_privilege_1 = require("../portal-privilege");
6
+ /**
7
+ * Utility to determine if User has privileges to edit a channel
8
+ * @export
9
+ * @param channel
10
+ * @param user
11
+ * @param updateData
12
+ * @returns {boolean}
13
+ */
14
+ function canEditChannelV2(channel, user = {}, updateData) {
15
+ if (portal_privilege_1.hasOrgAdminUpdateRights(user, channel.orgId)) {
16
+ return true;
17
+ }
18
+ const channelPermission = new channel_permission_1.ChannelPermission(channel);
19
+ return (channelPermission.canModerateChannel(user) &&
20
+ channelPermission.canUpdateProperties(user, updateData));
21
+ }
22
+ exports.canEditChannelV2 = canEditChannelV2;
23
+ //# sourceMappingURL=can-edit-channel-v2.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-edit-channel-v2.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-edit-channel-v2.ts"],"names":[],"mappings":";;;AAEA,8DAA0D;AAC1D,0DAA8D;AAE9D;;;;;;;GAOG;AACH,SAAgB,gBAAgB,CAC9B,OAAiB,EACjB,OAAiC,EAAE,EACnC,UAA4B;IAE5B,IAAI,0CAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE;QAChD,OAAO,IAAI,CAAC;KACb;IAED,MAAM,iBAAiB,GAAG,IAAI,sCAAiB,CAAC,OAAO,CAAC,CAAC;IACzD,OAAO,CACL,iBAAiB,CAAC,kBAAkB,CAAC,IAAwB,CAAC;QAC9D,iBAAiB,CAAC,mBAAmB,CAAC,IAAwB,EAAE,UAAU,CAAC,CAC5E,CAAC;AACJ,CAAC;AAdD,4CAcC"}
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canEditChannel = void 0;
4
+ const is_authorized_to_modify_channel_by_legacy_permissions_1 = require("./is-authorized-to-modify-channel-by-legacy-permissions");
5
+ const portal_privilege_1 = require("../portal-privilege");
6
+ /**
7
+ * Utility to determine if User has privileges to edit a channel
8
+ * @export
9
+ * @deprecated replace with canEditChannelV2 for v2 discussions
10
+ * @param channel
11
+ * @param user
12
+ * @returns {boolean}
13
+ */
14
+ function canEditChannel(channel, user = {}) {
15
+ if (portal_privilege_1.hasOrgAdminUpdateRights(user, channel.orgId)) {
16
+ return true;
17
+ }
18
+ return is_authorized_to_modify_channel_by_legacy_permissions_1.isAuthorizedToModifyChannelByLegacyPermissions(user, channel);
19
+ }
20
+ exports.canEditChannel = canEditChannel;
21
+ //# sourceMappingURL=can-edit-channel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-edit-channel.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-edit-channel.ts"],"names":[],"mappings":";;;AAEA,mIAAyH;AACzH,0DAA8D;AAE9D;;;;;;;GAOG;AACH,SAAgB,cAAc,CAC5B,OAAiB,EACjB,OAAiC,EAAE;IAEnC,IAAI,0CAAuB,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE;QAChD,OAAO,IAAI,CAAC;KACb;IAED,OAAO,sGAA8C,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACvE,CAAC;AATD,wCASC"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.canModifyChannel = void 0;
4
+ const platform_1 = require("../platform");
5
+ const is_authorized_to_modify_channel_by_legacy_permissions_1 = require("./is-authorized-to-modify-channel-by-legacy-permissions");
6
+ // NO V2 EQUIVALENT. Use canEditChannelV2 or canDeleteChannelV2
7
+ /**
8
+ * Utility to determine if User has privileges to modify a channel
9
+ * @deprecated use `canEditChannelV2` or `canDeleteChannelV2` instead.
10
+ * @export
11
+ * @param channel
12
+ * @param user
13
+ * @returns {boolean}
14
+ */
15
+ function canModifyChannel(channel, user = {}) {
16
+ if (platform_1.isOrgAdminInOrg(user, channel.orgId)) {
17
+ return true;
18
+ }
19
+ return is_authorized_to_modify_channel_by_legacy_permissions_1.isAuthorizedToModifyChannelByLegacyPermissions(user, channel);
20
+ }
21
+ exports.canModifyChannel = canModifyChannel;
22
+ //# sourceMappingURL=can-modify-channel.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"can-modify-channel.js","sourceRoot":"","sources":["../../../../../../src/discussions/api/utils/channels/can-modify-channel.ts"],"names":[],"mappings":";;;AAEA,0CAA8C;AAC9C,mIAAyH;AAEzH,+DAA+D;AAC/D;;;;;;;GAOG;AACH,SAAgB,gBAAgB,CAC9B,OAAiB,EACjB,OAAiC,EAAE;IAEnC,IAAI,0BAAe,CAAC,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE;QACxC,OAAO,IAAI,CAAC;KACb;IAED,OAAO,sGAA8C,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;AACvE,CAAC;AATD,4CASC"}