@intuitionrobotics/permissions 0.47.59 → 1.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +3 -0
- package/dist/app-backend/api/v1/permissions/_imports.d.ts +3 -0
- package/dist/app-backend/api/v1/permissions/_imports.d.ts.map +1 -0
- package/{shared/assign-types.js → dist/app-backend/api/v1/permissions/_imports.js} +3 -3
- package/{app-backend → dist/app-backend}/api/v1/permissions/_imports.js.map +1 -1
- package/dist/app-backend/api/v1/permissions/_permissions.d.ts +4 -0
- package/dist/app-backend/api/v1/permissions/_permissions.d.ts.map +1 -0
- package/{app-backend → dist/app-backend}/api/v1/permissions/_permissions.js +2 -4
- package/dist/app-backend/api/v1/permissions/_permissions.js.map +1 -0
- package/dist/app-backend/api/v1/permissions/assert.d.ts +10 -0
- package/dist/app-backend/api/v1/permissions/assert.d.ts.map +1 -0
- package/dist/app-backend/api/v1/permissions/assert.js +36 -0
- package/dist/app-backend/api/v1/permissions/assert.js.map +1 -0
- package/dist/app-backend/api/v1/permissions/assign/apis.d.ts +4 -0
- package/dist/app-backend/api/v1/permissions/assign/apis.d.ts.map +1 -0
- package/{app-backend → dist/app-backend}/api/v1/permissions/assign/apis.js +6 -7
- package/dist/app-backend/api/v1/permissions/assign/apis.js.map +1 -0
- package/dist/app-backend/api/v1/permissions/assign/app-permissions.d.ts +10 -0
- package/dist/app-backend/api/v1/permissions/assign/app-permissions.d.ts.map +1 -0
- package/dist/app-backend/api/v1/permissions/assign/app-permissions.js +42 -0
- package/dist/app-backend/api/v1/permissions/assign/app-permissions.js.map +1 -0
- package/dist/app-backend/api/v1/permissions/manage/apis.d.ts +4 -0
- package/dist/app-backend/api/v1/permissions/manage/apis.d.ts.map +1 -0
- package/{app-backend → dist/app-backend}/api/v1/permissions/manage/apis.js +8 -9
- package/dist/app-backend/api/v1/permissions/manage/apis.js.map +1 -0
- package/dist/app-backend/api/v1/permissions/tags/apis.d.ts +3 -0
- package/dist/app-backend/api/v1/permissions/tags/apis.d.ts.map +1 -0
- package/dist/app-backend/api/v1/permissions/tags/apis.js +3 -0
- package/{app-backend → dist/app-backend}/api/v1/permissions/tags/apis.js.map +1 -1
- package/dist/app-backend/api/v1/permissions/user-urls-permissions.d.ts +9 -0
- package/dist/app-backend/api/v1/permissions/user-urls-permissions.d.ts.map +1 -0
- package/dist/app-backend/api/v1/permissions/user-urls-permissions.js +34 -0
- package/dist/app-backend/api/v1/permissions/user-urls-permissions.js.map +1 -0
- package/dist/app-backend/api/v1/register/_register-project.d.ts +4 -0
- package/dist/app-backend/api/v1/register/_register-project.d.ts.map +1 -0
- package/dist/app-backend/api/v1/register/_register-project.js +20 -0
- package/dist/app-backend/api/v1/register/_register-project.js.map +1 -0
- package/dist/app-backend/api/v1/register/register-external-project.d.ts +9 -0
- package/dist/app-backend/api/v1/register/register-external-project.d.ts.map +1 -0
- package/dist/app-backend/api/v1/register/register-external-project.js +33 -0
- package/dist/app-backend/api/v1/register/register-external-project.js.map +1 -0
- package/dist/app-backend/api/v1/register/register-project.d.ts +11 -0
- package/dist/app-backend/api/v1/register/register-project.d.ts.map +1 -0
- package/dist/app-backend/api/v1/register/register-project.js +16 -0
- package/dist/app-backend/api/v1/register/register-project.js.map +1 -0
- package/dist/app-backend/api/v1/test/_imports.d.ts +2 -0
- package/dist/app-backend/api/v1/test/_imports.d.ts.map +1 -0
- package/dist/app-backend/api/v1/test/_imports.js +19 -0
- package/{app-backend → dist/app-backend}/api/v1/test/_imports.js.map +1 -1
- package/dist/app-backend/api/v1/test/_test-permissions.d.ts +4 -0
- package/dist/app-backend/api/v1/test/_test-permissions.d.ts.map +1 -0
- package/dist/app-backend/api/v1/test/_test-permissions.js +20 -0
- package/dist/app-backend/api/v1/test/_test-permissions.js.map +1 -0
- package/dist/app-backend/api/v1/test/test-permissions.d.ts +10 -0
- package/dist/app-backend/api/v1/test/test-permissions.d.ts.map +1 -0
- package/dist/app-backend/api/v1/test/test-permissions.js +34 -0
- package/dist/app-backend/api/v1/test/test-permissions.js.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/_user-custom-fields.d.ts +4 -0
- package/dist/app-backend/api/v1/user-custom-fields/_user-custom-fields.d.ts.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/_user-custom-fields.js +20 -0
- package/dist/app-backend/api/v1/user-custom-fields/_user-custom-fields.js.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.d.ts +9 -0
- package/dist/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.d.ts.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.js +17 -0
- package/dist/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.js.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.d.ts +9 -0
- package/dist/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.d.ts.map +1 -0
- package/dist/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.js +15 -0
- package/dist/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.js.map +1 -0
- package/{app-backend → dist/app-backend}/benchmark/permission-user-assert-benchmark.d.ts +1 -0
- package/dist/app-backend/benchmark/permission-user-assert-benchmark.d.ts.map +1 -0
- package/dist/app-backend/benchmark/permission-user-assert-benchmark.js +92 -0
- package/dist/app-backend/benchmark/permission-user-assert-benchmark.js.map +1 -0
- package/dist/app-backend/core/module-pack.d.ts +7 -0
- package/dist/app-backend/core/module-pack.d.ts.map +1 -0
- package/dist/app-backend/core/module-pack.js +39 -0
- package/dist/app-backend/core/module-pack.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/PermissionsModule.d.ts +3 -2
- package/dist/app-backend/modules/PermissionsModule.d.ts.map +1 -0
- package/dist/app-backend/modules/PermissionsModule.js +119 -0
- package/dist/app-backend/modules/PermissionsModule.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/TagsModule.d.ts +5 -4
- package/dist/app-backend/modules/TagsModule.d.ts.map +1 -0
- package/dist/app-backend/modules/TagsModule.js +36 -0
- package/dist/app-backend/modules/TagsModule.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/_imports.d.ts +4 -3
- package/dist/app-backend/modules/_imports.d.ts.map +1 -0
- package/{app-backend/api/v1/test → dist/app-backend/modules}/_imports.js +9 -5
- package/dist/app-backend/modules/_imports.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/db-types/assign.d.ts +7 -6
- package/dist/app-backend/modules/db-types/assign.d.ts.map +1 -0
- package/dist/app-backend/modules/db-types/assign.js +251 -0
- package/dist/app-backend/modules/db-types/assign.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/db-types/managment.d.ts +5 -4
- package/dist/app-backend/modules/db-types/managment.d.ts.map +1 -0
- package/dist/app-backend/modules/db-types/managment.js +210 -0
- package/dist/app-backend/modules/db-types/managment.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/permissions-assert.d.ts +4 -3
- package/dist/app-backend/modules/permissions-assert.d.ts.map +1 -0
- package/dist/app-backend/modules/permissions-assert.js +226 -0
- package/dist/app-backend/modules/permissions-assert.js.map +1 -0
- package/{app-backend → dist/app-backend}/modules/permissions-share.d.ts +2 -1
- package/dist/app-backend/modules/permissions-share.d.ts.map +1 -0
- package/dist/app-backend/modules/permissions-share.js +13 -0
- package/dist/app-backend/modules/permissions-share.js.map +1 -0
- package/dist/app-frontend/core/module-pack.d.ts +9 -0
- package/dist/app-frontend/core/module-pack.d.ts.map +1 -0
- package/dist/app-frontend/core/module-pack.js +41 -0
- package/dist/app-frontend/core/module-pack.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/PermissionsComponent.d.ts +2 -1
- package/dist/app-frontend/modules/PermissionsComponent.d.ts.map +1 -0
- package/dist/app-frontend/modules/PermissionsComponent.js +19 -0
- package/dist/app-frontend/modules/PermissionsComponent.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/PermissionsModuleFE.d.ts +1 -0
- package/dist/app-frontend/modules/PermissionsModuleFE.d.ts.map +1 -0
- package/dist/app-frontend/modules/PermissionsModuleFE.js +80 -0
- package/dist/app-frontend/modules/PermissionsModuleFE.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/assign/ApiCaller_PermissionsGroup.d.ts +6 -5
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsGroup.d.ts.map +1 -0
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsGroup.js +50 -0
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsGroup.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/assign/ApiCaller_PermissionsUser.d.ts +6 -5
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsUser.d.ts.map +1 -0
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsUser.js +50 -0
- package/dist/app-frontend/modules/assign/ApiCaller_PermissionsUser.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/manage/ApiCaller_PermissionsApi.d.ts +6 -5
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsApi.d.ts.map +1 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsApi.js +55 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsApi.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/manage/ApiCaller_PermissionsDomain.d.ts +6 -5
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsDomain.d.ts.map +1 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsDomain.js +61 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsDomain.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/manage/ApiCaller_PermissionsLevel.d.ts +6 -5
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsLevel.d.ts.map +1 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsLevel.js +61 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsLevel.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/manage/ApiCaller_PermissionsProject.d.ts +6 -5
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsProject.d.ts.map +1 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsProject.js +60 -0
- package/dist/app-frontend/modules/manage/ApiCaller_PermissionsProject.js.map +1 -0
- package/{app-frontend → dist/app-frontend}/modules/tags/ApiCaller_PermissionsTags.d.ts +6 -5
- package/dist/app-frontend/modules/tags/ApiCaller_PermissionsTags.d.ts.map +1 -0
- package/dist/app-frontend/modules/tags/ApiCaller_PermissionsTags.js +33 -0
- package/dist/app-frontend/modules/tags/ApiCaller_PermissionsTags.js.map +1 -0
- package/dist/backend.d.ts +2 -0
- package/dist/backend.d.ts.map +1 -0
- package/{shared/apis.js → dist/backend.js} +2 -3
- package/dist/backend.js.map +1 -0
- package/dist/frontend.d.ts +4 -0
- package/dist/frontend.d.ts.map +1 -0
- package/dist/frontend.js +21 -0
- package/dist/frontend.js.map +1 -0
- package/dist/index.d.ts +4 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +21 -0
- package/dist/index.js.map +1 -0
- package/{shared → dist/shared}/apis.d.ts +6 -5
- package/dist/shared/apis.d.ts.map +1 -0
- package/dist/shared/apis.js +23 -0
- package/dist/shared/apis.js.map +1 -0
- package/{shared → dist/shared}/assign-types.d.ts +3 -2
- package/dist/shared/assign-types.d.ts.map +1 -0
- package/{shared/manager-types.js → dist/shared/assign-types.js} +3 -3
- package/{shared → dist/shared}/assign-types.js.map +1 -1
- package/{shared → dist/shared}/manager-types.d.ts +3 -2
- package/dist/shared/manager-types.d.ts.map +1 -0
- package/dist/shared/manager-types.js +20 -0
- package/{shared → dist/shared}/manager-types.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/package.json +66 -17
- package/app-backend/api/v1/permissions/_imports.d.ts +0 -2
- package/app-backend/api/v1/permissions/_imports.js +0 -36
- package/app-backend/api/v1/permissions/_permissions.d.ts +0 -1
- package/app-backend/api/v1/permissions/_permissions.js.map +0 -1
- package/app-backend/api/v1/permissions/assert.d.ts +0 -1
- package/app-backend/api/v1/permissions/assert.js +0 -47
- package/app-backend/api/v1/permissions/assert.js.map +0 -1
- package/app-backend/api/v1/permissions/assign/apis.d.ts +0 -1
- package/app-backend/api/v1/permissions/assign/apis.js.map +0 -1
- package/app-backend/api/v1/permissions/assign/app-permissions.d.ts +0 -1
- package/app-backend/api/v1/permissions/assign/app-permissions.js +0 -55
- package/app-backend/api/v1/permissions/assign/app-permissions.js.map +0 -1
- package/app-backend/api/v1/permissions/manage/apis.d.ts +0 -1
- package/app-backend/api/v1/permissions/manage/apis.js.map +0 -1
- package/app-backend/api/v1/permissions/tags/apis.d.ts +0 -1
- package/app-backend/api/v1/permissions/tags/apis.js +0 -5
- package/app-backend/api/v1/permissions/user-urls-permissions.d.ts +0 -1
- package/app-backend/api/v1/permissions/user-urls-permissions.js +0 -46
- package/app-backend/api/v1/permissions/user-urls-permissions.js.map +0 -1
- package/app-backend/api/v1/register/_register-project.d.ts +0 -1
- package/app-backend/api/v1/register/_register-project.js +0 -22
- package/app-backend/api/v1/register/_register-project.js.map +0 -1
- package/app-backend/api/v1/register/register-external-project.d.ts +0 -6
- package/app-backend/api/v1/register/register-external-project.js +0 -46
- package/app-backend/api/v1/register/register-external-project.js.map +0 -1
- package/app-backend/api/v1/register/register-project.d.ts +0 -8
- package/app-backend/api/v1/register/register-project.js +0 -29
- package/app-backend/api/v1/register/register-project.js.map +0 -1
- package/app-backend/api/v1/test/_imports.d.ts +0 -1
- package/app-backend/api/v1/test/_test-permissions.d.ts +0 -1
- package/app-backend/api/v1/test/_test-permissions.js +0 -22
- package/app-backend/api/v1/test/_test-permissions.js.map +0 -1
- package/app-backend/api/v1/test/test-permissions.d.ts +0 -1
- package/app-backend/api/v1/test/test-permissions.js +0 -45
- package/app-backend/api/v1/test/test-permissions.js.map +0 -1
- package/app-backend/api/v1/user-custom-fields/_user-custom-fields.d.ts +0 -1
- package/app-backend/api/v1/user-custom-fields/_user-custom-fields.js +0 -22
- package/app-backend/api/v1/user-custom-fields/_user-custom-fields.js.map +0 -1
- package/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.d.ts +0 -6
- package/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.js +0 -31
- package/app-backend/api/v1/user-custom-fields/user-cf-by-share-groups.js.map +0 -1
- package/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.d.ts +0 -6
- package/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.js +0 -30
- package/app-backend/api/v1/user-custom-fields/users-cf-by-share-groups.js.map +0 -1
- package/app-backend/benchmark/permission-user-assert-benchmark.js +0 -108
- package/app-backend/benchmark/permission-user-assert-benchmark.js.map +0 -1
- package/app-backend/core/module-pack.d.ts +0 -6
- package/app-backend/core/module-pack.js +0 -56
- package/app-backend/core/module-pack.js.map +0 -1
- package/app-backend/modules/PermissionsModule.js +0 -140
- package/app-backend/modules/PermissionsModule.js.map +0 -1
- package/app-backend/modules/TagsModule.js +0 -51
- package/app-backend/modules/TagsModule.js.map +0 -1
- package/app-backend/modules/_imports.js +0 -44
- package/app-backend/modules/_imports.js.map +0 -1
- package/app-backend/modules/db-types/assign.js +0 -288
- package/app-backend/modules/db-types/assign.js.map +0 -1
- package/app-backend/modules/db-types/managment.js +0 -242
- package/app-backend/modules/db-types/managment.js.map +0 -1
- package/app-backend/modules/permissions-assert.js +0 -250
- package/app-backend/modules/permissions-assert.js.map +0 -1
- package/app-backend/modules/permissions-share.js +0 -27
- package/app-backend/modules/permissions-share.js.map +0 -1
- package/app-frontend/core/module-pack.d.ts +0 -8
- package/app-frontend/core/module-pack.js +0 -58
- package/app-frontend/core/module-pack.js.map +0 -1
- package/app-frontend/modules/PermissionsComponent.js +0 -23
- package/app-frontend/modules/PermissionsComponent.js.map +0 -1
- package/app-frontend/modules/PermissionsModuleFE.js +0 -92
- package/app-frontend/modules/PermissionsModuleFE.js.map +0 -1
- package/app-frontend/modules/assign/ApiCaller_PermissionsGroup.js +0 -55
- package/app-frontend/modules/assign/ApiCaller_PermissionsGroup.js.map +0 -1
- package/app-frontend/modules/assign/ApiCaller_PermissionsUser.js +0 -72
- package/app-frontend/modules/assign/ApiCaller_PermissionsUser.js.map +0 -1
- package/app-frontend/modules/manage/ApiCaller_PermissionsApi.js +0 -76
- package/app-frontend/modules/manage/ApiCaller_PermissionsApi.js.map +0 -1
- package/app-frontend/modules/manage/ApiCaller_PermissionsDomain.js +0 -83
- package/app-frontend/modules/manage/ApiCaller_PermissionsDomain.js.map +0 -1
- package/app-frontend/modules/manage/ApiCaller_PermissionsLevel.js +0 -83
- package/app-frontend/modules/manage/ApiCaller_PermissionsLevel.js.map +0 -1
- package/app-frontend/modules/manage/ApiCaller_PermissionsProject.js +0 -82
- package/app-frontend/modules/manage/ApiCaller_PermissionsProject.js.map +0 -1
- package/app-frontend/modules/tags/ApiCaller_PermissionsTags.js +0 -55
- package/app-frontend/modules/tags/ApiCaller_PermissionsTags.js.map +0 -1
- package/backend.d.ts +0 -1
- package/backend.js +0 -35
- package/backend.js.map +0 -1
- package/frontend.d.ts +0 -3
- package/frontend.js +0 -37
- package/frontend.js.map +0 -1
- package/index.d.ts +0 -3
- package/index.js +0 -37
- package/index.js.map +0 -1
- package/shared/apis.js.map +0 -1
|
@@ -1,250 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* ts-common is the basic building blocks of our typescript projects
|
|
4
|
-
*
|
|
5
|
-
* Copyright (C) 2020 Intuition Robotics
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
20
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
21
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
22
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
23
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
24
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
25
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
26
|
-
});
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.PermissionsAssert = exports.PermissionsAssert_Class = void 0;
|
|
30
|
-
const ts_common_1 = require("@intuitionrobotics/ts-common");
|
|
31
|
-
const backend_1 = require("@intuitionrobotics/thunderstorm/backend");
|
|
32
|
-
const managment_1 = require("./db-types/managment");
|
|
33
|
-
const assign_1 = require("./db-types/assign");
|
|
34
|
-
const thunderstorm_1 = require("@intuitionrobotics/thunderstorm");
|
|
35
|
-
const backend_2 = require("@intuitionrobotics/user-account/backend");
|
|
36
|
-
const PermissionsModule_1 = require("./PermissionsModule");
|
|
37
|
-
class PermissionsAssert_Class extends ts_common_1.Module {
|
|
38
|
-
constructor() {
|
|
39
|
-
super("PermissionsAssert");
|
|
40
|
-
this.Middleware = (keys) => (req, data, response, scopes) => __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
let account;
|
|
42
|
-
yield this.CustomMiddleware(keys, (projectId, customFields) => __awaiter(this, void 0, void 0, function* () {
|
|
43
|
-
account = yield backend_2.AccountModule.validateSession(req, scopes, response);
|
|
44
|
-
yield this.assertUserPermissions(projectId, data.url, account._id, customFields);
|
|
45
|
-
}))(req, data, response, scopes);
|
|
46
|
-
return { account };
|
|
47
|
-
});
|
|
48
|
-
this.CustomMiddleware = (keys, action) => (req, data, response) => __awaiter(this, void 0, void 0, function* () {
|
|
49
|
-
const customFields = {};
|
|
50
|
-
let object;
|
|
51
|
-
switch (data.method) {
|
|
52
|
-
case thunderstorm_1.HttpMethod.POST:
|
|
53
|
-
case thunderstorm_1.HttpMethod.PATCH:
|
|
54
|
-
case thunderstorm_1.HttpMethod.PUT:
|
|
55
|
-
object = data.body;
|
|
56
|
-
break;
|
|
57
|
-
case thunderstorm_1.HttpMethod.GET:
|
|
58
|
-
case thunderstorm_1.HttpMethod.DELETE:
|
|
59
|
-
object = data.query;
|
|
60
|
-
break;
|
|
61
|
-
default:
|
|
62
|
-
throw new ts_common_1.BadImplementationException(`Generic custom fields cannot be extracted on api with method: ${data.method}`);
|
|
63
|
-
}
|
|
64
|
-
(0, ts_common_1._keys)(object).filter(key => keys.includes(key)).forEach(key => {
|
|
65
|
-
const oElement = object[key];
|
|
66
|
-
if (oElement === undefined || oElement === null)
|
|
67
|
-
return;
|
|
68
|
-
if (typeof oElement !== "string")
|
|
69
|
-
return;
|
|
70
|
-
customFields[key] = oElement;
|
|
71
|
-
});
|
|
72
|
-
const projectId = PermissionsModule_1.PermissionsModule.getProjectIdentity()._id;
|
|
73
|
-
yield action(projectId, customFields);
|
|
74
|
-
});
|
|
75
|
-
}
|
|
76
|
-
assertUserPermissions(projectId, path, userId, requestCustomField) {
|
|
77
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
78
|
-
const [apiDetails, userDetails] = yield Promise.all([
|
|
79
|
-
this.getApiDetails(path, projectId),
|
|
80
|
-
this.getUserDetails(userId)
|
|
81
|
-
]);
|
|
82
|
-
this._assertUserPermissionsImpl(apiDetails, projectId, userDetails, requestCustomField);
|
|
83
|
-
});
|
|
84
|
-
}
|
|
85
|
-
_assertUserPermissionsImpl(apiDetails, projectId, userDetails, requestCustomField) {
|
|
86
|
-
if (!apiDetails.apiDb.accessLevelIds) {
|
|
87
|
-
if (!this.config.strictMode)
|
|
88
|
-
return;
|
|
89
|
-
throw new backend_1.ApiException(403, `No permissions configuration specified for api: ${projectId}--${apiDetails.apiDb.path}`);
|
|
90
|
-
}
|
|
91
|
-
this.assertUserPermissionsImpl(userDetails.userGroups, apiDetails.requestPermissions, [requestCustomField]);
|
|
92
|
-
}
|
|
93
|
-
assertUserSharingGroup(granterUserId, userGroup) {
|
|
94
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
95
|
-
const [granterUser, groupToShare] = yield Promise.all([this.getUserDetails(granterUserId), assign_1.GroupPermissionsDB.queryUnique({ _id: userGroup.groupId })]);
|
|
96
|
-
groupToShare.customFields = this.getCombineUserGroupCF(userGroup, groupToShare);
|
|
97
|
-
const requestPermissions = yield this.getAccessLevels(groupToShare.accessLevelIds || []);
|
|
98
|
-
const requestCustomFields = groupToShare.customFields;
|
|
99
|
-
this.assertUserPermissionsImpl(granterUser.userGroups, requestPermissions, requestCustomFields);
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
assertUserPermissionsImpl(userGroups, requestPermissions, requestCustomFields) {
|
|
103
|
-
if (!requestPermissions.length)
|
|
104
|
-
return;
|
|
105
|
-
const requestPairWithLevelsObj = { accessLevels: requestPermissions, customFields: requestCustomFields };
|
|
106
|
-
let groupMatch = false;
|
|
107
|
-
const groupsMatchArray = userGroups.map(group => {
|
|
108
|
-
const groupPairWithLevelsObj = { accessLevels: group.__accessLevels || [], customFields: group.customFields || [] };
|
|
109
|
-
return this.isMatchWithLevelsObj(groupPairWithLevelsObj, requestPairWithLevelsObj);
|
|
110
|
-
});
|
|
111
|
-
for (const match of groupsMatchArray) {
|
|
112
|
-
if (match)
|
|
113
|
-
groupMatch = true;
|
|
114
|
-
}
|
|
115
|
-
if (!groupMatch) {
|
|
116
|
-
throw new backend_1.ApiException(403, "Action Forbidden");
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
getUserDetails(uuid) {
|
|
120
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
121
|
-
const user = yield assign_1.UserPermissionsDB.queryUnique({ accountId: uuid });
|
|
122
|
-
const userGroups = (0, ts_common_1.filterDuplicates)(user.groups || []);
|
|
123
|
-
const groups = yield (0, ts_common_1.batchActionParallel)(userGroups.map(userGroup => userGroup.groupId), 10, subGroupIds => assign_1.GroupPermissionsDB.query({ where: { _id: { $in: subGroupIds } } }));
|
|
124
|
-
return {
|
|
125
|
-
user,
|
|
126
|
-
userGroups: this.getCombineUserGroups(userGroups, groups)
|
|
127
|
-
};
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
getCombineUserGroupCF(userGroup, group) {
|
|
131
|
-
const cfArray = [];
|
|
132
|
-
if (group.customFields) {
|
|
133
|
-
cfArray.push(...group.customFields);
|
|
134
|
-
}
|
|
135
|
-
if (userGroup.customField) {
|
|
136
|
-
cfArray.push(userGroup.customField);
|
|
137
|
-
}
|
|
138
|
-
return cfArray;
|
|
139
|
-
}
|
|
140
|
-
getCombineUserGroups(userGroups, groups) {
|
|
141
|
-
const combinedGroups = [];
|
|
142
|
-
groups.forEach(group => {
|
|
143
|
-
const existUserGroupItem = userGroups.find(groupItem => groupItem.groupId === group._id);
|
|
144
|
-
if (!existUserGroupItem)
|
|
145
|
-
throw new ts_common_1.BadImplementationException("You are missing group in your code implementation");
|
|
146
|
-
userGroups.forEach((userGroup) => {
|
|
147
|
-
if (userGroup.groupId === group._id) {
|
|
148
|
-
combinedGroups.push(Object.assign(Object.assign({}, group), { customFields: this.getCombineUserGroupCF(userGroup, group) }));
|
|
149
|
-
}
|
|
150
|
-
});
|
|
151
|
-
});
|
|
152
|
-
return combinedGroups;
|
|
153
|
-
}
|
|
154
|
-
getApiDetails(_path, projectId) {
|
|
155
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
156
|
-
const path = _path.substring(0, (_path + '?').indexOf('?'));
|
|
157
|
-
const apiDb = yield managment_1.ApiPermissionsDB.queryUnique({ path, projectId });
|
|
158
|
-
const requestPermissions = yield this.getAccessLevels(apiDb.accessLevelIds || []);
|
|
159
|
-
return {
|
|
160
|
-
apiDb,
|
|
161
|
-
requestPermissions
|
|
162
|
-
};
|
|
163
|
-
});
|
|
164
|
-
}
|
|
165
|
-
getApisDetails(urls, projectId) {
|
|
166
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
167
|
-
const paths = urls.map(_path => _path.substring(0, (_path + '?').indexOf('?')));
|
|
168
|
-
const apiDbs = yield (0, ts_common_1.batchActionParallel)(paths, 10, elements => managment_1.ApiPermissionsDB.query({ where: { projectId, path: { $in: elements } } }));
|
|
169
|
-
return Promise.all(paths.map((path) => __awaiter(this, void 0, void 0, function* () {
|
|
170
|
-
const apiDb = apiDbs.find(_apiDb => _apiDb.path === path);
|
|
171
|
-
if (!apiDb)
|
|
172
|
-
return;
|
|
173
|
-
try {
|
|
174
|
-
const requestPermissions = yield this.getAccessLevels(apiDb.accessLevelIds);
|
|
175
|
-
return ({
|
|
176
|
-
apiDb,
|
|
177
|
-
requestPermissions
|
|
178
|
-
});
|
|
179
|
-
}
|
|
180
|
-
catch (e) {
|
|
181
|
-
return;
|
|
182
|
-
}
|
|
183
|
-
})));
|
|
184
|
-
});
|
|
185
|
-
}
|
|
186
|
-
getAccessLevels(_accessLevelIds) {
|
|
187
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
188
|
-
const accessLevelIds = (0, ts_common_1.filterDuplicates)(_accessLevelIds || []);
|
|
189
|
-
const requestPermissions = yield (0, ts_common_1.batchActionParallel)(accessLevelIds, 10, elements => managment_1.AccessLevelPermissionsDB.query({ where: { _id: { $in: elements } } }));
|
|
190
|
-
const idNotFound = accessLevelIds.find(lId => !requestPermissions.find(r => r._id === lId));
|
|
191
|
-
if (idNotFound)
|
|
192
|
-
throw new backend_1.ApiException(404, `Could not find api level with _id: ${idNotFound}`);
|
|
193
|
-
return requestPermissions;
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
isMatchWithLevelsObj(groupPair, requestPair) {
|
|
197
|
-
let match = true;
|
|
198
|
-
requestPair.customFields.forEach(requestCF => {
|
|
199
|
-
if (!this.doesCustomFieldsSatisfies(groupPair.customFields, requestCF))
|
|
200
|
-
match = false;
|
|
201
|
-
});
|
|
202
|
-
if (!match)
|
|
203
|
-
return false;
|
|
204
|
-
const groupDomainLevelMap = this.getDomainLevelMap(groupPair.accessLevels);
|
|
205
|
-
requestPair.accessLevels.forEach((requiredLevel, index) => {
|
|
206
|
-
const userAccessLevel = groupDomainLevelMap[requiredLevel.domainId];
|
|
207
|
-
if (userAccessLevel === undefined || userAccessLevel < requiredLevel.value)
|
|
208
|
-
match = false;
|
|
209
|
-
});
|
|
210
|
-
return match;
|
|
211
|
-
}
|
|
212
|
-
getDomainLevelMap(accessLevels) {
|
|
213
|
-
return accessLevels.reduce((toRet, accessLevel) => {
|
|
214
|
-
const levelForDomain = toRet[accessLevel.domainId];
|
|
215
|
-
if (!levelForDomain || levelForDomain < accessLevel.value)
|
|
216
|
-
toRet[accessLevel.domainId] = accessLevel.value;
|
|
217
|
-
return toRet;
|
|
218
|
-
}, {});
|
|
219
|
-
}
|
|
220
|
-
doesCustomFieldsSatisfies(groupCustomFields = [], requestCustomField) {
|
|
221
|
-
if (!Object.keys(requestCustomField).length)
|
|
222
|
-
return true;
|
|
223
|
-
for (const customField of groupCustomFields) {
|
|
224
|
-
if (this.doesCustomFieldSatisfies(customField, requestCustomField))
|
|
225
|
-
return true;
|
|
226
|
-
}
|
|
227
|
-
return false;
|
|
228
|
-
}
|
|
229
|
-
doesCustomFieldSatisfies(groupCustomField, requestCustomField) {
|
|
230
|
-
return Object.keys(requestCustomField).reduce((doesSatisfies, requestCustomFieldKey) => {
|
|
231
|
-
const customFieldRegEx = this.getRegEx(groupCustomField[requestCustomFieldKey]);
|
|
232
|
-
return doesSatisfies && customFieldRegEx.test(requestCustomField[requestCustomFieldKey]);
|
|
233
|
-
}, true);
|
|
234
|
-
}
|
|
235
|
-
getRegEx(value) {
|
|
236
|
-
if (!value)
|
|
237
|
-
return new RegExp(`^${value}$`, "g");
|
|
238
|
-
let regExValue = value;
|
|
239
|
-
const startRegEx = '^';
|
|
240
|
-
const endRegEx = '$';
|
|
241
|
-
if (value[0] !== startRegEx)
|
|
242
|
-
regExValue = startRegEx + regExValue;
|
|
243
|
-
if (value[value.length - 1] !== endRegEx)
|
|
244
|
-
regExValue = regExValue + endRegEx;
|
|
245
|
-
return new RegExp(regExValue, "g");
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
exports.PermissionsAssert_Class = PermissionsAssert_Class;
|
|
249
|
-
exports.PermissionsAssert = new PermissionsAssert_Class();
|
|
250
|
-
//# sourceMappingURL=permissions-assert.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"permissions-assert.js","sourceRoot":"","sources":["../../../src/main/app-backend/modules/permissions-assert.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.PermissionsShare = exports.PermissionsShare_Class = void 0;
|
|
13
|
-
const ts_common_1 = require("@intuitionrobotics/ts-common");
|
|
14
|
-
const permissions_assert_1 = require("./permissions-assert");
|
|
15
|
-
class PermissionsShare_Class extends ts_common_1.Module {
|
|
16
|
-
constructor() {
|
|
17
|
-
super("PermissionsShare");
|
|
18
|
-
}
|
|
19
|
-
verifyPermissionGrantingAllowed(granterUserId, shareGroup) {
|
|
20
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
21
|
-
yield permissions_assert_1.PermissionsAssert.assertUserSharingGroup(granterUserId, shareGroup);
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
exports.PermissionsShare_Class = PermissionsShare_Class;
|
|
26
|
-
exports.PermissionsShare = new PermissionsShare_Class();
|
|
27
|
-
//# sourceMappingURL=permissions-share.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"permissions-share.js","sourceRoot":"","sources":["../../../src/main/app-backend/modules/permissions-share.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,4DAAoD;AAIpD,6DAE8B;AAG9B,MAAa,sBACZ,SAAQ,kBAAM;IAEd;QACC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAC3B,CAAC;IAEK,+BAA+B,CAAC,aAAqB,EAAE,UAAsB;;YAClF,MAAM,sCAAiB,CAAC,sBAAsB,CAAC,aAAa,EAAE,UAAU,CAAC,CAAC;QAC3E,CAAC;KAAA;CAED;AAXD,wDAWC;AAEY,QAAA,gBAAgB,GAAG,IAAI,sBAAsB,EAAE,CAAC"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
export declare const Frontend_ModulePack_Permissions: (import("../modules/assign/ApiCaller_PermissionsUser").PermissionsUserModule_Class | import("../modules/assign/ApiCaller_PermissionsGroup").PermissionsGroupModule_Class | import("../modules/manage/ApiCaller_PermissionsProject").PermissionsProjectModule_Class | import("../modules/manage/ApiCaller_PermissionsDomain").PermissionsDomainModule_Class | import("../modules/manage/ApiCaller_PermissionsLevel").PermissionsAccessLevelModule_Class | import("../modules/manage/ApiCaller_PermissionsApi").PermissionsApiModule_Class | import("../modules/tags/ApiCaller_PermissionsTags").PermissionsTagsModule_Class)[];
|
|
2
|
-
export * from "../modules/assign/ApiCaller_PermissionsUser";
|
|
3
|
-
export * from "../modules/assign/ApiCaller_PermissionsGroup";
|
|
4
|
-
export * from "../modules/manage/ApiCaller_PermissionsProject";
|
|
5
|
-
export * from "../modules/manage/ApiCaller_PermissionsDomain";
|
|
6
|
-
export * from "../modules/manage/ApiCaller_PermissionsLevel";
|
|
7
|
-
export * from "../modules/manage/ApiCaller_PermissionsApi";
|
|
8
|
-
export * from "../modules/tags/ApiCaller_PermissionsTags";
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* ts-common is the basic building blocks of our typescript projects
|
|
4
|
-
*
|
|
5
|
-
* Copyright (C) 2020 Intuition Robotics
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
20
|
-
if (k2 === undefined) k2 = k;
|
|
21
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
22
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
23
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
24
|
-
}
|
|
25
|
-
Object.defineProperty(o, k2, desc);
|
|
26
|
-
}) : (function(o, m, k, k2) {
|
|
27
|
-
if (k2 === undefined) k2 = k;
|
|
28
|
-
o[k2] = m[k];
|
|
29
|
-
}));
|
|
30
|
-
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
31
|
-
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
32
|
-
};
|
|
33
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
34
|
-
exports.Frontend_ModulePack_Permissions = void 0;
|
|
35
|
-
const ApiCaller_PermissionsUser_1 = require("../modules/assign/ApiCaller_PermissionsUser");
|
|
36
|
-
const ApiCaller_PermissionsGroup_1 = require("../modules/assign/ApiCaller_PermissionsGroup");
|
|
37
|
-
const ApiCaller_PermissionsProject_1 = require("../modules/manage/ApiCaller_PermissionsProject");
|
|
38
|
-
const ApiCaller_PermissionsDomain_1 = require("../modules/manage/ApiCaller_PermissionsDomain");
|
|
39
|
-
const ApiCaller_PermissionsLevel_1 = require("../modules/manage/ApiCaller_PermissionsLevel");
|
|
40
|
-
const ApiCaller_PermissionsApi_1 = require("../modules/manage/ApiCaller_PermissionsApi");
|
|
41
|
-
const ApiCaller_PermissionsTags_1 = require("../modules/tags/ApiCaller_PermissionsTags");
|
|
42
|
-
exports.Frontend_ModulePack_Permissions = [
|
|
43
|
-
ApiCaller_PermissionsUser_1.ApiCaller_PermissionsUser,
|
|
44
|
-
ApiCaller_PermissionsGroup_1.ApiCaller_PermissionsGroup,
|
|
45
|
-
ApiCaller_PermissionsProject_1.ApiCaller_PermissionsProject,
|
|
46
|
-
ApiCaller_PermissionsDomain_1.ApiCaller_PermissionsDomain,
|
|
47
|
-
ApiCaller_PermissionsLevel_1.ApiCaller_PermissionsAccessLevel,
|
|
48
|
-
ApiCaller_PermissionsApi_1.ApiCaller_PermissionsApi,
|
|
49
|
-
ApiCaller_PermissionsTags_1.ApiCaller_PermissionsTags
|
|
50
|
-
];
|
|
51
|
-
__exportStar(require("../modules/assign/ApiCaller_PermissionsUser"), exports);
|
|
52
|
-
__exportStar(require("../modules/assign/ApiCaller_PermissionsGroup"), exports);
|
|
53
|
-
__exportStar(require("../modules/manage/ApiCaller_PermissionsProject"), exports);
|
|
54
|
-
__exportStar(require("../modules/manage/ApiCaller_PermissionsDomain"), exports);
|
|
55
|
-
__exportStar(require("../modules/manage/ApiCaller_PermissionsLevel"), exports);
|
|
56
|
-
__exportStar(require("../modules/manage/ApiCaller_PermissionsApi"), exports);
|
|
57
|
-
__exportStar(require("../modules/tags/ApiCaller_PermissionsTags"), exports);
|
|
58
|
-
//# sourceMappingURL=module-pack.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"module-pack.js","sourceRoot":"","sources":["../../../src/main/app-frontend/core/module-pack.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;GAgBG;;;;;;;;;;;;;;;;;AAEH,2FAAsF;AACtF,6FAAwF;AACxF,iGAA4F;AAC5F,+FAA0F;AAC1F,6FAA8F;AAC9F,yFAAoF;AACpF,yFAAoF;AAEvE,QAAA,+BAA+B,GAAG;IAC9C,qDAAyB;IACzB,uDAA0B;IAC1B,2DAA4B;IAC5B,yDAA2B;IAC3B,6DAAgC;IAChC,mDAAwB;IACxB,qDAAyB;CACzB,CAAC;AAEF,8EAA2D;AAC3D,+EAA4D;AAC5D,iFAA8D;AAC9D,gFAA6D;AAC7D,+EAA4D;AAC5D,6EAA0D;AAC1D,4EAAyD"}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.PermissionsComponent = void 0;
|
|
4
|
-
const React = require("react");
|
|
5
|
-
const frontend_1 = require("@intuitionrobotics/thunderstorm/frontend");
|
|
6
|
-
const PermissionsModuleFE_1 = require("./PermissionsModuleFE");
|
|
7
|
-
class PermissionsComponent extends frontend_1.BaseComponent {
|
|
8
|
-
__onPermissionsChanged() {
|
|
9
|
-
this.forceUpdate();
|
|
10
|
-
}
|
|
11
|
-
render() {
|
|
12
|
-
const permitted = PermissionsModuleFE_1.PermissionsFE.doesUserHavePermissions(this.props.url);
|
|
13
|
-
if (permitted === undefined)
|
|
14
|
-
return this.props.loadingComponent ? React.createElement(this.props.loadingComponent, null) : null;
|
|
15
|
-
if (permitted)
|
|
16
|
-
return this.props.children;
|
|
17
|
-
if (this.props.fallback)
|
|
18
|
-
return React.createElement(this.props.fallback, null);
|
|
19
|
-
return null;
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
exports.PermissionsComponent = PermissionsComponent;
|
|
23
|
-
//# sourceMappingURL=PermissionsComponent.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PermissionsComponent.js","sourceRoot":"","sources":["../../../src/main/app-frontend/modules/PermissionsComponent.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAC/B,uEAAuE;AACvE,+DAG+B;AAS/B,MAAa,oBACZ,SAAQ,wBAAoB;IAG5B,sBAAsB;QACrB,IAAI,CAAC,WAAW,EAAE,CAAC;IACpB,CAAC;IAED,MAAM;QACL,MAAM,SAAS,GAAG,mCAAa,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACxE,IAAI,SAAS,KAAK,SAAS;YAC1B,OAAO,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC,CAAC,oBAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,OAAE,CAAC,CAAC,CAAC,IAAI,CAAC;QAE5E,IAAI,SAAS;YACZ,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC;QAE5B,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ;YACtB,OAAO,oBAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,OAAE,CAAC;QAE/B,OAAO,IAAI,CAAC;IACb,CAAC;CACD;AArBD,oDAqBC"}
|
|
@@ -1,92 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.PermissionsFE = exports.PermissionsModuleFE_Class = void 0;
|
|
13
|
-
const ts_common_1 = require("@intuitionrobotics/ts-common");
|
|
14
|
-
const thunder_dispatcher_1 = require("@intuitionrobotics/thunderstorm/app-frontend/core/thunder-dispatcher");
|
|
15
|
-
const frontend_1 = require("@intuitionrobotics/thunderstorm/frontend");
|
|
16
|
-
const thunderstorm_1 = require("@intuitionrobotics/thunderstorm");
|
|
17
|
-
const dispatch_onPermissionsChanged = new thunder_dispatcher_1.ThunderDispatcher("__onPermissionsChanged");
|
|
18
|
-
const dispatch_onPermissionsFailed = new thunder_dispatcher_1.ThunderDispatcher("__onPermissionsFailed");
|
|
19
|
-
class PermissionsModuleFE_Class extends ts_common_1.Module {
|
|
20
|
-
constructor() {
|
|
21
|
-
super("PermissionsModuleFE");
|
|
22
|
-
this.loadingUrls = new Set();
|
|
23
|
-
this.userUrlsPermissions = {};
|
|
24
|
-
this.requestCustomField = {};
|
|
25
|
-
this.debounceTime = 100;
|
|
26
|
-
this.retryCounter = 0;
|
|
27
|
-
this.setPermissions = () => {
|
|
28
|
-
if (!this.config || !this.config.projectId)
|
|
29
|
-
throw new ts_common_1.ImplementationMissingException("need to set up a project id config");
|
|
30
|
-
this.debounce(() => {
|
|
31
|
-
const urls = {};
|
|
32
|
-
this.loadingUrls.forEach(url => {
|
|
33
|
-
urls[url] = false;
|
|
34
|
-
});
|
|
35
|
-
frontend_1.XhrHttpModule
|
|
36
|
-
.createRequest(thunderstorm_1.HttpMethod.POST, "user-urls-permissions")
|
|
37
|
-
.setRelativeUrl(`/v1/permissions/user-urls-permissions`)
|
|
38
|
-
// .setOnError(`Failed to get user urls permissions`)
|
|
39
|
-
.setLabel(`Getting user urls permissions`)
|
|
40
|
-
.setJsonBody({
|
|
41
|
-
projectId: this.config.projectId,
|
|
42
|
-
urls: urls,
|
|
43
|
-
requestCustomField: this.requestCustomField
|
|
44
|
-
})
|
|
45
|
-
.setOnError(() => {
|
|
46
|
-
this.logWarning(`Failed to get user urls permissions`);
|
|
47
|
-
if (this.retryCounter < 5) {
|
|
48
|
-
this.retryCounter++;
|
|
49
|
-
return (0, ts_common_1._setTimeout)(this.setPermissions, 5 * ts_common_1.Second);
|
|
50
|
-
}
|
|
51
|
-
dispatch_onPermissionsFailed.dispatchModule();
|
|
52
|
-
})
|
|
53
|
-
.execute((userUrlsPermissions) => __awaiter(this, void 0, void 0, function* () {
|
|
54
|
-
this.retryCounter = 0;
|
|
55
|
-
Object.keys(userUrlsPermissions).forEach(url => {
|
|
56
|
-
this.loadingUrls.delete(url);
|
|
57
|
-
this.userUrlsPermissions[url] = userUrlsPermissions[url];
|
|
58
|
-
});
|
|
59
|
-
dispatch_onPermissionsChanged.dispatchUI();
|
|
60
|
-
}));
|
|
61
|
-
}, "get-permissions", this.debounceTime);
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
setDebounceTime(time) {
|
|
65
|
-
this.debounceTime = time;
|
|
66
|
-
}
|
|
67
|
-
setCustomField(key, value) {
|
|
68
|
-
this.requestCustomField[key] = value;
|
|
69
|
-
this.setPermissions();
|
|
70
|
-
}
|
|
71
|
-
loadUrls(urls) {
|
|
72
|
-
urls.forEach(url => {
|
|
73
|
-
if (this.loadingUrls.has(url) || this.userUrlsPermissions[url] !== undefined)
|
|
74
|
-
return;
|
|
75
|
-
this.loadingUrls.add(url);
|
|
76
|
-
});
|
|
77
|
-
this.setPermissions();
|
|
78
|
-
}
|
|
79
|
-
doesUserHavePermissions(url) {
|
|
80
|
-
if (this.loadingUrls.has(url))
|
|
81
|
-
return undefined;
|
|
82
|
-
const permitted = this.userUrlsPermissions[url];
|
|
83
|
-
if (permitted !== undefined)
|
|
84
|
-
return permitted;
|
|
85
|
-
this.loadingUrls.add(url);
|
|
86
|
-
this.setPermissions();
|
|
87
|
-
return undefined;
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
exports.PermissionsModuleFE_Class = PermissionsModuleFE_Class;
|
|
91
|
-
exports.PermissionsFE = new PermissionsModuleFE_Class();
|
|
92
|
-
//# sourceMappingURL=PermissionsModuleFE.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PermissionsModuleFE.js","sourceRoot":"","sources":["../../../src/main/app-frontend/modules/PermissionsModuleFE.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,55 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
-
});
|
|
10
|
-
};
|
|
11
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
exports.ApiCaller_PermissionsGroup = exports.PermissionsGroupModule_Class = void 0;
|
|
13
|
-
const frontend_1 = require("@intuitionrobotics/db-api-generator/frontend");
|
|
14
|
-
const frontend_2 = require("@intuitionrobotics/thunderstorm/frontend");
|
|
15
|
-
const dispatch_onPermissionsGroupsLoaded = new frontend_2.ThunderDispatcher("__onPermissionsGroupsLoaded");
|
|
16
|
-
class PermissionsGroupModule_Class extends frontend_1.BaseDB_ApiGeneratorCaller {
|
|
17
|
-
constructor() {
|
|
18
|
-
super({ key: "group", relativeUrl: "/v1/permissions/assign/group" }, "PermissionsGroupModule");
|
|
19
|
-
this.groups = [];
|
|
20
|
-
}
|
|
21
|
-
init() {
|
|
22
|
-
super.init();
|
|
23
|
-
}
|
|
24
|
-
onEntryCreated(response) {
|
|
25
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
26
|
-
this.query();
|
|
27
|
-
});
|
|
28
|
-
}
|
|
29
|
-
onEntryDeleted(response) {
|
|
30
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
31
|
-
this.query();
|
|
32
|
-
});
|
|
33
|
-
}
|
|
34
|
-
onEntryUpdated(response) {
|
|
35
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
36
|
-
this.query();
|
|
37
|
-
});
|
|
38
|
-
}
|
|
39
|
-
onGotUnique(response) {
|
|
40
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
41
|
-
});
|
|
42
|
-
}
|
|
43
|
-
onQueryReturned(response) {
|
|
44
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
45
|
-
this.groups = response;
|
|
46
|
-
dispatch_onPermissionsGroupsLoaded.dispatchUI();
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
getGroups() {
|
|
50
|
-
return this.groups;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
exports.PermissionsGroupModule_Class = PermissionsGroupModule_Class;
|
|
54
|
-
exports.ApiCaller_PermissionsGroup = new PermissionsGroupModule_Class();
|
|
55
|
-
//# sourceMappingURL=ApiCaller_PermissionsGroup.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ApiCaller_PermissionsGroup.js","sourceRoot":"","sources":["../../../../src/main/app-frontend/modules/assign/ApiCaller_PermissionsGroup.ts"],"names":[],"mappings":";;;;;;;;;;;;AAoBA,2EAAuF;AACvF,uEAEkD;AAOlD,MAAM,kCAAkC,GAAG,IAAI,4BAAiB,CAA2D,6BAA6B,CAAC,CAAC;AAE1J,MAAa,4BACZ,SAAQ,oCAA8C;IAGtD;QACC,KAAK,CAAC,EAAC,GAAG,EAAE,OAAO,EAAE,WAAW,EAAE,8BAA8B,EAAC,EAAE,wBAAwB,CAAC,CAAC;QAHtF,WAAM,GAA0B,EAAE,CAAC;IAI3C,CAAC;IAES,IAAI;QACb,KAAK,CAAC,IAAI,EAAE,CAAC;IACd,CAAC;IAEe,cAAc,CAAC,QAA6B;;YAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;QACd,CAAC;KAAA;IAEe,cAAc,CAAC,QAA6B;;YAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;QACd,CAAC;KAAA;IAEe,cAAc,CAAC,QAA6B;;YAC3D,IAAI,CAAC,KAAK,EAAE,CAAC;QACd,CAAC;KAAA;IAEe,WAAW,CAAC,QAA6B;;QACzD,CAAC;KAAA;IAEe,eAAe,CAAC,QAA+B;;YAC9D,IAAI,CAAC,MAAM,GAAG,QAAQ,CAAC;YACvB,kCAAkC,CAAC,UAAU,EAAE,CAAC;QACjD,CAAC;KAAA;IAED,SAAS;QACR,OAAO,IAAI,CAAC,MAAM,CAAC;IACpB,CAAC;CAED;AApCD,oEAoCC;AAEY,QAAA,0BAA0B,GAAG,IAAI,4BAA4B,EAAE,CAAC"}
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
/*
|
|
3
|
-
* ts-common is the basic building blocks of our typescript projects
|
|
4
|
-
*
|
|
5
|
-
* Copyright (C) 2020 Intuition Robotics
|
|
6
|
-
*
|
|
7
|
-
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
8
|
-
* you may not use this file except in compliance with the License.
|
|
9
|
-
* You may obtain a copy of the License at
|
|
10
|
-
*
|
|
11
|
-
* http://www.apache.org/licenses/LICENSE-2.0
|
|
12
|
-
*
|
|
13
|
-
* Unless required by applicable law or agreed to in writing, software
|
|
14
|
-
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
15
|
-
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
16
|
-
* See the License for the specific language governing permissions and
|
|
17
|
-
* limitations under the License.
|
|
18
|
-
*/
|
|
19
|
-
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
20
|
-
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
21
|
-
return new (P || (P = Promise))(function (resolve, reject) {
|
|
22
|
-
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
23
|
-
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
24
|
-
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
25
|
-
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
26
|
-
});
|
|
27
|
-
};
|
|
28
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.ApiCaller_PermissionsUser = exports.PermissionsUserModule_Class = void 0;
|
|
30
|
-
const frontend_1 = require("@intuitionrobotics/db-api-generator/frontend");
|
|
31
|
-
const frontend_2 = require("@intuitionrobotics/thunderstorm/frontend");
|
|
32
|
-
const dispatch_onPermissionsUsersLoaded = new frontend_2.ThunderDispatcher("__onPermissionsUsersLoaded");
|
|
33
|
-
class PermissionsUserModule_Class extends frontend_1.BaseDB_ApiGeneratorCaller {
|
|
34
|
-
constructor() {
|
|
35
|
-
super({ key: "user", relativeUrl: "/v1/permissions/assign/user" }, "PermissionsUserModule");
|
|
36
|
-
this.users = [];
|
|
37
|
-
}
|
|
38
|
-
init() {
|
|
39
|
-
}
|
|
40
|
-
onEntryCreated(response) {
|
|
41
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
onEntryDeleted(response) {
|
|
45
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
46
|
-
});
|
|
47
|
-
}
|
|
48
|
-
onEntryUpdated(response) {
|
|
49
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
50
|
-
this.query();
|
|
51
|
-
});
|
|
52
|
-
}
|
|
53
|
-
onGotUnique(response) {
|
|
54
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
55
|
-
});
|
|
56
|
-
}
|
|
57
|
-
onQueryReturned(response) {
|
|
58
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
59
|
-
this.users = response;
|
|
60
|
-
dispatch_onPermissionsUsersLoaded.dispatchUI();
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
getUserByAccountId(accountId) {
|
|
64
|
-
return this.users.filter(user => user.accountId).find(user => user.accountId === accountId);
|
|
65
|
-
}
|
|
66
|
-
getUsers() {
|
|
67
|
-
return this.users;
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
exports.PermissionsUserModule_Class = PermissionsUserModule_Class;
|
|
71
|
-
exports.ApiCaller_PermissionsUser = new PermissionsUserModule_Class();
|
|
72
|
-
//# sourceMappingURL=ApiCaller_PermissionsUser.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ApiCaller_PermissionsUser.js","sourceRoot":"","sources":["../../../../src/main/app-frontend/modules/assign/ApiCaller_PermissionsUser.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;GAgBG;;;;;;;;;;;;AAEH,2EAAuF;AAEvF,uEAA2E;AAM3E,MAAM,iCAAiC,GAAG,IAAI,4BAAiB,CAAyD,4BAA4B,CAAC,CAAC;AAEtJ,MAAa,2BACZ,SAAQ,oCAA6C;IAGrD;QACC,KAAK,CAAC,EAAC,GAAG,EAAE,MAAM,EAAE,WAAW,EAAE,6BAA6B,EAAC,EAAE,uBAAuB,CAAC,CAAC;QAHnF,UAAK,GAAyB,EAAE,CAAC;IAIzC,CAAC;IAES,IAAI;IACd,CAAC;IAEe,cAAc,CAAC,QAA4B;;QAC3D,CAAC;KAAA;IAEe,cAAc,CAAC,QAA4B;;QAC3D,CAAC;KAAA;IAEe,cAAc,CAAC,QAA4B;;YAC1D,IAAI,CAAC,KAAK,EAAE,CAAC;QACd,CAAC;KAAA;IAEe,WAAW,CAAC,QAA4B;;QACxD,CAAC;KAAA;IAEe,eAAe,CAAC,QAA8B;;YAC7D,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;YACtB,iCAAiC,CAAC,UAAU,EAAE,CAAC;QAChD,CAAC;KAAA;IAED,kBAAkB,CAAC,SAAiB;QACnC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAA,EAAE,CAAA,IAAI,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;IAC3F,CAAC;IAED,QAAQ;QACP,OAAO,IAAI,CAAC,KAAK,CAAC;IACnB,CAAC;CACD;AApCD,kEAoCC;AAEY,QAAA,yBAAyB,GAAG,IAAI,2BAA2B,EAAE,CAAC"}
|