@nocobase/evaluators 2.1.0-alpha.1 → 2.1.0-beta.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.
@@ -7,11 +7,9 @@
7
7
  * For more information, please refer to: https://www.nocobase.com/agreement.
8
8
  */
9
9
 
10
- var __create = Object.create;
11
10
  var __defProp = Object.defineProperty;
12
11
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
13
12
  var __getOwnPropNames = Object.getOwnPropertyNames;
14
- var __getProtoOf = Object.getPrototypeOf;
15
13
  var __hasOwnProp = Object.prototype.hasOwnProperty;
16
14
  var __export = (target, all) => {
17
15
  for (var name in all)
@@ -25,24 +23,32 @@ var __copyProps = (to, from, except, desc) => {
25
23
  }
26
24
  return to;
27
25
  };
28
- var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
29
- // If the importer is in node compatibility mode or this is not an ESM
30
- // file that has been converted to a CommonJS file using a Babel-
31
- // compatible transform (i.e. "__esModule" has not been set), then set
32
- // "default" to the CommonJS "module.exports" for node compatibility.
33
- isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
34
- mod
35
- ));
36
26
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
37
27
  var formulajs_exports = {};
38
28
  __export(formulajs_exports, {
39
29
  default: () => formulajs_default
40
30
  });
41
31
  module.exports = __toCommonJS(formulajs_exports);
42
- var import_formulajs = __toESM(require("../../utils/formulajs"));
32
+ var import_client = require("@nocobase/utils/client");
33
+ var import_formulajs = require("../../utils/formulajs");
34
+ const blockedIdentifiers = [
35
+ ...import_client.BASE_BLOCKED_IDENTIFIERS,
36
+ "window",
37
+ "document",
38
+ "parent",
39
+ "top",
40
+ "frames",
41
+ "navigator",
42
+ "location",
43
+ "localStorage",
44
+ "sessionStorage"
45
+ ];
46
+ const formulajs = (0, import_formulajs.createFormulaEvaluator)({
47
+ blockedIdentifiers
48
+ });
43
49
  var formulajs_default = {
44
50
  label: "Formula.js",
45
51
  tooltip: '{{t("Formula.js supports most Microsoft Excel formula functions.")}}',
46
52
  link: "FORMULAJS_DOC_URL",
47
- evaluate: import_formulajs.default
53
+ evaluate: formulajs
48
54
  };
@@ -13,6 +13,7 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
13
13
  var __getOwnPropNames = Object.getOwnPropertyNames;
14
14
  var __getProtoOf = Object.getPrototypeOf;
15
15
  var __hasOwnProp = Object.prototype.hasOwnProperty;
16
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
16
17
  var __export = (target, all) => {
17
18
  for (var name in all)
18
19
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -36,21 +37,48 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
36
37
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
37
38
  var server_exports = {};
38
39
  __export(server_exports, {
39
- Evaluator: () => import_utils3.Evaluator,
40
- appendArrayColumn: () => import_utils3.appendArrayColumn,
40
+ Evaluator: () => import_utils4.Evaluator,
41
+ appendArrayColumn: () => import_utils4.appendArrayColumn,
41
42
  default: () => server_default,
42
- evaluate: () => import_utils3.evaluate,
43
+ evaluate: () => import_utils4.evaluate,
43
44
  evaluators: () => evaluators
44
45
  });
45
46
  module.exports = __toCommonJS(server_exports);
46
47
  var import_utils = require("@nocobase/utils");
48
+ var import_utils2 = require("@nocobase/utils");
47
49
  var import_mathjs = __toESM(require("../utils/mathjs"));
48
- var import_formulajs = __toESM(require("../utils/formulajs"));
50
+ var import_formulajs = require("../utils/formulajs");
49
51
  var import_string = __toESM(require("../utils/string"));
50
- var import_utils3 = require("../utils");
52
+ var import_utils4 = require("../utils");
51
53
  const evaluators = new import_utils.Registry();
54
+ const baseFormulajs = (0, import_formulajs.createFormulaEvaluator)({
55
+ blockedIdentifiers: [
56
+ ...import_utils.BASE_BLOCKED_IDENTIFIERS,
57
+ "process",
58
+ "require",
59
+ "module",
60
+ "exports",
61
+ "__filename",
62
+ "__dirname",
63
+ "Buffer"
64
+ ]
65
+ });
66
+ let formulaLockdownReady = false;
67
+ function formulajs(expression, scope) {
68
+ if (!formulaLockdownReady) {
69
+ (0, import_utils2.lockdownSes)({
70
+ consoleTaming: "unsafe",
71
+ errorTaming: "unsafe",
72
+ overrideTaming: "moderate",
73
+ stackFiltering: "verbose"
74
+ });
75
+ formulaLockdownReady = true;
76
+ }
77
+ return baseFormulajs(expression, scope);
78
+ }
79
+ __name(formulajs, "formulajs");
52
80
  evaluators.register("math.js", import_mathjs.default);
53
- evaluators.register("formula.js", import_formulajs.default);
81
+ evaluators.register("formula.js", formulajs);
54
82
  evaluators.register("string", import_string.default);
55
83
  var server_default = evaluators;
56
84
  // Annotate the CommonJS export names for ESM import in node:
@@ -6,5 +6,10 @@
6
6
  * This project is dual-licensed under AGPL-3.0 and NocoBase Commercial License.
7
7
  * For more information, please refer to: https://www.nocobase.com/agreement.
8
8
  */
9
+ import 'ses';
10
+ export interface FormulaEvaluatorOptions {
11
+ blockedIdentifiers?: string[];
12
+ }
13
+ export declare function createFormulaEvaluator(options?: FormulaEvaluatorOptions): any;
9
14
  declare const _default: any;
10
15
  export default _default;
@@ -13,6 +13,7 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
13
13
  var __getOwnPropNames = Object.getOwnPropertyNames;
14
14
  var __getProtoOf = Object.getPrototypeOf;
15
15
  var __hasOwnProp = Object.prototype.hasOwnProperty;
16
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
16
17
  var __export = (target, all) => {
17
18
  for (var name in all)
18
19
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -36,22 +37,54 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
36
37
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
37
38
  var formulajs_exports = {};
38
39
  __export(formulajs_exports, {
40
+ createFormulaEvaluator: () => createFormulaEvaluator,
39
41
  default: () => formulajs_default
40
42
  });
41
43
  module.exports = __toCommonJS(formulajs_exports);
42
44
  var functions = __toESM(require("@formulajs/formulajs"));
43
45
  var import_mathjs = require("mathjs");
46
+ var import_ses = require("ses");
44
47
  var import__ = require(".");
45
- const fnNames = Object.keys(functions).filter((key) => key !== "default");
46
- const fns = fnNames.map((key) => functions[key]);
47
- var formulajs_default = import__.evaluate.bind(function(expression, scope = {}) {
48
- const fn = new Function(...fnNames, ...Object.keys(scope), `return ${expression}`);
49
- const result = fn(...fns, ...Object.values(scope));
50
- if (typeof result === "number") {
51
- if (Number.isNaN(result) || !Number.isFinite(result)) {
52
- return null;
48
+ const FUNCTION_NAMES = Object.keys(functions).filter((key) => key !== "default");
49
+ function buildEndowments(scope, blockedIdentifiers = []) {
50
+ const endowments = /* @__PURE__ */ Object.create(null);
51
+ for (const key of FUNCTION_NAMES) {
52
+ endowments[key] = functions[key];
53
+ }
54
+ if (scope && typeof scope === "object") {
55
+ for (const [key, value] of Object.entries(scope)) {
56
+ endowments[key] = value;
53
57
  }
54
- return (0, import_mathjs.round)(result, 9);
55
58
  }
56
- return result;
57
- }, {});
59
+ for (const key of blockedIdentifiers) {
60
+ endowments[key] = void 0;
61
+ }
62
+ return endowments;
63
+ }
64
+ __name(buildEndowments, "buildEndowments");
65
+ function runInSandbox(expression, scope, options) {
66
+ const compartment = new Compartment(buildEndowments(scope, options.blockedIdentifiers));
67
+ return compartment.evaluate(expression);
68
+ }
69
+ __name(runInSandbox, "runInSandbox");
70
+ function createFormulaEvaluator(options = {}) {
71
+ const mergedOptions = {
72
+ blockedIdentifiers: options.blockedIdentifiers
73
+ };
74
+ return import__.evaluate.bind(function(expression, scope = {}) {
75
+ const result = runInSandbox(expression, scope, mergedOptions);
76
+ if (typeof result === "number") {
77
+ if (Number.isNaN(result) || !Number.isFinite(result)) {
78
+ return null;
79
+ }
80
+ return (0, import_mathjs.round)(result, 9);
81
+ }
82
+ return result;
83
+ }, {});
84
+ }
85
+ __name(createFormulaEvaluator, "createFormulaEvaluator");
86
+ var formulajs_default = createFormulaEvaluator();
87
+ // Annotate the CommonJS export names for ESM import in node:
88
+ 0 && (module.exports = {
89
+ createFormulaEvaluator
90
+ });
package/package.json CHANGED
@@ -1,19 +1,20 @@
1
1
  {
2
2
  "name": "@nocobase/evaluators",
3
- "version": "2.1.0-alpha.1",
3
+ "version": "2.1.0-beta.1",
4
4
  "description": "",
5
5
  "main": "./lib/index.js",
6
6
  "types": "./lib/index.d.ts",
7
7
  "license": "AGPL-3.0",
8
8
  "dependencies": {
9
9
  "@formulajs/formulajs": "4.4.9",
10
- "@nocobase/utils": "2.1.0-alpha.1",
11
- "mathjs": "^10.6.0"
10
+ "@nocobase/utils": "2.1.0-beta.1",
11
+ "mathjs": "^15.1.0",
12
+ "ses": "^1.14.0"
12
13
  },
13
14
  "repository": {
14
15
  "type": "git",
15
16
  "url": "git+https://github.com/nocobase/nocobase.git",
16
17
  "directory": "packages/evaluators"
17
18
  },
18
- "gitHead": "d27baf21569643d6fa83f882233f4e90eb5b89f1"
19
+ "gitHead": "de3efeb357b6a98b813f1c14831afa832aed1780"
19
20
  }