@webiny/app-security-access-management 5.27.0-beta.0 → 5.28.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/components/GroupAutocomplete/graphql.js +14 -3
- package/components/GroupAutocomplete/graphql.js.map +1 -1
- package/components/GroupAutocomplete/index.js +23 -8
- package/components/GroupAutocomplete/index.js.map +1 -1
- package/components/NotAuthorizedError/NotAuthorizedError.js +39 -18
- package/components/NotAuthorizedError/NotAuthorizedError.js.map +1 -1
- package/components/NotAuthorizedError/index.js +13 -1
- package/components/NotAuthorizedError/index.js.map +1 -1
- package/index.js +57 -32
- package/index.js.map +1 -1
- package/package.json +12 -12
- package/plugins/constants.js +9 -2
- package/plugins/constants.js.map +1 -1
- package/plugins/index.js +20 -6
- package/plugins/index.js.map +1 -1
- package/plugins/installation.js +47 -25
- package/plugins/installation.js.map +1 -1
- package/plugins/permissionRenderer/SecurityPermissions.js +69 -46
- package/plugins/permissionRenderer/SecurityPermissions.js.map +1 -1
- package/plugins/permissionRenderer/index.js +33 -15
- package/plugins/permissionRenderer/index.js.map +1 -1
- package/plugins/routes.js +37 -19
- package/plugins/routes.js.map +1 -1
- package/plugins/secureRouteError.js +16 -4
- package/plugins/secureRouteError.js.map +1 -1
- package/types.js +5 -1
- package/types.js.map +1 -1
- package/ui/elements/GroupAutocompleteElement.js +34 -18
- package/ui/elements/GroupAutocompleteElement.js.map +1 -1
- package/ui/views/ApiKeys/ApiKeyForm.js +122 -81
- package/ui/views/ApiKeys/ApiKeyForm.js.map +1 -1
- package/ui/views/ApiKeys/ApiKeys.js +22 -7
- package/ui/views/ApiKeys/ApiKeys.js.map +1 -1
- package/ui/views/ApiKeys/ApiKeysDataList.js +101 -66
- package/ui/views/ApiKeys/ApiKeysDataList.js.map +1 -1
- package/ui/views/ApiKeys/graphql.js +22 -7
- package/ui/views/ApiKeys/graphql.js.map +1 -1
- package/ui/views/ApiKeys/index.js +18 -1
- package/ui/views/ApiKeys/index.js.map +1 -1
- package/ui/views/ApiKeys/utils.js +18 -5
- package/ui/views/ApiKeys/utils.js.map +1 -1
- package/ui/views/Groups/Groups.js +22 -7
- package/ui/views/Groups/Groups.js.map +1 -1
- package/ui/views/Groups/GroupsDataList.js +107 -71
- package/ui/views/Groups/GroupsDataList.js.map +1 -1
- package/ui/views/Groups/GroupsForm.js +125 -84
- package/ui/views/Groups/GroupsForm.js.map +1 -1
- package/ui/views/Groups/graphql.js +22 -7
- package/ui/views/Groups/graphql.js.map +1 -1
- package/ui/views/Groups/index.js +18 -1
- package/ui/views/Groups/index.js.map +1 -1
- package/ui/views/utils.js +16 -4
- package/ui/views/utils.js.map +1 -1
|
@@ -1,6 +1,17 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.LIST_GROUPS = void 0;
|
|
9
|
+
|
|
10
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
11
|
+
|
|
12
|
+
var _graphqlTag = _interopRequireDefault(require("graphql-tag"));
|
|
2
13
|
|
|
3
14
|
var _templateObject;
|
|
4
15
|
|
|
5
|
-
|
|
6
|
-
|
|
16
|
+
var LIST_GROUPS = (0, _graphqlTag.default)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n query listGroups {\n security {\n groups: listGroups {\n data {\n id\n slug\n name\n description\n createdOn\n }\n }\n }\n }\n"])));
|
|
17
|
+
exports.LIST_GROUPS = LIST_GROUPS;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["LIST_GROUPS","gql"],"sources":["graphql.ts"],"sourcesContent":["import gql from \"graphql-tag\";\n\nexport const LIST_GROUPS = gql`\n query listGroups {\n security {\n groups: listGroups {\n data {\n id\n slug\n name\n description\n createdOn\n }\n }\n }\n }\n`;\n"],"mappings":";;;;;;;;;;;AAAA;;;;AAEO,IAAMA,WAAW,OAAGC,mBAAH,4XAAjB"}
|
|
@@ -1,16 +1,31 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.GroupAutocomplete = void 0;
|
|
9
|
+
|
|
10
|
+
var _react = _interopRequireDefault(require("react"));
|
|
11
|
+
|
|
12
|
+
var _AutoComplete = require("@webiny/ui/AutoComplete");
|
|
13
|
+
|
|
14
|
+
var _graphql = require("./graphql");
|
|
15
|
+
|
|
16
|
+
var _reactHooks = require("@apollo/react-hooks");
|
|
17
|
+
|
|
18
|
+
var GroupAutocomplete = function GroupAutocomplete(props) {
|
|
19
|
+
var _useQuery = (0, _reactHooks.useQuery)(_graphql.LIST_GROUPS),
|
|
7
20
|
data = _useQuery.data,
|
|
8
21
|
loading = _useQuery.loading;
|
|
9
22
|
|
|
10
23
|
var options = loading || !data ? [] : data.security.groups.data;
|
|
11
|
-
return /*#__PURE__*/
|
|
24
|
+
return /*#__PURE__*/_react.default.createElement(_AutoComplete.AutoComplete, Object.assign({}, props, {
|
|
12
25
|
options: options,
|
|
13
26
|
valueProp: "id",
|
|
14
27
|
value: loading ? undefined : props.value
|
|
15
28
|
}));
|
|
16
|
-
};
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
exports.GroupAutocomplete = GroupAutocomplete;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["GroupAutocomplete","props","useQuery","LIST_GROUPS","data","loading","options","security","groups","undefined","value"],"sources":["index.tsx"],"sourcesContent":["import React from \"react\";\nimport { AutoComplete, AutoCompleteProps } from \"@webiny/ui/AutoComplete\";\nimport { LIST_GROUPS } from \"./graphql\";\nimport { useQuery } from \"@apollo/react-hooks\";\n\ntype GroupAutocompleteProps = Partial<AutoCompleteProps>;\nexport const GroupAutocomplete: React.FC<GroupAutocompleteProps> = props => {\n const { data, loading } = useQuery(LIST_GROUPS);\n\n const options = loading || !data ? [] : data.security.groups.data;\n\n return (\n <AutoComplete\n {...props}\n options={options}\n valueProp={\"id\"}\n value={loading ? undefined : props.value}\n />\n );\n};\n"],"mappings":";;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AAGO,IAAMA,iBAAmD,GAAG,SAAtDA,iBAAsD,CAAAC,KAAK,EAAI;EACxE,gBAA0B,IAAAC,oBAAA,EAASC,oBAAT,CAA1B;EAAA,IAAQC,IAAR,aAAQA,IAAR;EAAA,IAAcC,OAAd,aAAcA,OAAd;;EAEA,IAAMC,OAAO,GAAGD,OAAO,IAAI,CAACD,IAAZ,GAAmB,EAAnB,GAAwBA,IAAI,CAACG,QAAL,CAAcC,MAAd,CAAqBJ,IAA7D;EAEA,oBACI,6BAAC,0BAAD,oBACQH,KADR;IAEI,OAAO,EAAEK,OAFb;IAGI,SAAS,EAAE,IAHf;IAII,KAAK,EAAED,OAAO,GAAGI,SAAH,GAAeR,KAAK,CAACS;EAJvC,GADJ;AAQH,CAbM"}
|
|
@@ -1,11 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.NotAuthorizedError = void 0;
|
|
11
|
+
|
|
12
|
+
var React = _interopRequireWildcard(require("react"));
|
|
13
|
+
|
|
14
|
+
var _reactRouter = require("@webiny/react-router");
|
|
15
|
+
|
|
16
|
+
var _emotion = require("emotion");
|
|
17
|
+
|
|
18
|
+
var _styled = _interopRequireDefault(require("@emotion/styled"));
|
|
19
|
+
|
|
20
|
+
var _reactHelmet = _interopRequireDefault(require("react-helmet"));
|
|
21
|
+
|
|
22
|
+
var _SecureRouteError = _interopRequireDefault(require("./SecureRouteError.svg"));
|
|
23
|
+
|
|
24
|
+
var _Typography = require("@webiny/ui/Typography");
|
|
25
|
+
|
|
26
|
+
var ContentWrapper = /*#__PURE__*/(0, _styled.default)("div", {
|
|
9
27
|
target: "e18nns4o0",
|
|
10
28
|
label: "ContentWrapper"
|
|
11
29
|
})({
|
|
@@ -15,36 +33,39 @@ var ContentWrapper = /*#__PURE__*/styled("div", {
|
|
|
15
33
|
margin: "auto"
|
|
16
34
|
});
|
|
17
35
|
var styles = {
|
|
18
|
-
authErrorImgStyle: /*#__PURE__*/css({
|
|
36
|
+
authErrorImgStyle: /*#__PURE__*/(0, _emotion.css)({
|
|
19
37
|
width: "192px",
|
|
20
38
|
paddingBottom: "24px"
|
|
21
39
|
}, "label:authErrorImgStyle;"),
|
|
22
|
-
bodyStyle: /*#__PURE__*/css({
|
|
40
|
+
bodyStyle: /*#__PURE__*/(0, _emotion.css)({
|
|
23
41
|
color: "var(--mdc-theme-text-primary-on-background)",
|
|
24
42
|
display: "block"
|
|
25
43
|
}, "label:bodyStyle;"),
|
|
26
|
-
linkStyle: /*#__PURE__*/css({
|
|
44
|
+
linkStyle: /*#__PURE__*/(0, _emotion.css)({
|
|
27
45
|
textDecoration: "none",
|
|
28
46
|
"&:hover": {
|
|
29
47
|
textDecoration: "none"
|
|
30
48
|
}
|
|
31
49
|
}, "label:linkStyle;")
|
|
32
50
|
};
|
|
33
|
-
|
|
34
|
-
|
|
51
|
+
|
|
52
|
+
var NotAuthorizedError = function NotAuthorizedError() {
|
|
53
|
+
return /*#__PURE__*/React.createElement(ContentWrapper, null, /*#__PURE__*/React.createElement(_reactHelmet.default, {
|
|
35
54
|
title: "Not authorized"
|
|
36
55
|
}), /*#__PURE__*/React.createElement("img", {
|
|
37
56
|
className: styles.authErrorImgStyle,
|
|
38
|
-
src:
|
|
57
|
+
src: _SecureRouteError.default,
|
|
39
58
|
alt: "Not Authorized"
|
|
40
|
-
}), /*#__PURE__*/React.createElement(Typography, {
|
|
59
|
+
}), /*#__PURE__*/React.createElement(_Typography.Typography, {
|
|
41
60
|
use: "body1",
|
|
42
61
|
className: styles.bodyStyle
|
|
43
|
-
}, "You are not authorized to view this route."), /*#__PURE__*/React.createElement(Typography, {
|
|
62
|
+
}, "You are not authorized to view this route."), /*#__PURE__*/React.createElement(_Typography.Typography, {
|
|
44
63
|
use: "body1",
|
|
45
64
|
className: styles.bodyStyle
|
|
46
|
-
}, "Please contact your administrator to request access."), /*#__PURE__*/React.createElement(Link, {
|
|
65
|
+
}, "Please contact your administrator to request access."), /*#__PURE__*/React.createElement(_reactRouter.Link, {
|
|
47
66
|
to: "/",
|
|
48
67
|
className: styles.linkStyle
|
|
49
68
|
}, "Take me back."));
|
|
50
|
-
};
|
|
69
|
+
};
|
|
70
|
+
|
|
71
|
+
exports.NotAuthorizedError = NotAuthorizedError;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["ContentWrapper","styled","display","paddingTop","textAlign","margin","styles","authErrorImgStyle","css","width","paddingBottom","bodyStyle","color","linkStyle","textDecoration","NotAuthorizedError","authErrorImg"],"sources":["NotAuthorizedError.tsx"],"sourcesContent":["import * as React from \"react\";\nimport { Link } from \"@webiny/react-router\";\nimport { css } from \"emotion\";\nimport styled from \"@emotion/styled\";\nimport Helmet from \"react-helmet\";\nimport authErrorImg from \"./SecureRouteError.svg\";\nimport { Typography } from \"@webiny/ui/Typography\";\n\nconst ContentWrapper = styled(\"div\")({\n display: \"block\",\n paddingTop: \"15%\",\n textAlign: \"center\",\n margin: \"auto\"\n});\n\nconst styles = {\n authErrorImgStyle: css({\n width: \"192px\",\n paddingBottom: \"24px\"\n }),\n bodyStyle: css({\n color: \"var(--mdc-theme-text-primary-on-background)\",\n display: \"block\"\n }),\n linkStyle: css({\n textDecoration: \"none\",\n \"&:hover\": {\n textDecoration: \"none\"\n }\n })\n};\n\nexport const NotAuthorizedError: React.FC = () => {\n return (\n <ContentWrapper>\n <Helmet title={\"Not authorized\"} />\n\n <img className={styles.authErrorImgStyle} src={authErrorImg} alt=\"Not Authorized\" />\n\n <Typography use={\"body1\"} className={styles.bodyStyle}>\n You are not authorized to view this route.\n </Typography>\n\n <Typography use={\"body1\"} className={styles.bodyStyle}>\n Please contact your administrator to request access.\n </Typography>\n\n <Link to=\"/\" className={styles.linkStyle}>\n Take me back.\n </Link>\n </ContentWrapper>\n );\n};\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA,IAAMA,cAAc,oBAAGC,eAAH,EAAU,KAAV;EAAA;EAAA;AAAA,GAAiB;EACjCC,OAAO,EAAE,OADwB;EAEjCC,UAAU,EAAE,KAFqB;EAGjCC,SAAS,EAAE,QAHsB;EAIjCC,MAAM,EAAE;AAJyB,CAAjB,CAApB;AAOA,IAAMC,MAAM,GAAG;EACXC,iBAAiB,eAAE,IAAAC,YAAA,EAAI;IACnBC,KAAK,EAAE,OADY;IAEnBC,aAAa,EAAE;EAFI,CAAJ,6BADR;EAKXC,SAAS,eAAE,IAAAH,YAAA,EAAI;IACXI,KAAK,EAAE,6CADI;IAEXV,OAAO,EAAE;EAFE,CAAJ,qBALA;EASXW,SAAS,eAAE,IAAAL,YAAA,EAAI;IACXM,cAAc,EAAE,MADL;IAEX,WAAW;MACPA,cAAc,EAAE;IADT;EAFA,CAAJ;AATA,CAAf;;AAiBO,IAAMC,kBAA4B,GAAG,SAA/BA,kBAA+B,GAAM;EAC9C,oBACI,oBAAC,cAAD,qBACI,oBAAC,oBAAD;IAAQ,KAAK,EAAE;EAAf,EADJ,eAGI;IAAK,SAAS,EAAET,MAAM,CAACC,iBAAvB;IAA0C,GAAG,EAAES,yBAA/C;IAA6D,GAAG,EAAC;EAAjE,EAHJ,eAKI,oBAAC,sBAAD;IAAY,GAAG,EAAE,OAAjB;IAA0B,SAAS,EAAEV,MAAM,CAACK;EAA5C,gDALJ,eASI,oBAAC,sBAAD;IAAY,GAAG,EAAE,OAAjB;IAA0B,SAAS,EAAEL,MAAM,CAACK;EAA5C,0DATJ,eAaI,oBAAC,iBAAD;IAAM,EAAE,EAAC,GAAT;IAAa,SAAS,EAAEL,MAAM,CAACO;EAA/B,mBAbJ,CADJ;AAmBH,CApBM"}
|
|
@@ -1 +1,13 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
Object.defineProperty(exports, "NotAuthorizedError", {
|
|
7
|
+
enumerable: true,
|
|
8
|
+
get: function get() {
|
|
9
|
+
return _NotAuthorizedError.NotAuthorizedError;
|
|
10
|
+
}
|
|
11
|
+
});
|
|
12
|
+
|
|
13
|
+
var _NotAuthorizedError = require("./NotAuthorizedError");
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { NotAuthorizedError } from \"./NotAuthorizedError\";\n"],"mappings":";;;;;;;;;;;;AAAA"}
|
package/index.js
CHANGED
|
@@ -1,55 +1,80 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.default = exports.AccessManagementExtension = exports.AccessManagement = void 0;
|
|
11
|
+
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
|
|
14
|
+
var _plugins = require("@webiny/plugins");
|
|
15
|
+
|
|
16
|
+
var _appAdmin = require("@webiny/app-admin");
|
|
17
|
+
|
|
18
|
+
var _appSecurity = require("@webiny/app-security");
|
|
19
|
+
|
|
20
|
+
var _constants = require("./plugins/constants");
|
|
21
|
+
|
|
22
|
+
var _Groups = require("./ui/views/Groups");
|
|
23
|
+
|
|
24
|
+
var _ApiKeys = require("./ui/views/ApiKeys");
|
|
25
|
+
|
|
26
|
+
var _plugins2 = _interopRequireDefault(require("./plugins"));
|
|
27
|
+
|
|
9
28
|
/**
|
|
10
29
|
* TODO @ts-refactor
|
|
11
30
|
* Find out why is there empty default export
|
|
12
31
|
*/
|
|
13
32
|
// @ts-ignore
|
|
14
|
-
|
|
15
|
-
export default (function () {
|
|
33
|
+
var _default = function _default() {
|
|
16
34
|
return [];
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
exports.default = _default;
|
|
38
|
+
|
|
39
|
+
var AccessManagementExtension = function AccessManagementExtension() {
|
|
40
|
+
_plugins.plugins.register((0, _plugins2.default)());
|
|
41
|
+
|
|
42
|
+
return /*#__PURE__*/_react.default.createElement(_appAdmin.Plugins, null, /*#__PURE__*/_react.default.createElement(_appSecurity.HasPermission, {
|
|
43
|
+
name: _constants.Permission.Groups
|
|
44
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddRoute, {
|
|
23
45
|
exact: true,
|
|
24
46
|
path: "/access-management/groups"
|
|
25
|
-
}, /*#__PURE__*/
|
|
47
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.Layout, {
|
|
26
48
|
title: "Access Management - Groups"
|
|
27
|
-
}, /*#__PURE__*/
|
|
28
|
-
name: Permission.ApiKeys
|
|
29
|
-
}, /*#__PURE__*/
|
|
49
|
+
}, /*#__PURE__*/_react.default.createElement(_Groups.Groups, null)))), /*#__PURE__*/_react.default.createElement(_appSecurity.HasPermission, {
|
|
50
|
+
name: _constants.Permission.ApiKeys
|
|
51
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddRoute, {
|
|
30
52
|
exact: true,
|
|
31
53
|
path: "/access-management/api-keys"
|
|
32
|
-
}, /*#__PURE__*/
|
|
54
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.Layout, {
|
|
33
55
|
title: "Access Management - API Keys"
|
|
34
|
-
}, /*#__PURE__*/
|
|
35
|
-
any: [Permission.Groups, Permission.ApiKeys]
|
|
36
|
-
}, /*#__PURE__*/
|
|
56
|
+
}, /*#__PURE__*/_react.default.createElement(_ApiKeys.ApiKeys, null)))), /*#__PURE__*/_react.default.createElement(_appSecurity.HasPermission, {
|
|
57
|
+
any: [_constants.Permission.Groups, _constants.Permission.ApiKeys]
|
|
58
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddMenu, {
|
|
37
59
|
name: "settings"
|
|
38
|
-
}, /*#__PURE__*/
|
|
60
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddMenu, {
|
|
39
61
|
name: "settings.accessManagement",
|
|
40
62
|
label: "Access Management"
|
|
41
|
-
}, /*#__PURE__*/
|
|
42
|
-
name: Permission.Groups
|
|
43
|
-
}, /*#__PURE__*/
|
|
63
|
+
}, /*#__PURE__*/_react.default.createElement(_appSecurity.HasPermission, {
|
|
64
|
+
name: _constants.Permission.Groups
|
|
65
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddMenu, {
|
|
44
66
|
name: "settings.accessManagement.groups",
|
|
45
67
|
label: "Groups",
|
|
46
68
|
path: "/access-management/groups"
|
|
47
|
-
})), /*#__PURE__*/
|
|
48
|
-
name: Permission.ApiKeys
|
|
49
|
-
}, /*#__PURE__*/
|
|
69
|
+
})), /*#__PURE__*/_react.default.createElement(_appSecurity.HasPermission, {
|
|
70
|
+
name: _constants.Permission.ApiKeys
|
|
71
|
+
}, /*#__PURE__*/_react.default.createElement(_appAdmin.AddMenu, {
|
|
50
72
|
name: "settings.accessManagement.apiKeys",
|
|
51
73
|
label: "API Keys",
|
|
52
74
|
path: "/access-management/api-keys"
|
|
53
75
|
}))))));
|
|
54
76
|
};
|
|
55
|
-
|
|
77
|
+
|
|
78
|
+
exports.AccessManagementExtension = AccessManagementExtension;
|
|
79
|
+
var AccessManagement = /*#__PURE__*/(0, _react.memo)(AccessManagementExtension);
|
|
80
|
+
exports.AccessManagement = AccessManagement;
|
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["AccessManagementExtension","plugins","register","accessManagementPugins","Permission","Groups","ApiKeys","AccessManagement","memo"],"sources":["index.tsx"],"sourcesContent":["import React, { memo } from \"react\";\nimport { plugins } from \"@webiny/plugins\";\nimport { Layout, Plugins, AddMenu, AddRoute } from \"@webiny/app-admin\";\nimport { HasPermission } from \"@webiny/app-security\";\nimport { Permission } from \"~/plugins/constants\";\nimport { Groups } from \"~/ui/views/Groups\";\nimport { ApiKeys } from \"~/ui/views/ApiKeys\";\nimport accessManagementPugins from \"./plugins\";\n\n/**\n * TODO @ts-refactor\n * Find out why is there empty default export\n */\n// @ts-ignore\nexport default () => [];\n\nexport const AccessManagementExtension = () => {\n plugins.register(accessManagementPugins());\n\n return (\n <Plugins>\n <HasPermission name={Permission.Groups}>\n <AddRoute exact path={\"/access-management/groups\"}>\n <Layout title={\"Access Management - Groups\"}>\n <Groups />\n </Layout>\n </AddRoute>\n </HasPermission>\n <HasPermission name={Permission.ApiKeys}>\n <AddRoute exact path={\"/access-management/api-keys\"}>\n <Layout title={\"Access Management - API Keys\"}>\n <ApiKeys />\n </Layout>\n </AddRoute>\n </HasPermission>\n <HasPermission any={[Permission.Groups, Permission.ApiKeys]}>\n <AddMenu name={\"settings\"}>\n <AddMenu name={\"settings.accessManagement\"} label={\"Access Management\"}>\n <HasPermission name={Permission.Groups}>\n <AddMenu\n name={\"settings.accessManagement.groups\"}\n label={\"Groups\"}\n path={\"/access-management/groups\"}\n />\n </HasPermission>\n <HasPermission name={Permission.ApiKeys}>\n <AddMenu\n name={\"settings.accessManagement.apiKeys\"}\n label={\"API Keys\"}\n path={\"/access-management/api-keys\"}\n />\n </HasPermission>\n </AddMenu>\n </AddMenu>\n </HasPermission>\n </Plugins>\n );\n};\n\nexport const AccessManagement = memo(AccessManagementExtension);\n"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;AACA;AACA;AACA;AACA;eACe;EAAA,OAAM,EAAN;AAAA,C;;;;AAER,IAAMA,yBAAyB,GAAG,SAA5BA,yBAA4B,GAAM;EAC3CC,gBAAA,CAAQC,QAAR,CAAiB,IAAAC,iBAAA,GAAjB;;EAEA,oBACI,6BAAC,iBAAD,qBACI,6BAAC,0BAAD;IAAe,IAAI,EAAEC,qBAAA,CAAWC;EAAhC,gBACI,6BAAC,kBAAD;IAAU,KAAK,MAAf;IAAgB,IAAI,EAAE;EAAtB,gBACI,6BAAC,gBAAD;IAAQ,KAAK,EAAE;EAAf,gBACI,6BAAC,cAAD,OADJ,CADJ,CADJ,CADJ,eAQI,6BAAC,0BAAD;IAAe,IAAI,EAAED,qBAAA,CAAWE;EAAhC,gBACI,6BAAC,kBAAD;IAAU,KAAK,MAAf;IAAgB,IAAI,EAAE;EAAtB,gBACI,6BAAC,gBAAD;IAAQ,KAAK,EAAE;EAAf,gBACI,6BAAC,gBAAD,OADJ,CADJ,CADJ,CARJ,eAeI,6BAAC,0BAAD;IAAe,GAAG,EAAE,CAACF,qBAAA,CAAWC,MAAZ,EAAoBD,qBAAA,CAAWE,OAA/B;EAApB,gBACI,6BAAC,iBAAD;IAAS,IAAI,EAAE;EAAf,gBACI,6BAAC,iBAAD;IAAS,IAAI,EAAE,2BAAf;IAA4C,KAAK,EAAE;EAAnD,gBACI,6BAAC,0BAAD;IAAe,IAAI,EAAEF,qBAAA,CAAWC;EAAhC,gBACI,6BAAC,iBAAD;IACI,IAAI,EAAE,kCADV;IAEI,KAAK,EAAE,QAFX;IAGI,IAAI,EAAE;EAHV,EADJ,CADJ,eAQI,6BAAC,0BAAD;IAAe,IAAI,EAAED,qBAAA,CAAWE;EAAhC,gBACI,6BAAC,iBAAD;IACI,IAAI,EAAE,mCADV;IAEI,KAAK,EAAE,UAFX;IAGI,IAAI,EAAE;EAHV,EADJ,CARJ,CADJ,CADJ,CAfJ,CADJ;AAsCH,CAzCM;;;AA2CA,IAAMC,gBAAgB,gBAAG,IAAAC,WAAA,EAAKR,yBAAL,CAAzB"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@webiny/app-security-access-management",
|
|
3
|
-
"version": "5.
|
|
3
|
+
"version": "5.28.0",
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -15,14 +15,14 @@
|
|
|
15
15
|
"dependencies": {
|
|
16
16
|
"@apollo/react-hooks": "3.1.5",
|
|
17
17
|
"@emotion/styled": "10.3.0",
|
|
18
|
-
"@webiny/app": "5.
|
|
19
|
-
"@webiny/app-admin": "5.
|
|
20
|
-
"@webiny/app-security": "5.
|
|
21
|
-
"@webiny/form": "5.
|
|
22
|
-
"@webiny/plugins": "5.
|
|
23
|
-
"@webiny/react-router": "5.
|
|
24
|
-
"@webiny/ui": "5.
|
|
25
|
-
"@webiny/validation": "5.
|
|
18
|
+
"@webiny/app": "5.28.0",
|
|
19
|
+
"@webiny/app-admin": "5.28.0",
|
|
20
|
+
"@webiny/app-security": "5.28.0",
|
|
21
|
+
"@webiny/form": "5.28.0",
|
|
22
|
+
"@webiny/plugins": "5.28.0",
|
|
23
|
+
"@webiny/react-router": "5.28.0",
|
|
24
|
+
"@webiny/ui": "5.28.0",
|
|
25
|
+
"@webiny/validation": "5.28.0",
|
|
26
26
|
"emotion": "10.0.27",
|
|
27
27
|
"graphql-tag": "2.12.6",
|
|
28
28
|
"lodash": "4.17.21",
|
|
@@ -38,8 +38,8 @@
|
|
|
38
38
|
"@babel/preset-react": "^7.16.0",
|
|
39
39
|
"@babel/preset-typescript": "^7.16.0",
|
|
40
40
|
"@types/react-helmet": "^6.1.5",
|
|
41
|
-
"@webiny/cli": "^5.
|
|
42
|
-
"@webiny/project-utils": "^5.
|
|
41
|
+
"@webiny/cli": "^5.28.0",
|
|
42
|
+
"@webiny/project-utils": "^5.28.0",
|
|
43
43
|
"babel-plugin-emotion": "^9.2.8",
|
|
44
44
|
"babel-plugin-lodash": "^3.3.4",
|
|
45
45
|
"rimraf": "^3.0.2",
|
|
@@ -61,5 +61,5 @@
|
|
|
61
61
|
]
|
|
62
62
|
}
|
|
63
63
|
},
|
|
64
|
-
"gitHead": "
|
|
64
|
+
"gitHead": "9fd082a2e4a0e0116ee5a07e2a9ca385e8ac0173"
|
|
65
65
|
}
|
package/plugins/constants.js
CHANGED
|
@@ -1,6 +1,13 @@
|
|
|
1
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.Permission = void 0;
|
|
7
|
+
var Permission;
|
|
8
|
+
exports.Permission = Permission;
|
|
2
9
|
|
|
3
10
|
(function (Permission) {
|
|
4
11
|
Permission["Groups"] = "security.group";
|
|
5
12
|
Permission["ApiKeys"] = "security.apiKey";
|
|
6
|
-
})(Permission || (Permission = {}));
|
|
13
|
+
})(Permission || (exports.Permission = Permission = {}));
|
package/plugins/constants.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["Permission"],"sources":["constants.ts"],"sourcesContent":["export enum Permission {\n Groups = \"security.group\",\n ApiKeys = \"security.apiKey\"\n}\n"],"mappings":";;;;;;IAAYA,U;;;WAAAA,U;EAAAA,U;EAAAA,U;GAAAA,U,0BAAAA,U"}
|
package/plugins/index.js
CHANGED
|
@@ -1,6 +1,20 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
|
|
10
|
+
var _installation = _interopRequireDefault(require("./installation"));
|
|
11
|
+
|
|
12
|
+
var _permissionRenderer = _interopRequireDefault(require("./permissionRenderer"));
|
|
13
|
+
|
|
14
|
+
var _secureRouteError = _interopRequireDefault(require("./secureRouteError"));
|
|
15
|
+
|
|
16
|
+
var _default = function _default() {
|
|
17
|
+
return [_installation.default, _permissionRenderer.default, _secureRouteError.default];
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
exports.default = _default;
|
package/plugins/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["installation","permissionRenderer","secureRouteError"],"sources":["index.ts"],"sourcesContent":["import { PluginCollection } from \"@webiny/plugins/types\";\nimport installation from \"./installation\";\nimport permissionRenderer from \"./permissionRenderer\";\nimport secureRouteError from \"~/plugins/secureRouteError\";\n\nexport default (): PluginCollection => [installation, permissionRenderer, secureRouteError];\n"],"mappings":";;;;;;;;;AACA;;AACA;;AACA;;eAEe;EAAA,OAAwB,CAACA,qBAAD,EAAeC,2BAAf,EAAmCC,yBAAnC,CAAxB;AAAA,C"}
|
package/plugins/installation.js
CHANGED
|
@@ -1,37 +1,58 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
|
|
4
|
+
|
|
5
|
+
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.default = void 0;
|
|
11
|
+
|
|
12
|
+
var _regeneratorRuntime2 = _interopRequireDefault(require("@babel/runtime/helpers/regeneratorRuntime"));
|
|
13
|
+
|
|
14
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
15
|
+
|
|
16
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
17
|
+
|
|
18
|
+
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
|
|
19
|
+
|
|
20
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
21
|
+
|
|
22
|
+
var _graphqlTag = _interopRequireDefault(require("graphql-tag"));
|
|
23
|
+
|
|
24
|
+
var _reactHooks = require("@apollo/react-hooks");
|
|
25
|
+
|
|
26
|
+
var _Alert = require("@webiny/ui/Alert");
|
|
27
|
+
|
|
28
|
+
var _Progress = require("@webiny/ui/Progress");
|
|
29
|
+
|
|
30
|
+
var _SimpleForm = require("@webiny/app-admin/components/SimpleForm");
|
|
31
|
+
|
|
32
|
+
var _styled = _interopRequireDefault(require("@emotion/styled"));
|
|
4
33
|
|
|
5
34
|
var _templateObject, _templateObject2;
|
|
6
35
|
|
|
7
|
-
|
|
8
|
-
import React, { useState, useEffect } from "react";
|
|
9
|
-
import gql from "graphql-tag";
|
|
10
|
-
import { useApolloClient } from "@apollo/react-hooks";
|
|
11
|
-
import { Alert } from "@webiny/ui/Alert";
|
|
12
|
-
import { CircularProgress } from "@webiny/ui/Progress";
|
|
13
|
-
import { SimpleForm, SimpleFormContent } from "@webiny/app-admin/components/SimpleForm";
|
|
14
|
-
import styled from "@emotion/styled";
|
|
15
|
-
var SimpleFormPlaceholder = /*#__PURE__*/styled("div", {
|
|
36
|
+
var SimpleFormPlaceholder = /*#__PURE__*/(0, _styled.default)("div", {
|
|
16
37
|
target: "evolwsn0",
|
|
17
38
|
label: "SimpleFormPlaceholder"
|
|
18
39
|
})({
|
|
19
40
|
minHeight: 300,
|
|
20
41
|
minWidth: 400
|
|
21
42
|
});
|
|
22
|
-
var IS_INSTALLED =
|
|
23
|
-
var INSTALL =
|
|
43
|
+
var IS_INSTALLED = (0, _graphqlTag.default)(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2.default)(["\n query IsSecurityInstalled {\n security {\n version\n }\n }\n"])));
|
|
44
|
+
var INSTALL = (0, _graphqlTag.default)(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2.default)(["\n mutation InstallSecurity {\n security {\n install {\n data\n error {\n code\n message\n }\n }\n }\n }\n"])));
|
|
24
45
|
|
|
25
46
|
var SecurityInstaller = function SecurityInstaller(_ref) {
|
|
26
47
|
var onInstalled = _ref.onInstalled;
|
|
27
|
-
var client = useApolloClient();
|
|
48
|
+
var client = (0, _reactHooks.useApolloClient)();
|
|
28
49
|
|
|
29
|
-
var _useState = useState(null),
|
|
30
|
-
_useState2 =
|
|
50
|
+
var _useState = (0, _react.useState)(null),
|
|
51
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
31
52
|
error = _useState2[0],
|
|
32
53
|
setError = _useState2[1];
|
|
33
54
|
|
|
34
|
-
useEffect(function () {
|
|
55
|
+
(0, _react.useEffect)(function () {
|
|
35
56
|
client.mutate({
|
|
36
57
|
mutation: INSTALL
|
|
37
58
|
}).then(function (_ref2) {
|
|
@@ -47,13 +68,13 @@ var SecurityInstaller = function SecurityInstaller(_ref) {
|
|
|
47
68
|
setTimeout(onInstalled, 3000);
|
|
48
69
|
});
|
|
49
70
|
}, []);
|
|
50
|
-
var label = error ? /*#__PURE__*/
|
|
71
|
+
var label = error ? /*#__PURE__*/_react.default.createElement(_Alert.Alert, {
|
|
51
72
|
title: "Something went wrong",
|
|
52
73
|
type: "danger"
|
|
53
74
|
}, error) : "Installing Security...";
|
|
54
|
-
return /*#__PURE__*/
|
|
75
|
+
return /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleForm, null, /*#__PURE__*/_react.default.createElement(_Progress.CircularProgress, {
|
|
55
76
|
label: label
|
|
56
|
-
}), /*#__PURE__*/
|
|
77
|
+
}), /*#__PURE__*/_react.default.createElement(_SimpleForm.SimpleFormContent, null, /*#__PURE__*/_react.default.createElement(SimpleFormPlaceholder, null)));
|
|
57
78
|
};
|
|
58
79
|
|
|
59
80
|
var plugin = {
|
|
@@ -63,10 +84,10 @@ var plugin = {
|
|
|
63
84
|
dependencies: ["admin-installation-tenancy"],
|
|
64
85
|
secure: false,
|
|
65
86
|
getInstalledVersion: function getInstalledVersion(_ref3) {
|
|
66
|
-
return
|
|
87
|
+
return (0, _asyncToGenerator2.default)( /*#__PURE__*/(0, _regeneratorRuntime2.default)().mark(function _callee() {
|
|
67
88
|
var client, _yield$client$query, data;
|
|
68
89
|
|
|
69
|
-
return
|
|
90
|
+
return (0, _regeneratorRuntime2.default)().wrap(function _callee$(_context) {
|
|
70
91
|
while (1) {
|
|
71
92
|
switch (_context.prev = _context.next) {
|
|
72
93
|
case 0:
|
|
@@ -91,9 +112,10 @@ var plugin = {
|
|
|
91
112
|
},
|
|
92
113
|
render: function render(_ref4) {
|
|
93
114
|
var onInstalled = _ref4.onInstalled;
|
|
94
|
-
return /*#__PURE__*/
|
|
115
|
+
return /*#__PURE__*/_react.default.createElement(SecurityInstaller, {
|
|
95
116
|
onInstalled: onInstalled
|
|
96
117
|
});
|
|
97
118
|
}
|
|
98
119
|
};
|
|
99
|
-
|
|
120
|
+
var _default = plugin;
|
|
121
|
+
exports.default = _default;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"names":["SimpleFormPlaceholder","styled","minHeight","minWidth","IS_INSTALLED","gql","INSTALL","SecurityInstaller","onInstalled","client","useApolloClient","useState","error","setError","useEffect","mutate","mutation","then","data","security","install","message","setTimeout","label","plugin","name","type","title","dependencies","secure","getInstalledVersion","query","version","render"],"sources":["installation.tsx"],"sourcesContent":["import React, { useState, useEffect } from \"react\";\nimport gql from \"graphql-tag\";\nimport { useApolloClient } from \"@apollo/react-hooks\";\nimport { Alert } from \"@webiny/ui/Alert\";\nimport { CircularProgress } from \"@webiny/ui/Progress\";\nimport { SimpleForm, SimpleFormContent } from \"@webiny/app-admin/components/SimpleForm\";\nimport styled from \"@emotion/styled\";\nimport { AdminInstallationPlugin } from \"@webiny/app-admin/types\";\n\nconst SimpleFormPlaceholder = styled.div({\n minHeight: 300,\n minWidth: 400\n});\n\nconst IS_INSTALLED = gql`\n query IsSecurityInstalled {\n security {\n version\n }\n }\n`;\n\nconst INSTALL = gql`\n mutation InstallSecurity {\n security {\n install {\n data\n error {\n code\n message\n }\n }\n }\n }\n`;\n\ninterface SecurityInstallerProps {\n onInstalled: () => void;\n}\nconst SecurityInstaller: React.FC<SecurityInstallerProps> = ({ onInstalled }) => {\n const client = useApolloClient();\n const [error, setError] = useState(null);\n\n useEffect(() => {\n client.mutate({ mutation: INSTALL }).then(({ data }) => {\n const { error } = data.security.install;\n if (error) {\n setError(error.message);\n return;\n }\n\n // Just so the user sees the actual message.\n setTimeout(onInstalled, 3000);\n });\n }, []);\n\n const label = error ? (\n <Alert title={`Something went wrong`} type={\"danger\"}>\n {error}\n </Alert>\n ) : (\n `Installing Security...`\n );\n\n return (\n <SimpleForm>\n <CircularProgress label={label} />\n <SimpleFormContent>\n <SimpleFormPlaceholder />\n </SimpleFormContent>\n </SimpleForm>\n );\n};\n\nconst plugin: AdminInstallationPlugin = {\n name: \"admin-installation-security\",\n type: \"admin-installation\",\n title: `Security`,\n dependencies: [`admin-installation-tenancy`],\n secure: false,\n async getInstalledVersion({ client }) {\n const { data } = await client.query({ query: IS_INSTALLED });\n return data.security.version;\n },\n render({ onInstalled }) {\n return <SecurityInstaller onInstalled={onInstalled} />;\n }\n};\n\nexport default plugin;\n"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAGA,IAAMA,qBAAqB,oBAAGC,eAAH;EAAA;EAAA;AAAA,GAAc;EACrCC,SAAS,EAAE,GAD0B;EAErCC,QAAQ,EAAE;AAF2B,CAAd,CAA3B;AAKA,IAAMC,YAAY,OAAGC,mBAAH,kLAAlB;AAQA,IAAMC,OAAO,OAAGD,mBAAH,6TAAb;;AAiBA,IAAME,iBAAmD,GAAG,SAAtDA,iBAAsD,OAAqB;EAAA,IAAlBC,WAAkB,QAAlBA,WAAkB;EAC7E,IAAMC,MAAM,GAAG,IAAAC,2BAAA,GAAf;;EACA,gBAA0B,IAAAC,eAAA,EAAS,IAAT,CAA1B;EAAA;EAAA,IAAOC,KAAP;EAAA,IAAcC,QAAd;;EAEA,IAAAC,gBAAA,EAAU,YAAM;IACZL,MAAM,CAACM,MAAP,CAAc;MAAEC,QAAQ,EAAEV;IAAZ,CAAd,EAAqCW,IAArC,CAA0C,iBAAc;MAAA,IAAXC,IAAW,SAAXA,IAAW;MACpD,IAAQN,KAAR,GAAkBM,IAAI,CAACC,QAAL,CAAcC,OAAhC,CAAQR,KAAR;;MACA,IAAIA,KAAJ,EAAW;QACPC,QAAQ,CAACD,KAAK,CAACS,OAAP,CAAR;QACA;MACH,CALmD,CAOpD;;;MACAC,UAAU,CAACd,WAAD,EAAc,IAAd,CAAV;IACH,CATD;EAUH,CAXD,EAWG,EAXH;EAaA,IAAMe,KAAK,GAAGX,KAAK,gBACf,6BAAC,YAAD;IAAO,KAAK,wBAAZ;IAAsC,IAAI,EAAE;EAA5C,GACKA,KADL,CADe,2BAAnB;EAQA,oBACI,6BAAC,sBAAD,qBACI,6BAAC,0BAAD;IAAkB,KAAK,EAAEW;EAAzB,EADJ,eAEI,6BAAC,6BAAD,qBACI,6BAAC,qBAAD,OADJ,CAFJ,CADJ;AAQH,CAjCD;;AAmCA,IAAMC,MAA+B,GAAG;EACpCC,IAAI,EAAE,6BAD8B;EAEpCC,IAAI,EAAE,oBAF8B;EAGpCC,KAAK,YAH+B;EAIpCC,YAAY,EAAE,8BAJsB;EAKpCC,MAAM,EAAE,KAL4B;EAM9BC,mBAN8B,sCAME;IAAA;MAAA;;MAAA;QAAA;UAAA;YAAA;cAAVrB,MAAU,SAAVA,MAAU;cAAA;cAAA,OACXA,MAAM,CAACsB,KAAP,CAAa;gBAAEA,KAAK,EAAE3B;cAAT,CAAb,CADW;;YAAA;cAAA;cAC1Bc,IAD0B,uBAC1BA,IAD0B;cAAA,iCAE3BA,IAAI,CAACC,QAAL,CAAca,OAFa;;YAAA;YAAA;cAAA;UAAA;QAAA;MAAA;IAAA;EAGrC,CATmC;EAUpCC,MAVoC,yBAUZ;IAAA,IAAfzB,WAAe,SAAfA,WAAe;IACpB,oBAAO,6BAAC,iBAAD;MAAmB,WAAW,EAAEA;IAAhC,EAAP;EACH;AAZmC,CAAxC;eAeegB,M"}
|