@rosen-bridge/config 0.1.0

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 (50) hide show
  1. package/.eslintignore +1 -0
  2. package/CHANGELOG.md +8 -0
  3. package/README.md +24 -0
  4. package/dist/cli.d.ts +3 -0
  5. package/dist/cli.d.ts.map +1 -0
  6. package/dist/cli.js +102 -0
  7. package/dist/config.d.ts +131 -0
  8. package/dist/config.d.ts.map +1 -0
  9. package/dist/config.js +578 -0
  10. package/dist/index.d.ts +2 -0
  11. package/dist/index.d.ts.map +1 -0
  12. package/dist/index.js +2 -0
  13. package/dist/schema/Validators/fieldProperties.d.ts +29 -0
  14. package/dist/schema/Validators/fieldProperties.d.ts.map +1 -0
  15. package/dist/schema/Validators/fieldProperties.js +254 -0
  16. package/dist/schema/types/fields.d.ts +37 -0
  17. package/dist/schema/types/fields.d.ts.map +1 -0
  18. package/dist/schema/types/fields.js +2 -0
  19. package/dist/schema/types/validations.d.ts +46 -0
  20. package/dist/schema/types/validations.d.ts.map +1 -0
  21. package/dist/schema/types/validations.js +2 -0
  22. package/dist/tsconfig.tsbuildinfo +1 -0
  23. package/dist/utils.d.ts +36 -0
  24. package/dist/utils.d.ts.map +1 -0
  25. package/dist/utils.js +59 -0
  26. package/dist/value/validators.d.ts +3 -0
  27. package/dist/value/validators.d.ts.map +1 -0
  28. package/dist/value/validators.js +188 -0
  29. package/lib/cli.ts +113 -0
  30. package/lib/config.ts +664 -0
  31. package/lib/index.ts +1 -0
  32. package/lib/schema/Validators/fieldProperties.ts +273 -0
  33. package/lib/schema/types/fields.ts +46 -0
  34. package/lib/schema/types/validations.ts +63 -0
  35. package/lib/utils.ts +68 -0
  36. package/lib/value/validators.ts +268 -0
  37. package/package.json +48 -0
  38. package/tests/.gitkeep +0 -0
  39. package/tests/config.spec.ts +895 -0
  40. package/tests/configEnvSetup.ts +34 -0
  41. package/tests/configTestData.ts +977 -0
  42. package/tests/configTestFiles/custom-environment-variables.json +5 -0
  43. package/tests/configTestFiles/default.json +12 -0
  44. package/tests/configTestFiles/local.json +5 -0
  45. package/tests/utils.spec.ts +117 -0
  46. package/tests/utilsTestData.ts +26 -0
  47. package/tsconfig.build.json +7 -0
  48. package/tsconfig.build.tsbuildinfo +1 -0
  49. package/tsconfig.json +7 -0
  50. package/vitest.config.ts +11 -0
@@ -0,0 +1,188 @@
1
+ export const valueValidators = {
2
+ object: (value, field) => {
3
+ if (typeof value !== 'object') {
4
+ throw new Error(`value must be of object type`);
5
+ }
6
+ const schemaKeys = new Set(Object.keys(field.children));
7
+ for (const key of Object.keys(value)) {
8
+ if (!schemaKeys.has(key)) {
9
+ throw new Error(`"${key}" key is not found in the schema`);
10
+ }
11
+ }
12
+ },
13
+ string: (value, field) => {
14
+ if (typeof value !== 'string') {
15
+ throw new Error(`value must be of string type`);
16
+ }
17
+ },
18
+ boolean: (value, field) => {
19
+ if (typeof value !== 'boolean') {
20
+ throw new Error(`value must be of boolean type`);
21
+ }
22
+ },
23
+ number: (value, field) => {
24
+ if (typeof value !== 'number') {
25
+ throw new Error(`value must be of number type`);
26
+ }
27
+ },
28
+ bigint: (value, field) => {
29
+ if (typeof value !== 'bigint') {
30
+ throw new Error(`value must be of bigint type`);
31
+ }
32
+ },
33
+ };
34
+ const required = (value, validation, config, configValidator) => {
35
+ if (validation.when && !configValidator.isWhenTrue(validation.when, config)) {
36
+ return;
37
+ }
38
+ if (validation.required && value == undefined) {
39
+ throw new Error('value is required but not found in config');
40
+ }
41
+ };
42
+ export const valueValidations = {
43
+ boolean: { required },
44
+ string: {
45
+ required,
46
+ regex: (value, validation, config, configValidator) => {
47
+ if (
48
+ value == undefined ||
49
+ (validation.when &&
50
+ !configValidator.isWhenTrue(validation.when, config))
51
+ ) {
52
+ return;
53
+ }
54
+ const re = new RegExp(validation.regex);
55
+ const match = value.match(re);
56
+ if (match == null || match[0] !== value) {
57
+ throw new Error(`value should match the regex="${validation.regex}"`);
58
+ }
59
+ },
60
+ choices: (value, validation, config, configValidator) => {
61
+ if (
62
+ value == undefined ||
63
+ (validation.when &&
64
+ !configValidator.isWhenTrue(validation.when, config))
65
+ ) {
66
+ return;
67
+ }
68
+ if (!validation.choices.includes(value)) {
69
+ throw new Error(
70
+ `value should be one of the choices=[${validation.choices.join(
71
+ ', '
72
+ )}]`
73
+ );
74
+ }
75
+ },
76
+ },
77
+ number: {
78
+ required,
79
+ gt: (value, validation, config, configValidator) => {
80
+ if (
81
+ value == undefined ||
82
+ (validation.when &&
83
+ !configValidator.isWhenTrue(validation.when, config))
84
+ ) {
85
+ return;
86
+ }
87
+ if (value <= validation.gt) {
88
+ throw new Error(`value should be greater than ${validation.gt}`);
89
+ }
90
+ },
91
+ gte: (value, validation, config, configValidator) => {
92
+ if (
93
+ value == undefined ||
94
+ (validation.when &&
95
+ !configValidator.isWhenTrue(validation.when, config))
96
+ ) {
97
+ return;
98
+ }
99
+ if (value < validation.gte) {
100
+ throw new Error(
101
+ `value should be greater than or equal to ${validation.gte}`
102
+ );
103
+ }
104
+ },
105
+ lt: (value, validation, config, configValidator) => {
106
+ if (
107
+ value == undefined ||
108
+ (validation.when &&
109
+ !configValidator.isWhenTrue(validation.when, config))
110
+ ) {
111
+ return;
112
+ }
113
+ if (value >= validation.lt) {
114
+ throw new Error(`value should be less than ${validation.lt}`);
115
+ }
116
+ },
117
+ lte: (value, validation, config, configValidator) => {
118
+ if (
119
+ value == undefined ||
120
+ (validation.when &&
121
+ !configValidator.isWhenTrue(validation.when, config))
122
+ ) {
123
+ return;
124
+ }
125
+ if (value > validation.lte) {
126
+ throw new Error(
127
+ `value should be less than or equal to ${validation.lte}`
128
+ );
129
+ }
130
+ },
131
+ },
132
+ bigint: {
133
+ required,
134
+ gt: (value, validation, config, configValidator) => {
135
+ if (
136
+ value == undefined ||
137
+ (validation.when &&
138
+ !configValidator.isWhenTrue(validation.when, config))
139
+ ) {
140
+ return;
141
+ }
142
+ if (value <= validation.gt) {
143
+ throw new Error(`value should be greater than ${validation.gt}`);
144
+ }
145
+ },
146
+ gte: (value, validation, config, configValidator) => {
147
+ if (
148
+ value == undefined ||
149
+ (validation.when &&
150
+ !configValidator.isWhenTrue(validation.when, config))
151
+ ) {
152
+ return;
153
+ }
154
+ if (value < validation.gte) {
155
+ throw new Error(
156
+ `value should be greater than or equal to ${validation.gte}`
157
+ );
158
+ }
159
+ },
160
+ lt: (value, validation, config, configValidator) => {
161
+ if (
162
+ value == undefined ||
163
+ (validation.when &&
164
+ !configValidator.isWhenTrue(validation.when, config))
165
+ ) {
166
+ return;
167
+ }
168
+ if (value >= validation.lt) {
169
+ throw new Error(`value should be less than ${validation.lt}`);
170
+ }
171
+ },
172
+ lte: (value, validation, config, configValidator) => {
173
+ if (
174
+ value == undefined ||
175
+ (validation.when &&
176
+ !configValidator.isWhenTrue(validation.when, config))
177
+ ) {
178
+ return;
179
+ }
180
+ if (value > validation.lte) {
181
+ throw new Error(
182
+ `value should be less than or equal to ${validation.lte}`
183
+ );
184
+ }
185
+ },
186
+ },
187
+ };
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validators.js","sourceRoot":"","sources":["../../lib/value/validators.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConfigValidator } from '../config';\nimport * as types from '../schema/types/fields';\nimport {\n  VChoices,\n  VGreater,\n  VGreaterEqual,\n  VLess,\n  VLessEqual,\n  VRegex,\n  VRequired,\n} from '../schema/types/validations';\n\nexport const valueValidators: Record<string, any> = {\n  object: (value: Record<string, any>, field: types.ObjectField) => {\n    if (typeof value !== 'object') {\n      throw new Error(`value must be of object type`);\n    }\n\n    const schemaKeys = new Set(Object.keys(field.children));\n    for (const key of Object.keys(value)) {\n      if (!schemaKeys.has(key)) {\n        throw new Error(`\"${key}\" key is not found in the schema`);\n      }\n    }\n  },\n  string: (value: string, field: types.StringField) => {\n    if (typeof value !== 'string') {\n      throw new Error(`value must be of string type`);\n    }\n  },\n  boolean: (value: boolean, field: types.BooleanField) => {\n    if (typeof value !== 'boolean') {\n      throw new Error(`value must be of boolean type`);\n    }\n  },\n  number: (value: number, field: types.NumberField) => {\n    if (typeof value !== 'number') {\n      throw new Error(`value must be of number type`);\n    }\n  },\n  bigint: (value: bigint, field: types.BigIntField) => {\n    if (typeof value !== 'bigint') {\n      throw new Error(`value must be of bigint type`);\n    }\n  },\n};\n\nconst required = (\n  value: any,\n  validation: VRequired,\n  config: Record<string, any>,\n  configValidator: ConfigValidator\n) => {\n  if (validation.when && !configValidator.isWhenTrue(validation.when, config)) {\n    return;\n  }\n\n  if (validation.required && value == undefined) {\n    throw new Error('value is required but not found in config');\n  }\n};\n\nexport const valueValidations: Record<string, Record<string, any>> = {\n  boolean: { required },\n  string: {\n    required,\n    regex: (\n      value: string,\n      validation: VRegex,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      const re = new RegExp(validation.regex);\n      const match = value.match(re);\n      if (match == null || match[0] !== value) {\n        throw new Error(`value should match the regex=\"${validation.regex}\"`);\n      }\n    },\n    choices: (\n      value: string,\n      validation: VChoices,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (!validation.choices.includes(value)) {\n        throw new Error(\n          `value should be one of the choices=[${validation.choices.join(\n            ', '\n          )}]`\n        );\n      }\n    },\n  },\n  number: {\n    required,\n    gt: (\n      value: number,\n      validation: VGreater<number>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value <= validation.gt) {\n        throw new Error(`value should be greater than ${validation.gt}`);\n      }\n    },\n    gte: (\n      value: number,\n      validation: VGreaterEqual<number>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value < validation.gte) {\n        throw new Error(\n          `value should be greater than or equal to ${validation.gte}`\n        );\n      }\n    },\n    lt: (\n      value: number,\n      validation: VLess<number>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value >= validation.lt) {\n        throw new Error(`value should be less than ${validation.lt}`);\n      }\n    },\n    lte: (\n      value: number,\n      validation: VLessEqual<number>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value > validation.lte) {\n        throw new Error(\n          `value should be less than or equal to ${validation.lte}`\n        );\n      }\n    },\n  },\n  bigint: {\n    required,\n    gt: (\n      value: bigint,\n      validation: VGreater<bigint>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value <= validation.gt) {\n        throw new Error(`value should be greater than ${validation.gt}`);\n      }\n    },\n    gte: (\n      value: bigint,\n      validation: VGreaterEqual<bigint>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value < validation.gte) {\n        throw new Error(\n          `value should be greater than or equal to ${validation.gte}`\n        );\n      }\n    },\n    lt: (\n      value: bigint,\n      validation: VLess<bigint>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value >= validation.lt) {\n        throw new Error(`value should be less than ${validation.lt}`);\n      }\n    },\n    lte: (\n      value: bigint,\n      validation: VLessEqual<bigint>,\n      config: Record<string, any>,\n      configValidator: ConfigValidator\n    ) => {\n      if (\n        value == undefined ||\n        (validation.when &&\n          !configValidator.isWhenTrue(validation.when, config))\n      ) {\n        return;\n      }\n\n      if (value > validation.lte) {\n        throw new Error(\n          `value should be less than or equal to ${validation.lte}`\n        );\n      }\n    },\n  },\n};\n"]}
package/lib/cli.ts ADDED
@@ -0,0 +1,113 @@
1
+ #!/usr/bin/env -S node --experimental-specifier-resolution=node
2
+
3
+ import yargs from 'yargs';
4
+ import { hideBin } from 'yargs/helpers';
5
+ import chalk from 'chalk';
6
+ import ora from 'ora';
7
+ import { ConfigValidator } from './index';
8
+ import * as fs from 'fs';
9
+ import JsonBigIntFactory from 'json-bigint';
10
+ import * as yaml from 'js-yaml';
11
+
12
+ const JsonBigInt = JsonBigIntFactory({
13
+ alwaysParseAsBig: false,
14
+ useNativeBigInt: true,
15
+ });
16
+
17
+ yargs(hideBin(process.argv))
18
+ .command(
19
+ 'generate-default',
20
+ 'generates an object using the default values of the passed schema',
21
+ (yargs) =>
22
+ yargs
23
+ .option('schema', {
24
+ alias: 's',
25
+ demandOption: true,
26
+ description: 'input schema file path which should be in json format',
27
+ type: 'string',
28
+ })
29
+ .option('output', {
30
+ alias: 'o',
31
+ demandOption: true,
32
+ description: 'generated default values output path',
33
+ type: 'string',
34
+ })
35
+ .option('format', {
36
+ alias: 'f',
37
+ demandOption: true,
38
+ description: 'generated default values output path',
39
+ choices: ['json', 'yaml'],
40
+ default: 'yaml',
41
+ type: 'string',
42
+ }),
43
+ async (argv) => {
44
+ const spinner = ora();
45
+ spinner.start(`Generating config default values`);
46
+
47
+ const rawSchemaData = fs.readFileSync(argv.schema, 'utf-8');
48
+ const schema = JsonBigInt.parse(rawSchemaData);
49
+
50
+ const confValidator = new ConfigValidator(schema);
51
+ const defaultConf = confValidator.generateDefault();
52
+
53
+ let output = '';
54
+ switch (argv.format) {
55
+ case 'json': {
56
+ output = JsonBigInt.stringify(defaultConf);
57
+ break;
58
+ }
59
+ case 'yaml': {
60
+ output = yaml.dump(defaultConf);
61
+ break;
62
+ }
63
+ }
64
+
65
+ fs.writeFileSync(argv.output, output);
66
+
67
+ spinner.succeed(
68
+ chalk.green(`default config values were output at "${argv.output}"`)
69
+ );
70
+ }
71
+ )
72
+ .command(
73
+ 'generate-ts-types',
74
+ 'generates compatible TypeScript interface types for the passed schema',
75
+ (yargs) =>
76
+ yargs
77
+ .option('schema', {
78
+ alias: 's',
79
+ demandOption: true,
80
+ description: 'input schema file path which should be in json format',
81
+ type: 'string',
82
+ })
83
+ .option('output', {
84
+ alias: 'o',
85
+ demandOption: true,
86
+ description: 'generated TypeScript interfaces',
87
+ type: 'string',
88
+ })
89
+ .option('root-type', {
90
+ alias: 'r',
91
+ demandOption: true,
92
+ description: 'Name of top root interface',
93
+ type: 'string',
94
+ }),
95
+ async (argv) => {
96
+ const spinner = ora();
97
+ spinner.start(`Generating TypeScript types`);
98
+
99
+ const rawSchemaData = fs.readFileSync(argv.schema, 'utf-8');
100
+ const schema = JsonBigInt.parse(rawSchemaData);
101
+
102
+ const confValidator = new ConfigValidator(schema);
103
+ const tsTypes = confValidator.generateTSTypes(argv.rootType);
104
+
105
+ fs.writeFileSync(argv.output, tsTypes);
106
+
107
+ spinner.succeed(
108
+ chalk.green(`TypeScript types were output at "${argv.output}"`)
109
+ );
110
+ }
111
+ )
112
+ .demandCommand(1)
113
+ .parse();