@nocobase/plugin-flow-engine 2.0.0-alpha.2
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/LICENSE +661 -0
- package/README.md +29 -0
- package/build.config.ts +22 -0
- package/client.d.ts +2 -0
- package/client.js +1 -0
- package/dist/client/index.d.ts +15 -0
- package/dist/client/index.js +10 -0
- package/dist/externalVersion.js +21 -0
- package/dist/index.d.ts +10 -0
- package/dist/index.js +48 -0
- package/dist/locale/en-US.json +61 -0
- package/dist/locale/index.d.ts +141 -0
- package/dist/locale/index.js +79 -0
- package/dist/locale/zh-CN.json +61 -0
- package/dist/node_modules/ses/LICENSE +201 -0
- package/dist/node_modules/ses/LICENSE-aura +16 -0
- package/dist/node_modules/ses/LICENSE-caja +13 -0
- package/dist/node_modules/ses/LICENSE-corejs +19 -0
- package/dist/node_modules/ses/LICENSE-v8 +9 -0
- package/dist/node_modules/ses/assert-shim.js +1 -0
- package/dist/node_modules/ses/compartment-shim.js +1 -0
- package/dist/node_modules/ses/console-shim.js +1 -0
- package/dist/node_modules/ses/dist/lockdown.cjs +13912 -0
- package/dist/node_modules/ses/dist/lockdown.umd.js +13912 -0
- package/dist/node_modules/ses/dist/lockdown.umd.min.js +1 -0
- package/dist/node_modules/ses/dist/ses-hermes.cjs +13912 -0
- package/dist/node_modules/ses/dist/ses.cjs +1 -0
- package/dist/node_modules/ses/dist/ses.umd.js +13912 -0
- package/dist/node_modules/ses/dist/ses.umd.min.js +1 -0
- package/dist/node_modules/ses/dist/types.d.cts +606 -0
- package/dist/node_modules/ses/index.js +18 -0
- package/dist/node_modules/ses/lockdown-shim.js +1 -0
- package/dist/node_modules/ses/lockdown.js +1 -0
- package/dist/node_modules/ses/package.json +1 -0
- package/dist/node_modules/ses/src/assert-shim.js +4 -0
- package/dist/node_modules/ses/src/assert-sloppy-mode.js +11 -0
- package/dist/node_modules/ses/src/cauterize-property.js +69 -0
- package/dist/node_modules/ses/src/commons.js +425 -0
- package/dist/node_modules/ses/src/compartment-evaluate.js +93 -0
- package/dist/node_modules/ses/src/compartment-shim.js +22 -0
- package/dist/node_modules/ses/src/compartment.js +477 -0
- package/dist/node_modules/ses/src/console-shim.js +50 -0
- package/dist/node_modules/ses/src/enable-property-overrides.js +211 -0
- package/dist/node_modules/ses/src/enablements.js +244 -0
- package/dist/node_modules/ses/src/error/assert.js +584 -0
- package/dist/node_modules/ses/src/error/console.js +541 -0
- package/dist/node_modules/ses/src/error/fatal-assert.js +54 -0
- package/dist/node_modules/ses/src/error/internal-types.js +98 -0
- package/dist/node_modules/ses/src/error/note-log-args.js +77 -0
- package/dist/node_modules/ses/src/error/stringify-utils.js +195 -0
- package/dist/node_modules/ses/src/error/tame-console.js +197 -0
- package/dist/node_modules/ses/src/error/tame-error-constructor.js +284 -0
- package/dist/node_modules/ses/src/error/tame-v8-error-constructor.js +386 -0
- package/dist/node_modules/ses/src/error/types.js +59 -0
- package/dist/node_modules/ses/src/error/unhandled-rejection.js +122 -0
- package/dist/node_modules/ses/src/eval-scope.js +89 -0
- package/dist/node_modules/ses/src/get-anonymous-intrinsics.js +181 -0
- package/dist/node_modules/ses/src/get-source-url.js +50 -0
- package/dist/node_modules/ses/src/global-object.js +175 -0
- package/dist/node_modules/ses/src/intrinsics.js +192 -0
- package/dist/node_modules/ses/src/lockdown-shim.js +37 -0
- package/dist/node_modules/ses/src/lockdown.js +558 -0
- package/dist/node_modules/ses/src/make-eval-function.js +28 -0
- package/dist/node_modules/ses/src/make-evaluate.js +110 -0
- package/dist/node_modules/ses/src/make-function-constructor.js +79 -0
- package/dist/node_modules/ses/src/make-hardener.js +275 -0
- package/dist/node_modules/ses/src/make-safe-evaluator.js +112 -0
- package/dist/node_modules/ses/src/module-instance.js +497 -0
- package/dist/node_modules/ses/src/module-link.js +159 -0
- package/dist/node_modules/ses/src/module-load.js +719 -0
- package/dist/node_modules/ses/src/module-proxy.js +200 -0
- package/dist/node_modules/ses/src/permits-intrinsics.js +291 -0
- package/dist/node_modules/ses/src/permits.js +1761 -0
- package/dist/node_modules/ses/src/reporting-types.d.ts +13 -0
- package/dist/node_modules/ses/src/reporting.js +105 -0
- package/dist/node_modules/ses/src/scope-constants.js +180 -0
- package/dist/node_modules/ses/src/shim-arraybuffer-transfer.js +85 -0
- package/dist/node_modules/ses/src/sloppy-globals-scope-terminator.js +61 -0
- package/dist/node_modules/ses/src/strict-scope-terminator.js +99 -0
- package/dist/node_modules/ses/src/tame-date-constructor.js +127 -0
- package/dist/node_modules/ses/src/tame-domains.js +41 -0
- package/dist/node_modules/ses/src/tame-faux-data-properties.js +210 -0
- package/dist/node_modules/ses/src/tame-function-constructors.js +140 -0
- package/dist/node_modules/ses/src/tame-function-tostring.js +50 -0
- package/dist/node_modules/ses/src/tame-harden.js +29 -0
- package/dist/node_modules/ses/src/tame-locale-methods.js +78 -0
- package/dist/node_modules/ses/src/tame-math-object.js +41 -0
- package/dist/node_modules/ses/src/tame-module-source.js +51 -0
- package/dist/node_modules/ses/src/tame-regenerator-runtime.js +29 -0
- package/dist/node_modules/ses/src/tame-regexp-constructor.js +65 -0
- package/dist/node_modules/ses/src/tame-symbol-constructor.js +64 -0
- package/dist/node_modules/ses/src/transforms.js +267 -0
- package/dist/node_modules/ses/tools.js +25 -0
- package/dist/node_modules/ses/types.d.ts +606 -0
- package/dist/server/actions/ui-schema-action.d.ts +27 -0
- package/dist/server/actions/ui-schema-action.js +118 -0
- package/dist/server/collections/flowModelTreePath.d.ts +11 -0
- package/dist/server/collections/flowModelTreePath.js +74 -0
- package/dist/server/collections/flowModels.d.ts +11 -0
- package/dist/server/collections/flowModels.js +57 -0
- package/dist/server/collections/flowsql.d.ts +10 -0
- package/dist/server/collections/flowsql.js +51 -0
- package/dist/server/dao/ui_schema_node_dao.d.ts +26 -0
- package/dist/server/dao/ui_schema_node_dao.js +24 -0
- package/dist/server/helper.d.ts +8 -0
- package/dist/server/helper.js +9 -0
- package/dist/server/index.d.ts +9 -0
- package/dist/server/index.js +42 -0
- package/dist/server/model.d.ts +12 -0
- package/dist/server/model.js +38 -0
- package/dist/server/plugin.d.ts +26 -0
- package/dist/server/plugin.js +270 -0
- package/dist/server/repository.d.ts +116 -0
- package/dist/server/repository.js +1209 -0
- package/dist/server/server.d.ts +16 -0
- package/dist/server/server.js +198 -0
- package/dist/server/template/contexts.d.ts +73 -0
- package/dist/server/template/contexts.js +233 -0
- package/dist/server/template/resolver.d.ts +30 -0
- package/dist/server/template/resolver.js +225 -0
- package/dist/server/variables/registry.d.ts +42 -0
- package/dist/server/variables/registry.js +299 -0
- package/package.json +28 -0
- package/server.d.ts +2 -0
- package/server.js +1 -0
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { cauterizeProperty } from './cauterize-property.js';
|
|
2
|
+
import {
|
|
3
|
+
TypeError,
|
|
4
|
+
WeakSet,
|
|
5
|
+
arrayFilter,
|
|
6
|
+
create,
|
|
7
|
+
defineProperty,
|
|
8
|
+
entries,
|
|
9
|
+
freeze,
|
|
10
|
+
getOwnPropertyDescriptor,
|
|
11
|
+
getOwnPropertyDescriptors,
|
|
12
|
+
globalThis,
|
|
13
|
+
is,
|
|
14
|
+
isPrimitive,
|
|
15
|
+
hasOwn,
|
|
16
|
+
values,
|
|
17
|
+
weaksetHas,
|
|
18
|
+
} from './commons.js';
|
|
19
|
+
|
|
20
|
+
import {
|
|
21
|
+
constantProperties,
|
|
22
|
+
sharedGlobalPropertyNames,
|
|
23
|
+
universalPropertyNames,
|
|
24
|
+
permitted,
|
|
25
|
+
} from './permits.js';
|
|
26
|
+
|
|
27
|
+
/**
|
|
28
|
+
* @import {Reporter} from './reporting-types.js'
|
|
29
|
+
*/
|
|
30
|
+
|
|
31
|
+
const isFunction = obj => typeof obj === 'function';
|
|
32
|
+
|
|
33
|
+
// Like defineProperty, but throws if it would modify an existing property.
|
|
34
|
+
// We use this to ensure that two conflicting attempts to define the same
|
|
35
|
+
// property throws, causing SES initialization to fail. Otherwise, a
|
|
36
|
+
// conflict between, for example, two of SES's internal permits might
|
|
37
|
+
// get masked as one overwrites the other. Accordingly, the thrown error
|
|
38
|
+
// complains of a "Conflicting definition".
|
|
39
|
+
function initProperty(obj, name, desc) {
|
|
40
|
+
if (hasOwn(obj, name)) {
|
|
41
|
+
const preDesc = getOwnPropertyDescriptor(obj, name);
|
|
42
|
+
if (
|
|
43
|
+
!preDesc ||
|
|
44
|
+
!is(preDesc.value, desc.value) ||
|
|
45
|
+
preDesc.get !== desc.get ||
|
|
46
|
+
preDesc.set !== desc.set ||
|
|
47
|
+
preDesc.writable !== desc.writable ||
|
|
48
|
+
preDesc.enumerable !== desc.enumerable ||
|
|
49
|
+
preDesc.configurable !== desc.configurable
|
|
50
|
+
) {
|
|
51
|
+
throw TypeError(`Conflicting definitions of ${name}`);
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
defineProperty(obj, name, desc);
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
// Like defineProperties, but throws if it would modify an existing property.
|
|
58
|
+
// This ensures that the intrinsics added to the intrinsics collector object
|
|
59
|
+
// graph do not overlap.
|
|
60
|
+
function initProperties(obj, descs) {
|
|
61
|
+
for (const [name, desc] of entries(descs)) {
|
|
62
|
+
initProperty(obj, name, desc);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
// sampleGlobals creates an intrinsics object, suitable for
|
|
67
|
+
// interinsicsCollector.addIntrinsics, from the named properties of a global
|
|
68
|
+
// object.
|
|
69
|
+
function sampleGlobals(globalObject, newPropertyNames) {
|
|
70
|
+
const newIntrinsics = { __proto__: null };
|
|
71
|
+
for (const [globalName, intrinsicName] of entries(newPropertyNames)) {
|
|
72
|
+
if (hasOwn(globalObject, globalName)) {
|
|
73
|
+
newIntrinsics[intrinsicName] = globalObject[globalName];
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
return newIntrinsics;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* @param {Reporter} reporter
|
|
81
|
+
*/
|
|
82
|
+
export const makeIntrinsicsCollector = reporter => {
|
|
83
|
+
/** @type {Record<any, any>} */
|
|
84
|
+
const intrinsics = create(null);
|
|
85
|
+
let pseudoNatives;
|
|
86
|
+
|
|
87
|
+
const addIntrinsics = newIntrinsics => {
|
|
88
|
+
initProperties(intrinsics, getOwnPropertyDescriptors(newIntrinsics));
|
|
89
|
+
};
|
|
90
|
+
freeze(addIntrinsics);
|
|
91
|
+
|
|
92
|
+
// For each intrinsic, if it has a `.prototype` property, use the
|
|
93
|
+
// permits to find out the intrinsic name for that prototype and add it
|
|
94
|
+
// to the intrinsics.
|
|
95
|
+
const completePrototypes = () => {
|
|
96
|
+
for (const [name, intrinsic] of entries(intrinsics)) {
|
|
97
|
+
if (isPrimitive(intrinsic)) {
|
|
98
|
+
// eslint-disable-next-line no-continue
|
|
99
|
+
continue;
|
|
100
|
+
}
|
|
101
|
+
if (!hasOwn(intrinsic, 'prototype')) {
|
|
102
|
+
// eslint-disable-next-line no-continue
|
|
103
|
+
continue;
|
|
104
|
+
}
|
|
105
|
+
const permit = permitted[name];
|
|
106
|
+
if (typeof permit !== 'object') {
|
|
107
|
+
throw TypeError(`Expected permit object at permits.${name}`);
|
|
108
|
+
}
|
|
109
|
+
const namePrototype = permit.prototype;
|
|
110
|
+
if (!namePrototype) {
|
|
111
|
+
cauterizeProperty(
|
|
112
|
+
intrinsic,
|
|
113
|
+
'prototype',
|
|
114
|
+
false,
|
|
115
|
+
`${name}.prototype`,
|
|
116
|
+
reporter,
|
|
117
|
+
);
|
|
118
|
+
// eslint-disable-next-line no-continue
|
|
119
|
+
continue;
|
|
120
|
+
}
|
|
121
|
+
if (
|
|
122
|
+
typeof namePrototype !== 'string' ||
|
|
123
|
+
!hasOwn(permitted, namePrototype)
|
|
124
|
+
) {
|
|
125
|
+
throw TypeError(`Unrecognized ${name}.prototype permits entry`);
|
|
126
|
+
}
|
|
127
|
+
const intrinsicPrototype = intrinsic.prototype;
|
|
128
|
+
if (hasOwn(intrinsics, namePrototype)) {
|
|
129
|
+
if (intrinsics[namePrototype] !== intrinsicPrototype) {
|
|
130
|
+
throw TypeError(`Conflicting bindings of ${namePrototype}`);
|
|
131
|
+
}
|
|
132
|
+
// eslint-disable-next-line no-continue
|
|
133
|
+
continue;
|
|
134
|
+
}
|
|
135
|
+
intrinsics[namePrototype] = intrinsicPrototype;
|
|
136
|
+
}
|
|
137
|
+
};
|
|
138
|
+
freeze(completePrototypes);
|
|
139
|
+
|
|
140
|
+
const finalIntrinsics = () => {
|
|
141
|
+
freeze(intrinsics);
|
|
142
|
+
pseudoNatives = new WeakSet(arrayFilter(values(intrinsics), isFunction));
|
|
143
|
+
return intrinsics;
|
|
144
|
+
};
|
|
145
|
+
freeze(finalIntrinsics);
|
|
146
|
+
|
|
147
|
+
const isPseudoNative = obj => {
|
|
148
|
+
if (!pseudoNatives) {
|
|
149
|
+
throw TypeError(
|
|
150
|
+
'isPseudoNative can only be called after finalIntrinsics',
|
|
151
|
+
);
|
|
152
|
+
}
|
|
153
|
+
return weaksetHas(pseudoNatives, obj);
|
|
154
|
+
};
|
|
155
|
+
freeze(isPseudoNative);
|
|
156
|
+
|
|
157
|
+
const intrinsicsCollector = {
|
|
158
|
+
addIntrinsics,
|
|
159
|
+
completePrototypes,
|
|
160
|
+
finalIntrinsics,
|
|
161
|
+
isPseudoNative,
|
|
162
|
+
};
|
|
163
|
+
freeze(intrinsicsCollector);
|
|
164
|
+
|
|
165
|
+
addIntrinsics(constantProperties);
|
|
166
|
+
addIntrinsics(sampleGlobals(globalThis, universalPropertyNames));
|
|
167
|
+
|
|
168
|
+
return intrinsicsCollector;
|
|
169
|
+
};
|
|
170
|
+
|
|
171
|
+
/**
|
|
172
|
+
* getGlobalIntrinsics()
|
|
173
|
+
* Doesn't tame, delete, or modify anything. Samples globalObject to create an
|
|
174
|
+
* intrinsics record containing only the permitted global variables, listed
|
|
175
|
+
* by the intrinsic names appropriate for new globals, i.e., the globals of
|
|
176
|
+
* newly constructed compartments.
|
|
177
|
+
*
|
|
178
|
+
* WARNING:
|
|
179
|
+
* If run before lockdown, the returned intrinsics record will carry the
|
|
180
|
+
* *original* unsafe (feral, untamed) bindings of these global variables.
|
|
181
|
+
*
|
|
182
|
+
* @param {object} globalObject
|
|
183
|
+
* @param {Reporter} reporter
|
|
184
|
+
*/
|
|
185
|
+
export const getGlobalIntrinsics = (globalObject, reporter) => {
|
|
186
|
+
// TODO pass a proper reporter to `makeIntrinsicsCollector`
|
|
187
|
+
const { addIntrinsics, finalIntrinsics } = makeIntrinsicsCollector(reporter);
|
|
188
|
+
|
|
189
|
+
addIntrinsics(sampleGlobals(globalObject, sharedGlobalPropertyNames));
|
|
190
|
+
|
|
191
|
+
return finalIntrinsics();
|
|
192
|
+
};
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
// @ts-check
|
|
2
|
+
|
|
3
|
+
// We import this first to fail as fast as possible if the shim has been
|
|
4
|
+
// transformed or embedded in a way that causes it to run in sloppy mode.
|
|
5
|
+
// See https://github.com/endojs/endo/blob/master/packages/ses/error-codes/SES_NO_SLOPPY.md
|
|
6
|
+
import './assert-sloppy-mode.js';
|
|
7
|
+
import { globalThis } from './commons.js';
|
|
8
|
+
import { repairIntrinsics } from './lockdown.js';
|
|
9
|
+
|
|
10
|
+
/** @import {LockdownOptions} from '../types.js' */
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* @param {LockdownOptions} [options]
|
|
14
|
+
*/
|
|
15
|
+
globalThis.lockdown = options => {
|
|
16
|
+
const hardenIntrinsics = repairIntrinsics(options);
|
|
17
|
+
globalThis.harden = hardenIntrinsics();
|
|
18
|
+
};
|
|
19
|
+
|
|
20
|
+
/**
|
|
21
|
+
* @param {LockdownOptions} [options]
|
|
22
|
+
*/
|
|
23
|
+
globalThis.repairIntrinsics = options => {
|
|
24
|
+
const hardenIntrinsics = repairIntrinsics(options);
|
|
25
|
+
// Reveal hardenIntrinsics after repairs.
|
|
26
|
+
globalThis.hardenIntrinsics = () => {
|
|
27
|
+
// Reveal harden after hardenIntrinsics.
|
|
28
|
+
// Harden is dangerous before hardenIntrinsics because hardening just
|
|
29
|
+
// about anything will inadvertently render intrinsics irreparable.
|
|
30
|
+
// Also, for modules that must work both before or after lockdown (code
|
|
31
|
+
// that is portable between JS and SES), the existence of harden in global
|
|
32
|
+
// scope signals whether such code should attempt to use harden in the
|
|
33
|
+
// defense of its own API.
|
|
34
|
+
// @ts-ignore harden not yet recognized on globalThis.
|
|
35
|
+
globalThis.harden = hardenIntrinsics();
|
|
36
|
+
};
|
|
37
|
+
};
|