@lcap/nasl 3.5.0-beta.4 → 3.6.0-alpha.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/out/bak/translator.js +39 -119
- package/out/bak/translator.js.map +1 -1
- package/out/breakpoint/generator/BreakpointNode.d.ts +0 -3
- package/out/breakpoint/generator/BreakpointNode.js +0 -9
- package/out/breakpoint/generator/BreakpointNode.js.map +1 -1
- package/out/breakpoint/shared/constants.js +0 -1
- package/out/breakpoint/shared/constants.js.map +1 -1
- package/out/breakpoint/shared/utils.js +7 -31
- package/out/breakpoint/shared/utils.js.map +1 -1
- package/out/common/BaseNode.d.ts +13 -1
- package/out/common/BaseNode.js +52 -23
- package/out/common/BaseNode.js.map +1 -1
- package/out/common/Command.js +1 -0
- package/out/common/Command.js.map +1 -1
- package/out/common/EventEmitter.d.ts +1 -1
- package/out/common/EventEmitter.js +0 -4
- package/out/common/EventEmitter.js.map +1 -1
- package/out/concepts/App__.d.ts +76 -51
- package/out/concepts/App__.js +190 -87
- package/out/concepts/App__.js.map +1 -1
- package/out/concepts/BackendVariable__.js +2 -10
- package/out/concepts/BackendVariable__.js.map +1 -1
- package/out/concepts/BindAttribute__.js +6 -16
- package/out/concepts/BindAttribute__.js.map +1 -1
- package/out/concepts/BindDirective__.d.ts +0 -1
- package/out/concepts/BindDirective__.js +4 -19
- package/out/concepts/BindDirective__.js.map +1 -1
- package/out/concepts/BindEvent__.d.ts +1 -3
- package/out/concepts/BindEvent__.js +13 -38
- package/out/concepts/BindEvent__.js.map +1 -1
- package/out/concepts/CallFunction__.js +2 -10
- package/out/concepts/CallFunction__.js.map +1 -1
- package/out/concepts/CallLogic__.d.ts +0 -2
- package/out/concepts/CallLogic__.js +27 -38
- package/out/concepts/CallLogic__.js.map +1 -1
- package/out/concepts/Constant__.js +6 -7
- package/out/concepts/Constant__.js.map +1 -1
- package/out/concepts/Destination__.d.ts +1 -1
- package/out/concepts/Destination__.js +4 -6
- package/out/concepts/Destination__.js.map +1 -1
- package/out/concepts/End__.js +1 -2
- package/out/concepts/End__.js.map +1 -1
- package/out/concepts/Entity__.d.ts +1 -1
- package/out/concepts/Entity__.js +2 -0
- package/out/concepts/Entity__.js.map +1 -1
- package/out/concepts/Event__.d.ts +0 -14
- package/out/concepts/Event__.js +0 -61
- package/out/concepts/Event__.js.map +1 -1
- package/out/concepts/Frontend__.d.ts +88 -0
- package/out/concepts/Frontend__.js +143 -1
- package/out/concepts/Frontend__.js.map +1 -1
- package/out/concepts/Identifier__.d.ts +0 -5
- package/out/concepts/Identifier__.js +9 -19
- package/out/concepts/Identifier__.js.map +1 -1
- package/out/concepts/LogicItem__.d.ts +1 -1
- package/out/concepts/LogicItem__.js.map +1 -1
- package/out/concepts/Logic__.d.ts +1 -3
- package/out/concepts/Logic__.js +13 -16
- package/out/concepts/Logic__.js.map +1 -1
- package/out/concepts/MemberExpression__.d.ts +1 -1
- package/out/concepts/MemberExpression__.js +3 -3
- package/out/concepts/MemberExpression__.js.map +1 -1
- package/out/concepts/NewComposite__.js.map +1 -1
- package/out/concepts/Param__.js +3 -11
- package/out/concepts/Param__.js.map +1 -1
- package/out/concepts/ProcessElement__.js +1 -9
- package/out/concepts/ProcessElement__.js.map +1 -1
- package/out/concepts/Return__.js +9 -17
- package/out/concepts/Return__.js.map +1 -1
- package/out/concepts/Variable__.js +8 -17
- package/out/concepts/Variable__.js.map +1 -1
- package/out/concepts/ViewElement__.d.ts +2 -17
- package/out/concepts/ViewElement__.js +31 -143
- package/out/concepts/ViewElement__.js.map +1 -1
- package/out/concepts/View__.js +6 -6
- package/out/concepts/View__.js.map +1 -1
- package/out/concepts/index__.d.ts +0 -5
- package/out/concepts/index__.js +0 -5
- package/out/concepts/index__.js.map +1 -1
- package/out/concepts/utils/asserts.d.ts +3 -258
- package/out/concepts/utils/asserts.js +13 -351
- package/out/concepts/utils/asserts.js.map +1 -1
- package/out/concepts/utils/types.d.ts +3 -20
- package/out/generator/genBundleFiles.js +11 -25
- package/out/generator/genBundleFiles.js.map +1 -1
- package/out/generator/genReleaseBody.js +3 -12
- package/out/generator/genReleaseBody.js.map +1 -1
- package/out/generator/permission.js +3 -3
- package/out/generator/permission.js.map +1 -1
- package/out/natural/transformTSCode.js +1 -1
- package/out/natural/transformTSCode.js.map +1 -1
- package/out/server/extendBaseNode.js +22 -6
- package/out/server/extendBaseNode.js.map +1 -1
- package/out/server/getLogics.js +27 -62
- package/out/server/getLogics.js.map +1 -1
- package/out/server/getMemberIdentifier.js +1 -6
- package/out/server/getMemberIdentifier.js.map +1 -1
- package/out/server/naslServer.js +11 -28
- package/out/server/naslServer.js.map +1 -1
- package/out/server/translator.js +1 -6
- package/out/server/translator.js.map +1 -1
- package/out/service/storage/init.js +26 -2
- package/out/service/storage/init.js.map +1 -1
- package/out/templator/genCreateBlock.js +6 -6
- package/out/templator/genCreateBlock.js.map +1 -1
- package/out/templator/genCurdEditMultipleKeyBlock.js +16 -16
- package/out/templator/genCurdEditMultipleKeyBlock.js.map +1 -1
- package/out/templator/genCurdMultipleKeyBlock.d.ts +27 -0
- package/out/templator/genCurdMultipleKeyBlock.js +709 -37
- package/out/templator/genCurdMultipleKeyBlock.js.map +1 -1
- package/out/templator/genGetBlock.js +4 -4
- package/out/templator/genGetBlock.js.map +1 -1
- package/out/templator/genGridViewBlock.js +12 -12
- package/out/templator/genGridViewBlock.js.map +1 -1
- package/out/templator/genListViewBlock.js +4 -4
- package/out/templator/genListViewBlock.js.map +1 -1
- package/out/templator/genSelectBlock.js +3 -3
- package/out/templator/genSelectBlock.js.map +1 -1
- package/out/templator/genTableBlock.d.ts +2 -0
- package/out/templator/genTableBlock.js +124 -11
- package/out/templator/genTableBlock.js.map +1 -1
- package/out/templator/genUpdateBlock.js +8 -8
- package/out/templator/genUpdateBlock.js.map +1 -1
- package/out/templator/utils.d.ts +2 -2
- package/out/templator/utils.js.map +1 -1
- package/out/translator/utils.js +18 -0
- package/out/translator/utils.js.map +1 -1
- package/out/utils/i18nInfo.js +2 -7
- package/out/utils/i18nInfo.js.map +1 -1
- package/package.json +2 -2
- package/src/bak/translator.js +43 -121
- package/src/breakpoint/generator/BreakpointNode.ts +0 -12
- package/src/breakpoint/shared/constants.ts +0 -1
- package/src/breakpoint/shared/utils.ts +10 -37
- package/src/common/BaseNode.ts +60 -22
- package/src/common/Command.ts +1 -0
- package/src/common/EventEmitter.ts +1 -6
- package/src/concepts/App__.ts +251 -139
- package/src/concepts/BackendVariable__.ts +2 -10
- package/src/concepts/BindAttribute__.ts +6 -15
- package/src/concepts/BindDirective__.ts +4 -19
- package/src/concepts/BindEvent__.ts +12 -40
- package/src/concepts/CallFunction__.ts +2 -10
- package/src/concepts/CallLogic__.ts +32 -45
- package/src/concepts/Constant__.ts +7 -5
- package/src/concepts/Destination__.ts +4 -6
- package/src/concepts/End__.ts +0 -1
- package/src/concepts/Entity__.ts +3 -1
- package/src/concepts/Event__.ts +0 -70
- package/src/concepts/Frontend__.ts +251 -3
- package/src/concepts/Identifier__.ts +13 -29
- package/src/concepts/LogicItem__.ts +0 -1
- package/src/concepts/Logic__.ts +14 -21
- package/src/concepts/MemberExpression__.ts +3 -3
- package/src/concepts/NewComposite__.ts +6 -4
- package/src/concepts/Param__.ts +3 -11
- package/src/concepts/ProcessElement__.ts +1 -8
- package/src/concepts/Return__.ts +12 -15
- package/src/concepts/Variable__.ts +9 -17
- package/src/concepts/ViewElement__.ts +54 -166
- package/src/concepts/View__.ts +6 -8
- package/src/concepts/index__.ts +0 -5
- package/src/concepts/utils/asserts.ts +4 -367
- package/src/concepts/utils/types.ts +0 -28
- package/src/generator/genBundleFiles.ts +15 -33
- package/src/generator/genReleaseBody.ts +3 -14
- package/src/generator/permission.ts +6 -8
- package/src/natural/transformTSCode.ts +1 -1
- package/src/server/extendBaseNode.ts +41 -22
- package/src/server/getLogics.ts +41 -79
- package/src/server/getMemberIdentifier.ts +1 -7
- package/src/server/naslServer.ts +12 -30
- package/src/server/translator.ts +1 -7
- package/src/service/storage/init.ts +33 -2
- package/src/templator/genCreateBlock.ts +6 -6
- package/src/templator/genCurdEditMultipleKeyBlock.ts +16 -16
- package/src/templator/genCurdMultipleKeyBlock.ts +817 -93
- package/src/templator/genGetBlock.ts +4 -4
- package/src/templator/genGridViewBlock.ts +12 -12
- package/src/templator/genListViewBlock.ts +4 -4
- package/src/templator/genSelectBlock.ts +3 -3
- package/src/templator/genTableBlock.ts +137 -12
- package/src/templator/genUpdateBlock.ts +8 -8
- package/src/templator/utils.ts +2 -2
- package/src/translator/utils.ts +20 -0
- package/src/utils/i18nInfo.ts +2 -7
- package/test/concepts/call-function/fixtures/from-string.json +59 -68
- package/test/concepts/call-function/fixtures/to-string-global-tz.json +58 -67
- package/test/concepts/call-function/fixtures/to-string-no-tz.json +48 -57
- package/test/concepts/call-function/fixtures/to-string-user-tz.json +60 -69
- package/test/concepts/call-function/fixtures/to-string-utc-tz.json +60 -69
- package/test/concepts/call-interface/fixtures/only-interface.json +72 -81
- package/test/concepts/call-interface/fixtures/with-body-complex-argument.json +214 -223
- package/test/concepts/call-interface/fixtures/with-body-no-argument.json +76 -85
- package/test/concepts/call-interface/fixtures/with-body-simple-argument.json +91 -100
- package/test/concepts/call-interface/fixtures/with-headers-no-argument.json +79 -88
- package/test/concepts/call-interface/fixtures/with-headers.json +81 -90
- package/test/concepts/call-interface/fixtures/with-query-no-argument.json +79 -88
- package/test/concepts/call-interface/fixtures/with-query.json +81 -90
- package/test/concepts/call-logic/__snapshots__/getQuickInfoOffset.spec.ts.snap +2 -4
- package/test/concepts/call-logic/fixtures/entries-get-with-arguments.json +95 -104
- package/test/concepts/call-logic/fixtures/entries-update-with-arguments.json +200 -209
- package/test/concepts/call-logic/fixtures/global-logic-argument-no-expression.json +88 -97
- package/test/concepts/call-logic/fixtures/global-logic-argument-some-expression.json +115 -124
- package/test/concepts/call-logic/fixtures/json-deserialize.json +111 -120
- package/test/concepts/call-logic/fixtures/json-serialize-with-string.json +115 -124
- package/test/concepts/call-logic/fixtures/json-serialize.json +115 -124
- package/test/concepts/call-logic/fixtures/view-buildin-logic-with-argument.json +82 -91
- package/test/concepts/call-logic/fixtures/view-component-logic-no-argument.json +79 -88
- package/test/concepts/call-logic/fixtures/view-component-with-validation.json +135 -144
- package/test/concepts/identifier/fixtures/view-variable.json +136 -145
- package/test/concepts/view-element/__snapshots__/toVue.spec.ts.snap +1 -1
- package/test/concepts/view-element/fixtures/default-login.json +212 -221
- package/test/concepts/view-element/fixtures/default-not-found.json +174 -183
- package/test/concepts/view-element/fixtures/with-role-auth.json +82 -91
- package/test/concepts/view-element/fixtures/with-table.json +1834 -1843
- package/test/concepts/view-element/toVue.spec.ts +0 -1
- package/ts-worker/package.json +1 -1
- package/out/concepts/BusinessComponent__.d.ts +0 -641
- package/out/concepts/BusinessComponent__.js +0 -1901
- package/out/concepts/BusinessComponent__.js.map +0 -1
- package/out/concepts/BusinessLogic__.d.ts +0 -38
- package/out/concepts/BusinessLogic__.js +0 -358
- package/out/concepts/BusinessLogic__.js.map +0 -1
- package/out/concepts/CallEvent__.d.ts +0 -97
- package/out/concepts/CallEvent__.js +0 -263
- package/out/concepts/CallEvent__.js.map +0 -1
- package/out/concepts/FrontendType__.d.ts +0 -308
- package/out/concepts/FrontendType__.js +0 -605
- package/out/concepts/FrontendType__.js.map +0 -1
- package/out/concepts/ParamWithGroup__.d.ts +0 -39
- package/out/concepts/ParamWithGroup__.js +0 -85
- package/out/concepts/ParamWithGroup__.js.map +0 -1
- package/src/concepts/BusinessComponent__.ts +0 -2669
- package/src/concepts/BusinessLogic__.ts +0 -376
- package/src/concepts/CallEvent__.ts +0 -334
- package/src/concepts/FrontendType__.ts +0 -919
- package/src/concepts/ParamWithGroup__.ts +0 -101
package/src/common/BaseNode.ts
CHANGED
|
@@ -20,6 +20,38 @@ export function setActionable(value: boolean) {
|
|
|
20
20
|
actionable = value;
|
|
21
21
|
}
|
|
22
22
|
|
|
23
|
+
// 确保属性都是定义过的
|
|
24
|
+
function ensureDefined(object: any, concept: string) {
|
|
25
|
+
if (!object) {
|
|
26
|
+
return object;
|
|
27
|
+
}
|
|
28
|
+
const newObject: any = {};
|
|
29
|
+
const actualConcept = object?.concept || concept;
|
|
30
|
+
if (actualConcept) {
|
|
31
|
+
const propertyMap = getConceptPropertyMap(actualConcept);
|
|
32
|
+
for (const key in object) {
|
|
33
|
+
const property = propertyMap.get(key);
|
|
34
|
+
if (property) {
|
|
35
|
+
const objProperty = object[key] ?? null;
|
|
36
|
+
const propertyConcept = property?.objectRef;
|
|
37
|
+
if (propertyConcept) {
|
|
38
|
+
if (Array.isArray(objProperty)) {
|
|
39
|
+
newObject[key] = objProperty.map((objItem: any) => {
|
|
40
|
+
return ensureDefined(objItem, propertyConcept);
|
|
41
|
+
});
|
|
42
|
+
} else {
|
|
43
|
+
newObject[key] = ensureDefined(objProperty, propertyConcept);
|
|
44
|
+
}
|
|
45
|
+
} else {
|
|
46
|
+
newObject[key] = objProperty;
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
newObject.concept = actualConcept;
|
|
52
|
+
}
|
|
53
|
+
return newObject;
|
|
54
|
+
}
|
|
23
55
|
|
|
24
56
|
type NodePathOption = {
|
|
25
57
|
useName?: boolean,
|
|
@@ -210,6 +242,20 @@ export class BaseNode extends EventEmitter {
|
|
|
210
242
|
@property()
|
|
211
243
|
name: string = '';
|
|
212
244
|
|
|
245
|
+
/**
|
|
246
|
+
* 应用内节点的分组管理机制
|
|
247
|
+
* 暂无明确的名称定义要求,只要求唯一即可,建议使用时第一个分组给一个root分组
|
|
248
|
+
*/
|
|
249
|
+
@property()
|
|
250
|
+
composedBy?: Array<string>;
|
|
251
|
+
|
|
252
|
+
|
|
253
|
+
/**
|
|
254
|
+
* 分组管理在多人协作场景触点
|
|
255
|
+
*/
|
|
256
|
+
@property()
|
|
257
|
+
composedOrigin?: 'Form' | 'Table' | 'Process';
|
|
258
|
+
|
|
213
259
|
/**
|
|
214
260
|
* 当前节点的类型标注
|
|
215
261
|
*/
|
|
@@ -300,6 +346,10 @@ export class BaseNode extends EventEmitter {
|
|
|
300
346
|
if (utils.isNode && ('concept' in this) && !this.concept) {
|
|
301
347
|
Reflect.deleteProperty(this, 'concept');
|
|
302
348
|
}
|
|
349
|
+
|
|
350
|
+
if (this?.composedBy) {
|
|
351
|
+
(this as any)?.app && (this as any).app.addComposeNodes(this.composedBy, this);
|
|
352
|
+
}
|
|
303
353
|
}
|
|
304
354
|
|
|
305
355
|
fixInstantiate() {
|
|
@@ -1053,27 +1103,7 @@ export class BaseNode extends EventEmitter {
|
|
|
1053
1103
|
});
|
|
1054
1104
|
return JSON.parse(JSON.stringify(temp));
|
|
1055
1105
|
}
|
|
1056
|
-
|
|
1057
|
-
getNodeChinesePath(useIndex: boolean | string[] | NodePathOption) {
|
|
1058
|
-
let node: BaseNode = this;
|
|
1059
|
-
const pathArr: string[] = [];
|
|
1060
|
-
while (node && node.concept) {
|
|
1061
|
-
let pathText = '';
|
|
1062
|
-
const { parentNode } = node;
|
|
1063
|
-
if (parentNode) {
|
|
1064
|
-
const { name, title, label } = parentNode as any;
|
|
1065
|
-
pathText = `${(parentNode.constructor as any)?.nodeTitle || ''}${name || ''}`;
|
|
1066
|
-
if (title && label) {
|
|
1067
|
-
pathText += `(${title} | ${label})`;
|
|
1068
|
-
} else if (title || label) {
|
|
1069
|
-
pathText += `(${title || label})`;
|
|
1070
|
-
}
|
|
1071
|
-
pathArr.unshift(pathText);
|
|
1072
|
-
}
|
|
1073
|
-
node = parentNode;
|
|
1074
|
-
}
|
|
1075
|
-
return pathArr.join('/');
|
|
1076
|
-
}
|
|
1106
|
+
|
|
1077
1107
|
/**
|
|
1078
1108
|
* 查找引用
|
|
1079
1109
|
*/
|
|
@@ -1102,6 +1132,14 @@ export class BaseNode extends EventEmitter {
|
|
|
1102
1132
|
/* override */
|
|
1103
1133
|
}
|
|
1104
1134
|
|
|
1135
|
+
/**
|
|
1136
|
+
* 移除绑定实体元素的页面元素
|
|
1137
|
+
*/
|
|
1138
|
+
@action('移除绑定实体元素的页面元素')
|
|
1139
|
+
async removeBindEntityPropertyViewEelment(): Promise<any> {
|
|
1140
|
+
/* override */
|
|
1141
|
+
}
|
|
1142
|
+
|
|
1105
1143
|
/**
|
|
1106
1144
|
* 准备删除
|
|
1107
1145
|
*/
|
|
@@ -1458,7 +1496,7 @@ export class BaseNode extends EventEmitter {
|
|
|
1458
1496
|
if (typeAnnotation) {
|
|
1459
1497
|
const { typeKind, typeNamespace, typeName, properties } = typeAnnotation;
|
|
1460
1498
|
if (typeKind === 'reference' || typeKind === 'generic') {
|
|
1461
|
-
if (typeNamespace
|
|
1499
|
+
if (typeNamespace.endsWith('.enums')) return null;
|
|
1462
1500
|
return [{}];
|
|
1463
1501
|
}
|
|
1464
1502
|
if (typeNamespace === 'nasl.core' && ['String', 'Text', 'Email'].includes(typeName)) {
|
package/src/common/Command.ts
CHANGED
|
@@ -27,12 +27,7 @@ export class EventEmitter {
|
|
|
27
27
|
* @param eventName 事件名
|
|
28
28
|
* @param listener 监听器
|
|
29
29
|
*/
|
|
30
|
-
off(eventName
|
|
31
|
-
if (!eventName) {
|
|
32
|
-
(this as any)._events = {};
|
|
33
|
-
return;
|
|
34
|
-
}
|
|
35
|
-
|
|
30
|
+
off(eventName: string, listener: EventListener) {
|
|
36
31
|
const listeners = this._events[eventName];
|
|
37
32
|
if (listeners) {
|
|
38
33
|
const index = listeners.indexOf(listener);
|