@neuralinnovations/dataisland-sdk 0.0.1-dev4 → 0.0.1-dev40

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 (353) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +271 -36
  3. package/dist/index.d.ts +3 -0
  4. package/dist/index.d.ts.map +1 -0
  5. package/dist/index.js +3 -0
  6. package/dist/index.js.map +1 -0
  7. package/dist/package.json +103 -0
  8. package/dist/src/appBuilder.d.ts +44 -0
  9. package/dist/src/appBuilder.d.ts.map +1 -0
  10. package/dist/src/appBuilder.js +10 -0
  11. package/dist/src/appBuilder.js.map +1 -0
  12. package/dist/src/commands/deleteUserFullCommandHandler.d.ts +7 -0
  13. package/dist/src/commands/deleteUserFullCommandHandler.d.ts.map +1 -0
  14. package/dist/src/commands/deleteUserFullCommandHandler.js +21 -0
  15. package/dist/src/commands/deleteUserFullCommandHandler.js.map +1 -0
  16. package/dist/src/commands/startCommandHandler.d.ts +7 -0
  17. package/dist/src/commands/startCommandHandler.d.ts.map +1 -0
  18. package/dist/src/commands/startCommandHandler.js +27 -0
  19. package/dist/src/commands/startCommandHandler.js.map +1 -0
  20. package/dist/src/context.d.ts +24 -0
  21. package/dist/src/context.d.ts.map +1 -0
  22. package/dist/src/context.js +31 -0
  23. package/dist/src/context.js.map +1 -0
  24. package/dist/src/credentials.d.ts +33 -0
  25. package/dist/src/credentials.d.ts.map +1 -0
  26. package/dist/src/credentials.js +87 -0
  27. package/dist/src/credentials.js.map +1 -0
  28. package/dist/src/dataIslandApp.d.ts +50 -0
  29. package/dist/src/dataIslandApp.d.ts.map +1 -0
  30. package/dist/src/dataIslandApp.js +10 -0
  31. package/dist/src/dataIslandApp.js.map +1 -0
  32. package/dist/src/disposable.d.ts +84 -0
  33. package/dist/src/disposable.d.ts.map +1 -0
  34. package/dist/src/disposable.js +147 -0
  35. package/dist/src/disposable.js.map +1 -0
  36. package/dist/src/dto/accessGroupResponse.d.ts +30 -0
  37. package/dist/src/dto/accessGroupResponse.d.ts.map +1 -0
  38. package/dist/src/dto/accessGroupResponse.js +3 -0
  39. package/dist/src/dto/accessGroupResponse.js.map +1 -0
  40. package/dist/src/dto/badRequestResponse.d.ts +6 -0
  41. package/dist/src/dto/badRequestResponse.d.ts.map +1 -0
  42. package/dist/src/dto/badRequestResponse.js +3 -0
  43. package/dist/src/dto/badRequestResponse.js.map +1 -0
  44. package/dist/src/dto/chatResponse.d.ts +83 -0
  45. package/dist/src/dto/chatResponse.d.ts.map +1 -0
  46. package/dist/src/dto/chatResponse.js +45 -0
  47. package/dist/src/dto/chatResponse.js.map +1 -0
  48. package/dist/src/dto/limitsResponse.d.ts +29 -0
  49. package/dist/src/dto/limitsResponse.d.ts.map +1 -0
  50. package/dist/src/dto/limitsResponse.js +13 -0
  51. package/dist/src/dto/limitsResponse.js.map +1 -0
  52. package/dist/src/dto/statisticsResponse.d.ts +11 -0
  53. package/dist/src/dto/statisticsResponse.d.ts.map +1 -0
  54. package/dist/src/dto/statisticsResponse.js +3 -0
  55. package/dist/src/dto/statisticsResponse.js.map +1 -0
  56. package/dist/src/dto/userInfoResponse.d.ts +88 -0
  57. package/dist/src/dto/userInfoResponse.d.ts.map +1 -0
  58. package/dist/src/dto/userInfoResponse.js +3 -0
  59. package/dist/src/dto/userInfoResponse.js.map +1 -0
  60. package/dist/src/dto/workspacesResponse.d.ts +45 -0
  61. package/dist/src/dto/workspacesResponse.d.ts.map +1 -0
  62. package/dist/src/dto/workspacesResponse.js +3 -0
  63. package/dist/src/dto/workspacesResponse.js.map +1 -0
  64. package/dist/src/events.d.ts +17 -0
  65. package/dist/src/events.d.ts.map +1 -0
  66. package/dist/src/events.js +52 -0
  67. package/dist/src/events.js.map +1 -0
  68. package/dist/src/index.d.ts +66 -0
  69. package/dist/src/index.d.ts.map +1 -0
  70. package/dist/src/index.js +113 -0
  71. package/dist/src/index.js.map +1 -0
  72. package/dist/src/internal/app.impl.d.ts +28 -0
  73. package/dist/src/internal/app.impl.d.ts.map +1 -0
  74. package/dist/src/internal/app.impl.js +173 -0
  75. package/dist/src/internal/app.impl.js.map +1 -0
  76. package/dist/src/internal/appBuilder.impl.d.ts +27 -0
  77. package/dist/src/internal/appBuilder.impl.d.ts.map +1 -0
  78. package/dist/src/internal/appBuilder.impl.js +71 -0
  79. package/dist/src/internal/appBuilder.impl.js.map +1 -0
  80. package/dist/src/internal/createApp.impl.d.ts +4 -0
  81. package/dist/src/internal/createApp.impl.d.ts.map +1 -0
  82. package/dist/src/internal/createApp.impl.js +11 -0
  83. package/dist/src/internal/createApp.impl.js.map +1 -0
  84. package/dist/src/internal/registry.d.ts +66 -0
  85. package/dist/src/internal/registry.d.ts.map +1 -0
  86. package/dist/src/internal/registry.js +114 -0
  87. package/dist/src/internal/registry.js.map +1 -0
  88. package/dist/src/middleware.d.ts +6 -0
  89. package/dist/src/middleware.d.ts.map +1 -0
  90. package/dist/src/middleware.js +3 -0
  91. package/dist/src/middleware.js.map +1 -0
  92. package/dist/src/services/anonymousService.d.ts +8 -0
  93. package/dist/src/services/anonymousService.d.ts.map +1 -0
  94. package/dist/src/services/anonymousService.js +41 -0
  95. package/dist/src/services/anonymousService.js.map +1 -0
  96. package/dist/src/services/commandService.d.ts +18 -0
  97. package/dist/src/services/commandService.d.ts.map +1 -0
  98. package/dist/src/services/commandService.js +40 -0
  99. package/dist/src/services/commandService.js.map +1 -0
  100. package/dist/src/services/cookieService.d.ts +7 -0
  101. package/dist/src/services/cookieService.d.ts.map +1 -0
  102. package/dist/src/services/cookieService.js +18 -0
  103. package/dist/src/services/cookieService.js.map +1 -0
  104. package/dist/src/services/credentialService.d.ts +9 -0
  105. package/dist/src/services/credentialService.d.ts.map +1 -0
  106. package/dist/src/services/credentialService.js +26 -0
  107. package/dist/src/services/credentialService.js.map +1 -0
  108. package/dist/src/services/httpMethod.d.ts +2 -0
  109. package/dist/src/services/httpMethod.d.ts.map +1 -0
  110. package/dist/src/services/httpMethod.js +3 -0
  111. package/dist/src/services/httpMethod.js.map +1 -0
  112. package/dist/src/services/middlewareService.d.ts +10 -0
  113. package/dist/src/services/middlewareService.d.ts.map +1 -0
  114. package/dist/src/services/middlewareService.js +34 -0
  115. package/dist/src/services/middlewareService.js.map +1 -0
  116. package/dist/src/services/organizationService.d.ts +10 -0
  117. package/dist/src/services/organizationService.d.ts.map +1 -0
  118. package/dist/src/services/organizationService.js +19 -0
  119. package/dist/src/services/organizationService.js.map +1 -0
  120. package/dist/src/services/requestBuilder.d.ts +17 -0
  121. package/dist/src/services/requestBuilder.d.ts.map +1 -0
  122. package/dist/src/services/requestBuilder.js +105 -0
  123. package/dist/src/services/requestBuilder.js.map +1 -0
  124. package/dist/src/services/responseUtils.d.ts +8 -0
  125. package/dist/src/services/responseUtils.d.ts.map +1 -0
  126. package/dist/src/services/responseUtils.js +40 -0
  127. package/dist/src/services/responseUtils.js.map +1 -0
  128. package/dist/src/services/rpcService.d.ts +77 -0
  129. package/dist/src/services/rpcService.d.ts.map +1 -0
  130. package/dist/src/services/rpcService.js +125 -0
  131. package/dist/src/services/rpcService.js.map +1 -0
  132. package/dist/src/services/service.d.ts +21 -0
  133. package/dist/src/services/service.d.ts.map +1 -0
  134. package/dist/src/services/service.js +41 -0
  135. package/dist/src/services/service.js.map +1 -0
  136. package/dist/src/services/userProfileService.d.ts +9 -0
  137. package/dist/src/services/userProfileService.d.ts.map +1 -0
  138. package/dist/src/services/userProfileService.js +43 -0
  139. package/dist/src/services/userProfileService.js.map +1 -0
  140. package/dist/src/storages/chats/answer.d.ts +41 -0
  141. package/dist/src/storages/chats/answer.d.ts.map +1 -0
  142. package/dist/src/storages/chats/answer.impl.d.ts +29 -0
  143. package/dist/src/storages/chats/answer.impl.d.ts.map +1 -0
  144. package/dist/src/storages/chats/answer.impl.js +116 -0
  145. package/dist/src/storages/chats/answer.impl.js.map +1 -0
  146. package/dist/src/storages/chats/answer.js +15 -0
  147. package/dist/src/storages/chats/answer.js.map +1 -0
  148. package/dist/src/storages/chats/chat.d.ts +43 -0
  149. package/dist/src/storages/chats/chat.d.ts.map +1 -0
  150. package/dist/src/storages/chats/chat.impl.d.ts +25 -0
  151. package/dist/src/storages/chats/chat.impl.d.ts.map +1 -0
  152. package/dist/src/storages/chats/chat.impl.js +85 -0
  153. package/dist/src/storages/chats/chat.impl.js.map +1 -0
  154. package/dist/src/storages/chats/chat.js +12 -0
  155. package/dist/src/storages/chats/chat.js.map +1 -0
  156. package/dist/src/storages/chats/chats.d.ts +45 -0
  157. package/dist/src/storages/chats/chats.d.ts.map +1 -0
  158. package/dist/src/storages/chats/chats.impl.d.ts +19 -0
  159. package/dist/src/storages/chats/chats.impl.d.ts.map +1 -0
  160. package/dist/src/storages/chats/chats.impl.js +147 -0
  161. package/dist/src/storages/chats/chats.impl.js.map +1 -0
  162. package/dist/src/storages/chats/chats.js +16 -0
  163. package/dist/src/storages/chats/chats.js.map +1 -0
  164. package/dist/src/storages/files/file.d.ts +47 -0
  165. package/dist/src/storages/files/file.d.ts.map +1 -0
  166. package/dist/src/storages/files/file.impl.d.ts +25 -0
  167. package/dist/src/storages/files/file.impl.d.ts.map +1 -0
  168. package/dist/src/storages/files/file.impl.js +93 -0
  169. package/dist/src/storages/files/file.impl.js.map +1 -0
  170. package/dist/src/storages/files/file.js +17 -0
  171. package/dist/src/storages/files/file.js.map +1 -0
  172. package/dist/src/storages/files/files.d.ts +39 -0
  173. package/dist/src/storages/files/files.d.ts.map +1 -0
  174. package/dist/src/storages/files/files.impl.d.ts +24 -0
  175. package/dist/src/storages/files/files.impl.d.ts.map +1 -0
  176. package/dist/src/storages/files/files.impl.js +168 -0
  177. package/dist/src/storages/files/files.impl.js.map +1 -0
  178. package/dist/src/storages/files/files.js +20 -0
  179. package/dist/src/storages/files/files.js.map +1 -0
  180. package/dist/src/storages/files/filesPage.d.ts +28 -0
  181. package/dist/src/storages/files/filesPage.d.ts.map +1 -0
  182. package/dist/src/storages/files/filesPage.impl.d.ts +15 -0
  183. package/dist/src/storages/files/filesPage.impl.d.ts.map +1 -0
  184. package/dist/src/storages/files/filesPage.impl.js +38 -0
  185. package/dist/src/storages/files/filesPage.impl.js.map +1 -0
  186. package/dist/src/storages/files/filesPage.js +10 -0
  187. package/dist/src/storages/files/filesPage.js.map +1 -0
  188. package/dist/src/storages/groups/group.d.ts +63 -0
  189. package/dist/src/storages/groups/group.d.ts.map +1 -0
  190. package/dist/src/storages/groups/group.impl.d.ts +38 -0
  191. package/dist/src/storages/groups/group.impl.d.ts.map +1 -0
  192. package/dist/src/storages/groups/group.impl.js +210 -0
  193. package/dist/src/storages/groups/group.impl.js.map +1 -0
  194. package/dist/src/storages/groups/group.js +15 -0
  195. package/dist/src/storages/groups/group.js.map +1 -0
  196. package/dist/src/storages/groups/groups.d.ts +39 -0
  197. package/dist/src/storages/groups/groups.d.ts.map +1 -0
  198. package/dist/src/storages/groups/groups.impl.d.ts +30 -0
  199. package/dist/src/storages/groups/groups.impl.d.ts.map +1 -0
  200. package/dist/src/storages/groups/groups.impl.js +132 -0
  201. package/dist/src/storages/groups/groups.impl.js.map +1 -0
  202. package/dist/src/storages/groups/groups.js +20 -0
  203. package/dist/src/storages/groups/groups.js.map +1 -0
  204. package/dist/src/storages/organizations/organization.d.ts +95 -0
  205. package/dist/src/storages/organizations/organization.d.ts.map +1 -0
  206. package/dist/src/storages/organizations/organization.impl.d.ts +42 -0
  207. package/dist/src/storages/organizations/organization.impl.d.ts.map +1 -0
  208. package/dist/src/storages/organizations/organization.impl.js +240 -0
  209. package/dist/src/storages/organizations/organization.impl.js.map +1 -0
  210. package/dist/src/storages/organizations/organization.js +18 -0
  211. package/dist/src/storages/organizations/organization.js.map +1 -0
  212. package/dist/src/storages/organizations/organizations.d.ts +46 -0
  213. package/dist/src/storages/organizations/organizations.d.ts.map +1 -0
  214. package/dist/src/storages/organizations/organizations.impl.d.ts +38 -0
  215. package/dist/src/storages/organizations/organizations.impl.d.ts.map +1 -0
  216. package/dist/src/storages/organizations/organizations.impl.js +158 -0
  217. package/dist/src/storages/organizations/organizations.impl.js.map +1 -0
  218. package/dist/src/storages/organizations/organizations.js +20 -0
  219. package/dist/src/storages/organizations/organizations.js.map +1 -0
  220. package/dist/src/storages/user/userProfile.d.ts +54 -0
  221. package/dist/src/storages/user/userProfile.d.ts.map +1 -0
  222. package/dist/src/storages/user/userProfile.impl.d.ts +21 -0
  223. package/dist/src/storages/user/userProfile.impl.d.ts.map +1 -0
  224. package/dist/src/storages/user/userProfile.impl.js +114 -0
  225. package/dist/src/storages/user/userProfile.impl.js.map +1 -0
  226. package/dist/src/storages/user/userProfile.js +12 -0
  227. package/dist/src/storages/user/userProfile.js.map +1 -0
  228. package/dist/src/storages/workspaces/workspace.d.ts +44 -0
  229. package/dist/src/storages/workspaces/workspace.d.ts.map +1 -0
  230. package/dist/src/storages/workspaces/workspace.impl.d.ts +23 -0
  231. package/dist/src/storages/workspaces/workspace.impl.d.ts.map +1 -0
  232. package/dist/src/storages/workspaces/workspace.impl.js +98 -0
  233. package/dist/src/storages/workspaces/workspace.impl.js.map +1 -0
  234. package/dist/src/storages/workspaces/workspace.js +18 -0
  235. package/dist/src/storages/workspaces/workspace.js.map +1 -0
  236. package/dist/src/storages/workspaces/workspaces.d.ts +47 -0
  237. package/dist/src/storages/workspaces/workspaces.d.ts.map +1 -0
  238. package/dist/src/storages/workspaces/workspaces.impl.d.ts +33 -0
  239. package/dist/src/storages/workspaces/workspaces.impl.d.ts.map +1 -0
  240. package/dist/src/storages/workspaces/workspaces.impl.js +152 -0
  241. package/dist/src/storages/workspaces/workspaces.impl.js.map +1 -0
  242. package/dist/src/storages/workspaces/workspaces.js +19 -0
  243. package/dist/src/storages/workspaces/workspaces.js.map +1 -0
  244. package/dist/src/unitTest.d.ts +12 -0
  245. package/dist/src/unitTest.d.ts.map +1 -0
  246. package/dist/src/unitTest.js +44 -0
  247. package/dist/src/unitTest.js.map +1 -0
  248. package/dist/src/utils/browserUtils.d.ts +4 -0
  249. package/dist/src/utils/browserUtils.d.ts.map +1 -0
  250. package/dist/src/utils/browserUtils.js +64 -0
  251. package/dist/src/utils/browserUtils.js.map +1 -0
  252. package/dist/src/utils/request.d.ts +6 -0
  253. package/dist/src/utils/request.d.ts.map +1 -0
  254. package/dist/src/utils/request.js +3 -0
  255. package/dist/src/utils/request.js.map +1 -0
  256. package/dist/src/utils/utils.d.ts +3 -0
  257. package/dist/src/utils/utils.d.ts.map +1 -0
  258. package/dist/src/utils/utils.js +13 -0
  259. package/dist/src/utils/utils.js.map +1 -0
  260. package/index.d.ts +1 -0
  261. package/index.js +1 -0
  262. package/package.json +46 -5
  263. package/src/commands/deleteUserFullCommandHandler.ts +19 -0
  264. package/src/commands/startCommandHandler.ts +16 -5
  265. package/src/context.ts +4 -2
  266. package/src/credentials.ts +22 -0
  267. package/src/{appSdk.ts → dataIslandApp.ts} +3 -3
  268. package/src/disposable.ts +18 -5
  269. package/src/dto/accessGroupResponse.ts +19 -16
  270. package/src/dto/badRequestResponse.ts +6 -0
  271. package/src/dto/chatResponse.ts +59 -54
  272. package/src/dto/limitsResponse.ts +33 -0
  273. package/src/dto/statisticsResponse.ts +12 -0
  274. package/src/dto/userInfoResponse.ts +59 -2
  275. package/src/dto/workspacesResponse.ts +5 -3
  276. package/src/index.ts +46 -24
  277. package/src/internal/app.impl.ts +42 -9
  278. package/src/internal/createApp.impl.ts +4 -4
  279. package/src/internal/registry.ts +54 -6
  280. package/src/middleware.ts +2 -0
  281. package/src/services/anonymousService.ts +43 -0
  282. package/src/services/commandService.ts +4 -2
  283. package/src/services/cookieService.ts +16 -0
  284. package/src/services/httpMethod.ts +1 -0
  285. package/src/services/middlewareService.ts +1 -0
  286. package/src/services/organizationService.ts +2 -2
  287. package/src/services/requestBuilder.ts +10 -8
  288. package/src/services/responseUtils.ts +12 -0
  289. package/src/services/rpcService.ts +1 -0
  290. package/src/services/userProfileService.ts +18 -4
  291. package/src/storages/chats/answer.impl.ts +160 -0
  292. package/src/storages/chats/answer.ts +53 -0
  293. package/src/storages/chats/chat.impl.ts +107 -0
  294. package/src/storages/chats/chat.ts +55 -0
  295. package/src/storages/chats/chats.impl.ts +204 -0
  296. package/src/storages/chats/chats.ts +53 -0
  297. package/src/storages/files/file.impl.ts +111 -0
  298. package/src/storages/files/file.ts +58 -0
  299. package/src/storages/{files.impl.ts → files/files.impl.ts} +67 -46
  300. package/src/storages/{files.ts → files/files.ts} +14 -7
  301. package/src/storages/files/filesPage.impl.ts +37 -0
  302. package/src/storages/{filesPage.ts → files/filesPage.ts} +6 -0
  303. package/src/storages/groups/group.impl.ts +276 -0
  304. package/src/storages/groups/group.ts +73 -0
  305. package/src/storages/groups/groups.impl.ts +175 -0
  306. package/src/storages/groups/groups.ts +45 -0
  307. package/src/storages/organizations/organization.impl.ts +357 -0
  308. package/src/storages/organizations/organization.ts +118 -0
  309. package/src/storages/{organizations.impl.ts → organizations/organizations.impl.ts} +31 -13
  310. package/src/storages/{organizations.ts → organizations/organizations.ts} +1 -1
  311. package/src/storages/user/userProfile.impl.ts +136 -0
  312. package/src/storages/user/userProfile.ts +69 -0
  313. package/src/storages/{workspace.impl.ts → workspaces/workspace.impl.ts} +27 -7
  314. package/src/storages/{workspace.ts → workspaces/workspace.ts} +8 -3
  315. package/src/storages/{workspaces.impl.ts → workspaces/workspaces.impl.ts} +27 -32
  316. package/src/storages/{workspaces.ts → workspaces/workspaces.ts} +6 -2
  317. package/src/unitTest.ts +14 -3
  318. package/src/utils/browserUtils.ts +68 -0
  319. package/src/utils/request.ts +6 -0
  320. package/src/utils/utils.ts +8 -0
  321. package/.browserslistrc +0 -5
  322. package/.editorconfig +0 -25
  323. package/.eslintrc.json +0 -44
  324. package/.github/workflows/publish-npm.yml +0 -28
  325. package/.prettierignore +0 -1
  326. package/.prettierrc +0 -11
  327. package/.yarnrc +0 -2
  328. package/babel.config.js +0 -6
  329. package/jest.config.ts +0 -199
  330. package/jest.setup.ts +0 -2
  331. package/src/storages/chat.ts +0 -21
  332. package/src/storages/chats.ts +0 -17
  333. package/src/storages/file.impl.ts +0 -69
  334. package/src/storages/file.ts +0 -28
  335. package/src/storages/groups.impl.ts +0 -337
  336. package/src/storages/groups.ts +0 -43
  337. package/src/storages/organization.impl.ts +0 -68
  338. package/src/storages/organization.ts +0 -33
  339. package/src/storages/userProfile.impl.ts +0 -56
  340. package/src/storages/userProfile.ts +0 -42
  341. package/test/commands.test.ts +0 -24
  342. package/test/data/test_file.pdf +0 -0
  343. package/test/disposable.test.ts +0 -39
  344. package/test/events.test.ts +0 -151
  345. package/test/files.test.ts +0 -52
  346. package/test/index.test.ts +0 -122
  347. package/test/organization.test.ts +0 -57
  348. package/test/registry.test.ts +0 -44
  349. package/test/services.test.ts +0 -56
  350. package/test/setup.ts +0 -54
  351. package/test/unitTest.test.ts +0 -21
  352. package/test/workspace.test.ts +0 -71
  353. package/tsconfig.json +0 -31
@@ -0,0 +1,276 @@
1
+ import { Group, GroupEvent, GroupId } from "./group"
2
+ import { Disposable } from "../../disposable"
3
+ import {
4
+ AccessGroupDto,
5
+ AccessGroupResponse
6
+ } from "../../dto/accessGroupResponse"
7
+ import { UserDto } from "../../dto/userInfoResponse"
8
+ import { Workspace } from "../workspaces/workspace"
9
+ import { Context } from "../../context"
10
+ import { Organization } from "../organizations/organization"
11
+ import { RpcService } from "../../services/rpcService"
12
+ import { ResponseUtils } from "../../services/responseUtils"
13
+ import { WorkspacesResponse } from "../../dto/workspacesResponse"
14
+ import { WorkspaceId } from "../workspaces/workspaces"
15
+ import { UserId } from "../user/userProfile"
16
+
17
+ export class GroupImpl extends Group implements Disposable {
18
+ private _isDisposed: boolean = false
19
+ private _content?: AccessGroupDto
20
+ private _members?: UserDto[]
21
+ private _workspaces: Workspace[] = []
22
+ private _id?: GroupId
23
+
24
+ constructor(
25
+ private readonly context: Context,
26
+ public readonly organization: Organization
27
+ ) {
28
+ super()
29
+ }
30
+
31
+ async initFrom(id: GroupId): Promise<Group> {
32
+ // set id
33
+ this._id = id
34
+
35
+ // reload group and workspaces
36
+ const groupPromise = this.reloadGroup(id)
37
+ const workspacePromise = this.reloadWorkspaces(id)
38
+
39
+ // wait for all promises
40
+ await Promise.all([groupPromise, workspacePromise])
41
+
42
+ return this
43
+ }
44
+
45
+ async reloadGroup(id: GroupId): Promise<void> {
46
+ // fetch group
47
+ const response = await this.context.resolve(RpcService)
48
+ ?.requestBuilder("api/v1/AccessGroups")
49
+ .searchParam("groupId", id)
50
+ .sendGet()
51
+
52
+ // check response status
53
+ if (ResponseUtils.isFail(response)) {
54
+ await ResponseUtils.throwError(`Failed to get group: ${id}, organization: ${this.organization.id}`, response)
55
+ }
56
+
57
+ // parse group from the server's response
58
+ const group = (await response!.json()) as AccessGroupResponse
59
+ // init group
60
+ this._content = group.group
61
+ this._members = group.members
62
+ }
63
+
64
+ async reloadWorkspaces(id: GroupId): Promise<void> {
65
+ const groupWorkspaces = await this.loadWorkspaces(id)
66
+ this._workspaces.length = 0
67
+ this._workspaces.push(...groupWorkspaces)
68
+ }
69
+
70
+ async loadWorkspaces(groupId: GroupId): Promise<Workspace[]> {
71
+ // fetch workspaces
72
+ const response = await this.context.resolve(RpcService)
73
+ ?.requestBuilder("api/v1/AccessGroups/workspaces")
74
+ .searchParam("groupId", groupId)
75
+ .sendGet()
76
+
77
+ if (ResponseUtils.isFail(response)) {
78
+ await ResponseUtils.throwError(`Failed to get workspaces for group: ${this.id}, organization: ${this.organization.id}`, response)
79
+ }
80
+
81
+ // parse workspaces from the server's response
82
+ const workspaces = (await response!.json()) as WorkspacesResponse
83
+
84
+ // get workspaces
85
+ const result: Workspace[] = []
86
+ for (const workspaceDto of workspaces.workspaces) {
87
+ result.push(this.organization.workspaces.get(workspaceDto.id))
88
+ }
89
+
90
+ return result
91
+ }
92
+
93
+ get id(): GroupId {
94
+ if (this._id) {
95
+ return this._id
96
+ }
97
+ throw new Error("Access group is not loaded.")
98
+ }
99
+
100
+ get group(): AccessGroupDto {
101
+ if (this._content) {
102
+ return this._content
103
+ }
104
+ throw new Error("Access group is not loaded.")
105
+ }
106
+
107
+ get workspaces(): readonly Workspace[] {
108
+ return this._workspaces
109
+ }
110
+
111
+ get members(): UserDto[] {
112
+ if (this._members) {
113
+ return this._members
114
+ }
115
+ throw new Error("Access group is not loaded.")
116
+ }
117
+
118
+ async setName(name: string): Promise<void> {
119
+ if (name === undefined || name === null) {
120
+ throw new Error("Groups change, name is undefined or null")
121
+ }
122
+ if (name.length === 0 || name.trim().length === 0) {
123
+ throw new Error("Groups change, name is empty")
124
+ }
125
+ // send request to the server
126
+ const response = await this.context
127
+ .resolve(RpcService)
128
+ ?.requestBuilder("api/v1/AccessGroups/name")
129
+ .sendPutJson({
130
+ groupId: this.id,
131
+ name: name
132
+ })
133
+
134
+ // check response status
135
+ if (ResponseUtils.isFail(response)) {
136
+ await ResponseUtils.throwError(`Failed to change group name, group: ${this.id}, organization: ${this.organization.id}`, response)
137
+ }
138
+
139
+ // change name
140
+ if (this._content) {
141
+ this._content.name = name
142
+ }
143
+
144
+ // dispatch event
145
+ this.dispatch({
146
+ type: GroupEvent.UPDATED,
147
+ data: this
148
+ })
149
+ }
150
+
151
+ async setPermits(permits: { isAdmin: boolean }): Promise<void> {
152
+ // send request to the server
153
+ const response = await this.context
154
+ .resolve(RpcService)
155
+ ?.requestBuilder("api/v1/AccessGroups/permits")
156
+ .sendPutJson({
157
+ groupId: this.id,
158
+ permits: permits
159
+ })
160
+
161
+ if (ResponseUtils.isFail(response)) {
162
+ await ResponseUtils.throwError(`Failed to change group permits, group: ${this.id}, organization: ${this.organization.id}`, response)
163
+ }
164
+ }
165
+
166
+ async setWorkspaces(workspaces: string[]): Promise<void> {
167
+ if (workspaces === null || workspaces === undefined) {
168
+ throw new Error("Group add workspaces, workspaces is undefined or null")
169
+ }
170
+
171
+ // send request to the server
172
+ const response = await this.context
173
+ .resolve(RpcService)
174
+ ?.requestBuilder("api/v1/AccessGroups/workspaces")
175
+ .sendPutJson({
176
+ groupId: this.id,
177
+ actualWorkspaceIds: workspaces
178
+ })
179
+
180
+ if (ResponseUtils.isFail(response)) {
181
+ await ResponseUtils.throwError(`Failed to set workspaces for group: ${this.id}, organization: ${this.organization.id}`, response)
182
+ }
183
+
184
+ // reload workspaces
185
+ await this.reloadWorkspaces(this.id)
186
+
187
+ // dispatch event
188
+ this.dispatch({
189
+ type: GroupEvent.UPDATED,
190
+ data: this
191
+ })
192
+ }
193
+
194
+ async removeWorkspaces(workspaces: WorkspaceId[]): Promise<void> {
195
+ if (workspaces === null || workspaces === undefined) {
196
+ throw new Error("Group removeWorkspaces, workspaces is undefined or null")
197
+ }
198
+
199
+ // make set of workspaces
200
+ const groupWorkspaces = new Set(this.workspaces.map(w => w.id))
201
+
202
+ // check argument
203
+ if (!workspaces.every(w => groupWorkspaces.has(w))) {
204
+ const notExistingWorkspaces = workspaces.filter(workspaceId => !groupWorkspaces.has(workspaceId))
205
+ throw new Error(`Group removeWorkspaces, workspaces contains not existing workspaces: ${notExistingWorkspaces}`)
206
+ }
207
+
208
+ // remove workspaces
209
+ for (const id of workspaces) {
210
+ groupWorkspaces.delete(id)
211
+ }
212
+
213
+ // send request to the server
214
+ await this.setWorkspaces(Array.from(groupWorkspaces))
215
+ }
216
+
217
+ async setMembersIds(members: UserId[]) {
218
+ if (members === null || members === undefined) {
219
+ throw new Error("Group setMembersIds, members is undefined or null")
220
+ }
221
+
222
+ // send request to the server
223
+ const response = await this.context
224
+ .resolve(RpcService)
225
+ ?.requestBuilder("api/v1/AccessGroups/members")
226
+ .sendPutJson({
227
+ groupId: this.id,
228
+ memberIds: members
229
+ })
230
+
231
+ if (ResponseUtils.isFail(response)) {
232
+ await ResponseUtils.throwError(`Failed to set members for group: ${this.id}, organization: ${this.organization.id}`, response)
233
+ }
234
+
235
+ // reload group
236
+ await this.reloadGroup(this.id)
237
+
238
+ // dispatch event
239
+ this.dispatch({
240
+ type: GroupEvent.UPDATED,
241
+ data: this
242
+ })
243
+ }
244
+
245
+ async removeMembers(members: UserId[]): Promise<void> {
246
+ // check members
247
+ if (members === null || members === undefined) {
248
+ throw new Error("Group removeMembers, members is undefined or null")
249
+ }
250
+
251
+ // make set of members
252
+ const groupMembers = new Set(this.members.map(m => m.id))
253
+
254
+ // check argument
255
+ if (!members.every(m => groupMembers.has(m))) {
256
+ const notExistingMembers = members.filter(memberId => !groupMembers.has(memberId))
257
+ throw new Error(`Group removeMembers, members contains not existing members: ${notExistingMembers}`)
258
+ }
259
+
260
+ // remove members
261
+ for (const id of members) {
262
+ groupMembers.delete(id)
263
+ }
264
+
265
+ // send request to the server
266
+ await this.setMembersIds(Array.from(groupMembers))
267
+ }
268
+
269
+ get isDisposed(): boolean {
270
+ return this._isDisposed
271
+ }
272
+
273
+ dispose(): void {
274
+ this._isDisposed = true
275
+ }
276
+ }
@@ -0,0 +1,73 @@
1
+ import { EventDispatcher } from "../../events"
2
+ import { AccessGroupDto } from "../../dto/accessGroupResponse"
3
+ import { UserDto } from "../../dto/userInfoResponse"
4
+ import { Workspace } from "../workspaces/workspace"
5
+ import { WorkspaceId } from "../workspaces/workspaces"
6
+ import { UserId } from "../user/userProfile"
7
+
8
+ /**
9
+ * Group id.
10
+ */
11
+ export type GroupId = string
12
+
13
+ export enum GroupEvent {
14
+ UPDATED = "updated"
15
+ }
16
+
17
+ /**
18
+ * Group.
19
+ */
20
+ export abstract class Group extends EventDispatcher<GroupEvent, Group> {
21
+
22
+ /**
23
+ * Group id.
24
+ */
25
+ abstract get id(): GroupId
26
+
27
+ /**
28
+ * Group information.
29
+ */
30
+ abstract get group(): AccessGroupDto
31
+
32
+ /**
33
+ * Group members.
34
+ */
35
+ abstract get members(): UserDto[]
36
+
37
+ /**
38
+ * Group workspaces.
39
+ */
40
+ abstract get workspaces(): readonly Workspace[]
41
+
42
+ /**
43
+ * Set workspaces.
44
+ */
45
+ abstract setWorkspaces(workspaces: WorkspaceId[]): Promise<void>
46
+
47
+ /**
48
+ * Set name.
49
+ */
50
+ abstract setName(name: string): Promise<void>
51
+
52
+ /**
53
+ * Set permits.
54
+ */
55
+ abstract setPermits(permits: { isAdmin: boolean }): Promise<void>
56
+
57
+ /**
58
+ * Set members.
59
+ */
60
+ abstract setMembersIds(members: UserId[]): Promise<void>
61
+
62
+ /**
63
+ * Remove members.
64
+ * @param members
65
+ */
66
+ abstract removeMembers(members: UserId[]): Promise<void>
67
+
68
+ /**
69
+ * Remove workspaces.
70
+ * @param workspaces
71
+ */
72
+ abstract removeWorkspaces(workspaces: WorkspaceId[]): Promise<void>
73
+ }
@@ -0,0 +1,175 @@
1
+ import { Context } from "../../context"
2
+ import {
3
+ AccessGroupResponse,
4
+ AccessGroupsResponse
5
+ } from "../../dto/accessGroupResponse"
6
+ import { RpcService } from "../../services/rpcService"
7
+ import { Groups, GroupsEvent } from "./groups"
8
+ import { OrganizationImpl } from "../organizations/organization.impl"
9
+ import { ResponseUtils } from "../../services/responseUtils"
10
+ import { Group, GroupId } from "./group"
11
+ import { GroupImpl } from "./group.impl"
12
+
13
+ export class GroupsImpl extends Groups {
14
+
15
+ private _groups: Group[] = []
16
+
17
+ constructor(
18
+ public readonly organization: OrganizationImpl,
19
+ private readonly context: Context
20
+ ) {
21
+ super()
22
+ }
23
+
24
+ get collection(): readonly Group[] {
25
+ return this._groups
26
+ }
27
+
28
+ async initialize() {
29
+ await this.internalInit()
30
+ }
31
+
32
+ async create(name: string, permits: {
33
+ isAdmin: boolean
34
+ }, memberIds: string[]): Promise<Group> {
35
+ return await this.internalCreate(name, permits, memberIds)
36
+ }
37
+
38
+ get(id: GroupId): Group | undefined {
39
+ return this._groups.find(group => group.id === id)
40
+ }
41
+
42
+ async delete(id: GroupId): Promise<void> {
43
+ return await this.internalDeleteGroup(id)
44
+ }
45
+
46
+ //----------------------------------------------------------------------------
47
+ // INTERNALS
48
+ //----------------------------------------------------------------------------
49
+
50
+ /**
51
+ * Init access groups.
52
+ */
53
+ async internalInit(): Promise<void> {
54
+ // fetch groups
55
+ const response = await this.context.resolve(RpcService)
56
+ ?.requestBuilder("api/v1/Organizations/access_groups")
57
+ .searchParam("id", this.organization.id)
58
+ .sendGet()
59
+
60
+ // check response status
61
+ if (ResponseUtils.isFail(response)) {
62
+ await ResponseUtils.throwError(`Failed to get groups for organization: ${this.organization.id}`, response)
63
+ }
64
+
65
+ // parse groups from the server's response
66
+ const groups = (await response!.json()) as AccessGroupsResponse
67
+
68
+ const wait: Promise<Group>[] = []
69
+
70
+ // init groups
71
+ for (const gr of groups.groups) {
72
+ // create group implementation
73
+ const group = new GroupImpl(this.context, this.organization).initFrom(gr.id)
74
+
75
+ // add to the wait list
76
+ wait.push(group)
77
+ }
78
+
79
+ // wait for all groups
80
+ const groupsResult = await Promise.all(wait)
81
+
82
+ // add groups to the collection
83
+ for (const group of groupsResult) {
84
+ // add group to the collection
85
+ this._groups.push(group)
86
+ }
87
+ }
88
+
89
+ async internalCreate(name: string, permits: {
90
+ isAdmin: boolean
91
+ }, memberIds: string[]): Promise<Group> {
92
+ if (name === undefined || name === null) {
93
+ throw new Error("Group create, name is undefined or null")
94
+ }
95
+ if (name.length === 0 || name.trim().length === 0) {
96
+ throw new Error("Group create, name is empty")
97
+ }
98
+
99
+ // send request to the server
100
+ const response = await this.context
101
+ .resolve(RpcService)
102
+ ?.requestBuilder("api/v1/AccessGroups")
103
+ .sendPostJson({
104
+ name: name,
105
+ organizationId: this.organization.id,
106
+ permits: permits,
107
+ memberIds: memberIds
108
+ })
109
+
110
+ // check response status
111
+ if (ResponseUtils.isFail(response)) {
112
+ await ResponseUtils.throwError(`Failed to create group, organization: ${this.organization.id}`, response)
113
+ }
114
+ // parse group from the server's response
115
+ const content = (await response!.json()) as AccessGroupResponse
116
+
117
+ // create group implementation
118
+ const group = await new GroupImpl(this.context, this.organization).initFrom(content.group.id)
119
+
120
+ // add group to the collection
121
+ this._groups.push(group)
122
+
123
+ // dispatch event
124
+ this.dispatch({
125
+ type: GroupsEvent.ADDED,
126
+ data: group
127
+ })
128
+
129
+ return group
130
+ }
131
+
132
+ /**
133
+ * Delete group.
134
+ * @param id
135
+ */
136
+ async internalDeleteGroup(id: GroupId): Promise<void> {
137
+ if (id === undefined || id === null) {
138
+ throw new Error("Group delete, id is undefined or null")
139
+ }
140
+ if (id.length === 0 || id.trim().length === 0) {
141
+ throw new Error("Group delete, id is empty")
142
+ }
143
+
144
+ // send request to the server
145
+ const response = await this.context
146
+ .resolve(RpcService)
147
+ ?.requestBuilder("/api/v1/AccessGroups")
148
+ .searchParam("groupId", id)
149
+ .sendDelete()
150
+
151
+ // check response status
152
+ if (ResponseUtils.isFail(response)) {
153
+ await ResponseUtils.throwError(`Failed to delete group: ${id}, organization: ${this.organization.id}`, response)
154
+ }
155
+
156
+ // delete group from collection
157
+ const group = <GroupImpl>this._groups.find(f => f.id === id)
158
+ const index = this._groups.indexOf(group)
159
+ if (index < 0) {
160
+ throw new Error("Group delete, index is not found")
161
+ }
162
+
163
+ // remove group from collection
164
+ this._groups.splice(index, 1)
165
+
166
+ // dispatch event, group removed
167
+ this.dispatch({
168
+ type: GroupsEvent.REMOVED,
169
+ data: group
170
+ })
171
+
172
+ // dispose group
173
+ group.dispose()
174
+ }
175
+ }
@@ -0,0 +1,45 @@
1
+ import { EventDispatcher } from "../../events"
2
+ import { Group, GroupId } from "./group"
3
+
4
+ /**
5
+ * Group event.
6
+ */
7
+ export enum GroupsEvent {
8
+ ADDED = "added",
9
+ REMOVED = "removed",
10
+ UPDATED = "updated"
11
+ }
12
+
13
+ /**
14
+ * Groups storage.
15
+ */
16
+ export abstract class Groups extends EventDispatcher<GroupsEvent, Group> {
17
+
18
+ /**
19
+ * Collection.
20
+ */
21
+ abstract get collection(): ReadonlyArray<Group>
22
+
23
+ /**
24
+ * Create new group.
25
+ * @param name
26
+ * @param permits
27
+ * @param memberIds
28
+ */
29
+ abstract create(name: string, permits: {
30
+ isAdmin: boolean
31
+ }, memberIds: string[]): Promise<Group>
32
+
33
+ /**
34
+ * Get group by id.
35
+ * @param id
36
+ */
37
+ abstract get(id: GroupId): Group | undefined
38
+
39
+ /**
40
+ * delete group by id.
41
+ * @param id
42
+ */
43
+ abstract delete(id: GroupId): Promise<void>
44
+
45
+ }