@nocobase/acl 2.0.0-beta.9 → 2.0.1
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/lib/acl.d.ts +2 -1
- package/lib/acl.js +3 -0
- package/lib/fixed-params-manager.d.ts +3 -0
- package/lib/fixed-params-manager.js +7 -0
- package/package.json +4 -4
package/lib/acl.d.ts
CHANGED
|
@@ -13,7 +13,7 @@ import { ACLAvailableAction, AvailableActionOptions } from './acl-available-acti
|
|
|
13
13
|
import { ACLAvailableStrategy, AvailableStrategyOptions } from './acl-available-strategy';
|
|
14
14
|
import { ACLRole, ResourceActionsOptions, RoleActionParams } from './acl-role';
|
|
15
15
|
import { AllowManager, ConditionFunc } from './allow-manager';
|
|
16
|
-
import FixedParamsManager, { Merger } from './fixed-params-manager';
|
|
16
|
+
import FixedParamsManager, { Merger, GeneralMerger } from './fixed-params-manager';
|
|
17
17
|
import SnippetManager, { SnippetOptions } from './snippet-manager';
|
|
18
18
|
export interface CanResult {
|
|
19
19
|
role: string;
|
|
@@ -113,6 +113,7 @@ export declare class ACL extends EventEmitter {
|
|
|
113
113
|
* @internal
|
|
114
114
|
*/
|
|
115
115
|
getActionParams(ctx: any): Promise<void>;
|
|
116
|
+
addGeneralFixedParams(merger: GeneralMerger): void;
|
|
116
117
|
addFixedParams(resource: string, action: string, merger: Merger): void;
|
|
117
118
|
registerSnippet(snippet: SnippetOptions): void;
|
|
118
119
|
/**
|
package/lib/acl.js
CHANGED
|
@@ -368,6 +368,9 @@ const _ACL = class _ACL extends import_events.default {
|
|
|
368
368
|
await (0, import_koa_compose.default)(this.middlewares.nodes)(ctx, async () => {
|
|
369
369
|
});
|
|
370
370
|
}
|
|
371
|
+
addGeneralFixedParams(merger) {
|
|
372
|
+
this.fixedParamsManager.addGeneralParams(merger);
|
|
373
|
+
}
|
|
371
374
|
addFixedParams(resource, action, merger) {
|
|
372
375
|
this.fixedParamsManager.addParams(resource, action, merger);
|
|
373
376
|
}
|
|
@@ -7,10 +7,13 @@
|
|
|
7
7
|
* For more information, please refer to: https://www.nocobase.com/agreement.
|
|
8
8
|
*/
|
|
9
9
|
export type Merger = () => object;
|
|
10
|
+
export type GeneralMerger = (resource: string, action: string) => object;
|
|
10
11
|
export type ActionPath = string;
|
|
11
12
|
export default class FixedParamsManager {
|
|
12
13
|
merger: Map<string, Merger[]>;
|
|
14
|
+
generalMergers: Array<GeneralMerger>;
|
|
13
15
|
addParams(resource: string, action: string, merger: Merger): void;
|
|
16
|
+
addGeneralParams(merger: GeneralMerger): void;
|
|
14
17
|
getParamsMerger(resource: string, action: string): Merger[];
|
|
15
18
|
protected getActionPath(resource: string, action: string): string;
|
|
16
19
|
getParams(resource: string, action: string, extraParams?: any): {};
|
|
@@ -34,10 +34,14 @@ var import_utils = require("@nocobase/utils");
|
|
|
34
34
|
const SPLIT = ":";
|
|
35
35
|
const _FixedParamsManager = class _FixedParamsManager {
|
|
36
36
|
merger = /* @__PURE__ */ new Map();
|
|
37
|
+
generalMergers = [];
|
|
37
38
|
addParams(resource, action, merger) {
|
|
38
39
|
const path = this.getActionPath(resource, action);
|
|
39
40
|
this.merger.set(path, [...this.getParamsMerger(resource, action), merger]);
|
|
40
41
|
}
|
|
42
|
+
addGeneralParams(merger) {
|
|
43
|
+
this.generalMergers.push(merger);
|
|
44
|
+
}
|
|
41
45
|
getParamsMerger(resource, action) {
|
|
42
46
|
const path = this.getActionPath(resource, action);
|
|
43
47
|
return this.merger.get(path) || [];
|
|
@@ -47,6 +51,9 @@ const _FixedParamsManager = class _FixedParamsManager {
|
|
|
47
51
|
}
|
|
48
52
|
getParams(resource, action, extraParams = {}) {
|
|
49
53
|
const results = {};
|
|
54
|
+
for (const merger of this.generalMergers) {
|
|
55
|
+
_FixedParamsManager.mergeParams(results, merger(resource, action));
|
|
56
|
+
}
|
|
50
57
|
for (const merger of this.getParamsMerger(resource, action)) {
|
|
51
58
|
_FixedParamsManager.mergeParams(results, merger());
|
|
52
59
|
}
|
package/package.json
CHANGED
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@nocobase/acl",
|
|
3
|
-
"version": "2.0.
|
|
3
|
+
"version": "2.0.1",
|
|
4
4
|
"description": "",
|
|
5
5
|
"license": "AGPL-3.0",
|
|
6
6
|
"main": "./lib/index.js",
|
|
7
7
|
"types": "./lib/index.d.ts",
|
|
8
8
|
"dependencies": {
|
|
9
|
-
"@nocobase/resourcer": "2.0.
|
|
10
|
-
"@nocobase/utils": "2.0.
|
|
9
|
+
"@nocobase/resourcer": "2.0.1",
|
|
10
|
+
"@nocobase/utils": "2.0.1",
|
|
11
11
|
"minimatch": "^5.1.1"
|
|
12
12
|
},
|
|
13
13
|
"repository": {
|
|
@@ -15,5 +15,5 @@
|
|
|
15
15
|
"url": "git+https://github.com/nocobase/nocobase.git",
|
|
16
16
|
"directory": "packages/acl"
|
|
17
17
|
},
|
|
18
|
-
"gitHead": "
|
|
18
|
+
"gitHead": "e41d74b50e2025555dc71969a20fee180b8d0d0d"
|
|
19
19
|
}
|