ondc-code-generator 0.0.1 → 0.0.3

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.
Files changed (77) hide show
  1. package/dist/constants/syntax.js +2 -0
  2. package/{src/example.ts → dist/example.js} +1 -4
  3. package/dist/{Generator → generator}/config-compiler.js +25 -4
  4. package/dist/{Generator → generator}/generators/documentation/markdown-message-generator.js +0 -13
  5. package/dist/{Generator → generator}/generators/typescript/ts-generator.js +3 -4
  6. package/dist/{Generator → generator}/validators/abstract-validator.js +1 -1
  7. package/dist/{Generator → generator}/validators/config-validator.js +4 -4
  8. package/dist/{Generator → generator}/validators/session-data-config/session-data-validator.js +2 -2
  9. package/dist/{Generator → generator}/validators/tests-config/sub-validations.js +38 -33
  10. package/dist/{Generator → generator}/validators/tests-config/test-list-validator.js +3 -3
  11. package/dist/{Generator → generator}/validators/tests-config/test-validator.js +7 -7
  12. package/dist/index.js +1 -38
  13. package/dist/services/return-complier/tokens.js +3 -0
  14. package/dist/utils/general-utils/string-utils.js +10 -2
  15. package/package.json +6 -4
  16. package/dist/Generator/config-validator.js +0 -21
  17. package/dist/Generator/generators/markdown-message-generator.js +0 -25
  18. package/dist/Generator/pipline.js +0 -1
  19. package/dist/Generator/validators/validation-error.js +0 -9
  20. package/dist/services/rename-later/main.js +0 -1
  21. package/dist/services/rename-later/parser.js +0 -22
  22. package/dist/services/rename-later/tokens.js +0 -32
  23. package/dist/services/rename-later/tokens1.js +0 -33
  24. package/dist/utils/file-system.js +0 -1
  25. package/src/constants/operations.ts +0 -19
  26. package/src/constants/syntax.ts +0 -81
  27. package/src/generator/config-compiler.ts +0 -122
  28. package/src/generator/generators/classes/abstract-generator.ts +0 -29
  29. package/src/generator/generators/documentation/markdown-message-generator.ts +0 -43
  30. package/src/generator/generators/documentation/md-generator.ts +0 -76
  31. package/src/generator/generators/documentation/templates/index.mustache +0 -36
  32. package/src/generator/generators/documentation/templates/style.css +0 -204
  33. package/src/generator/generators/python/py-generator.ts +0 -0
  34. package/src/generator/generators/typescript/templates/api-test.mustache +0 -7
  35. package/src/generator/generators/typescript/templates/json-path-utils.ts +0 -17
  36. package/src/generator/generators/typescript/templates/schema-template.mustache +0 -18
  37. package/src/generator/generators/typescript/templates/test-config.mustache +0 -28
  38. package/src/generator/generators/typescript/templates/test-object.mustache +0 -20
  39. package/src/generator/generators/typescript/templates/validation-code.mustache +0 -39
  40. package/src/generator/generators/typescript/templates/validation-utils.ts +0 -117
  41. package/src/generator/generators/typescript/ts-ast.ts +0 -72
  42. package/src/generator/generators/typescript/ts-generator.ts +0 -275
  43. package/src/generator/validators/abstract-validator.ts +0 -23
  44. package/src/generator/validators/config-validator.ts +0 -55
  45. package/src/generator/validators/session-data-config/session-data-validator.ts +0 -58
  46. package/src/generator/validators/tests-config/sub-validations.ts +0 -302
  47. package/src/generator/validators/tests-config/test-list-validator.ts +0 -59
  48. package/src/generator/validators/tests-config/test-validator.ts +0 -69
  49. package/src/index.ts +0 -2
  50. package/src/services/return-complier/ast-functions/compile-to-markdown.ts +0 -152
  51. package/src/services/return-complier/ast-functions/semantic-validations.ts +0 -44
  52. package/src/services/return-complier/ast.ts +0 -147
  53. package/src/services/return-complier/combined.ts +0 -8
  54. package/src/services/return-complier/parser.ts +0 -128
  55. package/src/services/return-complier/tokens.ts +0 -184
  56. package/src/services/schema-service.ts +0 -42
  57. package/src/types/build.ts +0 -51
  58. package/src/types/compiler-types.ts +0 -3
  59. package/src/types/config-types.ts +0 -27
  60. package/src/types/error-codes.ts +0 -6
  61. package/src/types/general-types.ts +0 -2
  62. package/src/utils/config-utils/json-schema-utils.ts +0 -150
  63. package/src/utils/config-utils/yaml.ts +0 -17
  64. package/src/utils/fs-utils.ts +0 -32
  65. package/src/utils/general-utils/string-utils.ts +0 -76
  66. package/src/utils/general-utils/test-object-utils.ts +0 -14
  67. package/src/utils/general-utils/validation-utils.ts +0 -30
  68. package/src/utils/json-path-utils/extract-string-paths.ts +0 -139
  69. package/src/utils/json-path-utils/paths.ts +0 -44
  70. package/src/utils/logger.ts +0 -53
  71. package/tsconfig.json +0 -17
  72. /package/dist/{Generator → generator}/generators/classes/abstract-generator.js +0 -0
  73. /package/dist/{Generator → generator}/generators/documentation/md-generator.js +0 -0
  74. /package/dist/{Generator → generator}/generators/python/py-generator.js +0 -0
  75. /package/dist/{Generator → generator}/generators/typescript/templates/json-path-utils.js +0 -0
  76. /package/dist/{Generator → generator}/generators/typescript/templates/validation-utils.js +0 -0
  77. /package/dist/{Generator → generator}/generators/typescript/ts-ast.js +0 -0
@@ -1,204 +0,0 @@
1
- /* RESET DEFAULT STYLES */
2
- body, ul, li, p, blockquote {
3
- margin: 0;
4
- padding: 0;
5
- }
6
- ul, li {
7
- list-style: none;
8
- }
9
-
10
- /* BODY STYLES */
11
- body {
12
- font-family: "Helvetica Neue", Arial, sans-serif;
13
- background-color: #ffffff; /* Light background */
14
- color: #333333; /* Dark text */
15
- line-height: 1.8;
16
- padding: 20px;
17
- }
18
-
19
- /* LIST STYLES */
20
- ul {
21
- padding-left: 20px;
22
- }
23
-
24
- li {
25
- margin-bottom: 16px;
26
- position: relative;
27
- }
28
-
29
- li > p {
30
- margin-bottom: 8px;
31
- background-color: #f7f7f7; /* Light background */
32
- color: #555555; /* Dark text */
33
- padding: 10px 15px;
34
- border: 1px solid #ddd;
35
- border-radius: 5px;
36
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
37
- transition: background-color 0.3s, border 0.3s, box-shadow 0.3s;
38
- }
39
-
40
- li > p:hover {
41
- background-color: #e8e8e8;
42
- border-color: #1296d9; /* Updated to blue accent color */
43
- box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
44
- }
45
-
46
- /* NESTED LIST ITEMS */
47
- ul ul li > p {
48
- background-color: #f0f0f0; /* Slightly darker than parent */
49
- }
50
-
51
- ul ul li > p:hover {
52
- background-color: #e0e0e0;
53
- }
54
-
55
- /* HEADINGS AND EMPHASIS TEXT */
56
- h2,
57
- li > p > strong {
58
- color: #1296d9; /* Changed header color to match blue theme */
59
- font-weight: 600;
60
- }
61
-
62
- li > p > strong {
63
- font-size: 1.1em;
64
- }
65
-
66
- /* BLOCKQUOTE STYLES */
67
- blockquote {
68
- margin: 15px 0;
69
- padding: 15px 20px;
70
- background-color: #f7f7f7;
71
- border-left: 5px solid #1296d9; /* Updated border to blue */
72
- color: #555555;
73
- font-style: italic;
74
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
75
- transition: background-color 0.3s, border-left-color 0.3s, box-shadow 0.3s;
76
- }
77
-
78
- blockquote:hover {
79
- background-color: #e8e8e8;
80
- border-left-color: #1296d9; /* Updated hover border to blue */
81
- box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
82
- }
83
-
84
- /* BLOCKQUOTE INTERNAL ELEMENTS */
85
- blockquote > p {
86
- margin-bottom: 12px;
87
- padding: 10px 15px;
88
- background-color: #f7f7f7;
89
- border-radius: 5px;
90
- font-size: 1em;
91
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
92
- transition: background-color 0.3s, border 0.3s, box-shadow 0.3s;
93
- }
94
-
95
- blockquote > p:hover {
96
- background-color: #e8e8e8;
97
- border: 1px solid #1296d9; /* Updated border to blue on hover */
98
- box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
99
- }
100
-
101
- blockquote > ul {
102
- padding-left: 20px;
103
- margin-top: 10px;
104
- }
105
-
106
- blockquote > ul > li {
107
- margin-bottom: 16px;
108
- position: relative;
109
- background-color: #f7f7f7;
110
- padding: 10px 15px;
111
- border: 1px solid #ddd;
112
- border-radius: 5px;
113
- box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
114
- transition: background-color 0.3s, border 0.3s, box-shadow 0.3s;
115
- }
116
-
117
- blockquote > ul > li:hover {
118
- background-color: #e8e8e8;
119
- border-color: #1296d9; /* Updated border to blue on hover */
120
- box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
121
- }
122
-
123
- blockquote > ul > li > strong {
124
- color: #1296d9; /* Changed to blue for emphasis */
125
- font-weight: 600;
126
- font-size: 1.1em;
127
- }
128
-
129
- blockquote > ul > li > ul {
130
- padding-left: 20px;
131
- margin-top: 8px;
132
- }
133
-
134
- blockquote > ul > li > ul > li {
135
- background-color: #f0f0f0;
136
- padding: 8px 12px;
137
- border: 1px solid #ccc;
138
- border-radius: 4px;
139
- box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
140
- transition: background-color 0.3s, border 0.3s, box-shadow 0.3s;
141
- }
142
-
143
- blockquote > ul > li > ul > li:hover {
144
- background-color: #e0e0e0;
145
- border-color: #1296d9; /* Updated border to blue on hover */
146
- box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
147
- }
148
-
149
- /* COLLAPSIBLE INDICATORS */
150
- li.collapsible > p {
151
- cursor: pointer;
152
- }
153
-
154
- li.collapsible > p::before {
155
- content: "▼";
156
- display: inline-block;
157
- margin-right: 8px;
158
- transition: transform 0.3s, color 0.3s;
159
- color: #1296d9; /* Updated color to blue */
160
- }
161
-
162
- li.collapsible.collapsed > p::before {
163
- transform: rotate(-90deg);
164
- }
165
-
166
- li.collapsible > p:hover::before {
167
- color: #1296d9; /* Lighter blue on hover */
168
- }
169
-
170
- /* Hide nested lists by default */
171
- li.collapsible.collapsed > ul {
172
- display: none;
173
- }
174
-
175
- /* RESPONSIVE DESIGN */
176
- @media only screen and (max-width: 768px) {
177
- body {
178
- padding: 15px;
179
- }
180
- ul {
181
- padding-left: 15px;
182
- }
183
- li > p,
184
- blockquote > p,
185
- blockquote > ul > li {
186
- font-size: 0.95em;
187
- padding: 8px 12px;
188
- }
189
- }
190
-
191
- /* CUSTOM SCROLLBAR */
192
- ::-webkit-scrollbar {
193
- width: 8px;
194
- background-color: #ffffff;
195
- }
196
-
197
- ::-webkit-scrollbar-thumb {
198
- background-color: #ccc;
199
- border-radius: 10px;
200
- }
201
-
202
- ::-webkit-scrollbar-thumb:hover {
203
- background-color: #bbb;
204
- }
File without changes
@@ -1,7 +0,0 @@
1
- import payloadUtils from "../utils/json-path-utils";
2
- import validations from "../utils/validation-utils";
3
- import { testFunctionArray, validationInput, validationOutput } from "../types/test-config";
4
-
5
-
6
-
7
- export default {{{functionCode}}}
@@ -1,17 +0,0 @@
1
- import jsonpath from "jsonpath";
2
- function getJsonPath(payload: any, path: string) {
3
- let output = jsonpath.query(payload, path);
4
- if (isListOfStringsOrNull(output)) {
5
- output = output.map((o) => (o === null ? "null" : o));
6
- }
7
- return output.length === 0 ? [] : output;
8
- }
9
- function isListOfStringsOrNull(variable: any): boolean {
10
- return (
11
- Array.isArray(variable) &&
12
- variable.every((item) => item === null || typeof item === "string")
13
- );
14
- }
15
- export default {
16
- getJsonPath,
17
- };
@@ -1,18 +0,0 @@
1
-
2
-
3
- {{#actions}}
4
- import { {{{action}}} } from './{{{action}}}'
5
- {{/actions}}
6
-
7
-
8
- export default function getSchema(action : string){
9
- switch(action){
10
- {{#actions}}
11
- case '{{{action}}}':
12
- return {{{action}}};
13
- {{/actions}}
14
- default:
15
- throw new Error('Action not found');
16
- }
17
- }
18
-
@@ -1,28 +0,0 @@
1
-
2
- export interface ValidationConfig {
3
- runAllValidations: boolean;
4
- }
5
-
6
- export type validationOutput = {
7
- valid: boolean;
8
- code: number;
9
- description?: string;
10
- }[];
11
-
12
- /*
13
- {% comment %} export type ExternalData = {
14
- {{#externalData}}
15
- {{name}}?: string[];
16
- {{/externalData}}
17
- }; {% endcomment %}
18
- */
19
-
20
- export type ExternalData = {}
21
-
22
- export type validationInput = {
23
- payload: any;
24
- externalData: ExternalData;
25
- config: ValidationConfig
26
- };
27
-
28
- export type testFunctionArray = Array<(input: validationInput) => validationOutput>;
@@ -1,20 +0,0 @@
1
- function {{name}}(input: validationInput): validationOutput {
2
- const scope = payloadUtils.getJsonPath(input.payload,"{{{scopePath}}}");
3
- let subResults: validationOutput = [];
4
- let valid = true;
5
- for(const testObj of scope){
6
- testObj._EXTERNAL = input.externalData;
7
- {{#variables}}
8
- const {{name}} = {{{value}}}
9
- {{/variables}}
10
-
11
- {{#hasContinue}}
12
- const skipCheck = {{{skipCheckStatement}}};
13
- if(skipCheck) continue;
14
- {{/hasContinue}}
15
-
16
- {{{validationCode}}}
17
- delete testObj._EXTERNAL;
18
- }
19
- return [{valid: valid,code: {{successCode}} },...subResults];
20
- }
@@ -1,39 +0,0 @@
1
-
2
- {{#isNested}}
3
-
4
- {{{nestedFunctions}}}
5
-
6
- const testFunctions: testFunctionArray = [
7
- {{#names}}
8
- {{name}},
9
- {{/names}}
10
- ];
11
-
12
- let invalidResults: validationOutput = [];
13
- for (const fn of testFunctions) {
14
- const subResult = fn(input);
15
- // .filter(r => !r.valid);
16
- invalidResults = [...invalidResults, ...subResult];
17
- if(!input.config.runAllValidations && invalidResults.length > 0) {
18
- return invalidResults;
19
- }
20
- }
21
- if(invalidResults.length > 0) {
22
- // return invalidResults;
23
- subResults = invalidResults;
24
- valid = subResults.every(r => r.valid);
25
- }
26
-
27
- {{/isNested}}
28
-
29
- {{^isNested}}
30
- const validate = {{{returnStatement}}}
31
-
32
- if(!validate){
33
- return [{
34
- valid: false,
35
- code: {{errorCode}},
36
- description: `{{{errorDescription}}}`
37
- }]
38
- }
39
- {{/isNested}}
@@ -1,117 +0,0 @@
1
- function areUnique(operand: string[]) {
2
- const valuesSet = new Set(operand);
3
- return valuesSet.size === operand.length;
4
- }
5
-
6
- function arePresent(operand: string[]) {
7
-
8
- return noneIn(operand, ["", "null", "undefined"]) && operand.length > 0;
9
- }
10
-
11
- function allIn(left: string[], right: string[]) {
12
- return left.every((v) => right.includes(v));
13
- }
14
-
15
- function anyIn(left: string[], right: string[]) {
16
- return left.some((v) => right.includes(v));
17
- }
18
-
19
- function noneIn(left: string[], right: string[]) {
20
- return left.every((v) => !right.includes(v));
21
- }
22
-
23
- function equalTo(left: string[], right: string[]) {
24
- if (left.length !== right.length) return false;
25
- return left.every((v, i) => v === right[i]);
26
- }
27
-
28
- function greaterThan(left: string[], right: string[]): boolean {
29
- // Check if all elements in an array are ISO 8601 dates
30
- const areAllISO = (arr: string[]) => arr.every((v) => isISO8601(v));
31
- // Check if all elements in an array are numbers
32
- const areAllNumbers = (arr: string[]) =>
33
- arr.every((v) => !isNaN(Number(v)));
34
-
35
- if (areAllISO(left) && areAllISO(right)) {
36
- // Compare ISO 8601 dates
37
- const leftDates = left.map((date) => new Date(date).getTime());
38
- const rightDates = right.map((date) => new Date(date).getTime());
39
- return leftDates.every(
40
- (ld, index) => ld > rightDates[index] || index >= rightDates.length,
41
- );
42
- } else if (areAllNumbers(left) && areAllNumbers(right)) {
43
- // Compare numbers
44
- const leftNumbers = left.map(Number);
45
- const rightNumbers = right.map(Number);
46
- return leftNumbers.every(
47
- (ln, index) =>
48
- ln > rightNumbers[index] || index >= rightNumbers.length,
49
- );
50
- }
51
-
52
- // If neither condition is met, return false
53
- return false;
54
- }
55
-
56
- function lessThan(left: string[], right: string[]): boolean {
57
- // Check if all elements in an array are ISO 8601 dates
58
- const areAllISO = (arr: string[]) => arr.every((v) => isISO8601(v));
59
- // Check if all elements in an array are numbers
60
- const areAllNumbers = (arr: string[]) =>
61
- arr.every((v) => !isNaN(Number(v)));
62
-
63
- if (areAllISO(left) && areAllISO(right)) {
64
- // Compare ISO 8601 dates
65
- const leftDates = left.map((date) => new Date(date).getTime());
66
- const rightDates = right.map((date) => new Date(date).getTime());
67
- return leftDates.every(
68
- (ld, index) => ld < rightDates[index] || index >= rightDates.length,
69
- );
70
- } else if (areAllNumbers(left) && areAllNumbers(right)) {
71
- // Compare numbers
72
- const leftNumbers = left.map(Number);
73
- const rightNumbers = right.map(Number);
74
- return leftNumbers.every(
75
- (ln, index) =>
76
- ln < rightNumbers[index] || index >= rightNumbers.length,
77
- );
78
- }
79
-
80
- // If neither condition is met, return false
81
- return false;
82
- }
83
-
84
- function followRegex(left: string[], regexArray: string[]) {
85
- for (const regex of regexArray) {
86
- const re = new RegExp(regex);
87
- if (left.some((v) => !re.test(v))) return false;
88
- }
89
- return true;
90
- }
91
-
92
- function isISO8601(str: string): boolean {
93
- // Regular expression to match ISO 8601 format
94
- const iso8601Regex =
95
- /^\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}(?:\.\d+)?(?:Z|[+-]\d{2}:\d{2})$/;
96
-
97
- // Check if the string matches the ISO 8601 format
98
- if (!iso8601Regex.test(str)) {
99
- return false;
100
- }
101
-
102
- // Check if the string is a valid date
103
- const date = new Date(str);
104
- return !isNaN(date.getTime());
105
- }
106
-
107
- export default {
108
- areUnique,
109
- arePresent,
110
- allIn,
111
- anyIn,
112
- noneIn,
113
- equalTo,
114
- followRegex,
115
- greaterThan,
116
- lessThan,
117
- };
@@ -1,72 +0,0 @@
1
- import {
2
- AstNode,
3
- BinaryOperatorNode,
4
- CustomBinaryFunction,
5
- CustomUniaryFunction,
6
- NotOperatorNode,
7
- ReturnStatementNode,
8
- } from "../../../services/return-complier/ast.js";
9
- import { buildAstFromInput } from "../../../services/return-complier/combined.js";
10
- import { parseReturnInput } from "../../../services/return-complier/parser.js";
11
- import {
12
- AllIn,
13
- AnyIn,
14
- AreUnique,
15
- EqualTo,
16
- FollowRegex,
17
- GreaterThan,
18
- LessThan,
19
- NoneIn,
20
- ArePresent,
21
- } from "../../../services/return-complier/tokens.js";
22
-
23
- const uniaryFunction = {
24
- [AreUnique.LABEL ?? "are unique"]: "areUnique",
25
- [ArePresent.LABEL ?? "are present"]: "arePresent",
26
- };
27
- const binaryFunction = {
28
- [AllIn.LABEL ?? "all in"]: "allIn",
29
- [AnyIn.LABEL ?? "any in"]: "anyIn",
30
- [FollowRegex.LABEL ?? "follow regex"]: "followRegex",
31
- [NoneIn.LABEL ?? "none in"]: "noneIn",
32
- [EqualTo.LABEL ?? "equal to"]: "equalTo",
33
- [GreaterThan.LABEL ?? "greater than"]: "greaterThan",
34
- [LessThan.LABEL ?? "less than"]: "lessThan",
35
- };
36
-
37
- function compileToTs(node: AstNode): string {
38
- if (node.type === "returnStatement") {
39
- const returnNode = node as ReturnStatementNode;
40
- return compileToTs(returnNode.expression);
41
- }
42
- if (node.type === "binaryOperator") {
43
- const binaryNode = node as BinaryOperatorNode;
44
- const lhs = compileToTs(binaryNode.lhs);
45
- const rhs = compileToTs(binaryNode.rhs);
46
- return `(${lhs}) ${binaryNode.operator} (${rhs})`;
47
- }
48
- if (node.type === "notOperator") {
49
- const notNode = node as NotOperatorNode;
50
- const expression = compileToTs(notNode.expression);
51
- return `!(${expression})`;
52
- }
53
- if (node.type === "customUniaryFunction") {
54
- const unary = node as CustomUniaryFunction;
55
- const func = uniaryFunction[unary.customFunction];
56
- const varName = unary.expression.name;
57
- return `validations.${func}(${varName})`;
58
- }
59
- if (node.type === "customBinaryFunction") {
60
- const binary = node as CustomBinaryFunction;
61
- const func = binaryFunction[binary.customFunction];
62
- const lhs = binary.lhs.name;
63
- const rhs = binary.rhs.name;
64
- return `validations.${func}(${lhs}, ${rhs})`;
65
- }
66
- throw new Error("Unknown node type");
67
- }
68
-
69
- export const compileInputToTs = (input: string) => {
70
- const ast = buildAstFromInput(input);
71
- return compileToTs(ast);
72
- };