@iushev/react-rbac 1.0.15 → 1.0.18

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.
@@ -7,10 +7,10 @@ const jsx_runtime_1 = require("react/jsx-runtime");
7
7
  const useCheckAccess_1 = __importDefault(require("./useCheckAccess"));
8
8
  const NoAccess_1 = __importDefault(require("./NoAccess"));
9
9
  const CheckAccess = ({ roles, allow, params, match, busy: BusyComponent = () => null, noAccess: NoAccessComponent = NoAccess_1.default, children, }) => {
10
- const { checking, hasAccess } = useCheckAccess_1.default({ roles, allow, params, match });
10
+ const { checking, hasAccess } = (0, useCheckAccess_1.default)({ roles, allow, params, match });
11
11
  if (checking) {
12
- return jsx_runtime_1.jsx(BusyComponent, {}, void 0);
12
+ return (0, jsx_runtime_1.jsx)(BusyComponent, {});
13
13
  }
14
- return jsx_runtime_1.jsx(jsx_runtime_1.Fragment, { children: hasAccess ? jsx_runtime_1.jsx(jsx_runtime_1.Fragment, { children: children }, void 0) : jsx_runtime_1.jsx(NoAccessComponent, {}, void 0) }, void 0);
14
+ return (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: hasAccess ? (0, jsx_runtime_1.jsx)(jsx_runtime_1.Fragment, { children: children }) : (0, jsx_runtime_1.jsx)(NoAccessComponent, {}) });
15
15
  };
16
16
  exports.default = CheckAccess;
package/build/NoAccess.js CHANGED
@@ -2,7 +2,6 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  const jsx_runtime_1 = require("react/jsx-runtime");
4
4
  const NoAccess = () => {
5
- return (jsx_runtime_1.jsxs("div", { children: [jsx_runtime_1.jsx("h4", { children: "Access Denied" }, void 0),
6
- jsx_runtime_1.jsx("h5", { children: "You don't have permission to access." }, void 0)] }, void 0));
5
+ return ((0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("h4", { children: "Access Denied" }), (0, jsx_runtime_1.jsx)("h5", { children: "You don't have permission to access." })] }));
7
6
  };
8
7
  exports.default = NoAccess;
@@ -9,4 +9,8 @@ export default class RbacCheckAccess extends BaseCheckAccess {
9
9
  constructor(options: RbacCheckAccessOptions);
10
10
  checkAccess(username: string, itemName: string, params: RuleParams): Promise<boolean>;
11
11
  load(): Promise<void>;
12
+ private getRbacItems;
13
+ private getRbacParents;
14
+ private getRbacRules;
15
+ private getRbacAssignments;
12
16
  }
@@ -12,8 +12,9 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
12
12
  return (mod && mod.__esModule) ? mod : { "default": mod };
13
13
  };
14
14
  Object.defineProperty(exports, "__esModule", { value: true });
15
- const rbac_1 = require("@iushev/rbac");
16
15
  const axios_1 = __importDefault(require("axios"));
16
+ const http_status_codes_1 = __importDefault(require("http-status-codes"));
17
+ const rbac_1 = require("@iushev/rbac");
17
18
  class RbacCheckAccess extends rbac_1.BaseCheckAccess {
18
19
  constructor(options) {
19
20
  super(options);
@@ -22,12 +23,15 @@ class RbacCheckAccess extends rbac_1.BaseCheckAccess {
22
23
  baseURL: options.path,
23
24
  });
24
25
  this.axiosInstance.interceptors.request.use((config) => {
26
+ if (!config.headers) {
27
+ config.headers = {};
28
+ }
25
29
  if (options.authorization) {
26
30
  const token = options.authorization();
27
31
  config.headers.common["Authorization"] = "Bearer " + token;
28
32
  }
29
33
  else {
30
- config.headers.common["Authorization"] = null;
34
+ config.headers.common["Authorization"] = "";
31
35
  }
32
36
  return config;
33
37
  });
@@ -45,71 +49,99 @@ class RbacCheckAccess extends rbac_1.BaseCheckAccess {
45
49
  });
46
50
  }
47
51
  load() {
52
+ var _a;
48
53
  return __awaiter(this, void 0, void 0, function* () {
49
- console.log("Load RBAC");
50
- const response = yield this.axiosInstance.get("/rbac");
51
- const _rbac = response.data;
52
- this.items = Object.keys(_rbac.items).reduce((prevValue, name) => {
53
- var _a, _b;
54
- const item = _rbac.items[name];
55
- const ItemClass = item.type === rbac_1.ItemType.permission ? rbac_1.Permission : rbac_1.Role;
56
- prevValue.set(name, new ItemClass({
57
- name,
58
- type: item.type,
59
- description: (_a = item.description) !== null && _a !== void 0 ? _a : null,
60
- ruleName: (_b = item.ruleName) !== null && _b !== void 0 ? _b : null,
61
- }));
62
- return prevValue;
63
- }, new Map());
64
- this.parents = Object.keys(_rbac.items).reduce((prevValue, name) => {
65
- const item = _rbac.items[name];
66
- if (!item.children || item.children.length === 0) {
67
- return prevValue;
54
+ let _rbac;
55
+ try {
56
+ console.log("Load RBAC");
57
+ const response = yield this.axiosInstance.get("/rbac");
58
+ _rbac = response.data;
59
+ }
60
+ catch (err) {
61
+ if (axios_1.default.isAxiosError(err) && ((_a = err.response) === null || _a === void 0 ? void 0 : _a.status) === http_status_codes_1.default.NOT_FOUND) {
62
+ _rbac = {
63
+ assignments: {},
64
+ items: {},
65
+ rules: {},
66
+ };
68
67
  }
69
- item.children.forEach((childName) => {
70
- if (!this.items.has(childName)) {
71
- return;
72
- }
73
- if (!prevValue.has(childName)) {
74
- prevValue.set(childName, new Map());
75
- }
76
- prevValue.get(childName).set(name, this.items.get(name));
77
- });
68
+ else {
69
+ throw err;
70
+ }
71
+ }
72
+ this.items = this.getRbacItems(_rbac);
73
+ this.parents = this.getRbacParents(_rbac);
74
+ this.rules = this.getRbacRules(_rbac);
75
+ this.assignments = this.getRbacAssignments(_rbac);
76
+ });
77
+ }
78
+ getRbacItems({ items }) {
79
+ return Object.keys(items).reduce((prevValue, name) => {
80
+ var _a, _b;
81
+ const item = items[name];
82
+ const ItemClass = item.type === rbac_1.ItemType.permission ? rbac_1.Permission : rbac_1.Role;
83
+ prevValue.set(name, new ItemClass({
84
+ name,
85
+ type: item.type,
86
+ description: (_a = item.description) !== null && _a !== void 0 ? _a : null,
87
+ ruleName: (_b = item.ruleName) !== null && _b !== void 0 ? _b : null,
88
+ }));
89
+ return prevValue;
90
+ }, new Map());
91
+ }
92
+ getRbacParents({ items }) {
93
+ return Object.keys(items).reduce((prevValue, name) => {
94
+ const item = items[name];
95
+ if (!item.children || item.children.length === 0) {
78
96
  return prevValue;
79
- }, new Map());
80
- this.rules = Object.keys(_rbac.rules).reduce((prevValue, name) => {
97
+ }
98
+ item.children.forEach((childName) => {
99
+ if (!this.items.has(childName)) {
100
+ return;
101
+ }
102
+ if (!prevValue.has(childName)) {
103
+ prevValue.set(childName, new Map());
104
+ }
105
+ prevValue.get(childName).set(name, this.items.get(name));
106
+ });
107
+ return prevValue;
108
+ }, new Map());
109
+ }
110
+ getRbacRules({ rules }) {
111
+ return Object.keys(rules).reduce((prevValue, name) => {
112
+ var _a;
113
+ const ruleData = rules[name];
114
+ const RuleClass = (_a = this.ruleClasses.get(ruleData.data.typeName)) !== null && _a !== void 0 ? _a : rbac_1.Rule;
115
+ const rule = new RuleClass(name, JSON.parse(ruleData.data.rule));
116
+ prevValue.set(name, rule);
117
+ return prevValue;
118
+ }, new Map());
119
+ }
120
+ getRbacAssignments({ assignments }) {
121
+ return Object.keys(assignments).reduce((prevValue, username) => {
122
+ const _assignments = assignments[username];
123
+ _assignments.forEach((itemName) => {
81
124
  var _a;
82
- const ruleData = _rbac.rules[name];
83
- const RuleClass = (_a = this.ruleClasses.get(ruleData.data.typeName)) !== null && _a !== void 0 ? _a : rbac_1.Rule;
84
- const rule = new RuleClass(name, JSON.parse(ruleData.data.rule));
85
- prevValue.set(name, rule);
86
- return prevValue;
87
- }, new Map());
88
- this.assignments = Object.keys(_rbac.assignments).reduce((prevValue, username) => {
89
- const assignments = _rbac.assignments[username];
90
- assignments.forEach((itemName) => {
91
- var _a;
92
- if (prevValue.has(username)) {
93
- (_a = prevValue.get(username)) === null || _a === void 0 ? void 0 : _a.set(itemName, new rbac_1.Assignment({
125
+ if (prevValue.has(username)) {
126
+ (_a = prevValue.get(username)) === null || _a === void 0 ? void 0 : _a.set(itemName, new rbac_1.Assignment({
127
+ itemName,
128
+ username,
129
+ }));
130
+ }
131
+ else {
132
+ prevValue.set(username, new Map([
133
+ [
94
134
  itemName,
95
- username,
96
- }));
97
- }
98
- else {
99
- prevValue.set(username, new Map([
100
- [
135
+ new rbac_1.Assignment({
101
136
  itemName,
102
- new rbac_1.Assignment({
103
- itemName,
104
- username,
105
- }),
106
- ],
107
- ]));
108
- }
109
- });
110
- return prevValue;
111
- }, new Map());
112
- });
137
+ username,
138
+ }),
139
+ ],
140
+ ]));
141
+ }
142
+ });
143
+ return prevValue;
144
+ }, new Map());
113
145
  }
114
146
  }
115
147
  exports.default = RbacCheckAccess;
@@ -1,7 +1,11 @@
1
1
  "use strict";
2
2
  var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
3
  if (k2 === undefined) k2 = k;
4
- Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
5
9
  }) : (function(o, m, k, k2) {
6
10
  if (k2 === undefined) k2 = k;
7
11
  o[k2] = m[k];
@@ -39,8 +43,8 @@ const RbacContext = react_1.default.createContext({
39
43
  checkAccess: (_options) => __awaiter(void 0, void 0, void 0, function* () { return true; }),
40
44
  });
41
45
  const RbacProvider = ({ username, rbacUrl, token, isSuperuser, isGuest, ruleClasses, children, }) => {
42
- const [rbac, setRbac] = react_1.useState(null);
43
- react_1.useEffect(() => {
46
+ const [rbac, setRbac] = (0, react_1.useState)(null);
47
+ (0, react_1.useEffect)(() => {
44
48
  if (!token) {
45
49
  setRbac(null);
46
50
  }
@@ -54,7 +58,7 @@ const RbacProvider = ({ username, rbacUrl, token, isSuperuser, isGuest, ruleClas
54
58
  _rbac.load().then(() => setRbac(_rbac));
55
59
  }
56
60
  }, [rbacUrl, token]);
57
- const value = react_1.useMemo(() => {
61
+ const value = (0, react_1.useMemo)(() => {
58
62
  const checkAccess = ({ roles, allow = true, match, params = {} }) => __awaiter(void 0, void 0, void 0, function* () {
59
63
  const matchRole = () => __awaiter(void 0, void 0, void 0, function* () {
60
64
  if (!roles || roles.length === 0) {
@@ -98,7 +102,7 @@ const RbacProvider = ({ username, rbacUrl, token, isSuperuser, isGuest, ruleClas
98
102
  checkAccess,
99
103
  };
100
104
  }, [rbac, username, isGuest, isSuperuser]);
101
- return jsx_runtime_1.jsx(RbacContext.Provider, Object.assign({ value: value }, { children: children }), void 0);
105
+ return (0, jsx_runtime_1.jsx)(RbacContext.Provider, Object.assign({ value: value }, { children: children }));
102
106
  };
103
107
  exports.RbacProvider = RbacProvider;
104
108
  exports.RbacConsumer = RbacContext.Consumer;
@@ -6,12 +6,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const react_1 = require("react");
7
7
  const RbacContext_1 = __importDefault(require("./RbacContext"));
8
8
  function useCheckAccess({ roles, allow, params, match }) {
9
- const rbac = react_1.useContext(RbacContext_1.default);
10
- const [state, setState] = react_1.useState({
9
+ const rbac = (0, react_1.useContext)(RbacContext_1.default);
10
+ const [state, setState] = (0, react_1.useState)({
11
11
  checking: true,
12
12
  hasAccess: false,
13
13
  });
14
- react_1.useEffect(() => {
14
+ (0, react_1.useEffect)(() => {
15
15
  let subscribed = true;
16
16
  setState({
17
17
  checking: true,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@iushev/react-rbac",
3
- "version": "1.0.15",
3
+ "version": "1.0.18",
4
4
  "private": false,
5
5
  "author": "Ivaylo Ushev",
6
6
  "description": "",
@@ -12,17 +12,20 @@
12
12
  "test": "jest"
13
13
  },
14
14
  "devDependencies": {
15
- "typescript": "^4.4.4"
15
+ "typescript": "^4.6.2"
16
16
  },
17
17
  "peerDependencies": {
18
- "@iushev/rbac": "^1.0.19",
19
- "@types/react": "^16.14.5 || ^17.0.33",
20
- "@types/react-dom": "^17.0.10",
21
- "axios": "^0.24.0",
18
+ "@iushev/rbac": "^1.0.22",
19
+ "@types/react": "^16.14.5 || ^17.0.40",
20
+ "@types/react-dom": "^17.0.13",
21
+ "axios": ">= 0.26.1",
22
22
  "react": "^16.14.0 || ^17.0.2",
23
23
  "react-dom": "^16.14.0 || ^17.0.2"
24
24
  },
25
25
  "publishConfig": {
26
26
  "access": "public"
27
+ },
28
+ "dependencies": {
29
+ "http-status-codes": "^2.2.0"
27
30
  }
28
31
  }
@@ -1,3 +1,6 @@
1
+ import axios, { AxiosInstance } from "axios";
2
+ import statusCodes from "http-status-codes";
3
+
1
4
  import {
2
5
  Assignment,
3
6
  BaseCheckAccess,
@@ -11,8 +14,6 @@ import {
11
14
  RuleParams,
12
15
  } from "@iushev/rbac";
13
16
 
14
- import axios, { AxiosInstance } from "axios";
15
-
16
17
  export type RbacCheckAccessOptions = BaseCheckAccessOptions & {
17
18
  path: string;
18
19
  authorization: () => string;
@@ -31,11 +32,15 @@ export default class RbacCheckAccess extends BaseCheckAccess {
31
32
  });
32
33
 
33
34
  this.axiosInstance.interceptors.request.use((config) => {
35
+ if (!config.headers) {
36
+ config.headers = {};
37
+ }
38
+
34
39
  if (options.authorization) {
35
40
  const token = options.authorization();
36
- config.headers.common["Authorization"] = "Bearer " + token;
41
+ (config.headers.common as any as Record<string, string>)["Authorization"] = "Bearer " + token;
37
42
  } else {
38
- config.headers.common["Authorization"] = null;
43
+ (config.headers.common as any as Record<string, string>)["Authorization"] = "";
39
44
  }
40
45
  return config;
41
46
  });
@@ -50,12 +55,32 @@ export default class RbacCheckAccess extends BaseCheckAccess {
50
55
  }
51
56
 
52
57
  public async load(): Promise<void> {
53
- console.log("Load RBAC");
54
- const response = await this.axiosInstance.get<RBACResponse>("/rbac");
55
- const _rbac = response.data;
58
+ let _rbac: RBACResponse;
59
+ try {
60
+ console.log("Load RBAC");
61
+ const response = await this.axiosInstance.get<RBACResponse>("/rbac");
62
+ _rbac = response.data;
63
+ } catch (err) {
64
+ if (axios.isAxiosError(err) && err.response?.status === statusCodes.NOT_FOUND) {
65
+ _rbac = {
66
+ assignments: {},
67
+ items: {},
68
+ rules: {},
69
+ };
70
+ } else {
71
+ throw err;
72
+ }
73
+ }
74
+
75
+ this.items = this.getRbacItems(_rbac);
76
+ this.parents = this.getRbacParents(_rbac);
77
+ this.rules = this.getRbacRules(_rbac);
78
+ this.assignments = this.getRbacAssignments(_rbac);
79
+ }
56
80
 
57
- this.items = Object.keys(_rbac.items).reduce<Map<string, Item>>((prevValue, name) => {
58
- const item = _rbac.items[name];
81
+ private getRbacItems({ items }: RBACResponse) {
82
+ return Object.keys(items).reduce<Map<string, Item>>((prevValue, name) => {
83
+ const item = items[name];
59
84
  const ItemClass = item.type === ItemType.permission ? Permission : Role;
60
85
  prevValue.set(
61
86
  name,
@@ -68,9 +93,11 @@ export default class RbacCheckAccess extends BaseCheckAccess {
68
93
  );
69
94
  return prevValue;
70
95
  }, new Map());
96
+ }
71
97
 
72
- this.parents = Object.keys(_rbac.items).reduce<Map<string, Map<string, Item>>>((prevValue, name) => {
73
- const item = _rbac.items[name];
98
+ private getRbacParents({ items }: RBACResponse) {
99
+ return Object.keys(items).reduce<Map<string, Map<string, Item>>>((prevValue, name) => {
100
+ const item = items[name];
74
101
  if (!item.children || item.children.length === 0) {
75
102
  return prevValue;
76
103
  }
@@ -88,45 +115,46 @@ export default class RbacCheckAccess extends BaseCheckAccess {
88
115
 
89
116
  return prevValue;
90
117
  }, new Map());
118
+ }
91
119
 
92
- this.rules = Object.keys(_rbac.rules).reduce<Map<string, Rule>>((prevValue, name) => {
93
- const ruleData = _rbac.rules[name];
120
+ private getRbacRules({ rules }: RBACResponse) {
121
+ return Object.keys(rules).reduce<Map<string, Rule>>((prevValue, name) => {
122
+ const ruleData = rules[name];
94
123
  const RuleClass = this.ruleClasses.get(ruleData.data.typeName) ?? Rule;
95
124
  const rule = new RuleClass(name, JSON.parse(ruleData.data.rule));
96
125
  prevValue.set(name, rule);
97
126
  return prevValue;
98
127
  }, new Map());
128
+ }
99
129
 
100
- this.assignments = Object.keys(_rbac.assignments).reduce<Map<string, Map<string, Assignment>>>(
101
- (prevValue, username) => {
102
- const assignments = _rbac.assignments[username];
103
- assignments.forEach((itemName) => {
104
- if (prevValue.has(username)) {
105
- prevValue.get(username)?.set(
130
+ private getRbacAssignments({ assignments }: RBACResponse) {
131
+ return Object.keys(assignments).reduce<Map<string, Map<string, Assignment>>>((prevValue, username) => {
132
+ const _assignments = assignments[username];
133
+ _assignments.forEach((itemName) => {
134
+ if (prevValue.has(username)) {
135
+ prevValue.get(username)?.set(
136
+ itemName,
137
+ new Assignment({
106
138
  itemName,
107
- new Assignment({
108
- itemName,
109
- username,
110
- })
111
- );
112
- } else {
113
- prevValue.set(
114
139
  username,
115
- new Map([
116
- [
140
+ })
141
+ );
142
+ } else {
143
+ prevValue.set(
144
+ username,
145
+ new Map([
146
+ [
147
+ itemName,
148
+ new Assignment({
117
149
  itemName,
118
- new Assignment({
119
- itemName,
120
- username,
121
- }),
122
- ],
123
- ])
124
- );
125
- }
126
- });
127
- return prevValue;
128
- },
129
- new Map()
130
- );
150
+ username,
151
+ }),
152
+ ],
153
+ ])
154
+ );
155
+ }
156
+ });
157
+ return prevValue;
158
+ }, new Map());
131
159
  }
132
160
  }