@strapi/permissions 0.0.0-next.fab38a080023b0850fc7a8ec8605d1ee6970e3c9 → 0.0.0-next.fb92031f3d90f3d2a2d191ba65725b6c8e329a5d

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.
Files changed (46) hide show
  1. package/LICENSE +18 -3
  2. package/dist/domain/index.d.ts +1 -0
  3. package/dist/domain/index.d.ts.map +1 -0
  4. package/dist/domain/index.js +8 -29
  5. package/dist/domain/index.js.map +1 -1
  6. package/dist/domain/index.mjs +3 -0
  7. package/dist/domain/index.mjs.map +1 -0
  8. package/dist/domain/permission/index.d.ts +2 -1
  9. package/dist/domain/permission/index.d.ts.map +1 -0
  10. package/dist/domain/permission/index.js +28 -29
  11. package/dist/domain/permission/index.js.map +1 -1
  12. package/dist/domain/permission/index.mjs +36 -0
  13. package/dist/domain/permission/index.mjs.map +1 -0
  14. package/dist/engine/abilities/casl-ability.d.ts +3 -13
  15. package/dist/engine/abilities/casl-ability.d.ts.map +1 -0
  16. package/dist/engine/abilities/casl-ability.js +52 -52
  17. package/dist/engine/abilities/casl-ability.js.map +1 -1
  18. package/dist/engine/abilities/casl-ability.mjs +66 -0
  19. package/dist/engine/abilities/casl-ability.mjs.map +1 -0
  20. package/dist/engine/abilities/index.d.ts +1 -0
  21. package/dist/engine/abilities/index.d.ts.map +1 -0
  22. package/dist/engine/abilities/index.js +8 -18
  23. package/dist/engine/abilities/index.js.map +1 -1
  24. package/dist/engine/abilities/index.mjs +2 -0
  25. package/dist/engine/abilities/index.mjs.map +1 -0
  26. package/dist/engine/hooks.d.ts +2 -1
  27. package/dist/engine/hooks.d.ts.map +1 -0
  28. package/dist/engine/hooks.js +67 -86
  29. package/dist/engine/hooks.js.map +1 -1
  30. package/dist/engine/hooks.mjs +76 -0
  31. package/dist/engine/hooks.mjs.map +1 -0
  32. package/dist/engine/index.d.ts +3 -1
  33. package/dist/engine/index.d.ts.map +1 -0
  34. package/dist/engine/index.js +87 -91
  35. package/dist/engine/index.js.map +1 -1
  36. package/dist/engine/index.mjs +139 -0
  37. package/dist/engine/index.mjs.map +1 -0
  38. package/dist/index.d.ts +2 -5
  39. package/dist/index.d.ts.map +1 -0
  40. package/dist/index.js +10 -31
  41. package/dist/index.js.map +1 -1
  42. package/dist/index.mjs +5 -0
  43. package/dist/index.mjs.map +1 -0
  44. package/dist/types.d.ts +19 -0
  45. package/dist/types.d.ts.map +1 -0
  46. package/package.json +17 -15
@@ -0,0 +1,139 @@
1
+ import _ from 'lodash/fp';
2
+ import qs from 'qs';
3
+ import { createWillRegisterContext, createEngineHooks, createBeforeEvaluateContext, createValidateContext } from './hooks.mjs';
4
+ import * as index from './abilities/index.mjs';
5
+ export { index as abilities };
6
+ import { caslAbilityBuilder } from './abilities/casl-ability.mjs';
7
+
8
+ /**
9
+ * Create a default state object for the engine
10
+ */ const createEngineState = ()=>{
11
+ const hooks = createEngineHooks();
12
+ return {
13
+ hooks
14
+ };
15
+ };
16
+ const newEngine = (params)=>{
17
+ const { providers, abilityBuilderFactory = caslAbilityBuilder } = params;
18
+ const state = createEngineState();
19
+ const runValidationHook = async (hook, context)=>state.hooks[hook].call(context);
20
+ /**
21
+ * Evaluate a permission using local and registered behaviors (using hooks).
22
+ * Validate, format (add condition, etc...), evaluate (evaluate conditions) and register a permission
23
+ */ const evaluate = async (params)=>{
24
+ const { options, register } = params;
25
+ const preFormatValidation = await runValidationHook('before-format::validate.permission', createBeforeEvaluateContext(params.permission));
26
+ if (preFormatValidation === false) {
27
+ return;
28
+ }
29
+ const permission = await state.hooks['format.permission'].call(params.permission);
30
+ const afterFormatValidation = await runValidationHook('after-format::validate.permission', createValidateContext(permission));
31
+ if (afterFormatValidation === false) {
32
+ return;
33
+ }
34
+ await state.hooks['before-evaluate.permission'].call(createBeforeEvaluateContext(permission));
35
+ const { action: actionName, subject, properties, conditions = [], actionParameters = {} } = permission;
36
+ let action = actionName;
37
+ if (actionParameters && Object.keys(actionParameters).length > 0) {
38
+ action = `${actionName}?${qs.stringify(actionParameters)}`;
39
+ }
40
+ if (conditions.length === 0) {
41
+ return register({
42
+ action,
43
+ subject,
44
+ properties
45
+ });
46
+ }
47
+ const resolveConditions = _.map(providers.condition.get);
48
+ const removeInvalidConditions = _.filter((condition)=>_.isFunction(condition.handler));
49
+ const evaluateConditions = (conditions)=>{
50
+ return Promise.all(conditions.map(async (condition)=>({
51
+ condition,
52
+ result: await condition.handler(_.merge(options, {
53
+ permission: _.cloneDeep(permission)
54
+ }))
55
+ })));
56
+ };
57
+ const removeInvalidResults = _.filter(({ result })=>_.isBoolean(result) || _.isObject(result));
58
+ const evaluatedConditions = await Promise.resolve(conditions).then(resolveConditions).then(removeInvalidConditions).then(evaluateConditions).then(removeInvalidResults);
59
+ const resultPropEq = _.propEq('result');
60
+ const pickResults = _.map(_.prop('result'));
61
+ if (evaluatedConditions.every(resultPropEq(false))) {
62
+ return;
63
+ }
64
+ if (_.isEmpty(evaluatedConditions) || evaluatedConditions.some(resultPropEq(true))) {
65
+ return register({
66
+ action,
67
+ subject,
68
+ properties
69
+ });
70
+ }
71
+ const results = pickResults(evaluatedConditions).filter(_.isObject);
72
+ if (_.isEmpty(results)) {
73
+ return register({
74
+ action,
75
+ subject,
76
+ properties
77
+ });
78
+ }
79
+ return register({
80
+ action,
81
+ subject,
82
+ properties,
83
+ condition: {
84
+ $and: [
85
+ {
86
+ $or: results
87
+ }
88
+ ]
89
+ }
90
+ });
91
+ };
92
+ return {
93
+ get hooks () {
94
+ return state.hooks;
95
+ },
96
+ /**
97
+ * Create a register function that wraps a `can` function
98
+ * used to register a permission in the ability builder
99
+ */ createRegisterFunction (can, options) {
100
+ return async (permission)=>{
101
+ const hookContext = createWillRegisterContext({
102
+ options,
103
+ permission
104
+ });
105
+ await state.hooks['before-register.permission'].call(hookContext);
106
+ return can(permission);
107
+ };
108
+ },
109
+ /**
110
+ * Register a new handler for a given hook
111
+ */ on (hook, handler) {
112
+ const validHooks = Object.keys(state.hooks);
113
+ const isValidHook = validHooks.includes(hook);
114
+ if (!isValidHook) {
115
+ throw new Error(`Invalid hook supplied when trying to register an handler to the permission engine. Got "${hook}" but expected one of ${validHooks.join(', ')}`);
116
+ }
117
+ state.hooks[hook].register(handler);
118
+ return this;
119
+ },
120
+ /**
121
+ * Generate an ability based on the instance's
122
+ * ability builder and the given permissions
123
+ */ async generateAbility (permissions, options = {}) {
124
+ const { can, build } = abilityBuilderFactory();
125
+ for (const permission of permissions){
126
+ const register = this.createRegisterFunction(can, options);
127
+ await evaluate({
128
+ permission,
129
+ options,
130
+ register
131
+ });
132
+ }
133
+ return build();
134
+ }
135
+ };
136
+ };
137
+
138
+ export { newEngine as new };
139
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../src/engine/index.ts"],"sourcesContent":["import _ from 'lodash/fp';\nimport qs from 'qs';\nimport { Ability } from '@casl/ability';\nimport { providerFactory } from '@strapi/utils';\n\nimport {\n createEngineHooks,\n createWillRegisterContext,\n createBeforeEvaluateContext,\n createValidateContext,\n} from './hooks';\nimport type { PermissionEngineHooks, HookName } from './hooks';\n\nimport * as abilities from './abilities';\nimport { Permission } from '../domain/permission';\nimport type { PermissionRule } from '../types';\n\nexport { abilities };\n\ntype Provider = Omit<ReturnType<typeof providerFactory>, 'register'> & {\n register(...args: unknown[]): Promise<Provider> | Provider;\n};\n\ntype ActionProvider = Provider;\ntype ConditionProvider = Provider;\n\nexport interface Engine {\n hooks: PermissionEngineHooks;\n on(hook: HookName, handler: (...args: any[]) => any): Engine;\n generateAbility(permissions: Permission[], options?: object): Promise<Ability>;\n createRegisterFunction(\n can: (permission: PermissionRule) => unknown,\n options: Record<string, unknown>\n ): (permission: PermissionRule) => Promise<unknown>;\n}\n\nexport interface EngineParams {\n providers: { action: ActionProvider; condition: ConditionProvider };\n abilityBuilderFactory?(): abilities.CustomAbilityBuilder;\n}\n\ninterface EvaluateParams {\n options: Record<string, unknown>;\n register: (permission: PermissionRule) => Promise<unknown>;\n permission: Permission;\n}\n\ninterface Condition {\n name: string;\n handler(...params: unknown[]): boolean | object;\n}\n\n/**\n * Create a default state object for the engine\n */\nconst createEngineState = () => {\n const hooks = createEngineHooks();\n\n return { hooks };\n};\n\nconst newEngine = (params: EngineParams): Engine => {\n const { providers, abilityBuilderFactory = abilities.caslAbilityBuilder } = params;\n\n const state = createEngineState();\n\n const runValidationHook = async (hook: HookName, context: unknown) =>\n state.hooks[hook].call(context);\n\n /**\n * Evaluate a permission using local and registered behaviors (using hooks).\n * Validate, format (add condition, etc...), evaluate (evaluate conditions) and register a permission\n */\n const evaluate = async (params: EvaluateParams) => {\n const { options, register } = params;\n\n const preFormatValidation = await runValidationHook(\n 'before-format::validate.permission',\n createBeforeEvaluateContext(params.permission)\n );\n\n if (preFormatValidation === false) {\n return;\n }\n\n const permission = (await state.hooks['format.permission'].call(\n params.permission\n )) as Permission;\n\n const afterFormatValidation = await runValidationHook(\n 'after-format::validate.permission',\n createValidateContext(permission)\n );\n\n if (afterFormatValidation === false) {\n return;\n }\n\n await state.hooks['before-evaluate.permission'].call(createBeforeEvaluateContext(permission));\n\n const {\n action: actionName,\n subject,\n properties,\n conditions = [],\n actionParameters = {},\n } = permission;\n\n let action = actionName;\n\n if (actionParameters && Object.keys(actionParameters).length > 0) {\n action = `${actionName}?${qs.stringify(actionParameters)}`;\n }\n\n if (conditions.length === 0) {\n return register({ action, subject, properties });\n }\n\n const resolveConditions = _.map(providers.condition.get);\n\n const removeInvalidConditions = _.filter((condition: Condition) =>\n _.isFunction(condition.handler)\n );\n\n const evaluateConditions = (conditions: Condition[]) => {\n return Promise.all(\n conditions.map(async (condition) => ({\n condition,\n result: await condition.handler(\n _.merge(options, { permission: _.cloneDeep(permission) })\n ),\n }))\n );\n };\n\n const removeInvalidResults = _.filter(\n ({ result }) => _.isBoolean(result) || _.isObject(result)\n );\n\n const evaluatedConditions = await Promise.resolve(conditions)\n .then(resolveConditions)\n .then(removeInvalidConditions)\n .then(evaluateConditions)\n .then(removeInvalidResults);\n\n const resultPropEq = _.propEq('result');\n const pickResults = _.map(_.prop('result'));\n\n if (evaluatedConditions.every(resultPropEq(false))) {\n return;\n }\n\n if (_.isEmpty(evaluatedConditions) || evaluatedConditions.some(resultPropEq(true))) {\n return register({ action, subject, properties });\n }\n\n const results = pickResults(evaluatedConditions).filter(_.isObject);\n\n if (_.isEmpty(results)) {\n return register({ action, subject, properties });\n }\n\n return register({\n action,\n subject,\n properties,\n condition: { $and: [{ $or: results }] },\n });\n };\n\n return {\n get hooks() {\n return state.hooks;\n },\n\n /**\n * Create a register function that wraps a `can` function\n * used to register a permission in the ability builder\n */\n createRegisterFunction(can, options: Record<string, unknown>) {\n return async (permission: PermissionRule) => {\n const hookContext = createWillRegisterContext({ options, permission });\n\n await state.hooks['before-register.permission'].call(hookContext);\n\n return can(permission);\n };\n },\n\n /**\n * Register a new handler for a given hook\n */\n on(hook, handler) {\n const validHooks = Object.keys(state.hooks);\n const isValidHook = validHooks.includes(hook);\n\n if (!isValidHook) {\n throw new Error(\n `Invalid hook supplied when trying to register an handler to the permission engine. Got \"${hook}\" but expected one of ${validHooks.join(\n ', '\n )}`\n );\n }\n\n state.hooks[hook].register(handler);\n\n return this;\n },\n\n /**\n * Generate an ability based on the instance's\n * ability builder and the given permissions\n */\n async generateAbility(permissions, options: Record<string, unknown> = {}) {\n const { can, build } = abilityBuilderFactory();\n\n for (const permission of permissions) {\n const register = this.createRegisterFunction(can, options);\n\n await evaluate({ permission, options, register });\n }\n\n return build();\n },\n };\n};\n\nexport { newEngine as new };\n"],"names":["createEngineState","hooks","createEngineHooks","newEngine","params","providers","abilityBuilderFactory","abilities","state","runValidationHook","hook","context","call","evaluate","options","register","preFormatValidation","createBeforeEvaluateContext","permission","afterFormatValidation","createValidateContext","action","actionName","subject","properties","conditions","actionParameters","Object","keys","length","qs","stringify","resolveConditions","_","map","condition","get","removeInvalidConditions","filter","isFunction","handler","evaluateConditions","Promise","all","result","merge","cloneDeep","removeInvalidResults","isBoolean","isObject","evaluatedConditions","resolve","then","resultPropEq","propEq","pickResults","prop","every","isEmpty","some","results","$and","$or","createRegisterFunction","can","hookContext","createWillRegisterContext","on","validHooks","isValidHook","includes","Error","join","generateAbility","permissions","build"],"mappings":"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"}
package/dist/index.d.ts CHANGED
@@ -1,7 +1,4 @@
1
1
  import * as domain from './domain';
2
2
  import * as engine from './engine';
3
- declare const _default: {
4
- domain: typeof domain;
5
- engine: typeof engine;
6
- };
7
- export = _default;
3
+ export { domain, engine };
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AAEnC,OAAO,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC"}
package/dist/index.js CHANGED
@@ -1,31 +1,10 @@
1
- "use strict";
2
- var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
- if (k2 === undefined) k2 = 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);
9
- }) : (function(o, m, k, k2) {
10
- if (k2 === undefined) k2 = k;
11
- o[k2] = m[k];
12
- }));
13
- var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
- Object.defineProperty(o, "default", { enumerable: true, value: v });
15
- }) : function(o, v) {
16
- o["default"] = v;
17
- });
18
- var __importStar = (this && this.__importStar) || function (mod) {
19
- if (mod && mod.__esModule) return mod;
20
- var result = {};
21
- if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
- __setModuleDefault(result, mod);
23
- return result;
24
- };
25
- const domain = __importStar(require("./domain"));
26
- const engine = __importStar(require("./engine"));
27
- module.exports = {
28
- domain,
29
- engine,
30
- };
31
- //# sourceMappingURL=index.js.map
1
+ 'use strict';
2
+
3
+ var index = require('./domain/index.js');
4
+ var index$1 = require('./engine/index.js');
5
+
6
+
7
+
8
+ exports.domain = index;
9
+ exports.engine = index$1;
10
+ //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,iDAAmC;AACnC,iDAAmC;AAEnC,iBAAS;IACP,MAAM;IACN,MAAM;CACP,CAAC"}
1
+ {"version":3,"file":"index.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;"}
package/dist/index.mjs ADDED
@@ -0,0 +1,5 @@
1
+ import * as index from './domain/index.mjs';
2
+ export { index as domain };
3
+ import * as index$1 from './engine/index.mjs';
4
+ export { index$1 as engine };
5
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * These were imported from `@strapi/types` but if we do that
3
+ * it becomes a circular dependency. This is the source of truth,
4
+ * they're re-exported from `@strapi/types` for convenience.
5
+ */
6
+ import type { Subject } from '@casl/ability';
7
+ export interface ParametrizedAction {
8
+ name: string;
9
+ params: Record<string, unknown>;
10
+ }
11
+ export interface PermissionRule {
12
+ action: string | ParametrizedAction;
13
+ subject?: Subject | null;
14
+ properties?: {
15
+ fields?: string[];
16
+ };
17
+ condition?: Record<string, unknown>;
18
+ }
19
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AACH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE7C,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACjC;AACD,MAAM,WAAW,cAAc;IAC7B,MAAM,EAAE,MAAM,GAAG,kBAAkB,CAAC;IACpC,OAAO,CAAC,EAAE,OAAO,GAAG,IAAI,CAAC;IACzB,UAAU,CAAC,EAAE;QACX,MAAM,CAAC,EAAE,MAAM,EAAE,CAAC;KACnB,CAAC;IACF,SAAS,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;CACrC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@strapi/permissions",
3
- "version": "0.0.0-next.fab38a080023b0850fc7a8ec8605d1ee6970e3c9",
3
+ "version": "0.0.0-next.fb92031f3d90f3d2a2d191ba65725b6c8e329a5d",
4
4
  "description": "Strapi's permission layer.",
5
5
  "repository": {
6
6
  "type": "git",
@@ -19,35 +19,37 @@
19
19
  "url": "https://strapi.io"
20
20
  }
21
21
  ],
22
- "files": [
23
- "./dist"
24
- ],
25
22
  "main": "./dist/index.js",
23
+ "module": "./dist/index.mjs",
24
+ "source": "./src/index.ts",
26
25
  "types": "./dist/index.d.ts",
26
+ "files": [
27
+ "dist/"
28
+ ],
27
29
  "scripts": {
28
- "build": "run -T tsc",
29
- "build:ts": "run build",
30
- "watch": "run -T tsc -w --preserveWatchOutput",
30
+ "build": "run -T npm-run-all clean --parallel build:code build:types",
31
+ "build:code": "run -T rollup -c",
32
+ "build:types": "run -T tsc -p tsconfig.build.json --emitDeclarationOnly",
31
33
  "clean": "run -T rimraf ./dist",
32
- "prepublishOnly": "yarn clean && yarn build",
34
+ "lint": "run -T eslint .",
35
+ "test:ts": "run -T tsc --noEmit",
33
36
  "test:unit": "run -T jest",
34
37
  "test:unit:watch": "run -T jest --watch",
35
- "lint": "run -T eslint ."
38
+ "watch": "run -T rollup -c -w"
36
39
  },
37
40
  "dependencies": {
38
41
  "@casl/ability": "6.5.0",
39
- "@strapi/utils": "0.0.0-next.fab38a080023b0850fc7a8ec8605d1ee6970e3c9",
42
+ "@strapi/utils": "0.0.0-next.fb92031f3d90f3d2a2d191ba65725b6c8e329a5d",
40
43
  "lodash": "4.17.21",
41
44
  "qs": "6.11.1",
42
45
  "sift": "16.0.1"
43
46
  },
44
47
  "devDependencies": {
45
- "eslint-config-custom": "0.0.0-next.fab38a080023b0850fc7a8ec8605d1ee6970e3c9",
46
- "tsconfig": "0.0.0-next.fab38a080023b0850fc7a8ec8605d1ee6970e3c9"
48
+ "eslint-config-custom": "0.0.0-next.fb92031f3d90f3d2a2d191ba65725b6c8e329a5d",
49
+ "tsconfig": "0.0.0-next.fb92031f3d90f3d2a2d191ba65725b6c8e329a5d"
47
50
  },
48
51
  "engines": {
49
- "node": ">=16.0.0 <=20.x.x",
52
+ "node": ">=18.0.0 <=22.x.x",
50
53
  "npm": ">=6.0.0"
51
- },
52
- "gitHead": "fab38a080023b0850fc7a8ec8605d1ee6970e3c9"
54
+ }
53
55
  }