Param 输入参数
1. 结构声明
- TS Declaration
- JSON Schema
class Param extends BaseNode {
name: string = '';
description?: string;
spread?: boolean;
typeAnnotation?: TypeAnnotation;
defaultValue?: DefaultValue;
}
{
"type": "object",
"properties": {
"composedBy": {
"type": "array",
"items": {
"type": "string"
}
},
"changedTime": {
"$ref": "#/definitions/long"
},
"name": {
"type": "string"
},
"description": {
"type": "string"
},
"spread": {
"type": "boolean"
},
"typeAnnotation": {
"$ref": "#/definitions/TypeAnnotation"
},
"defaultValue": {
"$ref": "#/definitions/DefaultValue"
}
},
"required": [
"name"
],
"additionalProperties": false
}
2. 节点示例
(1) 示例
AST 如下:
- JSON
- YAML
{
"concept": "Param",
"name": "filter",
"description": "",
"typeAnnotation": {
"concept": "TypeAnnotation",
"typeKind": "primitive",
"typeNamespace": "nasl.core",
"typeName": "Date",
"inferred": false,
"ruleMap": {}
}
}
concept: Param
name: filter
description: ""
typeAnnotation:
concept: TypeAnnotation
typeKind: primitive
typeNamespace: nasl.core
typeName: Date
inferred: false
ruleMap: {}
对应的代码如下:
- 文本化 NASL
- Natural TS
filter: Date
filter: Date
(2) 无类型标注的参数
AST 如下:
- JSON
- YAML
{
"concept": "Param",
"name": "index",
"description": ""
}
concept: Param
name: index
description: ""
对应的代码如下:
- 文本化 NASL
- Natural TS
index: String
index: String