@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 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.0-beta.9",
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.0-beta.9",
10
- "@nocobase/utils": "2.0.0-beta.9",
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": "36ef50291e22fe1024c819b8748d51a59a5ea4f8"
18
+ "gitHead": "e41d74b50e2025555dc71969a20fee180b8d0d0d"
19
19
  }