@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.
- package/LICENSE +201 -0
- package/README.md +271 -36
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -0
- package/dist/package.json +103 -0
- package/dist/src/appBuilder.d.ts +44 -0
- package/dist/src/appBuilder.d.ts.map +1 -0
- package/dist/src/appBuilder.js +10 -0
- package/dist/src/appBuilder.js.map +1 -0
- package/dist/src/commands/deleteUserFullCommandHandler.d.ts +7 -0
- package/dist/src/commands/deleteUserFullCommandHandler.d.ts.map +1 -0
- package/dist/src/commands/deleteUserFullCommandHandler.js +21 -0
- package/dist/src/commands/deleteUserFullCommandHandler.js.map +1 -0
- package/dist/src/commands/startCommandHandler.d.ts +7 -0
- package/dist/src/commands/startCommandHandler.d.ts.map +1 -0
- package/dist/src/commands/startCommandHandler.js +27 -0
- package/dist/src/commands/startCommandHandler.js.map +1 -0
- package/dist/src/context.d.ts +24 -0
- package/dist/src/context.d.ts.map +1 -0
- package/dist/src/context.js +31 -0
- package/dist/src/context.js.map +1 -0
- package/dist/src/credentials.d.ts +33 -0
- package/dist/src/credentials.d.ts.map +1 -0
- package/dist/src/credentials.js +87 -0
- package/dist/src/credentials.js.map +1 -0
- package/dist/src/dataIslandApp.d.ts +50 -0
- package/dist/src/dataIslandApp.d.ts.map +1 -0
- package/dist/src/dataIslandApp.js +10 -0
- package/dist/src/dataIslandApp.js.map +1 -0
- package/dist/src/disposable.d.ts +84 -0
- package/dist/src/disposable.d.ts.map +1 -0
- package/dist/src/disposable.js +147 -0
- package/dist/src/disposable.js.map +1 -0
- package/dist/src/dto/accessGroupResponse.d.ts +30 -0
- package/dist/src/dto/accessGroupResponse.d.ts.map +1 -0
- package/dist/src/dto/accessGroupResponse.js +3 -0
- package/dist/src/dto/accessGroupResponse.js.map +1 -0
- package/dist/src/dto/badRequestResponse.d.ts +6 -0
- package/dist/src/dto/badRequestResponse.d.ts.map +1 -0
- package/dist/src/dto/badRequestResponse.js +3 -0
- package/dist/src/dto/badRequestResponse.js.map +1 -0
- package/dist/src/dto/chatResponse.d.ts +83 -0
- package/dist/src/dto/chatResponse.d.ts.map +1 -0
- package/dist/src/dto/chatResponse.js +45 -0
- package/dist/src/dto/chatResponse.js.map +1 -0
- package/dist/src/dto/limitsResponse.d.ts +29 -0
- package/dist/src/dto/limitsResponse.d.ts.map +1 -0
- package/dist/src/dto/limitsResponse.js +13 -0
- package/dist/src/dto/limitsResponse.js.map +1 -0
- package/dist/src/dto/statisticsResponse.d.ts +11 -0
- package/dist/src/dto/statisticsResponse.d.ts.map +1 -0
- package/dist/src/dto/statisticsResponse.js +3 -0
- package/dist/src/dto/statisticsResponse.js.map +1 -0
- package/dist/src/dto/userInfoResponse.d.ts +88 -0
- package/dist/src/dto/userInfoResponse.d.ts.map +1 -0
- package/dist/src/dto/userInfoResponse.js +3 -0
- package/dist/src/dto/userInfoResponse.js.map +1 -0
- package/dist/src/dto/workspacesResponse.d.ts +45 -0
- package/dist/src/dto/workspacesResponse.d.ts.map +1 -0
- package/dist/src/dto/workspacesResponse.js +3 -0
- package/dist/src/dto/workspacesResponse.js.map +1 -0
- package/dist/src/events.d.ts +17 -0
- package/dist/src/events.d.ts.map +1 -0
- package/dist/src/events.js +52 -0
- package/dist/src/events.js.map +1 -0
- package/dist/src/index.d.ts +66 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +113 -0
- package/dist/src/index.js.map +1 -0
- package/dist/src/internal/app.impl.d.ts +28 -0
- package/dist/src/internal/app.impl.d.ts.map +1 -0
- package/dist/src/internal/app.impl.js +173 -0
- package/dist/src/internal/app.impl.js.map +1 -0
- package/dist/src/internal/appBuilder.impl.d.ts +27 -0
- package/dist/src/internal/appBuilder.impl.d.ts.map +1 -0
- package/dist/src/internal/appBuilder.impl.js +71 -0
- package/dist/src/internal/appBuilder.impl.js.map +1 -0
- package/dist/src/internal/createApp.impl.d.ts +4 -0
- package/dist/src/internal/createApp.impl.d.ts.map +1 -0
- package/dist/src/internal/createApp.impl.js +11 -0
- package/dist/src/internal/createApp.impl.js.map +1 -0
- package/dist/src/internal/registry.d.ts +66 -0
- package/dist/src/internal/registry.d.ts.map +1 -0
- package/dist/src/internal/registry.js +114 -0
- package/dist/src/internal/registry.js.map +1 -0
- package/dist/src/middleware.d.ts +6 -0
- package/dist/src/middleware.d.ts.map +1 -0
- package/dist/src/middleware.js +3 -0
- package/dist/src/middleware.js.map +1 -0
- package/dist/src/services/anonymousService.d.ts +8 -0
- package/dist/src/services/anonymousService.d.ts.map +1 -0
- package/dist/src/services/anonymousService.js +41 -0
- package/dist/src/services/anonymousService.js.map +1 -0
- package/dist/src/services/commandService.d.ts +18 -0
- package/dist/src/services/commandService.d.ts.map +1 -0
- package/dist/src/services/commandService.js +40 -0
- package/dist/src/services/commandService.js.map +1 -0
- package/dist/src/services/cookieService.d.ts +7 -0
- package/dist/src/services/cookieService.d.ts.map +1 -0
- package/dist/src/services/cookieService.js +18 -0
- package/dist/src/services/cookieService.js.map +1 -0
- package/dist/src/services/credentialService.d.ts +9 -0
- package/dist/src/services/credentialService.d.ts.map +1 -0
- package/dist/src/services/credentialService.js +26 -0
- package/dist/src/services/credentialService.js.map +1 -0
- package/dist/src/services/httpMethod.d.ts +2 -0
- package/dist/src/services/httpMethod.d.ts.map +1 -0
- package/dist/src/services/httpMethod.js +3 -0
- package/dist/src/services/httpMethod.js.map +1 -0
- package/dist/src/services/middlewareService.d.ts +10 -0
- package/dist/src/services/middlewareService.d.ts.map +1 -0
- package/dist/src/services/middlewareService.js +34 -0
- package/dist/src/services/middlewareService.js.map +1 -0
- package/dist/src/services/organizationService.d.ts +10 -0
- package/dist/src/services/organizationService.d.ts.map +1 -0
- package/dist/src/services/organizationService.js +19 -0
- package/dist/src/services/organizationService.js.map +1 -0
- package/dist/src/services/requestBuilder.d.ts +17 -0
- package/dist/src/services/requestBuilder.d.ts.map +1 -0
- package/dist/src/services/requestBuilder.js +105 -0
- package/dist/src/services/requestBuilder.js.map +1 -0
- package/dist/src/services/responseUtils.d.ts +8 -0
- package/dist/src/services/responseUtils.d.ts.map +1 -0
- package/dist/src/services/responseUtils.js +40 -0
- package/dist/src/services/responseUtils.js.map +1 -0
- package/dist/src/services/rpcService.d.ts +77 -0
- package/dist/src/services/rpcService.d.ts.map +1 -0
- package/dist/src/services/rpcService.js +125 -0
- package/dist/src/services/rpcService.js.map +1 -0
- package/dist/src/services/service.d.ts +21 -0
- package/dist/src/services/service.d.ts.map +1 -0
- package/dist/src/services/service.js +41 -0
- package/dist/src/services/service.js.map +1 -0
- package/dist/src/services/userProfileService.d.ts +9 -0
- package/dist/src/services/userProfileService.d.ts.map +1 -0
- package/dist/src/services/userProfileService.js +43 -0
- package/dist/src/services/userProfileService.js.map +1 -0
- package/dist/src/storages/chats/answer.d.ts +41 -0
- package/dist/src/storages/chats/answer.d.ts.map +1 -0
- package/dist/src/storages/chats/answer.impl.d.ts +29 -0
- package/dist/src/storages/chats/answer.impl.d.ts.map +1 -0
- package/dist/src/storages/chats/answer.impl.js +116 -0
- package/dist/src/storages/chats/answer.impl.js.map +1 -0
- package/dist/src/storages/chats/answer.js +15 -0
- package/dist/src/storages/chats/answer.js.map +1 -0
- package/dist/src/storages/chats/chat.d.ts +43 -0
- package/dist/src/storages/chats/chat.d.ts.map +1 -0
- package/dist/src/storages/chats/chat.impl.d.ts +25 -0
- package/dist/src/storages/chats/chat.impl.d.ts.map +1 -0
- package/dist/src/storages/chats/chat.impl.js +85 -0
- package/dist/src/storages/chats/chat.impl.js.map +1 -0
- package/dist/src/storages/chats/chat.js +12 -0
- package/dist/src/storages/chats/chat.js.map +1 -0
- package/dist/src/storages/chats/chats.d.ts +45 -0
- package/dist/src/storages/chats/chats.d.ts.map +1 -0
- package/dist/src/storages/chats/chats.impl.d.ts +19 -0
- package/dist/src/storages/chats/chats.impl.d.ts.map +1 -0
- package/dist/src/storages/chats/chats.impl.js +147 -0
- package/dist/src/storages/chats/chats.impl.js.map +1 -0
- package/dist/src/storages/chats/chats.js +16 -0
- package/dist/src/storages/chats/chats.js.map +1 -0
- package/dist/src/storages/files/file.d.ts +47 -0
- package/dist/src/storages/files/file.d.ts.map +1 -0
- package/dist/src/storages/files/file.impl.d.ts +25 -0
- package/dist/src/storages/files/file.impl.d.ts.map +1 -0
- package/dist/src/storages/files/file.impl.js +93 -0
- package/dist/src/storages/files/file.impl.js.map +1 -0
- package/dist/src/storages/files/file.js +17 -0
- package/dist/src/storages/files/file.js.map +1 -0
- package/dist/src/storages/files/files.d.ts +39 -0
- package/dist/src/storages/files/files.d.ts.map +1 -0
- package/dist/src/storages/files/files.impl.d.ts +24 -0
- package/dist/src/storages/files/files.impl.d.ts.map +1 -0
- package/dist/src/storages/files/files.impl.js +168 -0
- package/dist/src/storages/files/files.impl.js.map +1 -0
- package/dist/src/storages/files/files.js +20 -0
- package/dist/src/storages/files/files.js.map +1 -0
- package/dist/src/storages/files/filesPage.d.ts +28 -0
- package/dist/src/storages/files/filesPage.d.ts.map +1 -0
- package/dist/src/storages/files/filesPage.impl.d.ts +15 -0
- package/dist/src/storages/files/filesPage.impl.d.ts.map +1 -0
- package/dist/src/storages/files/filesPage.impl.js +38 -0
- package/dist/src/storages/files/filesPage.impl.js.map +1 -0
- package/dist/src/storages/files/filesPage.js +10 -0
- package/dist/src/storages/files/filesPage.js.map +1 -0
- package/dist/src/storages/groups/group.d.ts +63 -0
- package/dist/src/storages/groups/group.d.ts.map +1 -0
- package/dist/src/storages/groups/group.impl.d.ts +38 -0
- package/dist/src/storages/groups/group.impl.d.ts.map +1 -0
- package/dist/src/storages/groups/group.impl.js +210 -0
- package/dist/src/storages/groups/group.impl.js.map +1 -0
- package/dist/src/storages/groups/group.js +15 -0
- package/dist/src/storages/groups/group.js.map +1 -0
- package/dist/src/storages/groups/groups.d.ts +39 -0
- package/dist/src/storages/groups/groups.d.ts.map +1 -0
- package/dist/src/storages/groups/groups.impl.d.ts +30 -0
- package/dist/src/storages/groups/groups.impl.d.ts.map +1 -0
- package/dist/src/storages/groups/groups.impl.js +132 -0
- package/dist/src/storages/groups/groups.impl.js.map +1 -0
- package/dist/src/storages/groups/groups.js +20 -0
- package/dist/src/storages/groups/groups.js.map +1 -0
- package/dist/src/storages/organizations/organization.d.ts +95 -0
- package/dist/src/storages/organizations/organization.d.ts.map +1 -0
- package/dist/src/storages/organizations/organization.impl.d.ts +42 -0
- package/dist/src/storages/organizations/organization.impl.d.ts.map +1 -0
- package/dist/src/storages/organizations/organization.impl.js +240 -0
- package/dist/src/storages/organizations/organization.impl.js.map +1 -0
- package/dist/src/storages/organizations/organization.js +18 -0
- package/dist/src/storages/organizations/organization.js.map +1 -0
- package/dist/src/storages/organizations/organizations.d.ts +46 -0
- package/dist/src/storages/organizations/organizations.d.ts.map +1 -0
- package/dist/src/storages/organizations/organizations.impl.d.ts +38 -0
- package/dist/src/storages/organizations/organizations.impl.d.ts.map +1 -0
- package/dist/src/storages/organizations/organizations.impl.js +158 -0
- package/dist/src/storages/organizations/organizations.impl.js.map +1 -0
- package/dist/src/storages/organizations/organizations.js +20 -0
- package/dist/src/storages/organizations/organizations.js.map +1 -0
- package/dist/src/storages/user/userProfile.d.ts +54 -0
- package/dist/src/storages/user/userProfile.d.ts.map +1 -0
- package/dist/src/storages/user/userProfile.impl.d.ts +21 -0
- package/dist/src/storages/user/userProfile.impl.d.ts.map +1 -0
- package/dist/src/storages/user/userProfile.impl.js +114 -0
- package/dist/src/storages/user/userProfile.impl.js.map +1 -0
- package/dist/src/storages/user/userProfile.js +12 -0
- package/dist/src/storages/user/userProfile.js.map +1 -0
- package/dist/src/storages/workspaces/workspace.d.ts +44 -0
- package/dist/src/storages/workspaces/workspace.d.ts.map +1 -0
- package/dist/src/storages/workspaces/workspace.impl.d.ts +23 -0
- package/dist/src/storages/workspaces/workspace.impl.d.ts.map +1 -0
- package/dist/src/storages/workspaces/workspace.impl.js +98 -0
- package/dist/src/storages/workspaces/workspace.impl.js.map +1 -0
- package/dist/src/storages/workspaces/workspace.js +18 -0
- package/dist/src/storages/workspaces/workspace.js.map +1 -0
- package/dist/src/storages/workspaces/workspaces.d.ts +47 -0
- package/dist/src/storages/workspaces/workspaces.d.ts.map +1 -0
- package/dist/src/storages/workspaces/workspaces.impl.d.ts +33 -0
- package/dist/src/storages/workspaces/workspaces.impl.d.ts.map +1 -0
- package/dist/src/storages/workspaces/workspaces.impl.js +152 -0
- package/dist/src/storages/workspaces/workspaces.impl.js.map +1 -0
- package/dist/src/storages/workspaces/workspaces.js +19 -0
- package/dist/src/storages/workspaces/workspaces.js.map +1 -0
- package/dist/src/unitTest.d.ts +12 -0
- package/dist/src/unitTest.d.ts.map +1 -0
- package/dist/src/unitTest.js +44 -0
- package/dist/src/unitTest.js.map +1 -0
- package/dist/src/utils/browserUtils.d.ts +4 -0
- package/dist/src/utils/browserUtils.d.ts.map +1 -0
- package/dist/src/utils/browserUtils.js +64 -0
- package/dist/src/utils/browserUtils.js.map +1 -0
- package/dist/src/utils/request.d.ts +6 -0
- package/dist/src/utils/request.d.ts.map +1 -0
- package/dist/src/utils/request.js +3 -0
- package/dist/src/utils/request.js.map +1 -0
- package/dist/src/utils/utils.d.ts +3 -0
- package/dist/src/utils/utils.d.ts.map +1 -0
- package/dist/src/utils/utils.js +13 -0
- package/dist/src/utils/utils.js.map +1 -0
- package/index.d.ts +1 -0
- package/index.js +1 -0
- package/package.json +46 -5
- package/src/commands/deleteUserFullCommandHandler.ts +19 -0
- package/src/commands/startCommandHandler.ts +16 -5
- package/src/context.ts +4 -2
- package/src/credentials.ts +22 -0
- package/src/{appSdk.ts → dataIslandApp.ts} +3 -3
- package/src/disposable.ts +18 -5
- package/src/dto/accessGroupResponse.ts +19 -16
- package/src/dto/badRequestResponse.ts +6 -0
- package/src/dto/chatResponse.ts +59 -54
- package/src/dto/limitsResponse.ts +33 -0
- package/src/dto/statisticsResponse.ts +12 -0
- package/src/dto/userInfoResponse.ts +59 -2
- package/src/dto/workspacesResponse.ts +5 -3
- package/src/index.ts +46 -24
- package/src/internal/app.impl.ts +42 -9
- package/src/internal/createApp.impl.ts +4 -4
- package/src/internal/registry.ts +54 -6
- package/src/middleware.ts +2 -0
- package/src/services/anonymousService.ts +43 -0
- package/src/services/commandService.ts +4 -2
- package/src/services/cookieService.ts +16 -0
- package/src/services/httpMethod.ts +1 -0
- package/src/services/middlewareService.ts +1 -0
- package/src/services/organizationService.ts +2 -2
- package/src/services/requestBuilder.ts +10 -8
- package/src/services/responseUtils.ts +12 -0
- package/src/services/rpcService.ts +1 -0
- package/src/services/userProfileService.ts +18 -4
- package/src/storages/chats/answer.impl.ts +160 -0
- package/src/storages/chats/answer.ts +53 -0
- package/src/storages/chats/chat.impl.ts +107 -0
- package/src/storages/chats/chat.ts +55 -0
- package/src/storages/chats/chats.impl.ts +204 -0
- package/src/storages/chats/chats.ts +53 -0
- package/src/storages/files/file.impl.ts +111 -0
- package/src/storages/files/file.ts +58 -0
- package/src/storages/{files.impl.ts → files/files.impl.ts} +67 -46
- package/src/storages/{files.ts → files/files.ts} +14 -7
- package/src/storages/files/filesPage.impl.ts +37 -0
- package/src/storages/{filesPage.ts → files/filesPage.ts} +6 -0
- package/src/storages/groups/group.impl.ts +276 -0
- package/src/storages/groups/group.ts +73 -0
- package/src/storages/groups/groups.impl.ts +175 -0
- package/src/storages/groups/groups.ts +45 -0
- package/src/storages/organizations/organization.impl.ts +357 -0
- package/src/storages/organizations/organization.ts +118 -0
- package/src/storages/{organizations.impl.ts → organizations/organizations.impl.ts} +31 -13
- package/src/storages/{organizations.ts → organizations/organizations.ts} +1 -1
- package/src/storages/user/userProfile.impl.ts +136 -0
- package/src/storages/user/userProfile.ts +69 -0
- package/src/storages/{workspace.impl.ts → workspaces/workspace.impl.ts} +27 -7
- package/src/storages/{workspace.ts → workspaces/workspace.ts} +8 -3
- package/src/storages/{workspaces.impl.ts → workspaces/workspaces.impl.ts} +27 -32
- package/src/storages/{workspaces.ts → workspaces/workspaces.ts} +6 -2
- package/src/unitTest.ts +14 -3
- package/src/utils/browserUtils.ts +68 -0
- package/src/utils/request.ts +6 -0
- package/src/utils/utils.ts +8 -0
- package/.browserslistrc +0 -5
- package/.editorconfig +0 -25
- package/.eslintrc.json +0 -44
- package/.github/workflows/publish-npm.yml +0 -28
- package/.prettierignore +0 -1
- package/.prettierrc +0 -11
- package/.yarnrc +0 -2
- package/babel.config.js +0 -6
- package/jest.config.ts +0 -199
- package/jest.setup.ts +0 -2
- package/src/storages/chat.ts +0 -21
- package/src/storages/chats.ts +0 -17
- package/src/storages/file.impl.ts +0 -69
- package/src/storages/file.ts +0 -28
- package/src/storages/groups.impl.ts +0 -337
- package/src/storages/groups.ts +0 -43
- package/src/storages/organization.impl.ts +0 -68
- package/src/storages/organization.ts +0 -33
- package/src/storages/userProfile.impl.ts +0 -56
- package/src/storages/userProfile.ts +0 -42
- package/test/commands.test.ts +0 -24
- package/test/data/test_file.pdf +0 -0
- package/test/disposable.test.ts +0 -39
- package/test/events.test.ts +0 -151
- package/test/files.test.ts +0 -52
- package/test/index.test.ts +0 -122
- package/test/organization.test.ts +0 -57
- package/test/registry.test.ts +0 -44
- package/test/services.test.ts +0 -56
- package/test/setup.ts +0 -54
- package/test/unitTest.test.ts +0 -21
- package/test/workspace.test.ts +0 -71
- package/tsconfig.json +0 -31
@@ -0,0 +1,15 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Group = exports.GroupEvent = void 0;
|
4
|
+
const events_1 = require("../../events");
|
5
|
+
var GroupEvent;
|
6
|
+
(function (GroupEvent) {
|
7
|
+
GroupEvent["UPDATED"] = "updated";
|
8
|
+
})(GroupEvent || (exports.GroupEvent = GroupEvent = {}));
|
9
|
+
/**
|
10
|
+
* Group.
|
11
|
+
*/
|
12
|
+
class Group extends events_1.EventDispatcher {
|
13
|
+
}
|
14
|
+
exports.Group = Group;
|
15
|
+
//# sourceMappingURL=group.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"group.js","sourceRoot":"","sources":["../../../../src/storages/groups/group.ts"],"names":[],"mappings":";;;AAAA,yCAA8C;AAY9C,IAAY,UAEX;AAFD,WAAY,UAAU;IACpB,iCAAmB,CAAA;AACrB,CAAC,EAFW,UAAU,0BAAV,UAAU,QAErB;AAED;;GAEG;AACH,MAAsB,KAAM,SAAQ,wBAAkC;CAqDrE;AArDD,sBAqDC"}
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import { EventDispatcher } from "../../events";
|
2
|
+
import { Group, GroupId } from "./group";
|
3
|
+
/**
|
4
|
+
* Group event.
|
5
|
+
*/
|
6
|
+
export declare enum GroupsEvent {
|
7
|
+
ADDED = "added",
|
8
|
+
REMOVED = "removed",
|
9
|
+
UPDATED = "updated"
|
10
|
+
}
|
11
|
+
/**
|
12
|
+
* Groups storage.
|
13
|
+
*/
|
14
|
+
export declare abstract class Groups extends EventDispatcher<GroupsEvent, Group> {
|
15
|
+
/**
|
16
|
+
* Collection.
|
17
|
+
*/
|
18
|
+
abstract get collection(): ReadonlyArray<Group>;
|
19
|
+
/**
|
20
|
+
* Create new group.
|
21
|
+
* @param name
|
22
|
+
* @param permits
|
23
|
+
* @param memberIds
|
24
|
+
*/
|
25
|
+
abstract create(name: string, permits: {
|
26
|
+
isAdmin: boolean;
|
27
|
+
}, memberIds: string[]): Promise<Group>;
|
28
|
+
/**
|
29
|
+
* Get group by id.
|
30
|
+
* @param id
|
31
|
+
*/
|
32
|
+
abstract get(id: GroupId): Group | undefined;
|
33
|
+
/**
|
34
|
+
* delete group by id.
|
35
|
+
* @param id
|
36
|
+
*/
|
37
|
+
abstract delete(id: GroupId): Promise<void>;
|
38
|
+
}
|
39
|
+
//# sourceMappingURL=groups.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"groups.d.ts","sourceRoot":"","sources":["../../../../src/storages/groups/groups.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAExC;;GAEG;AACH,oBAAY,WAAW;IACrB,KAAK,UAAU;IACf,OAAO,YAAY;IACnB,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,8BAAsB,MAAO,SAAQ,eAAe,CAAC,WAAW,EAAE,KAAK,CAAC;IAEtE;;OAEG;IACH,QAAQ,KAAK,UAAU,IAAI,aAAa,CAAC,KAAK,CAAC,CAAA;IAE/C;;;;;OAKG;IACH,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QACrC,OAAO,EAAE,OAAO,CAAA;KACjB,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC;IAEvC;;;OAGG;IACH,QAAQ,CAAC,GAAG,CAAC,EAAE,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS;IAE5C;;;OAGG;IACH,QAAQ,CAAC,MAAM,CAAC,EAAE,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;CAE5C"}
|
@@ -0,0 +1,30 @@
|
|
1
|
+
import { Context } from "../../context";
|
2
|
+
import { Groups } from "./groups";
|
3
|
+
import { OrganizationImpl } from "../organizations/organization.impl";
|
4
|
+
import { Group, GroupId } from "./group";
|
5
|
+
export declare class GroupsImpl extends Groups {
|
6
|
+
readonly organization: OrganizationImpl;
|
7
|
+
private readonly context;
|
8
|
+
private _groups;
|
9
|
+
constructor(organization: OrganizationImpl, context: Context);
|
10
|
+
get collection(): readonly Group[];
|
11
|
+
initialize(): Promise<void>;
|
12
|
+
create(name: string, permits: {
|
13
|
+
isAdmin: boolean;
|
14
|
+
}, memberIds: string[]): Promise<Group>;
|
15
|
+
get(id: GroupId): Group | undefined;
|
16
|
+
delete(id: GroupId): Promise<void>;
|
17
|
+
/**
|
18
|
+
* Init access groups.
|
19
|
+
*/
|
20
|
+
internalInit(): Promise<void>;
|
21
|
+
internalCreate(name: string, permits: {
|
22
|
+
isAdmin: boolean;
|
23
|
+
}, memberIds: string[]): Promise<Group>;
|
24
|
+
/**
|
25
|
+
* Delete group.
|
26
|
+
* @param id
|
27
|
+
*/
|
28
|
+
internalDeleteGroup(id: GroupId): Promise<void>;
|
29
|
+
}
|
30
|
+
//# sourceMappingURL=groups.impl.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"groups.impl.d.ts","sourceRoot":"","sources":["../../../../src/storages/groups/groups.impl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AAMvC,OAAO,EAAE,MAAM,EAAe,MAAM,UAAU,CAAA;AAC9C,OAAO,EAAE,gBAAgB,EAAE,MAAM,oCAAoC,CAAA;AAErE,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,SAAS,CAAA;AAGxC,qBAAa,UAAW,SAAQ,MAAM;aAKlB,YAAY,EAAE,gBAAgB;IAC9C,OAAO,CAAC,QAAQ,CAAC,OAAO;IAJ1B,OAAO,CAAC,OAAO,CAAc;gBAGX,YAAY,EAAE,gBAAgB,EAC7B,OAAO,EAAE,OAAO;IAKnC,IAAI,UAAU,IAAI,SAAS,KAAK,EAAE,CAEjC;IAEK,UAAU;IAIV,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAClC,OAAO,EAAE,OAAO,CAAA;KACjB,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC;IAIvC,GAAG,CAAC,EAAE,EAAE,OAAO,GAAG,KAAK,GAAG,SAAS;IAI7B,MAAM,CAAC,EAAE,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;IAQxC;;OAEG;IACG,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAoC7B,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE;QAC1C,OAAO,EAAE,OAAO,CAAA;KACjB,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,KAAK,CAAC;IAyCvC;;;OAGG;IACG,mBAAmB,CAAC,EAAE,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC;CAuCtD"}
|
@@ -0,0 +1,132 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.GroupsImpl = void 0;
|
4
|
+
const rpcService_1 = require("../../services/rpcService");
|
5
|
+
const groups_1 = require("./groups");
|
6
|
+
const responseUtils_1 = require("../../services/responseUtils");
|
7
|
+
const group_impl_1 = require("./group.impl");
|
8
|
+
class GroupsImpl extends groups_1.Groups {
|
9
|
+
constructor(organization, context) {
|
10
|
+
super();
|
11
|
+
this.organization = organization;
|
12
|
+
this.context = context;
|
13
|
+
this._groups = [];
|
14
|
+
}
|
15
|
+
get collection() {
|
16
|
+
return this._groups;
|
17
|
+
}
|
18
|
+
async initialize() {
|
19
|
+
await this.internalInit();
|
20
|
+
}
|
21
|
+
async create(name, permits, memberIds) {
|
22
|
+
return await this.internalCreate(name, permits, memberIds);
|
23
|
+
}
|
24
|
+
get(id) {
|
25
|
+
return this._groups.find(group => group.id === id);
|
26
|
+
}
|
27
|
+
async delete(id) {
|
28
|
+
return await this.internalDeleteGroup(id);
|
29
|
+
}
|
30
|
+
//----------------------------------------------------------------------------
|
31
|
+
// INTERNALS
|
32
|
+
//----------------------------------------------------------------------------
|
33
|
+
/**
|
34
|
+
* Init access groups.
|
35
|
+
*/
|
36
|
+
async internalInit() {
|
37
|
+
var _a;
|
38
|
+
// fetch groups
|
39
|
+
const response = await ((_a = this.context.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Organizations/access_groups").searchParam("id", this.organization.id).sendGet());
|
40
|
+
// check response status
|
41
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
42
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to get groups for organization: ${this.organization.id}`, response);
|
43
|
+
}
|
44
|
+
// parse groups from the server's response
|
45
|
+
const groups = (await response.json());
|
46
|
+
const wait = [];
|
47
|
+
// init groups
|
48
|
+
for (const gr of groups.groups) {
|
49
|
+
// create group implementation
|
50
|
+
const group = new group_impl_1.GroupImpl(this.context, this.organization).initFrom(gr.id);
|
51
|
+
// add to the wait list
|
52
|
+
wait.push(group);
|
53
|
+
}
|
54
|
+
// wait for all groups
|
55
|
+
const groupsResult = await Promise.all(wait);
|
56
|
+
// add groups to the collection
|
57
|
+
for (const group of groupsResult) {
|
58
|
+
// add group to the collection
|
59
|
+
this._groups.push(group);
|
60
|
+
}
|
61
|
+
}
|
62
|
+
async internalCreate(name, permits, memberIds) {
|
63
|
+
var _a;
|
64
|
+
if (name === undefined || name === null) {
|
65
|
+
throw new Error("Group create, name is undefined or null");
|
66
|
+
}
|
67
|
+
if (name.length === 0 || name.trim().length === 0) {
|
68
|
+
throw new Error("Group create, name is empty");
|
69
|
+
}
|
70
|
+
// send request to the server
|
71
|
+
const response = await ((_a = this.context
|
72
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/AccessGroups").sendPostJson({
|
73
|
+
name: name,
|
74
|
+
organizationId: this.organization.id,
|
75
|
+
permits: permits,
|
76
|
+
memberIds: memberIds
|
77
|
+
}));
|
78
|
+
// check response status
|
79
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
80
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to create group, organization: ${this.organization.id}`, response);
|
81
|
+
}
|
82
|
+
// parse group from the server's response
|
83
|
+
const content = (await response.json());
|
84
|
+
// create group implementation
|
85
|
+
const group = await new group_impl_1.GroupImpl(this.context, this.organization).initFrom(content.group.id);
|
86
|
+
// add group to the collection
|
87
|
+
this._groups.push(group);
|
88
|
+
// dispatch event
|
89
|
+
this.dispatch({
|
90
|
+
type: groups_1.GroupsEvent.ADDED,
|
91
|
+
data: group
|
92
|
+
});
|
93
|
+
return group;
|
94
|
+
}
|
95
|
+
/**
|
96
|
+
* Delete group.
|
97
|
+
* @param id
|
98
|
+
*/
|
99
|
+
async internalDeleteGroup(id) {
|
100
|
+
var _a;
|
101
|
+
if (id === undefined || id === null) {
|
102
|
+
throw new Error("Group delete, id is undefined or null");
|
103
|
+
}
|
104
|
+
if (id.length === 0 || id.trim().length === 0) {
|
105
|
+
throw new Error("Group delete, id is empty");
|
106
|
+
}
|
107
|
+
// send request to the server
|
108
|
+
const response = await ((_a = this.context
|
109
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("/api/v1/AccessGroups").searchParam("groupId", id).sendDelete());
|
110
|
+
// check response status
|
111
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
112
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to delete group: ${id}, organization: ${this.organization.id}`, response);
|
113
|
+
}
|
114
|
+
// delete group from collection
|
115
|
+
const group = this._groups.find(f => f.id === id);
|
116
|
+
const index = this._groups.indexOf(group);
|
117
|
+
if (index < 0) {
|
118
|
+
throw new Error("Group delete, index is not found");
|
119
|
+
}
|
120
|
+
// remove group from collection
|
121
|
+
this._groups.splice(index, 1);
|
122
|
+
// dispatch event, group removed
|
123
|
+
this.dispatch({
|
124
|
+
type: groups_1.GroupsEvent.REMOVED,
|
125
|
+
data: group
|
126
|
+
});
|
127
|
+
// dispose group
|
128
|
+
group.dispose();
|
129
|
+
}
|
130
|
+
}
|
131
|
+
exports.GroupsImpl = GroupsImpl;
|
132
|
+
//# sourceMappingURL=groups.impl.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"groups.impl.js","sourceRoot":"","sources":["../../../../src/storages/groups/groups.impl.ts"],"names":[],"mappings":"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"}
|
@@ -0,0 +1,20 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.Groups = exports.GroupsEvent = void 0;
|
4
|
+
const events_1 = require("../../events");
|
5
|
+
/**
|
6
|
+
* Group event.
|
7
|
+
*/
|
8
|
+
var GroupsEvent;
|
9
|
+
(function (GroupsEvent) {
|
10
|
+
GroupsEvent["ADDED"] = "added";
|
11
|
+
GroupsEvent["REMOVED"] = "removed";
|
12
|
+
GroupsEvent["UPDATED"] = "updated";
|
13
|
+
})(GroupsEvent || (exports.GroupsEvent = GroupsEvent = {}));
|
14
|
+
/**
|
15
|
+
* Groups storage.
|
16
|
+
*/
|
17
|
+
class Groups extends events_1.EventDispatcher {
|
18
|
+
}
|
19
|
+
exports.Groups = Groups;
|
20
|
+
//# sourceMappingURL=groups.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"groups.js","sourceRoot":"","sources":["../../../../src/storages/groups/groups.ts"],"names":[],"mappings":";;;AAAA,yCAA8C;AAG9C;;GAEG;AACH,IAAY,WAIX;AAJD,WAAY,WAAW;IACrB,8BAAe,CAAA;IACf,kCAAmB,CAAA;IACnB,kCAAmB,CAAA;AACrB,CAAC,EAJW,WAAW,2BAAX,WAAW,QAItB;AAED;;GAEG;AACH,MAAsB,MAAO,SAAQ,wBAAmC;CA6BvE;AA7BD,wBA6BC"}
|
@@ -0,0 +1,95 @@
|
|
1
|
+
import { Workspaces } from "../workspaces/workspaces";
|
2
|
+
import { OrganizationId } from "./organizations";
|
3
|
+
import { Groups } from "../groups/groups";
|
4
|
+
import { Chats } from "../chats/chats";
|
5
|
+
import { EventDispatcher } from "../../events";
|
6
|
+
import { CurrentLimitsData, UserDto, UsersStatisticsResponse } from "../../dto/userInfoResponse";
|
7
|
+
import { GroupId } from "../groups/group";
|
8
|
+
import { StatisticsResponse } from "../../dto/statisticsResponse";
|
9
|
+
import { SegmentData } from "../../dto/limitsResponse";
|
10
|
+
/**
|
11
|
+
* Organization event.
|
12
|
+
*/
|
13
|
+
export declare enum OrganizationEvent {
|
14
|
+
CHANGED = "changed"
|
15
|
+
}
|
16
|
+
/**
|
17
|
+
* Organization.
|
18
|
+
*/
|
19
|
+
export declare abstract class Organization extends EventDispatcher<OrganizationEvent, Organization> {
|
20
|
+
/**
|
21
|
+
* Organization id.
|
22
|
+
*/
|
23
|
+
abstract get id(): OrganizationId;
|
24
|
+
/**
|
25
|
+
* Organization name.
|
26
|
+
*/
|
27
|
+
abstract get name(): string;
|
28
|
+
/**
|
29
|
+
* Organization description.
|
30
|
+
*/
|
31
|
+
abstract get description(): string;
|
32
|
+
/**
|
33
|
+
* Workspaces.
|
34
|
+
*/
|
35
|
+
abstract get workspaces(): Workspaces;
|
36
|
+
/**
|
37
|
+
* Chats.
|
38
|
+
*/
|
39
|
+
abstract get chats(): Chats;
|
40
|
+
/**
|
41
|
+
* Groups.
|
42
|
+
*/
|
43
|
+
abstract get accessGroups(): Groups;
|
44
|
+
/**
|
45
|
+
* Get organization members
|
46
|
+
*/
|
47
|
+
abstract members(): Promise<UserDto[]>;
|
48
|
+
/**
|
49
|
+
* Get organization statistics
|
50
|
+
* @param dateFrom
|
51
|
+
* @param dateTo
|
52
|
+
*/
|
53
|
+
abstract statistics(dateFrom: number, dateTo: number): Promise<StatisticsResponse>;
|
54
|
+
/**
|
55
|
+
* Get organization statistics
|
56
|
+
* @param dateFrom
|
57
|
+
* @param dateTo
|
58
|
+
*/
|
59
|
+
abstract membersStatistics(dateFrom: number, dateTo: number): Promise<UsersStatisticsResponse>;
|
60
|
+
/**
|
61
|
+
* Get statistics for user
|
62
|
+
* @param dateFrom
|
63
|
+
* @param dateTo
|
64
|
+
*/
|
65
|
+
abstract userStatistic(userid: string, dateFrom: number, dateTo: number): Promise<StatisticsResponse>;
|
66
|
+
/**
|
67
|
+
* Get user limits data
|
68
|
+
*/
|
69
|
+
abstract userLimits(): Promise<CurrentLimitsData>;
|
70
|
+
/**
|
71
|
+
* Get default organization limits
|
72
|
+
*/
|
73
|
+
abstract organizationLimits(): Promise<SegmentData>;
|
74
|
+
/**
|
75
|
+
* Get all available segments data
|
76
|
+
*/
|
77
|
+
abstract limitSegments(): Promise<SegmentData[]>;
|
78
|
+
/**
|
79
|
+
* Change organization name and description.
|
80
|
+
*/
|
81
|
+
abstract change(name: string, description: string): Promise<void>;
|
82
|
+
/**
|
83
|
+
* Invite users with given emails to organization
|
84
|
+
*/
|
85
|
+
abstract inviteUsers(emails: string[], accessGroups: GroupId[]): Promise<void>;
|
86
|
+
/**
|
87
|
+
* Create invite code for users outside organization
|
88
|
+
*/
|
89
|
+
abstract createInviteCode(accessGroups: GroupId[]): Promise<string>;
|
90
|
+
/**
|
91
|
+
* Validate invite code for user
|
92
|
+
*/
|
93
|
+
abstract validateInviteCode(code: string): Promise<void>;
|
94
|
+
}
|
95
|
+
//# sourceMappingURL=organization.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"organization.d.ts","sourceRoot":"","sources":["../../../../src/storages/organizations/organization.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AACzC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AACtC,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAA;AAC9C,OAAO,EAAE,iBAAiB,EAAE,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AAChG,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAA;AACzC,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAA;AACjE,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAA;AAEtD;;GAEG;AACH,oBAAY,iBAAiB;IAC3B,OAAO,YAAY;CACpB;AAED;;GAEG;AACH,8BAAsB,YAAa,SAAQ,eAAe,CACxD,iBAAiB,EACjB,YAAY,CACb;IACC;;OAEG;IACH,QAAQ,KAAK,EAAE,IAAI,cAAc,CAAA;IAEjC;;OAEG;IACH,QAAQ,KAAK,IAAI,IAAI,MAAM,CAAA;IAE3B;;OAEG;IACH,QAAQ,KAAK,WAAW,IAAI,MAAM,CAAA;IAElC;;OAEG;IACH,QAAQ,KAAK,UAAU,IAAI,UAAU,CAAA;IAErC;;OAEG;IACH,QAAQ,KAAK,KAAK,IAAI,KAAK,CAAA;IAE3B;;OAEG;IACH,QAAQ,KAAK,YAAY,IAAI,MAAM,CAAA;IAEnC;;OAEG;IACH,QAAQ,CAAC,OAAO,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAEtC;;;;OAIG;IACH,QAAQ,CAAC,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAGlF;;;;OAIG;IACH,QAAQ,CAAC,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC;IAG9F;;;;OAIG;IACH,QAAQ,CAAC,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAGrG;;OAEG;IACH,QAAQ,CAAC,UAAU,IAAI,OAAO,CAAC,iBAAiB,CAAC;IAEjD;;OAEG;IACH,QAAQ,CAAC,kBAAkB,IAAI,OAAO,CAAC,WAAW,CAAC;IAEnD;;OAEG;IACH,QAAQ,CAAC,aAAa,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAEhD;;OAEG;IACH,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAEjE;;OAEG;IACH,QAAQ,CAAC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,YAAY,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAE9E;;OAEG;IACH,QAAQ,CAAC,gBAAgB,CAAC,YAAY,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAEnE;;OAEG;IACH,QAAQ,CAAC,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CACzD"}
|
@@ -0,0 +1,42 @@
|
|
1
|
+
import { OrganizationId } from "./organizations";
|
2
|
+
import { Disposable } from "../../disposable";
|
3
|
+
import { CurrentLimitsData, OrganizationDto, UserDto, UsersStatisticsResponse } from "../../dto/userInfoResponse";
|
4
|
+
import { Workspaces } from "../workspaces/workspaces";
|
5
|
+
import { Context } from "../../context";
|
6
|
+
import { Organization } from "./organization";
|
7
|
+
import { Groups } from "../groups/groups";
|
8
|
+
import { Chats } from "../chats/chats";
|
9
|
+
import { StatisticsResponse } from "../../dto/statisticsResponse";
|
10
|
+
import { SegmentData } from "../../dto/limitsResponse";
|
11
|
+
export declare class OrganizationImpl extends Organization implements Disposable {
|
12
|
+
private readonly context;
|
13
|
+
private _isDisposed;
|
14
|
+
private _isAdmin;
|
15
|
+
private _content?;
|
16
|
+
private readonly _workspaces;
|
17
|
+
private readonly _accessGroups;
|
18
|
+
private readonly _chats;
|
19
|
+
constructor(context: Context);
|
20
|
+
initFrom(content: OrganizationDto, isAdmin: boolean): Promise<OrganizationImpl>;
|
21
|
+
get isAdmin(): boolean;
|
22
|
+
get isDisposed(): boolean;
|
23
|
+
dispose(): void;
|
24
|
+
get id(): OrganizationId;
|
25
|
+
get name(): string;
|
26
|
+
get description(): string;
|
27
|
+
get workspaces(): Workspaces;
|
28
|
+
get accessGroups(): Groups;
|
29
|
+
get chats(): Chats;
|
30
|
+
members(): Promise<UserDto[]>;
|
31
|
+
change(name: string, description: string): Promise<void>;
|
32
|
+
statistics(dateFrom: number, dateTo: number): Promise<StatisticsResponse>;
|
33
|
+
membersStatistics(dateFrom: number, dateTo: number): Promise<UsersStatisticsResponse>;
|
34
|
+
userStatistic(userId: string, dateFrom: number, dateTo: number): Promise<StatisticsResponse>;
|
35
|
+
userLimits(): Promise<CurrentLimitsData>;
|
36
|
+
organizationLimits(): Promise<SegmentData>;
|
37
|
+
limitSegments(): Promise<SegmentData[]>;
|
38
|
+
inviteUsers(emails: string[], accessGroups: string[]): Promise<void>;
|
39
|
+
createInviteCode(accessGroups: string[]): Promise<string>;
|
40
|
+
validateInviteCode(code: string): Promise<void>;
|
41
|
+
}
|
42
|
+
//# sourceMappingURL=organization.impl.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"organization.impl.d.ts","sourceRoot":"","sources":["../../../../src/storages/organizations/organization.impl.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAA;AAChD,OAAO,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAA;AAC7C,OAAO,EAA4C,iBAAiB,EAAE,eAAe,EAA2B,OAAO,EAAkB,uBAAuB,EAAE,MAAM,4BAA4B,CAAA;AACpM,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAErD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,YAAY,EAAqB,MAAM,gBAAgB,CAAA;AAEhE,OAAO,EAAE,MAAM,EAAE,MAAM,kBAAkB,CAAA;AAEzC,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAA;AAGtC,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAA;AACjE,OAAO,EAAmB,WAAW,EAAgB,MAAM,0BAA0B,CAAA;AAGrF,qBAAa,gBAAiB,SAAQ,YAAa,YAAW,UAAU;IAQ1D,OAAO,CAAC,QAAQ,CAAC,OAAO;IAPpC,OAAO,CAAC,WAAW,CAAiB;IACpC,OAAO,CAAC,QAAQ,CAAiB;IACjC,OAAO,CAAC,QAAQ,CAAC,CAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAgB;IAC5C,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAY;IAC1C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAW;gBAEL,OAAO,EAAE,OAAO;IAOhC,QAAQ,CACnB,OAAO,EAAE,eAAe,EACxB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,gBAAgB,CAAC;IAY5B,IAAI,OAAO,IAAI,OAAO,CAErB;IAED,IAAI,UAAU,IAAI,OAAO,CAExB;IAED,OAAO,IAAI,IAAI;IAIf,IAAI,EAAE,IAAI,cAAc,CAEvB;IAED,IAAI,IAAI,IAAI,MAAM,CAEjB;IAED,IAAI,WAAW,IAAI,MAAM,CAExB;IAED,IAAI,UAAU,IAAI,UAAU,CAE3B;IAED,IAAI,YAAY,IAAI,MAAM,CAEzB;IAED,IAAI,KAAK,IAAI,KAAK,CAEjB;IAEK,OAAO,IAAI,OAAO,CAAC,OAAO,EAAE,CAAC;IAqB7B,MAAM,CAAC,IAAI,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IA+CxD,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAqBzE,iBAAiB,CAAC,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,uBAAuB,CAAC;IAqBrF,aAAa,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC;IAsB5F,UAAU,IAAI,OAAO,CAAC,iBAAiB,CAAC;IAiDxC,kBAAkB,IAAI,OAAO,CAAC,WAAW,CAAC;IAoB1C,aAAa,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;IAmBvC,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAiBpE,gBAAgB,CAAC,YAAY,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,MAAM,CAAC;IAsBzD,kBAAkB,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CActD"}
|
@@ -0,0 +1,240 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.OrganizationImpl = void 0;
|
4
|
+
const workspaces_impl_1 = require("../workspaces/workspaces.impl");
|
5
|
+
const organization_1 = require("./organization");
|
6
|
+
const groups_impl_1 = require("../groups/groups.impl");
|
7
|
+
const chats_impl_1 = require("../chats/chats.impl");
|
8
|
+
const rpcService_1 = require("../../services/rpcService");
|
9
|
+
const responseUtils_1 = require("../../services/responseUtils");
|
10
|
+
class OrganizationImpl extends organization_1.Organization {
|
11
|
+
constructor(context) {
|
12
|
+
super();
|
13
|
+
this.context = context;
|
14
|
+
this._isDisposed = false;
|
15
|
+
this._isAdmin = false;
|
16
|
+
this._workspaces = new workspaces_impl_1.WorkspacesImpl(this, this.context);
|
17
|
+
this._accessGroups = new groups_impl_1.GroupsImpl(this, this.context);
|
18
|
+
this._chats = new chats_impl_1.ChatsImpl(this, this.context);
|
19
|
+
}
|
20
|
+
async initFrom(content, isAdmin) {
|
21
|
+
this._content = content;
|
22
|
+
this._isAdmin = isAdmin;
|
23
|
+
// init workspaces by organization id
|
24
|
+
await this._workspaces.initFrom(content.id);
|
25
|
+
await this._chats.initFrom(content.id);
|
26
|
+
await this._accessGroups.initialize();
|
27
|
+
return this;
|
28
|
+
}
|
29
|
+
get isAdmin() {
|
30
|
+
return this._isAdmin;
|
31
|
+
}
|
32
|
+
get isDisposed() {
|
33
|
+
return this._isDisposed;
|
34
|
+
}
|
35
|
+
dispose() {
|
36
|
+
this._isDisposed = true;
|
37
|
+
}
|
38
|
+
get id() {
|
39
|
+
var _a;
|
40
|
+
return (_a = this._content) === null || _a === void 0 ? void 0 : _a.id;
|
41
|
+
}
|
42
|
+
get name() {
|
43
|
+
var _a;
|
44
|
+
return (_a = this._content) === null || _a === void 0 ? void 0 : _a.profile.name;
|
45
|
+
}
|
46
|
+
get description() {
|
47
|
+
var _a;
|
48
|
+
return (_a = this._content) === null || _a === void 0 ? void 0 : _a.profile.description;
|
49
|
+
}
|
50
|
+
get workspaces() {
|
51
|
+
return this._workspaces;
|
52
|
+
}
|
53
|
+
get accessGroups() {
|
54
|
+
return this._accessGroups;
|
55
|
+
}
|
56
|
+
get chats() {
|
57
|
+
return this._chats;
|
58
|
+
}
|
59
|
+
async members() {
|
60
|
+
var _a;
|
61
|
+
// send request to the server
|
62
|
+
const response = await ((_a = this.context
|
63
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Organizations/members").searchParam("id", this.id).sendGet());
|
64
|
+
// check response status
|
65
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
66
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed during fetch of organization members ${this.id}`, response);
|
67
|
+
}
|
68
|
+
return (await response.json()).members;
|
69
|
+
}
|
70
|
+
async change(name, description) {
|
71
|
+
var _a;
|
72
|
+
if (!this._content) {
|
73
|
+
throw new Error("Organization is not loaded.");
|
74
|
+
}
|
75
|
+
if (name === this.name && description === this.description) {
|
76
|
+
return Promise.resolve();
|
77
|
+
}
|
78
|
+
if (name === undefined || name === null || name.trim() === "") {
|
79
|
+
throw new Error("Name is required. Please provide a valid name.");
|
80
|
+
}
|
81
|
+
if (description === undefined ||
|
82
|
+
description === null ||
|
83
|
+
description.trim() === "") {
|
84
|
+
throw new Error("Description is required. Please provide a valid description.");
|
85
|
+
}
|
86
|
+
const response = await ((_a = this.context
|
87
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Organizations").sendPutJson({
|
88
|
+
organizationId: this.id,
|
89
|
+
profile: {
|
90
|
+
name,
|
91
|
+
description
|
92
|
+
}
|
93
|
+
}));
|
94
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
95
|
+
await responseUtils_1.ResponseUtils.throwError("Failed to change organization", response);
|
96
|
+
}
|
97
|
+
if (this._content) {
|
98
|
+
this._content.profile.name = name;
|
99
|
+
this._content.profile.description = description;
|
100
|
+
}
|
101
|
+
this.dispatch({
|
102
|
+
type: organization_1.OrganizationEvent.CHANGED,
|
103
|
+
data: this
|
104
|
+
});
|
105
|
+
}
|
106
|
+
async statistics(dateFrom, dateTo) {
|
107
|
+
var _a;
|
108
|
+
// send request to the server
|
109
|
+
const response = await ((_a = this.context
|
110
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Stats/organization").searchParam("organizationId", this.id).searchParam("dateFrom", dateFrom.toString()).searchParam("dateTo", dateTo.toString()).sendGet());
|
111
|
+
// check response status
|
112
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
113
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed during fetch of organization statistics ${this.id}`, response);
|
114
|
+
}
|
115
|
+
return await response.json();
|
116
|
+
}
|
117
|
+
async membersStatistics(dateFrom, dateTo) {
|
118
|
+
var _a;
|
119
|
+
// send request to the server
|
120
|
+
const response = await ((_a = this.context
|
121
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Stats/organization/members").searchParam("organizationId", this.id).searchParam("dateFrom", dateFrom.toString()).searchParam("dateTo", dateTo.toString()).sendGet());
|
122
|
+
// check response status
|
123
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
124
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed during fetch of organization members statistics ${this.id}`, response);
|
125
|
+
}
|
126
|
+
return await response.json();
|
127
|
+
}
|
128
|
+
async userStatistic(userId, dateFrom, dateTo) {
|
129
|
+
var _a;
|
130
|
+
// send request to the server
|
131
|
+
const response = await ((_a = this.context
|
132
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Stats/user").searchParam("userId", userId).searchParam("organizationId", this.id).searchParam("dateFrom", dateFrom.toString()).searchParam("dateTo", dateTo.toString()).sendGet());
|
133
|
+
// check response status
|
134
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
135
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed during fetch of user statistics ${this.id}`, response);
|
136
|
+
}
|
137
|
+
return await response.json();
|
138
|
+
}
|
139
|
+
async userLimits() {
|
140
|
+
var _a, _b, _c;
|
141
|
+
// fetch limits
|
142
|
+
const response = await ((_a = this.context.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Users/limits").searchParam("organizationId", this.id).sendGet());
|
143
|
+
// check response status
|
144
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
145
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to get limits in organization: ${this.id}`, response);
|
146
|
+
}
|
147
|
+
// parse limits from the server's response
|
148
|
+
const limits = (await response.json());
|
149
|
+
const currentLimits = { segment: limits.userSegment.key, limits: [] };
|
150
|
+
for (const limit of limits.userLimits) {
|
151
|
+
const type = limit.action;
|
152
|
+
const currentItem = { action: type, records: [] };
|
153
|
+
if (limit.records.length == 0)
|
154
|
+
continue;
|
155
|
+
for (const record of limit.records) {
|
156
|
+
const segmentRecord = limits.userSegment.dayItems.find(item => item.daysCount == record.daysCount);
|
157
|
+
if (segmentRecord == null) {
|
158
|
+
throw new Error(`Invalid response during get limits in organization: ${this.id}. Days count with ${type} not found in segment ${limits.userSegment.key}`);
|
159
|
+
}
|
160
|
+
const actionRecord = segmentRecord === null || segmentRecord === void 0 ? void 0 : segmentRecord.actionItems.find(item => item.type == type);
|
161
|
+
if (actionRecord == null) {
|
162
|
+
throw new Error(`Invalid response during get limits in organization: ${this.id}. Type ${type} not found in segment ${limits.userSegment.key}`);
|
163
|
+
}
|
164
|
+
const currentRecord = {};
|
165
|
+
currentRecord.daysCount = record.daysCount;
|
166
|
+
currentRecord.activeTill = record.activeTill;
|
167
|
+
currentRecord.all = (_b = actionRecord === null || actionRecord === void 0 ? void 0 : actionRecord.tokenLimit) !== null && _b !== void 0 ? _b : actionRecord === null || actionRecord === void 0 ? void 0 : actionRecord.countLimit;
|
168
|
+
const available = (_c = record.tokenLimit) !== null && _c !== void 0 ? _c : record.countLimit;
|
169
|
+
currentRecord.used = currentRecord.all - available;
|
170
|
+
currentItem.records.push(currentRecord);
|
171
|
+
}
|
172
|
+
currentLimits.limits.push(currentItem);
|
173
|
+
}
|
174
|
+
return currentLimits;
|
175
|
+
}
|
176
|
+
async organizationLimits() {
|
177
|
+
var _a;
|
178
|
+
// fetch limits
|
179
|
+
const response = await ((_a = this.context.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Descriptions/limits/organization").searchParam("organizationId", this.id).sendGet());
|
180
|
+
// check response status
|
181
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
182
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to get limits in organization: ${this.id}`, response);
|
183
|
+
}
|
184
|
+
const json = await response.json();
|
185
|
+
// parse limits from the server's response
|
186
|
+
const limits = json.segment;
|
187
|
+
return limits;
|
188
|
+
}
|
189
|
+
async limitSegments() {
|
190
|
+
var _a;
|
191
|
+
// fetch limits
|
192
|
+
const response = await ((_a = this.context.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Descriptions/limits/segments").searchParam("organizationId", this.id).sendGet());
|
193
|
+
// check response status
|
194
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
195
|
+
await responseUtils_1.ResponseUtils.throwError(`Failed to get limits in organization: ${this.id}`, response);
|
196
|
+
}
|
197
|
+
const json = await response.json();
|
198
|
+
// parse limits from the server's response
|
199
|
+
const limits = json.segments;
|
200
|
+
return limits;
|
201
|
+
}
|
202
|
+
async inviteUsers(emails, accessGroups) {
|
203
|
+
var _a;
|
204
|
+
const response = await ((_a = this.context
|
205
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Invites").sendPostJson({
|
206
|
+
organizationId: this.id,
|
207
|
+
emails: emails,
|
208
|
+
accessGroupIds: accessGroups
|
209
|
+
}));
|
210
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
211
|
+
await responseUtils_1.ResponseUtils.throwError(`Invite users failed for organization ${this.id}`, response);
|
212
|
+
}
|
213
|
+
}
|
214
|
+
async createInviteCode(accessGroups) {
|
215
|
+
var _a;
|
216
|
+
const response = await ((_a = this.context
|
217
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Invites/link").sendPostJson({
|
218
|
+
organizationId: this.id,
|
219
|
+
accessGroupIds: accessGroups
|
220
|
+
}));
|
221
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
222
|
+
await responseUtils_1.ResponseUtils.throwError(`Invite code creation failed for organization ${this.id}`, response);
|
223
|
+
}
|
224
|
+
const json = await response.json();
|
225
|
+
const code = json.code;
|
226
|
+
return code;
|
227
|
+
}
|
228
|
+
async validateInviteCode(code) {
|
229
|
+
var _a;
|
230
|
+
const response = await ((_a = this.context
|
231
|
+
.resolve(rpcService_1.RpcService)) === null || _a === void 0 ? void 0 : _a.requestBuilder("api/v1/Invites/apply").sendPutJson({
|
232
|
+
code: code,
|
233
|
+
}));
|
234
|
+
if (responseUtils_1.ResponseUtils.isFail(response)) {
|
235
|
+
await responseUtils_1.ResponseUtils.throwError(`Invite code validation failed for organization ${this.id}`, response);
|
236
|
+
}
|
237
|
+
}
|
238
|
+
}
|
239
|
+
exports.OrganizationImpl = OrganizationImpl;
|
240
|
+
//# sourceMappingURL=organization.impl.js.map
|