ondc-code-generator 0.0.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/.idea/code-generator.iml +12 -0
- package/.idea/modules.xml +8 -0
- package/.idea/vcs.xml +6 -0
- package/LICENSE +21 -0
- package/README.md +0 -0
- package/custom-loader.js +4 -0
- package/dist/Generator/config-compiler.js +53 -0
- package/dist/Generator/config-validator.js +21 -0
- package/dist/Generator/generators/classes/abstract-generator.js +16 -0
- package/dist/Generator/generators/documentation/markdown-message-generator.js +37 -0
- package/dist/Generator/generators/documentation/md-generator.js +57 -0
- package/dist/Generator/generators/markdown-message-generator.js +25 -0
- package/dist/Generator/generators/python/py-generator.js +1 -0
- package/dist/Generator/generators/typescript/templates/json-path-utils.js +15 -0
- package/dist/Generator/generators/typescript/templates/validation-utils.js +91 -0
- package/dist/Generator/generators/typescript/ts-ast.js +50 -0
- package/dist/Generator/generators/typescript/ts-generator.js +184 -0
- package/dist/Generator/pipline.js +1 -0
- package/dist/Generator/validators/abstract-validator.js +6 -0
- package/dist/Generator/validators/config-validator.js +32 -0
- package/dist/Generator/validators/session-data-config/session-data-validator.js +35 -0
- package/dist/Generator/validators/tests-config/sub-validations.js +194 -0
- package/dist/Generator/validators/tests-config/test-list-validator.js +36 -0
- package/dist/Generator/validators/tests-config/test-validator.js +24 -0
- package/dist/Generator/validators/validation-error.js +9 -0
- package/dist/constants/operations.js +17 -0
- package/dist/constants/syntax.js +75 -0
- package/dist/index.js +39 -0
- package/dist/services/rename-later/main.js +1 -0
- package/dist/services/rename-later/parser.js +22 -0
- package/dist/services/rename-later/tokens.js +32 -0
- package/dist/services/rename-later/tokens1.js +33 -0
- package/dist/services/return-complier/ast-functions/compile-to-markdown.js +66 -0
- package/dist/services/return-complier/ast-functions/semantic-validations.js +30 -0
- package/dist/services/return-complier/ast.js +92 -0
- package/dist/services/return-complier/combined.js +7 -0
- package/dist/services/return-complier/parser.js +95 -0
- package/dist/services/return-complier/tokens.js +144 -0
- package/dist/services/schema-service.js +29 -0
- package/dist/types/build.js +1 -0
- package/dist/types/compiler-types.js +4 -0
- package/dist/types/config-types.js +1 -0
- package/dist/types/error-codes.js +1 -0
- package/dist/types/general-types.js +1 -0
- package/dist/utils/config-utils/json-schema-utils.js +91 -0
- package/dist/utils/config-utils/yaml.js +16 -0
- package/dist/utils/file-system.js +1 -0
- package/dist/utils/fs-utils.js +20 -0
- package/dist/utils/general-utils/string-utils.js +56 -0
- package/dist/utils/general-utils/test-object-utils.js +12 -0
- package/dist/utils/general-utils/validation-utils.js +21 -0
- package/dist/utils/json-path-utils/extract-string-paths.js +113 -0
- package/dist/utils/json-path-utils/paths.js +46 -0
- package/dist/utils/logger.js +41 -0
- package/docs/error-gen.md +33 -0
- package/docs/return-grammer.md +23 -0
- package/docs/sampleConfig.md +39 -0
- package/generated/L1-validations/api-tests/cancel.ts +569 -0
- package/generated/L1-validations/api-tests/confirm.ts +1162 -0
- package/generated/L1-validations/api-tests/init.ts +1063 -0
- package/generated/L1-validations/api-tests/on_cancel.ts +2069 -0
- package/generated/L1-validations/api-tests/on_confirm.ts +2219 -0
- package/generated/L1-validations/api-tests/on_init.ts +1949 -0
- package/generated/L1-validations/api-tests/on_search.ts +1574 -0
- package/generated/L1-validations/api-tests/on_select.ts +1723 -0
- package/generated/L1-validations/api-tests/on_status.ts +2221 -0
- package/generated/L1-validations/api-tests/on_update.ts +1969 -0
- package/generated/L1-validations/api-tests/search.ts +695 -0
- package/generated/L1-validations/api-tests/select.ts +994 -0
- package/generated/L1-validations/api-tests/status.ts +443 -0
- package/generated/L1-validations/api-tests/update.ts +898 -0
- package/generated/L1-validations/error.ts +64 -0
- package/generated/L1-validations/index.ts +138 -0
- package/generated/L1-validations/page/index.html +2118 -0
- package/generated/L1-validations/page/style.css +225 -0
- package/generated/L1-validations/readme.md +1779 -0
- package/generated/L1-validations/types/test-config.ts +27 -0
- package/generated/L1-validations/utils/json-path-utils.ts +17 -0
- package/generated/L1-validations/utils/validation-utils.ts +116 -0
- package/generated-structure/api-tests/search.ts +24 -0
- package/generated-structure/error.ts +0 -0
- package/generated-structure/index.ts +0 -0
- package/generated-structure/types/test-config.ts +21 -0
- package/nodemon.json +5 -0
- package/package.json +40 -0
- package/samples/build.yaml +24799 -0
- package/samples/output.md +91 -0
- package/samples/output.ts +27 -0
- package/samples/selections.json +216 -0
- package/samples/validation-config.json +3422 -0
- package/samples/x-validations.yaml +2893 -0
- package/src/constants/operations.ts +19 -0
- package/src/constants/syntax.ts +81 -0
- package/src/example.ts +25 -0
- package/src/generator/config-compiler.ts +122 -0
- package/src/generator/generators/classes/abstract-generator.ts +29 -0
- package/src/generator/generators/documentation/markdown-message-generator.ts +43 -0
- package/src/generator/generators/documentation/md-generator.ts +76 -0
- package/src/generator/generators/documentation/templates/index.mustache +36 -0
- package/src/generator/generators/documentation/templates/style.css +204 -0
- package/src/generator/generators/python/py-generator.ts +0 -0
- package/src/generator/generators/typescript/templates/api-test.mustache +7 -0
- package/src/generator/generators/typescript/templates/json-path-utils.ts +17 -0
- package/src/generator/generators/typescript/templates/schema-template.mustache +18 -0
- package/src/generator/generators/typescript/templates/test-config.mustache +28 -0
- package/src/generator/generators/typescript/templates/test-object.mustache +20 -0
- package/src/generator/generators/typescript/templates/validation-code.mustache +39 -0
- package/src/generator/generators/typescript/templates/validation-utils.ts +117 -0
- package/src/generator/generators/typescript/ts-ast.ts +72 -0
- package/src/generator/generators/typescript/ts-generator.ts +275 -0
- package/src/generator/validators/abstract-validator.ts +23 -0
- package/src/generator/validators/config-validator.ts +55 -0
- package/src/generator/validators/session-data-config/session-data-validator.ts +58 -0
- package/src/generator/validators/tests-config/sub-validations.ts +302 -0
- package/src/generator/validators/tests-config/test-list-validator.ts +59 -0
- package/src/generator/validators/tests-config/test-validator.ts +69 -0
- package/src/index.ts +2 -0
- package/src/services/return-complier/ast-functions/compile-to-markdown.ts +152 -0
- package/src/services/return-complier/ast-functions/semantic-validations.ts +44 -0
- package/src/services/return-complier/ast.ts +147 -0
- package/src/services/return-complier/combined.ts +8 -0
- package/src/services/return-complier/parser.ts +128 -0
- package/src/services/return-complier/tokens.ts +184 -0
- package/src/services/schema-service.ts +42 -0
- package/src/types/build.ts +51 -0
- package/src/types/compiler-types.ts +3 -0
- package/src/types/config-types.ts +27 -0
- package/src/types/error-codes.ts +6 -0
- package/src/types/general-types.ts +2 -0
- package/src/utils/config-utils/json-schema-utils.ts +150 -0
- package/src/utils/config-utils/yaml.ts +17 -0
- package/src/utils/fs-utils.ts +32 -0
- package/src/utils/general-utils/string-utils.ts +76 -0
- package/src/utils/general-utils/test-object-utils.ts +14 -0
- package/src/utils/general-utils/validation-utils.ts +30 -0
- package/src/utils/json-path-utils/extract-string-paths.ts +139 -0
- package/src/utils/json-path-utils/paths.ts +44 -0
- package/src/utils/logger.ts +53 -0
- package/tsconfig.json +17 -0
|
@@ -0,0 +1,1574 @@
|
|
|
1
|
+
import payloadUtils from "../utils/json-path-utils";
|
|
2
|
+
import validations from "../utils/validation-utils";
|
|
3
|
+
import {
|
|
4
|
+
testFunctionArray,
|
|
5
|
+
validationInput,
|
|
6
|
+
validationOutput,
|
|
7
|
+
} from "../types/test-config";
|
|
8
|
+
|
|
9
|
+
export default function on_search(input: validationInput): validationOutput {
|
|
10
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
11
|
+
let subResults: validationOutput = [];
|
|
12
|
+
let valid = true;
|
|
13
|
+
for (const testObj of scope) {
|
|
14
|
+
testObj._EXTERNAL = input.externalData;
|
|
15
|
+
|
|
16
|
+
function Attri_Required_1_CONTEXT_TIMESTAMP(
|
|
17
|
+
input: validationInput,
|
|
18
|
+
): validationOutput {
|
|
19
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
20
|
+
let subResults: validationOutput = [];
|
|
21
|
+
let valid = true;
|
|
22
|
+
for (const testObj of scope) {
|
|
23
|
+
testObj._EXTERNAL = input.externalData;
|
|
24
|
+
const attr = payloadUtils.getJsonPath(
|
|
25
|
+
testObj,
|
|
26
|
+
"$.context.timestamp",
|
|
27
|
+
);
|
|
28
|
+
|
|
29
|
+
const validate = validations.arePresent(attr);
|
|
30
|
+
|
|
31
|
+
if (!validate) {
|
|
32
|
+
return [
|
|
33
|
+
{
|
|
34
|
+
valid: false,
|
|
35
|
+
code: 30000,
|
|
36
|
+
description: `- **condition Attri_Required_1_CONTEXT_TIMESTAMP**: $.context.timestamp must be present in the payload`,
|
|
37
|
+
},
|
|
38
|
+
];
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
delete testObj._EXTERNAL;
|
|
42
|
+
}
|
|
43
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
44
|
+
}
|
|
45
|
+
function Attri_Required_2_CONTEXT_BAP_ID(
|
|
46
|
+
input: validationInput,
|
|
47
|
+
): validationOutput {
|
|
48
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
49
|
+
let subResults: validationOutput = [];
|
|
50
|
+
let valid = true;
|
|
51
|
+
for (const testObj of scope) {
|
|
52
|
+
testObj._EXTERNAL = input.externalData;
|
|
53
|
+
const attr = payloadUtils.getJsonPath(
|
|
54
|
+
testObj,
|
|
55
|
+
"$.context.bap_id",
|
|
56
|
+
);
|
|
57
|
+
|
|
58
|
+
const validate = validations.arePresent(attr);
|
|
59
|
+
|
|
60
|
+
if (!validate) {
|
|
61
|
+
return [
|
|
62
|
+
{
|
|
63
|
+
valid: false,
|
|
64
|
+
code: 30000,
|
|
65
|
+
description: `- **condition Attri_Required_2_CONTEXT_BAP_ID**: $.context.bap_id must be present in the payload`,
|
|
66
|
+
},
|
|
67
|
+
];
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
delete testObj._EXTERNAL;
|
|
71
|
+
}
|
|
72
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
73
|
+
}
|
|
74
|
+
function Attri_Required_3_CONTEXT_TRANSACTION_ID(
|
|
75
|
+
input: validationInput,
|
|
76
|
+
): validationOutput {
|
|
77
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
78
|
+
let subResults: validationOutput = [];
|
|
79
|
+
let valid = true;
|
|
80
|
+
for (const testObj of scope) {
|
|
81
|
+
testObj._EXTERNAL = input.externalData;
|
|
82
|
+
const attr = payloadUtils.getJsonPath(
|
|
83
|
+
testObj,
|
|
84
|
+
"$.context.transaction_id",
|
|
85
|
+
);
|
|
86
|
+
|
|
87
|
+
const validate = validations.arePresent(attr);
|
|
88
|
+
|
|
89
|
+
if (!validate) {
|
|
90
|
+
return [
|
|
91
|
+
{
|
|
92
|
+
valid: false,
|
|
93
|
+
code: 30000,
|
|
94
|
+
description: `- **condition Attri_Required_3_CONTEXT_TRANSACTION_ID**: $.context.transaction_id must be present in the payload`,
|
|
95
|
+
},
|
|
96
|
+
];
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
delete testObj._EXTERNAL;
|
|
100
|
+
}
|
|
101
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
102
|
+
}
|
|
103
|
+
function Attri_Required_4_CONTEXT_MESSAGE_ID(
|
|
104
|
+
input: validationInput,
|
|
105
|
+
): validationOutput {
|
|
106
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
107
|
+
let subResults: validationOutput = [];
|
|
108
|
+
let valid = true;
|
|
109
|
+
for (const testObj of scope) {
|
|
110
|
+
testObj._EXTERNAL = input.externalData;
|
|
111
|
+
const attr = payloadUtils.getJsonPath(
|
|
112
|
+
testObj,
|
|
113
|
+
"$.context.message_id",
|
|
114
|
+
);
|
|
115
|
+
|
|
116
|
+
const validate = validations.arePresent(attr);
|
|
117
|
+
|
|
118
|
+
if (!validate) {
|
|
119
|
+
return [
|
|
120
|
+
{
|
|
121
|
+
valid: false,
|
|
122
|
+
code: 30000,
|
|
123
|
+
description: `- **condition Attri_Required_4_CONTEXT_MESSAGE_ID**: $.context.message_id must be present in the payload`,
|
|
124
|
+
},
|
|
125
|
+
];
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
delete testObj._EXTERNAL;
|
|
129
|
+
}
|
|
130
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
131
|
+
}
|
|
132
|
+
function Attri_Required_5_CONTEXT_VERSION(
|
|
133
|
+
input: validationInput,
|
|
134
|
+
): validationOutput {
|
|
135
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
136
|
+
let subResults: validationOutput = [];
|
|
137
|
+
let valid = true;
|
|
138
|
+
for (const testObj of scope) {
|
|
139
|
+
testObj._EXTERNAL = input.externalData;
|
|
140
|
+
const attr = payloadUtils.getJsonPath(
|
|
141
|
+
testObj,
|
|
142
|
+
"$.context.version",
|
|
143
|
+
);
|
|
144
|
+
|
|
145
|
+
const validate = validations.arePresent(attr);
|
|
146
|
+
|
|
147
|
+
if (!validate) {
|
|
148
|
+
return [
|
|
149
|
+
{
|
|
150
|
+
valid: false,
|
|
151
|
+
code: 30000,
|
|
152
|
+
description: `- **condition Attri_Required_5_CONTEXT_VERSION**: $.context.version must be present in the payload`,
|
|
153
|
+
},
|
|
154
|
+
];
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
delete testObj._EXTERNAL;
|
|
158
|
+
}
|
|
159
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
160
|
+
}
|
|
161
|
+
function Attri_Required_6_CONTEXT_BAP_URI(
|
|
162
|
+
input: validationInput,
|
|
163
|
+
): validationOutput {
|
|
164
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
165
|
+
let subResults: validationOutput = [];
|
|
166
|
+
let valid = true;
|
|
167
|
+
for (const testObj of scope) {
|
|
168
|
+
testObj._EXTERNAL = input.externalData;
|
|
169
|
+
const attr = payloadUtils.getJsonPath(
|
|
170
|
+
testObj,
|
|
171
|
+
"$.context.bap_uri",
|
|
172
|
+
);
|
|
173
|
+
|
|
174
|
+
const validate = validations.arePresent(attr);
|
|
175
|
+
|
|
176
|
+
if (!validate) {
|
|
177
|
+
return [
|
|
178
|
+
{
|
|
179
|
+
valid: false,
|
|
180
|
+
code: 30000,
|
|
181
|
+
description: `- **condition Attri_Required_6_CONTEXT_BAP_URI**: $.context.bap_uri must be present in the payload`,
|
|
182
|
+
},
|
|
183
|
+
];
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
delete testObj._EXTERNAL;
|
|
187
|
+
}
|
|
188
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
189
|
+
}
|
|
190
|
+
function Attri_Required_7_CONTEXT_TTL(
|
|
191
|
+
input: validationInput,
|
|
192
|
+
): validationOutput {
|
|
193
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
194
|
+
let subResults: validationOutput = [];
|
|
195
|
+
let valid = true;
|
|
196
|
+
for (const testObj of scope) {
|
|
197
|
+
testObj._EXTERNAL = input.externalData;
|
|
198
|
+
const attr = payloadUtils.getJsonPath(testObj, "$.context.ttl");
|
|
199
|
+
|
|
200
|
+
const validate = validations.arePresent(attr);
|
|
201
|
+
|
|
202
|
+
if (!validate) {
|
|
203
|
+
return [
|
|
204
|
+
{
|
|
205
|
+
valid: false,
|
|
206
|
+
code: 30000,
|
|
207
|
+
description: `- **condition Attri_Required_7_CONTEXT_TTL**: $.context.ttl must be present in the payload`,
|
|
208
|
+
},
|
|
209
|
+
];
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
delete testObj._EXTERNAL;
|
|
213
|
+
}
|
|
214
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
215
|
+
}
|
|
216
|
+
function Attri_Required_8_CONTEXT_BPP_ID(
|
|
217
|
+
input: validationInput,
|
|
218
|
+
): validationOutput {
|
|
219
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
220
|
+
let subResults: validationOutput = [];
|
|
221
|
+
let valid = true;
|
|
222
|
+
for (const testObj of scope) {
|
|
223
|
+
testObj._EXTERNAL = input.externalData;
|
|
224
|
+
const attr = payloadUtils.getJsonPath(
|
|
225
|
+
testObj,
|
|
226
|
+
"$.context.bpp_id",
|
|
227
|
+
);
|
|
228
|
+
|
|
229
|
+
const validate = validations.arePresent(attr);
|
|
230
|
+
|
|
231
|
+
if (!validate) {
|
|
232
|
+
return [
|
|
233
|
+
{
|
|
234
|
+
valid: false,
|
|
235
|
+
code: 30000,
|
|
236
|
+
description: `- **condition Attri_Required_8_CONTEXT_BPP_ID**: $.context.bpp_id must be present in the payload`,
|
|
237
|
+
},
|
|
238
|
+
];
|
|
239
|
+
}
|
|
240
|
+
|
|
241
|
+
delete testObj._EXTERNAL;
|
|
242
|
+
}
|
|
243
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
244
|
+
}
|
|
245
|
+
function Attri_Required_9_CONTEXT_BPP_URI(
|
|
246
|
+
input: validationInput,
|
|
247
|
+
): validationOutput {
|
|
248
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
249
|
+
let subResults: validationOutput = [];
|
|
250
|
+
let valid = true;
|
|
251
|
+
for (const testObj of scope) {
|
|
252
|
+
testObj._EXTERNAL = input.externalData;
|
|
253
|
+
const attr = payloadUtils.getJsonPath(
|
|
254
|
+
testObj,
|
|
255
|
+
"$.context.bpp_uri",
|
|
256
|
+
);
|
|
257
|
+
|
|
258
|
+
const validate = validations.arePresent(attr);
|
|
259
|
+
|
|
260
|
+
if (!validate) {
|
|
261
|
+
return [
|
|
262
|
+
{
|
|
263
|
+
valid: false,
|
|
264
|
+
code: 30000,
|
|
265
|
+
description: `- **condition Attri_Required_9_CONTEXT_BPP_URI**: $.context.bpp_uri must be present in the payload`,
|
|
266
|
+
},
|
|
267
|
+
];
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
delete testObj._EXTERNAL;
|
|
271
|
+
}
|
|
272
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
273
|
+
}
|
|
274
|
+
function Enum_Required_19_CONTEXT_ACTION(
|
|
275
|
+
input: validationInput,
|
|
276
|
+
): validationOutput {
|
|
277
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
278
|
+
let subResults: validationOutput = [];
|
|
279
|
+
let valid = true;
|
|
280
|
+
for (const testObj of scope) {
|
|
281
|
+
testObj._EXTERNAL = input.externalData;
|
|
282
|
+
const enumList = ["on_search"];
|
|
283
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
284
|
+
testObj,
|
|
285
|
+
"$.context.action",
|
|
286
|
+
);
|
|
287
|
+
|
|
288
|
+
const validate =
|
|
289
|
+
validations.allIn(enumPath, enumList) &&
|
|
290
|
+
validations.arePresent(enumPath);
|
|
291
|
+
|
|
292
|
+
if (!validate) {
|
|
293
|
+
return [
|
|
294
|
+
{
|
|
295
|
+
valid: false,
|
|
296
|
+
code: 30000,
|
|
297
|
+
description: `- **condition Enum_Required_19_CONTEXT_ACTION**: all of the following sub conditions must be met:
|
|
298
|
+
|
|
299
|
+
- **condition Enum_Required_19_CONTEXT_ACTION.1**: every element of $.context.action must be in ["on_search"]
|
|
300
|
+
- **condition Enum_Required_19_CONTEXT_ACTION.2**: $.context.action must be present in the payload`,
|
|
301
|
+
},
|
|
302
|
+
];
|
|
303
|
+
}
|
|
304
|
+
|
|
305
|
+
delete testObj._EXTERNAL;
|
|
306
|
+
}
|
|
307
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
308
|
+
}
|
|
309
|
+
function Enum_Required_20_COUNTRY_CODE(
|
|
310
|
+
input: validationInput,
|
|
311
|
+
): validationOutput {
|
|
312
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
313
|
+
let subResults: validationOutput = [];
|
|
314
|
+
let valid = true;
|
|
315
|
+
for (const testObj of scope) {
|
|
316
|
+
testObj._EXTERNAL = input.externalData;
|
|
317
|
+
const enumList = ["IND"];
|
|
318
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
319
|
+
testObj,
|
|
320
|
+
"$.context.location.country.code",
|
|
321
|
+
);
|
|
322
|
+
|
|
323
|
+
const validate =
|
|
324
|
+
validations.allIn(enumPath, enumList) &&
|
|
325
|
+
validations.arePresent(enumPath);
|
|
326
|
+
|
|
327
|
+
if (!validate) {
|
|
328
|
+
return [
|
|
329
|
+
{
|
|
330
|
+
valid: false,
|
|
331
|
+
code: 30000,
|
|
332
|
+
description: `- **condition Enum_Required_20_COUNTRY_CODE**: all of the following sub conditions must be met:
|
|
333
|
+
|
|
334
|
+
- **condition Enum_Required_20_COUNTRY_CODE.1**: every element of $.context.location.country.code must be in ["IND"]
|
|
335
|
+
- **condition Enum_Required_20_COUNTRY_CODE.2**: $.context.location.country.code must be present in the payload`,
|
|
336
|
+
},
|
|
337
|
+
];
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
delete testObj._EXTERNAL;
|
|
341
|
+
}
|
|
342
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
343
|
+
}
|
|
344
|
+
function Enum_Required_21_CITY_CODE(
|
|
345
|
+
input: validationInput,
|
|
346
|
+
): validationOutput {
|
|
347
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
348
|
+
let subResults: validationOutput = [];
|
|
349
|
+
let valid = true;
|
|
350
|
+
for (const testObj of scope) {
|
|
351
|
+
testObj._EXTERNAL = input.externalData;
|
|
352
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
353
|
+
testObj,
|
|
354
|
+
"$.context.location.city.code",
|
|
355
|
+
);
|
|
356
|
+
|
|
357
|
+
const validate = validations.arePresent(enumPath);
|
|
358
|
+
|
|
359
|
+
if (!validate) {
|
|
360
|
+
return [
|
|
361
|
+
{
|
|
362
|
+
valid: false,
|
|
363
|
+
code: 30000,
|
|
364
|
+
description: `- **condition Enum_Required_21_CITY_CODE**: $.context.location.city.code must be present in the payload`,
|
|
365
|
+
},
|
|
366
|
+
];
|
|
367
|
+
}
|
|
368
|
+
|
|
369
|
+
delete testObj._EXTERNAL;
|
|
370
|
+
}
|
|
371
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
372
|
+
}
|
|
373
|
+
function Enum_Required_22_CONTEXT_DOMAIN(
|
|
374
|
+
input: validationInput,
|
|
375
|
+
): validationOutput {
|
|
376
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
377
|
+
let subResults: validationOutput = [];
|
|
378
|
+
let valid = true;
|
|
379
|
+
for (const testObj of scope) {
|
|
380
|
+
testObj._EXTERNAL = input.externalData;
|
|
381
|
+
const enumList = ["ONDC:TRV11"];
|
|
382
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
383
|
+
testObj,
|
|
384
|
+
"$.context.domain",
|
|
385
|
+
);
|
|
386
|
+
|
|
387
|
+
const validate =
|
|
388
|
+
validations.allIn(enumPath, enumList) &&
|
|
389
|
+
validations.arePresent(enumPath);
|
|
390
|
+
|
|
391
|
+
if (!validate) {
|
|
392
|
+
return [
|
|
393
|
+
{
|
|
394
|
+
valid: false,
|
|
395
|
+
code: 30000,
|
|
396
|
+
description: `- **condition Enum_Required_22_CONTEXT_DOMAIN**: all of the following sub conditions must be met:
|
|
397
|
+
|
|
398
|
+
- **condition Enum_Required_22_CONTEXT_DOMAIN.1**: every element of $.context.domain must be in ["ONDC:TRV11"]
|
|
399
|
+
- **condition Enum_Required_22_CONTEXT_DOMAIN.2**: $.context.domain must be present in the payload`,
|
|
400
|
+
},
|
|
401
|
+
];
|
|
402
|
+
}
|
|
403
|
+
|
|
404
|
+
delete testObj._EXTERNAL;
|
|
405
|
+
}
|
|
406
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
407
|
+
}
|
|
408
|
+
function on_search_Message_TESTS(
|
|
409
|
+
input: validationInput,
|
|
410
|
+
): validationOutput {
|
|
411
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
412
|
+
let subResults: validationOutput = [];
|
|
413
|
+
let valid = true;
|
|
414
|
+
for (const testObj of scope) {
|
|
415
|
+
testObj._EXTERNAL = input.externalData;
|
|
416
|
+
const errorBlock = payloadUtils.getJsonPath(
|
|
417
|
+
testObj,
|
|
418
|
+
"$.error.code",
|
|
419
|
+
);
|
|
420
|
+
|
|
421
|
+
const skipCheck = validations.arePresent(errorBlock);
|
|
422
|
+
if (skipCheck) continue;
|
|
423
|
+
|
|
424
|
+
function Attri_Required_10_DESCRIPTOR_NAME(
|
|
425
|
+
input: validationInput,
|
|
426
|
+
): validationOutput {
|
|
427
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
428
|
+
let subResults: validationOutput = [];
|
|
429
|
+
let valid = true;
|
|
430
|
+
for (const testObj of scope) {
|
|
431
|
+
testObj._EXTERNAL = input.externalData;
|
|
432
|
+
const attr = payloadUtils.getJsonPath(
|
|
433
|
+
testObj,
|
|
434
|
+
"$.message.catalog.descriptor.name",
|
|
435
|
+
);
|
|
436
|
+
|
|
437
|
+
const validate = validations.arePresent(attr);
|
|
438
|
+
|
|
439
|
+
if (!validate) {
|
|
440
|
+
return [
|
|
441
|
+
{
|
|
442
|
+
valid: false,
|
|
443
|
+
code: 30000,
|
|
444
|
+
description: `- **condition Attri_Required_10_DESCRIPTOR_NAME**: $.message.catalog.descriptor.name must be present in the payload`,
|
|
445
|
+
},
|
|
446
|
+
];
|
|
447
|
+
}
|
|
448
|
+
|
|
449
|
+
delete testObj._EXTERNAL;
|
|
450
|
+
}
|
|
451
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
452
|
+
}
|
|
453
|
+
function Attri_Required_11_PROVIDERS_ID(
|
|
454
|
+
input: validationInput,
|
|
455
|
+
): validationOutput {
|
|
456
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
457
|
+
let subResults: validationOutput = [];
|
|
458
|
+
let valid = true;
|
|
459
|
+
for (const testObj of scope) {
|
|
460
|
+
testObj._EXTERNAL = input.externalData;
|
|
461
|
+
const attr = payloadUtils.getJsonPath(
|
|
462
|
+
testObj,
|
|
463
|
+
"$.message.catalog.providers[*].id",
|
|
464
|
+
);
|
|
465
|
+
|
|
466
|
+
const validate = validations.arePresent(attr);
|
|
467
|
+
|
|
468
|
+
if (!validate) {
|
|
469
|
+
return [
|
|
470
|
+
{
|
|
471
|
+
valid: false,
|
|
472
|
+
code: 30000,
|
|
473
|
+
description: `- **condition Attri_Required_11_PROVIDERS_ID**: $.message.catalog.providers[*].id must be present in the payload`,
|
|
474
|
+
},
|
|
475
|
+
];
|
|
476
|
+
}
|
|
477
|
+
|
|
478
|
+
delete testObj._EXTERNAL;
|
|
479
|
+
}
|
|
480
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
481
|
+
}
|
|
482
|
+
function Attri_Required_12_DESCRIPTOR_NAME(
|
|
483
|
+
input: validationInput,
|
|
484
|
+
): validationOutput {
|
|
485
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
486
|
+
let subResults: validationOutput = [];
|
|
487
|
+
let valid = true;
|
|
488
|
+
for (const testObj of scope) {
|
|
489
|
+
testObj._EXTERNAL = input.externalData;
|
|
490
|
+
const attr = payloadUtils.getJsonPath(
|
|
491
|
+
testObj,
|
|
492
|
+
"$.message.catalog.providers[*].descriptor.name",
|
|
493
|
+
);
|
|
494
|
+
|
|
495
|
+
const validate = validations.arePresent(attr);
|
|
496
|
+
|
|
497
|
+
if (!validate) {
|
|
498
|
+
return [
|
|
499
|
+
{
|
|
500
|
+
valid: false,
|
|
501
|
+
code: 30000,
|
|
502
|
+
description: `- **condition Attri_Required_12_DESCRIPTOR_NAME**: $.message.catalog.providers[*].descriptor.name must be present in the payload`,
|
|
503
|
+
},
|
|
504
|
+
];
|
|
505
|
+
}
|
|
506
|
+
|
|
507
|
+
delete testObj._EXTERNAL;
|
|
508
|
+
}
|
|
509
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
510
|
+
}
|
|
511
|
+
function Attri_Required_13_FULFILLMENTS_ID(
|
|
512
|
+
input: validationInput,
|
|
513
|
+
): validationOutput {
|
|
514
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
515
|
+
let subResults: validationOutput = [];
|
|
516
|
+
let valid = true;
|
|
517
|
+
for (const testObj of scope) {
|
|
518
|
+
testObj._EXTERNAL = input.externalData;
|
|
519
|
+
const attr = payloadUtils.getJsonPath(
|
|
520
|
+
testObj,
|
|
521
|
+
"$.message.catalog.providers[*].fulfillments[*].id",
|
|
522
|
+
);
|
|
523
|
+
|
|
524
|
+
const validate = validations.arePresent(attr);
|
|
525
|
+
|
|
526
|
+
if (!validate) {
|
|
527
|
+
return [
|
|
528
|
+
{
|
|
529
|
+
valid: false,
|
|
530
|
+
code: 30000,
|
|
531
|
+
description: `- **condition Attri_Required_13_FULFILLMENTS_ID**: $.message.catalog.providers[*].fulfillments[*].id must be present in the payload`,
|
|
532
|
+
},
|
|
533
|
+
];
|
|
534
|
+
}
|
|
535
|
+
|
|
536
|
+
delete testObj._EXTERNAL;
|
|
537
|
+
}
|
|
538
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
539
|
+
}
|
|
540
|
+
function Attri_Required_14_LOCATION_GPS(
|
|
541
|
+
input: validationInput,
|
|
542
|
+
): validationOutput {
|
|
543
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
544
|
+
let subResults: validationOutput = [];
|
|
545
|
+
let valid = true;
|
|
546
|
+
for (const testObj of scope) {
|
|
547
|
+
testObj._EXTERNAL = input.externalData;
|
|
548
|
+
const attr = payloadUtils.getJsonPath(
|
|
549
|
+
testObj,
|
|
550
|
+
"$.message.catalog.providers[*].fulfillments[*].stops[*].location.gps",
|
|
551
|
+
);
|
|
552
|
+
|
|
553
|
+
const validate = validations.arePresent(attr);
|
|
554
|
+
|
|
555
|
+
if (!validate) {
|
|
556
|
+
return [
|
|
557
|
+
{
|
|
558
|
+
valid: false,
|
|
559
|
+
code: 30000,
|
|
560
|
+
description: `- **condition Attri_Required_14_LOCATION_GPS**: $.message.catalog.providers[*].fulfillments[*].stops[*].location.gps must be present in the payload`,
|
|
561
|
+
},
|
|
562
|
+
];
|
|
563
|
+
}
|
|
564
|
+
|
|
565
|
+
delete testObj._EXTERNAL;
|
|
566
|
+
}
|
|
567
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
568
|
+
}
|
|
569
|
+
function Attri_Required_15_FULFILLMENTS_ID(
|
|
570
|
+
input: validationInput,
|
|
571
|
+
): validationOutput {
|
|
572
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
573
|
+
let subResults: validationOutput = [];
|
|
574
|
+
let valid = true;
|
|
575
|
+
for (const testObj of scope) {
|
|
576
|
+
testObj._EXTERNAL = input.externalData;
|
|
577
|
+
const attr = payloadUtils.getJsonPath(
|
|
578
|
+
testObj,
|
|
579
|
+
"$.message.catalog.providers[*].fulfillments[*].id",
|
|
580
|
+
);
|
|
581
|
+
|
|
582
|
+
const validate = validations.arePresent(attr);
|
|
583
|
+
|
|
584
|
+
if (!validate) {
|
|
585
|
+
return [
|
|
586
|
+
{
|
|
587
|
+
valid: false,
|
|
588
|
+
code: 30000,
|
|
589
|
+
description: `- **condition Attri_Required_15_FULFILLMENTS_ID**: $.message.catalog.providers[*].fulfillments[*].id must be present in the payload`,
|
|
590
|
+
},
|
|
591
|
+
];
|
|
592
|
+
}
|
|
593
|
+
|
|
594
|
+
delete testObj._EXTERNAL;
|
|
595
|
+
}
|
|
596
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
597
|
+
}
|
|
598
|
+
function Attri_Required_16_CATEGORIES_ID(
|
|
599
|
+
input: validationInput,
|
|
600
|
+
): validationOutput {
|
|
601
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
602
|
+
let subResults: validationOutput = [];
|
|
603
|
+
let valid = true;
|
|
604
|
+
for (const testObj of scope) {
|
|
605
|
+
testObj._EXTERNAL = input.externalData;
|
|
606
|
+
const attr = payloadUtils.getJsonPath(
|
|
607
|
+
testObj,
|
|
608
|
+
"$.message.catalog.providers[*].categories[*].id",
|
|
609
|
+
);
|
|
610
|
+
|
|
611
|
+
const validate = validations.arePresent(attr);
|
|
612
|
+
|
|
613
|
+
if (!validate) {
|
|
614
|
+
return [
|
|
615
|
+
{
|
|
616
|
+
valid: false,
|
|
617
|
+
code: 30000,
|
|
618
|
+
description: `- **condition Attri_Required_16_CATEGORIES_ID**: $.message.catalog.providers[*].categories[*].id must be present in the payload`,
|
|
619
|
+
},
|
|
620
|
+
];
|
|
621
|
+
}
|
|
622
|
+
|
|
623
|
+
delete testObj._EXTERNAL;
|
|
624
|
+
}
|
|
625
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
626
|
+
}
|
|
627
|
+
function Attri_Required_17_RANGE_START(
|
|
628
|
+
input: validationInput,
|
|
629
|
+
): validationOutput {
|
|
630
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
631
|
+
let subResults: validationOutput = [];
|
|
632
|
+
let valid = true;
|
|
633
|
+
for (const testObj of scope) {
|
|
634
|
+
testObj._EXTERNAL = input.externalData;
|
|
635
|
+
const attr = payloadUtils.getJsonPath(
|
|
636
|
+
testObj,
|
|
637
|
+
"$.message.catalog.providers[*].time.range.start",
|
|
638
|
+
);
|
|
639
|
+
|
|
640
|
+
const validate = validations.arePresent(attr);
|
|
641
|
+
|
|
642
|
+
if (!validate) {
|
|
643
|
+
return [
|
|
644
|
+
{
|
|
645
|
+
valid: false,
|
|
646
|
+
code: 30000,
|
|
647
|
+
description: `- **condition Attri_Required_17_RANGE_START**: $.message.catalog.providers[*].time.range.start must be present in the payload`,
|
|
648
|
+
},
|
|
649
|
+
];
|
|
650
|
+
}
|
|
651
|
+
|
|
652
|
+
delete testObj._EXTERNAL;
|
|
653
|
+
}
|
|
654
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
655
|
+
}
|
|
656
|
+
function Attri_Required_18_RANGE_END(
|
|
657
|
+
input: validationInput,
|
|
658
|
+
): validationOutput {
|
|
659
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
660
|
+
let subResults: validationOutput = [];
|
|
661
|
+
let valid = true;
|
|
662
|
+
for (const testObj of scope) {
|
|
663
|
+
testObj._EXTERNAL = input.externalData;
|
|
664
|
+
const attr = payloadUtils.getJsonPath(
|
|
665
|
+
testObj,
|
|
666
|
+
"$.message.catalog.providers[*].time.range.end",
|
|
667
|
+
);
|
|
668
|
+
|
|
669
|
+
const validate = validations.arePresent(attr);
|
|
670
|
+
|
|
671
|
+
if (!validate) {
|
|
672
|
+
return [
|
|
673
|
+
{
|
|
674
|
+
valid: false,
|
|
675
|
+
code: 30000,
|
|
676
|
+
description: `- **condition Attri_Required_18_RANGE_END**: $.message.catalog.providers[*].time.range.end must be present in the payload`,
|
|
677
|
+
},
|
|
678
|
+
];
|
|
679
|
+
}
|
|
680
|
+
|
|
681
|
+
delete testObj._EXTERNAL;
|
|
682
|
+
}
|
|
683
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
684
|
+
}
|
|
685
|
+
function Enum_Required_23_DESCRIPTOR_CODE(
|
|
686
|
+
input: validationInput,
|
|
687
|
+
): validationOutput {
|
|
688
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
689
|
+
let subResults: validationOutput = [];
|
|
690
|
+
let valid = true;
|
|
691
|
+
for (const testObj of scope) {
|
|
692
|
+
testObj._EXTERNAL = input.externalData;
|
|
693
|
+
const enumList = ["TICKET", "PASS"];
|
|
694
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
695
|
+
testObj,
|
|
696
|
+
"$.message.catalog.providers[*].categories[*].descriptor.code",
|
|
697
|
+
);
|
|
698
|
+
|
|
699
|
+
const validate =
|
|
700
|
+
validations.allIn(enumPath, enumList) &&
|
|
701
|
+
validations.arePresent(enumPath);
|
|
702
|
+
|
|
703
|
+
if (!validate) {
|
|
704
|
+
return [
|
|
705
|
+
{
|
|
706
|
+
valid: false,
|
|
707
|
+
code: 30000,
|
|
708
|
+
description: `- **condition Enum_Required_23_DESCRIPTOR_CODE**: all of the following sub conditions must be met:
|
|
709
|
+
|
|
710
|
+
- **condition Enum_Required_23_DESCRIPTOR_CODE.1**: every element of $.message.catalog.providers[*].categories[*].descriptor.code must be in ["TICKET", "PASS"]
|
|
711
|
+
- **condition Enum_Required_23_DESCRIPTOR_CODE.2**: $.message.catalog.providers[*].categories[*].descriptor.code must be present in the payload`,
|
|
712
|
+
},
|
|
713
|
+
];
|
|
714
|
+
}
|
|
715
|
+
|
|
716
|
+
delete testObj._EXTERNAL;
|
|
717
|
+
}
|
|
718
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
719
|
+
}
|
|
720
|
+
function Enum_Required_24_DESCRIPTOR_CODE(
|
|
721
|
+
input: validationInput,
|
|
722
|
+
): validationOutput {
|
|
723
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
724
|
+
let subResults: validationOutput = [];
|
|
725
|
+
let valid = true;
|
|
726
|
+
for (const testObj of scope) {
|
|
727
|
+
testObj._EXTERNAL = input.externalData;
|
|
728
|
+
const enumList = ["SJT", "SFSJT", "RJT", "PASS"];
|
|
729
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
730
|
+
testObj,
|
|
731
|
+
"$.message.catalog.providers[*].descriptor.code",
|
|
732
|
+
);
|
|
733
|
+
|
|
734
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
735
|
+
if (skipCheck) continue;
|
|
736
|
+
|
|
737
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
738
|
+
|
|
739
|
+
if (!validate) {
|
|
740
|
+
return [
|
|
741
|
+
{
|
|
742
|
+
valid: false,
|
|
743
|
+
code: 30000,
|
|
744
|
+
description: `- **condition Enum_Required_24_DESCRIPTOR_CODE**: every element of $.message.catalog.providers[*].descriptor.code must be in ["SJT", "SFSJT", "RJT", "PASS"]
|
|
745
|
+
|
|
746
|
+
> Note: **Condition Enum_Required_24_DESCRIPTOR_CODE** can be skipped if the following conditions are met:
|
|
747
|
+
>
|
|
748
|
+
> - **condition B**: $.message.catalog.providers[*].descriptor.code must **not** be present in the payload`,
|
|
749
|
+
},
|
|
750
|
+
];
|
|
751
|
+
}
|
|
752
|
+
|
|
753
|
+
delete testObj._EXTERNAL;
|
|
754
|
+
}
|
|
755
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
756
|
+
}
|
|
757
|
+
function Enum_Required_25_VEHICLE_CATEGORY(
|
|
758
|
+
input: validationInput,
|
|
759
|
+
): validationOutput {
|
|
760
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
761
|
+
let subResults: validationOutput = [];
|
|
762
|
+
let valid = true;
|
|
763
|
+
for (const testObj of scope) {
|
|
764
|
+
testObj._EXTERNAL = input.externalData;
|
|
765
|
+
const enumList = ["BUS", "METRO"];
|
|
766
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
767
|
+
testObj,
|
|
768
|
+
"$.message.catalog.providers[*].fulfillments[*].vehicle.category",
|
|
769
|
+
);
|
|
770
|
+
|
|
771
|
+
const validate =
|
|
772
|
+
validations.allIn(enumPath, enumList) &&
|
|
773
|
+
validations.arePresent(enumPath);
|
|
774
|
+
|
|
775
|
+
if (!validate) {
|
|
776
|
+
return [
|
|
777
|
+
{
|
|
778
|
+
valid: false,
|
|
779
|
+
code: 30000,
|
|
780
|
+
description: `- **condition Enum_Required_25_VEHICLE_CATEGORY**: all of the following sub conditions must be met:
|
|
781
|
+
|
|
782
|
+
- **condition Enum_Required_25_VEHICLE_CATEGORY.1**: every element of $.message.catalog.providers[*].fulfillments[*].vehicle.category must be in ["BUS", "METRO"]
|
|
783
|
+
- **condition Enum_Required_25_VEHICLE_CATEGORY.2**: $.message.catalog.providers[*].fulfillments[*].vehicle.category must be present in the payload`,
|
|
784
|
+
},
|
|
785
|
+
];
|
|
786
|
+
}
|
|
787
|
+
|
|
788
|
+
delete testObj._EXTERNAL;
|
|
789
|
+
}
|
|
790
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
791
|
+
}
|
|
792
|
+
function Enum_Required_26_FULFILLMENTS_TYPE(
|
|
793
|
+
input: validationInput,
|
|
794
|
+
): validationOutput {
|
|
795
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
796
|
+
let subResults: validationOutput = [];
|
|
797
|
+
let valid = true;
|
|
798
|
+
for (const testObj of scope) {
|
|
799
|
+
testObj._EXTERNAL = input.externalData;
|
|
800
|
+
const enumList = ["ROUTE", "TRIP"];
|
|
801
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
802
|
+
testObj,
|
|
803
|
+
"$.message.catalog.providers[*].fulfillments[*].type",
|
|
804
|
+
);
|
|
805
|
+
|
|
806
|
+
const validate =
|
|
807
|
+
validations.allIn(enumPath, enumList) &&
|
|
808
|
+
validations.arePresent(enumPath);
|
|
809
|
+
|
|
810
|
+
if (!validate) {
|
|
811
|
+
return [
|
|
812
|
+
{
|
|
813
|
+
valid: false,
|
|
814
|
+
code: 30000,
|
|
815
|
+
description: `- **condition Enum_Required_26_FULFILLMENTS_TYPE**: all of the following sub conditions must be met:
|
|
816
|
+
|
|
817
|
+
- **condition Enum_Required_26_FULFILLMENTS_TYPE.1**: every element of $.message.catalog.providers[*].fulfillments[*].type must be in ["ROUTE", "TRIP"]
|
|
818
|
+
- **condition Enum_Required_26_FULFILLMENTS_TYPE.2**: $.message.catalog.providers[*].fulfillments[*].type must be present in the payload`,
|
|
819
|
+
},
|
|
820
|
+
];
|
|
821
|
+
}
|
|
822
|
+
|
|
823
|
+
delete testObj._EXTERNAL;
|
|
824
|
+
}
|
|
825
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
826
|
+
}
|
|
827
|
+
function Enum_Required_27_FULFILLMENTS_TYPE(
|
|
828
|
+
input: validationInput,
|
|
829
|
+
): validationOutput {
|
|
830
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
831
|
+
let subResults: validationOutput = [];
|
|
832
|
+
let valid = true;
|
|
833
|
+
for (const testObj of scope) {
|
|
834
|
+
testObj._EXTERNAL = input.externalData;
|
|
835
|
+
const enumList = [
|
|
836
|
+
"START",
|
|
837
|
+
"END",
|
|
838
|
+
"INTERMEDIATE_STOP",
|
|
839
|
+
"TRANSIT_STOP",
|
|
840
|
+
];
|
|
841
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
842
|
+
testObj,
|
|
843
|
+
"$.message.catalog.providers[*].fulfillments[*].type",
|
|
844
|
+
);
|
|
845
|
+
|
|
846
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
847
|
+
if (skipCheck) continue;
|
|
848
|
+
|
|
849
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
850
|
+
|
|
851
|
+
if (!validate) {
|
|
852
|
+
return [
|
|
853
|
+
{
|
|
854
|
+
valid: false,
|
|
855
|
+
code: 30000,
|
|
856
|
+
description: `- **condition Enum_Required_27_FULFILLMENTS_TYPE**: every element of $.message.catalog.providers[*].fulfillments[*].type must be in ["START", "END", "INTERMEDIATE_STOP", "TRANSIT_STOP"]
|
|
857
|
+
|
|
858
|
+
> Note: **Condition Enum_Required_27_FULFILLMENTS_TYPE** can be skipped if the following conditions are met:
|
|
859
|
+
>
|
|
860
|
+
> - **condition B**: $.message.catalog.providers[*].fulfillments[*].type must **not** be present in the payload`,
|
|
861
|
+
},
|
|
862
|
+
];
|
|
863
|
+
}
|
|
864
|
+
|
|
865
|
+
delete testObj._EXTERNAL;
|
|
866
|
+
}
|
|
867
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
868
|
+
}
|
|
869
|
+
function Enum_Required_28_AUTHORIZATION_TYPE(
|
|
870
|
+
input: validationInput,
|
|
871
|
+
): validationOutput {
|
|
872
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
873
|
+
let subResults: validationOutput = [];
|
|
874
|
+
let valid = true;
|
|
875
|
+
for (const testObj of scope) {
|
|
876
|
+
testObj._EXTERNAL = input.externalData;
|
|
877
|
+
const enumList = ["QR"];
|
|
878
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
879
|
+
testObj,
|
|
880
|
+
"$.message.catalog.providers[*].fulfillments[*].stops[*].authorization.type",
|
|
881
|
+
);
|
|
882
|
+
|
|
883
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
884
|
+
if (skipCheck) continue;
|
|
885
|
+
|
|
886
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
887
|
+
|
|
888
|
+
if (!validate) {
|
|
889
|
+
return [
|
|
890
|
+
{
|
|
891
|
+
valid: false,
|
|
892
|
+
code: 30000,
|
|
893
|
+
description: `- **condition Enum_Required_28_AUTHORIZATION_TYPE**: every element of $.message.catalog.providers[*].fulfillments[*].stops[*].authorization.type must be in ["QR"]
|
|
894
|
+
|
|
895
|
+
> Note: **Condition Enum_Required_28_AUTHORIZATION_TYPE** can be skipped if the following conditions are met:
|
|
896
|
+
>
|
|
897
|
+
> - **condition B**: $.message.catalog.providers[*].fulfillments[*].stops[*].authorization.type must **not** be present in the payload`,
|
|
898
|
+
},
|
|
899
|
+
];
|
|
900
|
+
}
|
|
901
|
+
|
|
902
|
+
delete testObj._EXTERNAL;
|
|
903
|
+
}
|
|
904
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
905
|
+
}
|
|
906
|
+
function Enum_Required_29_AUTHORIZATION_STATUS(
|
|
907
|
+
input: validationInput,
|
|
908
|
+
): validationOutput {
|
|
909
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
910
|
+
let subResults: validationOutput = [];
|
|
911
|
+
let valid = true;
|
|
912
|
+
for (const testObj of scope) {
|
|
913
|
+
testObj._EXTERNAL = input.externalData;
|
|
914
|
+
const enumList = ["UNCLAIMED", "CLAIMED"];
|
|
915
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
916
|
+
testObj,
|
|
917
|
+
"$.message.catalog.providers[*].fulfillments[*].stops[*].authorization.status",
|
|
918
|
+
);
|
|
919
|
+
|
|
920
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
921
|
+
if (skipCheck) continue;
|
|
922
|
+
|
|
923
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
924
|
+
|
|
925
|
+
if (!validate) {
|
|
926
|
+
return [
|
|
927
|
+
{
|
|
928
|
+
valid: false,
|
|
929
|
+
code: 30000,
|
|
930
|
+
description: `- **condition Enum_Required_29_AUTHORIZATION_STATUS**: every element of $.message.catalog.providers[*].fulfillments[*].stops[*].authorization.status must be in ["UNCLAIMED", "CLAIMED"]
|
|
931
|
+
|
|
932
|
+
> Note: **Condition Enum_Required_29_AUTHORIZATION_STATUS** can be skipped if the following conditions are met:
|
|
933
|
+
>
|
|
934
|
+
> - **condition B**: $.message.catalog.providers[*].fulfillments[*].stops[*].authorization.status must **not** be present in the payload`,
|
|
935
|
+
},
|
|
936
|
+
];
|
|
937
|
+
}
|
|
938
|
+
|
|
939
|
+
delete testObj._EXTERNAL;
|
|
940
|
+
}
|
|
941
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
942
|
+
}
|
|
943
|
+
function Enum_Required_30_PAYMENTS_STATUS(
|
|
944
|
+
input: validationInput,
|
|
945
|
+
): validationOutput {
|
|
946
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
947
|
+
let subResults: validationOutput = [];
|
|
948
|
+
let valid = true;
|
|
949
|
+
for (const testObj of scope) {
|
|
950
|
+
testObj._EXTERNAL = input.externalData;
|
|
951
|
+
const enumList = ["NOT-PAID", "PAID"];
|
|
952
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
953
|
+
testObj,
|
|
954
|
+
"$.message.catalog.providers[*].payments[*].status",
|
|
955
|
+
);
|
|
956
|
+
|
|
957
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
958
|
+
if (skipCheck) continue;
|
|
959
|
+
|
|
960
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
961
|
+
|
|
962
|
+
if (!validate) {
|
|
963
|
+
return [
|
|
964
|
+
{
|
|
965
|
+
valid: false,
|
|
966
|
+
code: 30000,
|
|
967
|
+
description: `- **condition Enum_Required_30_PAYMENTS_STATUS**: every element of $.message.catalog.providers[*].payments[*].status must be in ["NOT-PAID", "PAID"]
|
|
968
|
+
|
|
969
|
+
> Note: **Condition Enum_Required_30_PAYMENTS_STATUS** can be skipped if the following conditions are met:
|
|
970
|
+
>
|
|
971
|
+
> - **condition B**: $.message.catalog.providers[*].payments[*].status must **not** be present in the payload`,
|
|
972
|
+
},
|
|
973
|
+
];
|
|
974
|
+
}
|
|
975
|
+
|
|
976
|
+
delete testObj._EXTERNAL;
|
|
977
|
+
}
|
|
978
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
979
|
+
}
|
|
980
|
+
function Enum_Required_31_PAYMENTS_COLLECTED_BY(
|
|
981
|
+
input: validationInput,
|
|
982
|
+
): validationOutput {
|
|
983
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
984
|
+
let subResults: validationOutput = [];
|
|
985
|
+
let valid = true;
|
|
986
|
+
for (const testObj of scope) {
|
|
987
|
+
testObj._EXTERNAL = input.externalData;
|
|
988
|
+
const enumList = ["BPP", "BAP"];
|
|
989
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
990
|
+
testObj,
|
|
991
|
+
"$.message.catalog.providers[*].payments[*].collected_by",
|
|
992
|
+
);
|
|
993
|
+
|
|
994
|
+
const validate =
|
|
995
|
+
validations.allIn(enumPath, enumList) &&
|
|
996
|
+
validations.arePresent(enumPath);
|
|
997
|
+
|
|
998
|
+
if (!validate) {
|
|
999
|
+
return [
|
|
1000
|
+
{
|
|
1001
|
+
valid: false,
|
|
1002
|
+
code: 30000,
|
|
1003
|
+
description: `- **condition Enum_Required_31_PAYMENTS_COLLECTED_BY**: all of the following sub conditions must be met:
|
|
1004
|
+
|
|
1005
|
+
- **condition Enum_Required_31_PAYMENTS_COLLECTED_BY.1**: every element of $.message.catalog.providers[*].payments[*].collected_by must be in ["BPP", "BAP"]
|
|
1006
|
+
- **condition Enum_Required_31_PAYMENTS_COLLECTED_BY.2**: $.message.catalog.providers[*].payments[*].collected_by must be present in the payload`,
|
|
1007
|
+
},
|
|
1008
|
+
];
|
|
1009
|
+
}
|
|
1010
|
+
|
|
1011
|
+
delete testObj._EXTERNAL;
|
|
1012
|
+
}
|
|
1013
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1014
|
+
}
|
|
1015
|
+
function Enum_Required_32_PAYMENTS_TYPE(
|
|
1016
|
+
input: validationInput,
|
|
1017
|
+
): validationOutput {
|
|
1018
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
1019
|
+
let subResults: validationOutput = [];
|
|
1020
|
+
let valid = true;
|
|
1021
|
+
for (const testObj of scope) {
|
|
1022
|
+
testObj._EXTERNAL = input.externalData;
|
|
1023
|
+
const enumList = [
|
|
1024
|
+
"PRE-ORDER",
|
|
1025
|
+
"ON-FULFILLMENT",
|
|
1026
|
+
"POST-FULFILLMENT",
|
|
1027
|
+
];
|
|
1028
|
+
const enumPath = payloadUtils.getJsonPath(
|
|
1029
|
+
testObj,
|
|
1030
|
+
"$.message.catalog.providers[*].payments[*].type",
|
|
1031
|
+
);
|
|
1032
|
+
|
|
1033
|
+
const skipCheck = !validations.arePresent(enumPath);
|
|
1034
|
+
if (skipCheck) continue;
|
|
1035
|
+
|
|
1036
|
+
const validate = validations.allIn(enumPath, enumList);
|
|
1037
|
+
|
|
1038
|
+
if (!validate) {
|
|
1039
|
+
return [
|
|
1040
|
+
{
|
|
1041
|
+
valid: false,
|
|
1042
|
+
code: 30000,
|
|
1043
|
+
description: `- **condition Enum_Required_32_PAYMENTS_TYPE**: every element of $.message.catalog.providers[*].payments[*].type must be in ["PRE-ORDER", "ON-FULFILLMENT", "POST-FULFILLMENT"]
|
|
1044
|
+
|
|
1045
|
+
> Note: **Condition Enum_Required_32_PAYMENTS_TYPE** can be skipped if the following conditions are met:
|
|
1046
|
+
>
|
|
1047
|
+
> - **condition B**: $.message.catalog.providers[*].payments[*].type must **not** be present in the payload`,
|
|
1048
|
+
},
|
|
1049
|
+
];
|
|
1050
|
+
}
|
|
1051
|
+
|
|
1052
|
+
delete testObj._EXTERNAL;
|
|
1053
|
+
}
|
|
1054
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1055
|
+
}
|
|
1056
|
+
function FARE_POLICY_Tag_Required_33_DESCRIPTOR_CODE(
|
|
1057
|
+
input: validationInput,
|
|
1058
|
+
): validationOutput {
|
|
1059
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
1060
|
+
let subResults: validationOutput = [];
|
|
1061
|
+
let valid = true;
|
|
1062
|
+
for (const testObj of scope) {
|
|
1063
|
+
testObj._EXTERNAL = input.externalData;
|
|
1064
|
+
const validTags = ["FARE_POLICY"];
|
|
1065
|
+
const tagPath = payloadUtils.getJsonPath(
|
|
1066
|
+
testObj,
|
|
1067
|
+
"$.message.catalog.providers[*].items[*].tags[*].descriptor.code",
|
|
1068
|
+
);
|
|
1069
|
+
|
|
1070
|
+
const skipCheck = !validations.arePresent(tagPath);
|
|
1071
|
+
if (skipCheck) continue;
|
|
1072
|
+
|
|
1073
|
+
const validate = validations.allIn(tagPath, validTags);
|
|
1074
|
+
|
|
1075
|
+
if (!validate) {
|
|
1076
|
+
return [
|
|
1077
|
+
{
|
|
1078
|
+
valid: false,
|
|
1079
|
+
code: 30000,
|
|
1080
|
+
description: `- **condition FARE_POLICY_Tag_Required_33_DESCRIPTOR_CODE**: every element of $.message.catalog.providers[*].items[*].tags[*].descriptor.code must be in ["FARE_POLICY"]
|
|
1081
|
+
|
|
1082
|
+
> Note: **Condition FARE_POLICY_Tag_Required_33_DESCRIPTOR_CODE** can be skipped if the following conditions are met:
|
|
1083
|
+
>
|
|
1084
|
+
> - **condition B**: $.message.catalog.providers[*].items[*].tags[*].descriptor.code must **not** be present in the payload`,
|
|
1085
|
+
},
|
|
1086
|
+
];
|
|
1087
|
+
}
|
|
1088
|
+
|
|
1089
|
+
delete testObj._EXTERNAL;
|
|
1090
|
+
}
|
|
1091
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1092
|
+
}
|
|
1093
|
+
function validate_tag_0_FARE_POLICY(
|
|
1094
|
+
input: validationInput,
|
|
1095
|
+
): validationOutput {
|
|
1096
|
+
const scope = payloadUtils.getJsonPath(
|
|
1097
|
+
input.payload,
|
|
1098
|
+
"$.message.catalog.providers[*].items[*].tags[?(@.descriptor.code=='FARE_POLICY')]",
|
|
1099
|
+
);
|
|
1100
|
+
let subResults: validationOutput = [];
|
|
1101
|
+
let valid = true;
|
|
1102
|
+
for (const testObj of scope) {
|
|
1103
|
+
testObj._EXTERNAL = input.externalData;
|
|
1104
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1105
|
+
testObj,
|
|
1106
|
+
"$.list[*].descriptor.code",
|
|
1107
|
+
);
|
|
1108
|
+
const validValues = [
|
|
1109
|
+
"RESTRICTED_PERSON",
|
|
1110
|
+
"RESTRICTION_PROOF",
|
|
1111
|
+
];
|
|
1112
|
+
|
|
1113
|
+
const validate = validations.allIn(
|
|
1114
|
+
subTags,
|
|
1115
|
+
validValues,
|
|
1116
|
+
);
|
|
1117
|
+
|
|
1118
|
+
if (!validate) {
|
|
1119
|
+
return [
|
|
1120
|
+
{
|
|
1121
|
+
valid: false,
|
|
1122
|
+
code: 30000,
|
|
1123
|
+
description: `- **condition validate_tag_0_FARE_POLICY**: every element of $.message.catalog.providers[*].items[*].tags[?(@.descriptor.code=='FARE_POLICY')].list[*].descriptor.code must be in ["RESTRICTED_PERSON", "RESTRICTION_PROOF"]`,
|
|
1124
|
+
},
|
|
1125
|
+
];
|
|
1126
|
+
}
|
|
1127
|
+
|
|
1128
|
+
delete testObj._EXTERNAL;
|
|
1129
|
+
}
|
|
1130
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1131
|
+
}
|
|
1132
|
+
function ROUTE_INFO_Tag_Required_35_DESCRIPTOR_CODE(
|
|
1133
|
+
input: validationInput,
|
|
1134
|
+
): validationOutput {
|
|
1135
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
1136
|
+
let subResults: validationOutput = [];
|
|
1137
|
+
let valid = true;
|
|
1138
|
+
for (const testObj of scope) {
|
|
1139
|
+
testObj._EXTERNAL = input.externalData;
|
|
1140
|
+
const validTags = [
|
|
1141
|
+
"ROUTE_INFO",
|
|
1142
|
+
"TICKET_INFO",
|
|
1143
|
+
"TRIP_DETAILS",
|
|
1144
|
+
];
|
|
1145
|
+
const tagPath = payloadUtils.getJsonPath(
|
|
1146
|
+
testObj,
|
|
1147
|
+
"$.message.catalog.providers[*].fulfillments[*].tags[*].descriptor.code",
|
|
1148
|
+
);
|
|
1149
|
+
|
|
1150
|
+
const skipCheck = !validations.arePresent(tagPath);
|
|
1151
|
+
if (skipCheck) continue;
|
|
1152
|
+
|
|
1153
|
+
const validate = validations.allIn(tagPath, validTags);
|
|
1154
|
+
|
|
1155
|
+
if (!validate) {
|
|
1156
|
+
return [
|
|
1157
|
+
{
|
|
1158
|
+
valid: false,
|
|
1159
|
+
code: 30000,
|
|
1160
|
+
description: `- **condition ROUTE_INFO_Tag_Required_35_DESCRIPTOR_CODE**: every element of $.message.catalog.providers[*].fulfillments[*].tags[*].descriptor.code must be in ["ROUTE_INFO", "TICKET_INFO", "TRIP_DETAILS"]
|
|
1161
|
+
|
|
1162
|
+
> Note: **Condition ROUTE_INFO_Tag_Required_35_DESCRIPTOR_CODE** can be skipped if the following conditions are met:
|
|
1163
|
+
>
|
|
1164
|
+
> - **condition B**: $.message.catalog.providers[*].fulfillments[*].tags[*].descriptor.code must **not** be present in the payload`,
|
|
1165
|
+
},
|
|
1166
|
+
];
|
|
1167
|
+
}
|
|
1168
|
+
|
|
1169
|
+
delete testObj._EXTERNAL;
|
|
1170
|
+
}
|
|
1171
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1172
|
+
}
|
|
1173
|
+
function validate_tag_1_ROUTE_INFO(
|
|
1174
|
+
input: validationInput,
|
|
1175
|
+
): validationOutput {
|
|
1176
|
+
const scope = payloadUtils.getJsonPath(
|
|
1177
|
+
input.payload,
|
|
1178
|
+
"$.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='ROUTE_INFO')]",
|
|
1179
|
+
);
|
|
1180
|
+
let subResults: validationOutput = [];
|
|
1181
|
+
let valid = true;
|
|
1182
|
+
for (const testObj of scope) {
|
|
1183
|
+
testObj._EXTERNAL = input.externalData;
|
|
1184
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1185
|
+
testObj,
|
|
1186
|
+
"$.list[*].descriptor.code",
|
|
1187
|
+
);
|
|
1188
|
+
const validValues = ["ROUTE_ID", "ROUTE_DIRECTION"];
|
|
1189
|
+
|
|
1190
|
+
const validate = validations.allIn(
|
|
1191
|
+
subTags,
|
|
1192
|
+
validValues,
|
|
1193
|
+
);
|
|
1194
|
+
|
|
1195
|
+
if (!validate) {
|
|
1196
|
+
return [
|
|
1197
|
+
{
|
|
1198
|
+
valid: false,
|
|
1199
|
+
code: 30000,
|
|
1200
|
+
description: `- **condition validate_tag_1_ROUTE_INFO**: every element of $.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='ROUTE_INFO')].list[*].descriptor.code must be in ["ROUTE_ID", "ROUTE_DIRECTION"]`,
|
|
1201
|
+
},
|
|
1202
|
+
];
|
|
1203
|
+
}
|
|
1204
|
+
|
|
1205
|
+
delete testObj._EXTERNAL;
|
|
1206
|
+
}
|
|
1207
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1208
|
+
}
|
|
1209
|
+
function validate_tag_1_TICKET_INFO(
|
|
1210
|
+
input: validationInput,
|
|
1211
|
+
): validationOutput {
|
|
1212
|
+
const scope = payloadUtils.getJsonPath(
|
|
1213
|
+
input.payload,
|
|
1214
|
+
"$.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='TICKET_INFO')]",
|
|
1215
|
+
);
|
|
1216
|
+
let subResults: validationOutput = [];
|
|
1217
|
+
let valid = true;
|
|
1218
|
+
for (const testObj of scope) {
|
|
1219
|
+
testObj._EXTERNAL = input.externalData;
|
|
1220
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1221
|
+
testObj,
|
|
1222
|
+
"$.list[*].descriptor.code",
|
|
1223
|
+
);
|
|
1224
|
+
const validValues = ["NUMBER"];
|
|
1225
|
+
|
|
1226
|
+
const validate = validations.allIn(
|
|
1227
|
+
subTags,
|
|
1228
|
+
validValues,
|
|
1229
|
+
);
|
|
1230
|
+
|
|
1231
|
+
if (!validate) {
|
|
1232
|
+
return [
|
|
1233
|
+
{
|
|
1234
|
+
valid: false,
|
|
1235
|
+
code: 30000,
|
|
1236
|
+
description: `- **condition validate_tag_1_TICKET_INFO**: every element of $.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='TICKET_INFO')].list[*].descriptor.code must be in ["NUMBER"]`,
|
|
1237
|
+
},
|
|
1238
|
+
];
|
|
1239
|
+
}
|
|
1240
|
+
|
|
1241
|
+
delete testObj._EXTERNAL;
|
|
1242
|
+
}
|
|
1243
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1244
|
+
}
|
|
1245
|
+
function validate_tag_1_TRIP_DETAILS(
|
|
1246
|
+
input: validationInput,
|
|
1247
|
+
): validationOutput {
|
|
1248
|
+
const scope = payloadUtils.getJsonPath(
|
|
1249
|
+
input.payload,
|
|
1250
|
+
"$.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='TRIP_DETAILS')]",
|
|
1251
|
+
);
|
|
1252
|
+
let subResults: validationOutput = [];
|
|
1253
|
+
let valid = true;
|
|
1254
|
+
for (const testObj of scope) {
|
|
1255
|
+
testObj._EXTERNAL = input.externalData;
|
|
1256
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1257
|
+
testObj,
|
|
1258
|
+
"$.list[*].descriptor.code",
|
|
1259
|
+
);
|
|
1260
|
+
const validValues = [
|
|
1261
|
+
"AVAILABLE_TRIPS",
|
|
1262
|
+
"UTILIZED_TRIPS",
|
|
1263
|
+
];
|
|
1264
|
+
|
|
1265
|
+
const validate = validations.allIn(
|
|
1266
|
+
subTags,
|
|
1267
|
+
validValues,
|
|
1268
|
+
);
|
|
1269
|
+
|
|
1270
|
+
if (!validate) {
|
|
1271
|
+
return [
|
|
1272
|
+
{
|
|
1273
|
+
valid: false,
|
|
1274
|
+
code: 30000,
|
|
1275
|
+
description: `- **condition validate_tag_1_TRIP_DETAILS**: every element of $.message.catalog.providers[*].fulfillments[*].tags[?(@.descriptor.code=='TRIP_DETAILS')].list[*].descriptor.code must be in ["AVAILABLE_TRIPS", "UTILIZED_TRIPS"]`,
|
|
1276
|
+
},
|
|
1277
|
+
];
|
|
1278
|
+
}
|
|
1279
|
+
|
|
1280
|
+
delete testObj._EXTERNAL;
|
|
1281
|
+
}
|
|
1282
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1283
|
+
}
|
|
1284
|
+
function BUYER_FINDER_FEES_Tag_Required_39_DESCRIPTOR_CODE(
|
|
1285
|
+
input: validationInput,
|
|
1286
|
+
): validationOutput {
|
|
1287
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
1288
|
+
let subResults: validationOutput = [];
|
|
1289
|
+
let valid = true;
|
|
1290
|
+
for (const testObj of scope) {
|
|
1291
|
+
testObj._EXTERNAL = input.externalData;
|
|
1292
|
+
const validTags = [
|
|
1293
|
+
"BUYER_FINDER_FEES",
|
|
1294
|
+
"SETTLEMENT_TERMS",
|
|
1295
|
+
];
|
|
1296
|
+
const tagPath = payloadUtils.getJsonPath(
|
|
1297
|
+
testObj,
|
|
1298
|
+
"$.message.catalog.providers[*].payments[*].tags[*].descriptor.code",
|
|
1299
|
+
);
|
|
1300
|
+
|
|
1301
|
+
const skipCheck = !validations.arePresent(tagPath);
|
|
1302
|
+
if (skipCheck) continue;
|
|
1303
|
+
|
|
1304
|
+
const validate = validations.allIn(tagPath, validTags);
|
|
1305
|
+
|
|
1306
|
+
if (!validate) {
|
|
1307
|
+
return [
|
|
1308
|
+
{
|
|
1309
|
+
valid: false,
|
|
1310
|
+
code: 30000,
|
|
1311
|
+
description: `- **condition BUYER_FINDER_FEES_Tag_Required_39_DESCRIPTOR_CODE**: every element of $.message.catalog.providers[*].payments[*].tags[*].descriptor.code must be in ["BUYER_FINDER_FEES", "SETTLEMENT_TERMS"]
|
|
1312
|
+
|
|
1313
|
+
> Note: **Condition BUYER_FINDER_FEES_Tag_Required_39_DESCRIPTOR_CODE** can be skipped if the following conditions are met:
|
|
1314
|
+
>
|
|
1315
|
+
> - **condition B**: $.message.catalog.providers[*].payments[*].tags[*].descriptor.code must **not** be present in the payload`,
|
|
1316
|
+
},
|
|
1317
|
+
];
|
|
1318
|
+
}
|
|
1319
|
+
|
|
1320
|
+
delete testObj._EXTERNAL;
|
|
1321
|
+
}
|
|
1322
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1323
|
+
}
|
|
1324
|
+
function validate_tag_2_BUYER_FINDER_FEES(
|
|
1325
|
+
input: validationInput,
|
|
1326
|
+
): validationOutput {
|
|
1327
|
+
const scope = payloadUtils.getJsonPath(
|
|
1328
|
+
input.payload,
|
|
1329
|
+
"$.message.catalog.providers[*].payments[*].tags[?(@.descriptor.code=='BUYER_FINDER_FEES')]",
|
|
1330
|
+
);
|
|
1331
|
+
let subResults: validationOutput = [];
|
|
1332
|
+
let valid = true;
|
|
1333
|
+
for (const testObj of scope) {
|
|
1334
|
+
testObj._EXTERNAL = input.externalData;
|
|
1335
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1336
|
+
testObj,
|
|
1337
|
+
"$.list[*].descriptor.code",
|
|
1338
|
+
);
|
|
1339
|
+
const validValues = [
|
|
1340
|
+
"BUYER_FINDER_FEES_TYPE",
|
|
1341
|
+
"BUYER_FINDER_FEES_PERCENTAGE",
|
|
1342
|
+
"BUYER_FINDER_FEES_AMOUNT",
|
|
1343
|
+
];
|
|
1344
|
+
|
|
1345
|
+
const validate = validations.allIn(
|
|
1346
|
+
subTags,
|
|
1347
|
+
validValues,
|
|
1348
|
+
);
|
|
1349
|
+
|
|
1350
|
+
if (!validate) {
|
|
1351
|
+
return [
|
|
1352
|
+
{
|
|
1353
|
+
valid: false,
|
|
1354
|
+
code: 30000,
|
|
1355
|
+
description: `- **condition validate_tag_2_BUYER_FINDER_FEES**: every element of $.message.catalog.providers[*].payments[*].tags[?(@.descriptor.code=='BUYER_FINDER_FEES')].list[*].descriptor.code must be in ["BUYER_FINDER_FEES_TYPE", "BUYER_FINDER_FEES_PERCENTAGE", "BUYER_FINDER_FEES_AMOUNT"]`,
|
|
1356
|
+
},
|
|
1357
|
+
];
|
|
1358
|
+
}
|
|
1359
|
+
|
|
1360
|
+
delete testObj._EXTERNAL;
|
|
1361
|
+
}
|
|
1362
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1363
|
+
}
|
|
1364
|
+
function validate_tag_2_SETTLEMENT_TERMS(
|
|
1365
|
+
input: validationInput,
|
|
1366
|
+
): validationOutput {
|
|
1367
|
+
const scope = payloadUtils.getJsonPath(
|
|
1368
|
+
input.payload,
|
|
1369
|
+
"$.message.catalog.providers[*].payments[*].tags[?(@.descriptor.code=='SETTLEMENT_TERMS')]",
|
|
1370
|
+
);
|
|
1371
|
+
let subResults: validationOutput = [];
|
|
1372
|
+
let valid = true;
|
|
1373
|
+
for (const testObj of scope) {
|
|
1374
|
+
testObj._EXTERNAL = input.externalData;
|
|
1375
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1376
|
+
testObj,
|
|
1377
|
+
"$.list[*].descriptor.code",
|
|
1378
|
+
);
|
|
1379
|
+
const validValues = [
|
|
1380
|
+
"SETTLEMENT_WINDOW",
|
|
1381
|
+
"SETTLEMENT_BASIS",
|
|
1382
|
+
"SETTLEMENT_TYPE",
|
|
1383
|
+
"MANDATORY_ARBITRATION",
|
|
1384
|
+
"COURT_JURISDICTION",
|
|
1385
|
+
"DELAY_INTEREST",
|
|
1386
|
+
"STATIC_TERMS",
|
|
1387
|
+
"SETTLEMENT_AMOUNT",
|
|
1388
|
+
];
|
|
1389
|
+
|
|
1390
|
+
const validate = validations.allIn(
|
|
1391
|
+
subTags,
|
|
1392
|
+
validValues,
|
|
1393
|
+
);
|
|
1394
|
+
|
|
1395
|
+
if (!validate) {
|
|
1396
|
+
return [
|
|
1397
|
+
{
|
|
1398
|
+
valid: false,
|
|
1399
|
+
code: 30000,
|
|
1400
|
+
description: `- **condition validate_tag_2_SETTLEMENT_TERMS**: every element of $.message.catalog.providers[*].payments[*].tags[?(@.descriptor.code=='SETTLEMENT_TERMS')].list[*].descriptor.code must be in ["SETTLEMENT_WINDOW", "SETTLEMENT_BASIS", "SETTLEMENT_TYPE", "MANDATORY_ARBITRATION", "COURT_JURISDICTION", "DELAY_INTEREST", "STATIC_TERMS", "SETTLEMENT_AMOUNT"]`,
|
|
1401
|
+
},
|
|
1402
|
+
];
|
|
1403
|
+
}
|
|
1404
|
+
|
|
1405
|
+
delete testObj._EXTERNAL;
|
|
1406
|
+
}
|
|
1407
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1408
|
+
}
|
|
1409
|
+
function SCHEDULED_INFO_Tag_Required_42_DESCRIPTOR_CODE(
|
|
1410
|
+
input: validationInput,
|
|
1411
|
+
): validationOutput {
|
|
1412
|
+
const scope = payloadUtils.getJsonPath(input.payload, "$");
|
|
1413
|
+
let subResults: validationOutput = [];
|
|
1414
|
+
let valid = true;
|
|
1415
|
+
for (const testObj of scope) {
|
|
1416
|
+
testObj._EXTERNAL = input.externalData;
|
|
1417
|
+
const validTags = ["SCHEDULED_INFO"];
|
|
1418
|
+
const tagPath = payloadUtils.getJsonPath(
|
|
1419
|
+
testObj,
|
|
1420
|
+
"$.message.catalog.providers[*].tags[*].descriptor.code",
|
|
1421
|
+
);
|
|
1422
|
+
|
|
1423
|
+
const skipCheck = !validations.arePresent(tagPath);
|
|
1424
|
+
if (skipCheck) continue;
|
|
1425
|
+
|
|
1426
|
+
const validate = validations.allIn(tagPath, validTags);
|
|
1427
|
+
|
|
1428
|
+
if (!validate) {
|
|
1429
|
+
return [
|
|
1430
|
+
{
|
|
1431
|
+
valid: false,
|
|
1432
|
+
code: 30000,
|
|
1433
|
+
description: `- **condition SCHEDULED_INFO_Tag_Required_42_DESCRIPTOR_CODE**: every element of $.message.catalog.providers[*].tags[*].descriptor.code must be in ["SCHEDULED_INFO"]
|
|
1434
|
+
|
|
1435
|
+
> Note: **Condition SCHEDULED_INFO_Tag_Required_42_DESCRIPTOR_CODE** can be skipped if the following conditions are met:
|
|
1436
|
+
>
|
|
1437
|
+
> - **condition B**: $.message.catalog.providers[*].tags[*].descriptor.code must **not** be present in the payload`,
|
|
1438
|
+
},
|
|
1439
|
+
];
|
|
1440
|
+
}
|
|
1441
|
+
|
|
1442
|
+
delete testObj._EXTERNAL;
|
|
1443
|
+
}
|
|
1444
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1445
|
+
}
|
|
1446
|
+
function validate_tag_3_SCHEDULED_INFO(
|
|
1447
|
+
input: validationInput,
|
|
1448
|
+
): validationOutput {
|
|
1449
|
+
const scope = payloadUtils.getJsonPath(
|
|
1450
|
+
input.payload,
|
|
1451
|
+
"$.message.catalog.providers[*].tags[?(@.descriptor.code=='SCHEDULED_INFO')]",
|
|
1452
|
+
);
|
|
1453
|
+
let subResults: validationOutput = [];
|
|
1454
|
+
let valid = true;
|
|
1455
|
+
for (const testObj of scope) {
|
|
1456
|
+
testObj._EXTERNAL = input.externalData;
|
|
1457
|
+
const subTags = payloadUtils.getJsonPath(
|
|
1458
|
+
testObj,
|
|
1459
|
+
"$.list[*].descriptor.code",
|
|
1460
|
+
);
|
|
1461
|
+
const validValues = ["GTFS"];
|
|
1462
|
+
|
|
1463
|
+
const validate = validations.allIn(
|
|
1464
|
+
subTags,
|
|
1465
|
+
validValues,
|
|
1466
|
+
);
|
|
1467
|
+
|
|
1468
|
+
if (!validate) {
|
|
1469
|
+
return [
|
|
1470
|
+
{
|
|
1471
|
+
valid: false,
|
|
1472
|
+
code: 30000,
|
|
1473
|
+
description: `- **condition validate_tag_3_SCHEDULED_INFO**: every element of $.message.catalog.providers[*].tags[?(@.descriptor.code=='SCHEDULED_INFO')].list[*].descriptor.code must be in ["GTFS"]`,
|
|
1474
|
+
},
|
|
1475
|
+
];
|
|
1476
|
+
}
|
|
1477
|
+
|
|
1478
|
+
delete testObj._EXTERNAL;
|
|
1479
|
+
}
|
|
1480
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1481
|
+
}
|
|
1482
|
+
|
|
1483
|
+
const testFunctions: testFunctionArray = [
|
|
1484
|
+
Attri_Required_10_DESCRIPTOR_NAME,
|
|
1485
|
+
Attri_Required_11_PROVIDERS_ID,
|
|
1486
|
+
Attri_Required_12_DESCRIPTOR_NAME,
|
|
1487
|
+
Attri_Required_13_FULFILLMENTS_ID,
|
|
1488
|
+
Attri_Required_14_LOCATION_GPS,
|
|
1489
|
+
Attri_Required_15_FULFILLMENTS_ID,
|
|
1490
|
+
Attri_Required_16_CATEGORIES_ID,
|
|
1491
|
+
Attri_Required_17_RANGE_START,
|
|
1492
|
+
Attri_Required_18_RANGE_END,
|
|
1493
|
+
Enum_Required_23_DESCRIPTOR_CODE,
|
|
1494
|
+
Enum_Required_24_DESCRIPTOR_CODE,
|
|
1495
|
+
Enum_Required_25_VEHICLE_CATEGORY,
|
|
1496
|
+
Enum_Required_26_FULFILLMENTS_TYPE,
|
|
1497
|
+
Enum_Required_27_FULFILLMENTS_TYPE,
|
|
1498
|
+
Enum_Required_28_AUTHORIZATION_TYPE,
|
|
1499
|
+
Enum_Required_29_AUTHORIZATION_STATUS,
|
|
1500
|
+
Enum_Required_30_PAYMENTS_STATUS,
|
|
1501
|
+
Enum_Required_31_PAYMENTS_COLLECTED_BY,
|
|
1502
|
+
Enum_Required_32_PAYMENTS_TYPE,
|
|
1503
|
+
FARE_POLICY_Tag_Required_33_DESCRIPTOR_CODE,
|
|
1504
|
+
validate_tag_0_FARE_POLICY,
|
|
1505
|
+
ROUTE_INFO_Tag_Required_35_DESCRIPTOR_CODE,
|
|
1506
|
+
validate_tag_1_ROUTE_INFO,
|
|
1507
|
+
validate_tag_1_TICKET_INFO,
|
|
1508
|
+
validate_tag_1_TRIP_DETAILS,
|
|
1509
|
+
BUYER_FINDER_FEES_Tag_Required_39_DESCRIPTOR_CODE,
|
|
1510
|
+
validate_tag_2_BUYER_FINDER_FEES,
|
|
1511
|
+
validate_tag_2_SETTLEMENT_TERMS,
|
|
1512
|
+
SCHEDULED_INFO_Tag_Required_42_DESCRIPTOR_CODE,
|
|
1513
|
+
validate_tag_3_SCHEDULED_INFO,
|
|
1514
|
+
];
|
|
1515
|
+
|
|
1516
|
+
let invalidResults: validationOutput = [];
|
|
1517
|
+
for (const fn of testFunctions) {
|
|
1518
|
+
const subResult = fn(input);
|
|
1519
|
+
// .filter(r => !r.valid);
|
|
1520
|
+
invalidResults = [...invalidResults, ...subResult];
|
|
1521
|
+
if (
|
|
1522
|
+
!input.config.runAllValidations &&
|
|
1523
|
+
invalidResults.length > 0
|
|
1524
|
+
) {
|
|
1525
|
+
return invalidResults;
|
|
1526
|
+
}
|
|
1527
|
+
}
|
|
1528
|
+
if (invalidResults.length > 0) {
|
|
1529
|
+
// return invalidResults;
|
|
1530
|
+
subResults = invalidResults;
|
|
1531
|
+
valid = subResults.every((r) => r.valid);
|
|
1532
|
+
}
|
|
1533
|
+
|
|
1534
|
+
delete testObj._EXTERNAL;
|
|
1535
|
+
}
|
|
1536
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1537
|
+
}
|
|
1538
|
+
|
|
1539
|
+
const testFunctions: testFunctionArray = [
|
|
1540
|
+
Attri_Required_1_CONTEXT_TIMESTAMP,
|
|
1541
|
+
Attri_Required_2_CONTEXT_BAP_ID,
|
|
1542
|
+
Attri_Required_3_CONTEXT_TRANSACTION_ID,
|
|
1543
|
+
Attri_Required_4_CONTEXT_MESSAGE_ID,
|
|
1544
|
+
Attri_Required_5_CONTEXT_VERSION,
|
|
1545
|
+
Attri_Required_6_CONTEXT_BAP_URI,
|
|
1546
|
+
Attri_Required_7_CONTEXT_TTL,
|
|
1547
|
+
Attri_Required_8_CONTEXT_BPP_ID,
|
|
1548
|
+
Attri_Required_9_CONTEXT_BPP_URI,
|
|
1549
|
+
Enum_Required_19_CONTEXT_ACTION,
|
|
1550
|
+
Enum_Required_20_COUNTRY_CODE,
|
|
1551
|
+
Enum_Required_21_CITY_CODE,
|
|
1552
|
+
Enum_Required_22_CONTEXT_DOMAIN,
|
|
1553
|
+
on_search_Message_TESTS,
|
|
1554
|
+
];
|
|
1555
|
+
|
|
1556
|
+
let invalidResults: validationOutput = [];
|
|
1557
|
+
for (const fn of testFunctions) {
|
|
1558
|
+
const subResult = fn(input);
|
|
1559
|
+
// .filter(r => !r.valid);
|
|
1560
|
+
invalidResults = [...invalidResults, ...subResult];
|
|
1561
|
+
if (!input.config.runAllValidations && invalidResults.length > 0) {
|
|
1562
|
+
return invalidResults;
|
|
1563
|
+
}
|
|
1564
|
+
}
|
|
1565
|
+
if (invalidResults.length > 0) {
|
|
1566
|
+
// return invalidResults;
|
|
1567
|
+
subResults = invalidResults;
|
|
1568
|
+
valid = subResults.every((r) => r.valid);
|
|
1569
|
+
}
|
|
1570
|
+
|
|
1571
|
+
delete testObj._EXTERNAL;
|
|
1572
|
+
}
|
|
1573
|
+
return [{ valid: valid, code: 200 }, ...subResults];
|
|
1574
|
+
}
|