@sot1986/appsync-precognition 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/README.md ADDED
@@ -0,0 +1 @@
1
+ # appsync-precognition
@@ -0,0 +1,34 @@
1
+ //#endregion
2
+ //#region src/types.d.ts
3
+ interface Rule<T = unknown> {
4
+ check: boolean;
5
+ message: string;
6
+ value: T;
7
+ }
8
+ type ShortRule<T extends string> = T | `${T}:${string}`;
9
+ type ArrayKeys<T extends unknown[]> = T extends [unknown, ...unknown[]] ? T extends Record<infer Index, unknown> ? Index extends `${number}` ? Index : never : never : `${number}`;
10
+ type ObjectKeys<T extends object> = T extends unknown[] ? ArrayKeys<T> : keyof T & string;
11
+ interface HasConstructor {
12
+ new (...args: unknown[]): unknown;
13
+ }
14
+ type NestedKeyOf<T> = T extends Record<infer Key, unknown> ? T extends HasConstructor ? never : T extends CallableFunction ? never : Key extends string | number ? (ObjectKeys<T> | (T[Key] extends object ? `${ObjectKeys<Pick<T, Key>>}.${NestedKeyOf<T[Key]>}` : T extends unknown[] ? T extends [unknown, ...unknown[]] ? never : T[number] extends object ? `${number}.${NestedKeyOf<T[number]>}` : never : never)) : never : never;
15
+ declare namespace rules_d_exports {
16
+ export { names, parse };
17
+ }
18
+ declare const names: {
19
+ readonly min: "min";
20
+ readonly max: "max";
21
+ readonly between: "between";
22
+ readonly email: "email";
23
+ readonly url: "url";
24
+ readonly uuid: "uuid";
25
+ readonly regex: "regex";
26
+ readonly in: "in";
27
+ };
28
+ declare function parse<T>(value: T, rule: ShortRule<keyof typeof names>): Rule<T>;
29
+ //#endregion
30
+ //#region src/index.d.ts
31
+ declare function validate<T extends object>(obj: T, checks: Partial<Record<NestedKeyOf<T>, (ShortRule<keyof typeof rules_d_exports["names"]> | Rule)[]>>): T;
32
+ //#endregion
33
+ export { validate };
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi9zcmMvdHlwZXMudHMiLCIuLi9zcmMvcnVsZXMudHMiLCIuLi9zcmMvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOltdLCJtYXBwaW5ncyI6Ijs7VUFFaUI7OztTQUdSOztLQUdHLDhCQUE4QixPQUFPO0tBRTVDLGlDQUNELG9DQUNFLFVBQVU7S0FPWCwrQkFDRCxzQkFDRSxVQUFVLFdBQ0o7VUFFRixjQUFBOzs7S0FJRSxpQkFBaUIsVUFBVSw2QkFDbkMsVUFBVSx5QkFFUixVQUFVLDBEQUdMLFdBQVcsTUFBTSxFQUFFLHlCQUNiLFdBQVcsS0FBSyxHQUFHLFNBQVMsWUFBWSxFQUFFLFVBQzdDLHNCQUNFLDRDQUVFLHdDQUNlLFlBQVk7Ozs7Y0NwQ2hDOzs7Ozs7Ozs7O2lCQVdHLGdCQUFnQixTQUFTLHVCQUF1QixTQUFTLEtBQUs7OztpQkNWOUQsZ0NBQ1QsV0FDRyxRQUFRLE9BQU8sWUFBWSxLQUFLLHVCQUF1Qiw0QkFBa0IsWUFDaEYifQ==
package/dist/index.js ADDED
@@ -0,0 +1,184 @@
1
+ import { util } from "@aws-appsync/utils";
2
+
3
+ //#region src/utils.ts
4
+ function isArray(value) {
5
+ if (typeof value === "object" && !!value && Object.hasOwn(value, "length")) return typeof value.length === "number";
6
+ return false;
7
+ }
8
+ function getNestedValue(obj, path) {
9
+ return path.split(".").reduce((current, key) => util.matches("^d+$", key) ? current[Number(key)] : current[key], obj);
10
+ }
11
+ function setNestedValue(obj, path, value) {
12
+ const keys = path.split(".");
13
+ if (keys.length === 1) {
14
+ obj[keys[0]] = value;
15
+ return;
16
+ }
17
+ const lastKey = keys.pop();
18
+ const parentObject = getNestedValue(obj, keys.join("."));
19
+ if (typeof parentObject === "object" && !!parentObject) parentObject[lastKey] = value;
20
+ }
21
+
22
+ //#endregion
23
+ //#region src/rules.ts
24
+ function parse(value, rule) {
25
+ const [ruleName, params] = rule.includes(":") ? rule.split(":", 2) : [rule, ""];
26
+ switch (ruleName) {
27
+ case "min": return minRule(value, ...params.split(","));
28
+ case "max": return maxRule(value, ...params.split(", "));
29
+ case "between": return betweenRule(value, ...params.split(", "));
30
+ case "email": return emailRule(value);
31
+ case "url": return urlRule(value);
32
+ case "uuid": return uuidRule(value);
33
+ case "regex": return regexRule(value, params);
34
+ case "in": return inRule(value, ...params.split(", "));
35
+ default: return {
36
+ check: false,
37
+ message: `Unknown rule ${ruleName}`,
38
+ value
39
+ };
40
+ }
41
+ }
42
+ function minRule(value, ...params) {
43
+ const minValue = Number(params[0] ?? "0");
44
+ const result = {
45
+ check: false,
46
+ message: `Value must be greater than or equal to ${minValue}`,
47
+ value
48
+ };
49
+ if (typeof value === "number") result.check = value >= minValue;
50
+ if (typeof result.value === "string") {
51
+ result.value = result.value.trim();
52
+ result.check = result.value.length >= minValue;
53
+ }
54
+ if (isArray(value)) {
55
+ result.check = value.length >= minValue;
56
+ result.message = `Array must contain at least ${minValue} elements`;
57
+ }
58
+ return result;
59
+ }
60
+ function maxRule(value, ...params) {
61
+ const maxValue = Number(params[0] ?? "0");
62
+ const result = {
63
+ check: false,
64
+ message: `Value must be less than or equal to ${maxValue}`,
65
+ value
66
+ };
67
+ if (typeof value === "number") result.check = value <= maxValue;
68
+ if (typeof result.value === "string") {
69
+ result.value = result.value.trim();
70
+ result.check = result.value.length <= maxValue;
71
+ result.message = `String must contain at most ${maxValue} characters`;
72
+ }
73
+ if (isArray(value)) {
74
+ result.check = value.length <= maxValue;
75
+ result.message = `Array must contain at most ${maxValue} elements`;
76
+ }
77
+ return result;
78
+ }
79
+ function betweenRule(value, ...params) {
80
+ const minValue = Number(params[0] ?? "0");
81
+ const maxValue = Number(params[1] ?? "0");
82
+ const result = {
83
+ check: false,
84
+ message: `Value must be between ${minValue} and ${maxValue}`,
85
+ value
86
+ };
87
+ if (typeof value === "number") result.check = value >= minValue && value <= maxValue;
88
+ if (typeof result.value === "string") {
89
+ result.value = result.value.trim();
90
+ result.check = result.value.length >= minValue && result.value.length <= maxValue;
91
+ result.message = `String must contain between ${minValue} and ${maxValue} characters`;
92
+ }
93
+ if (isArray(value)) {
94
+ result.check = value.length >= minValue && value.length <= maxValue;
95
+ result.message = `Array must contain between ${minValue} and ${maxValue} elements`;
96
+ }
97
+ return result;
98
+ }
99
+ function emailRule(value) {
100
+ const result = {
101
+ check: false,
102
+ message: "Value must be a valid email address",
103
+ value
104
+ };
105
+ if (typeof value === "string") {
106
+ result.value = value.trim();
107
+ result.check = util.matches("^[^s@]+@[^s@]+.[^s@]+$", result.value);
108
+ }
109
+ return result;
110
+ }
111
+ function urlRule(value) {
112
+ const result = {
113
+ check: false,
114
+ message: "Value must be a valid URL",
115
+ value
116
+ };
117
+ if (typeof value === "string") {
118
+ result.value = value.trim();
119
+ result.check = util.matches("^(http|https):\\/\\/[\\w\\-_]+(\\.[\\w\\-_]+)+([\\w\\-\\.,@?^=%&:/~\\+#]*[\\w\\-\\@?^=%&/~\\+#])?$", result.value);
120
+ }
121
+ return result;
122
+ }
123
+ function uuidRule(value) {
124
+ const result = {
125
+ check: false,
126
+ message: "Value must be a valid UUID",
127
+ value
128
+ };
129
+ if (typeof result.value === "string") result.check = util.matches("^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$", value);
130
+ return result;
131
+ }
132
+ function regexRule(value, ...params) {
133
+ const regex = params[0] ?? "";
134
+ const result = {
135
+ check: false,
136
+ message: "Value must match the specified regular expression",
137
+ value
138
+ };
139
+ if (typeof result.value === "string") {
140
+ result.value = result.value.trim();
141
+ result.check = util.matches(regex, result.value);
142
+ }
143
+ return result;
144
+ }
145
+ function inRule(value, ...params) {
146
+ const result = {
147
+ check: false,
148
+ message: "Value must be one of the specified values",
149
+ value
150
+ };
151
+ if (typeof result.value === "string") {
152
+ result.value = result.value.trim();
153
+ result.check = params.includes(result.value);
154
+ }
155
+ if (typeof value === "number") result.check = params.map(Number).includes(value);
156
+ return result;
157
+ }
158
+
159
+ //#endregion
160
+ //#region src/index.ts
161
+ function validate(obj, checks) {
162
+ let hasErrors = false;
163
+ const errorMessages = [];
164
+ Object.keys(checks).forEach((path) => {
165
+ const value = getNestedValue(obj, path);
166
+ if (typeof value === "string") setNestedValue(obj, path, value.trim());
167
+ checks[path]?.forEach((rule) => {
168
+ const result = typeof rule === "string" ? parse(value, rule) : { ...rule };
169
+ if (result.check) return;
170
+ hasErrors = true;
171
+ errorMessages.push(result.message);
172
+ util.appendError(result.message, "ValidationError", null, {
173
+ path,
174
+ value
175
+ });
176
+ });
177
+ });
178
+ if (hasErrors) util.error(errorMessages[0], "ValidationError");
179
+ return obj;
180
+ }
181
+
182
+ //#endregion
183
+ export { validate };
184
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","names":["result: Rule<T>","errorMessages: string[]","rules.parse"],"sources":["../src/utils.ts","../src/rules.ts","../src/index.ts"],"sourcesContent":["import type { NestedKeyOf } from './types'\nimport { util } from '@aws-appsync/utils'\n\nexport function isString(value: unknown): value is string {\n  return typeof value === 'string'\n}\n\nexport function isArray(value: unknown): value is unknown[] {\n  if (typeof value === 'object' && !!value && Object.hasOwn(value, 'length')) {\n    return typeof (value as unknown[]).length === 'number'\n  }\n  return false\n}\n\nexport function getNestedValue<T extends object>(obj: T, path: NestedKeyOf<T>): any {\n  return path.split('.').reduce<unknown>((current, key) => util.matches('^\\d+$', key)\n    ? (current as unknown[])[Number(key)]\n    : (current as Record<string, unknown>)[key], obj)\n}\n\nexport function setNestedValue<T extends object>(obj: T, path: NestedKeyOf<T>, value: unknown): void {\n  const keys = path.split('.')\n  if (keys.length === 1) {\n    obj[keys[0] as keyof typeof obj] = value as any\n    return\n  }\n  const lastKey = keys.pop() as string\n  const parentObject = getNestedValue(obj, keys.join('.') as NestedKeyOf<T>)\n  if (typeof parentObject === 'object' && !!parentObject) {\n    parentObject[lastKey] = value\n  }\n}\n","import type { Rule, ShortRule } from './types'\nimport { util } from '@aws-appsync/utils'\nimport { isArray } from './utils'\n\nexport const names = {\n  min: 'min',\n  max: 'max',\n  between: 'between',\n  email: 'email',\n  url: 'url',\n  uuid: 'uuid',\n  regex: 'regex',\n  in: 'in',\n} as const\n\nexport function parse<T>(value: T, rule: ShortRule<keyof typeof names>): Rule<T> {\n  const [ruleName, params] = rule.includes(':') ? rule.split(':', 2) : [rule, '']\n\n  switch (ruleName as keyof typeof names) {\n    case 'min':\n      return minRule(value, ...params.split(','))\n    case 'max':\n      return maxRule(value, ...params.split(', '))\n    case 'between':\n      return betweenRule(value, ...params.split(', '))\n    case 'email':\n      return emailRule(value)\n    case 'url':\n      return urlRule(value)\n    case 'uuid':\n      return uuidRule(value)\n    case 'regex':\n      return regexRule(value, params)\n    case 'in':\n      return inRule(value, ...params.split(', '))\n    default:\n      return { check: false, message: `Unknown rule ${ruleName}`, value }\n  }\n}\n\nfunction minRule<T>(value: T, ...params: string[]): Rule<T> {\n  const minValue = Number(params[0] ?? '0')\n  const result: Rule<T> = {\n    check: false,\n    message: `Value must be greater than or equal to ${minValue}`,\n    value,\n  }\n  if (typeof value === 'number') {\n    result.check = value >= minValue\n  }\n  if (typeof result.value === 'string') {\n    result.value = result.value.trim() as T\n    result.check = (result.value as string).length >= minValue\n  }\n  if (isArray(value)) {\n    result.check = value.length >= minValue\n    result.message = `Array must contain at least ${minValue} elements`\n  }\n  return result\n}\n\nfunction maxRule<T>(value: T, ...params: string[]): Rule<T> {\n  const maxValue = Number(params[0] ?? '0')\n  const result: Rule<T> = {\n    check: false,\n    message: `Value must be less than or equal to ${maxValue}`,\n    value,\n  }\n\n  if (typeof value === 'number') {\n    result.check = value <= maxValue\n  }\n  if (typeof result.value === 'string') {\n    result.value = result.value.trim() as T\n    result.check = (result.value as string).length <= maxValue\n    result.message = `String must contain at most ${maxValue} characters`\n  }\n  if (isArray(value)) {\n    result.check = value.length <= maxValue\n    result.message = `Array must contain at most ${maxValue} elements`\n  }\n  return result\n}\n\nfunction betweenRule<T>(value: T, ...params: string[]): Rule<T> {\n  const minValue = Number(params[0] ?? '0')\n  const maxValue = Number(params[1] ?? '0')\n  const result: Rule<T> = {\n    check: false,\n    message: `Value must be between ${minValue} and ${maxValue}`,\n    value,\n  }\n  if (typeof value === 'number') {\n    result.check = value >= minValue && value <= maxValue\n  }\n  if (typeof result.value === 'string') {\n    result.value = result.value.trim() as T\n    result.check = (result.value as string).length >= minValue && (result.value as string).length <= maxValue\n    result.message = `String must contain between ${minValue} and ${maxValue} characters`\n  }\n  if (isArray(value)) {\n    result.check = value.length >= minValue && value.length <= maxValue\n    result.message = `Array must contain between ${minValue} and ${maxValue} elements`\n  }\n  return result\n}\n\nfunction emailRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: 'Value must be a valid email address',\n    value,\n  }\n\n  if (typeof value === 'string') {\n    result.value = value.trim() as T\n    result.check = util.matches('^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$', result.value as string)\n  }\n  return result\n}\n\nfunction urlRule<T>(value: T): Rule<T> {\n  const result = {\n    check: false,\n    message: 'Value must be a valid URL',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.value = value.trim() as T\n    result.check = util.matches(\n      '^(http|https):\\\\/\\\\/[\\\\w\\\\-_]+(\\\\.[\\\\w\\\\-_]+)+([\\\\w\\\\-\\\\.,@?^=%&:/~\\\\+#]*[\\\\w\\\\-\\\\@?^=%&/~\\\\+#])?$',\n      result.value as string,\n    )\n  }\n  return result\n}\n\nfunction uuidRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: 'Value must be a valid UUID',\n    value,\n  }\n  if (typeof result.value === 'string') {\n    result.check = util.matches(\n      '^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$',\n      value as string,\n    )\n  }\n  return result\n}\n\nfunction regexRule<T>(value: T, ...params: string[]): Rule<T> {\n  const regex = params[0] ?? ''\n  const result: Rule<T> = {\n    check: false,\n    message: 'Value must match the specified regular expression',\n    value,\n  }\n  if (typeof result.value === 'string') {\n    result.value = result.value.trim() as T\n    result.check = util.matches(regex, result.value as string)\n  }\n  return result\n}\n\nfunction inRule<T>(value: T, ...params: string[]): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: 'Value must be one of the specified values',\n    value,\n  }\n  if (typeof result.value === 'string') {\n    result.value = result.value.trim() as T\n    result.check = params.includes(result.value as string)\n  }\n  if (typeof value === 'number') {\n    result.check = params.map(Number).includes(value)\n  }\n  return result\n}\n","import type { NestedKeyOf, Rule, ShortRule } from './types'\nimport { util } from '@aws-appsync/utils'\nimport * as rules from './rules'\nimport { getNestedValue, setNestedValue } from './utils'\n\nexport function validate<T extends object>(\n  obj: T,\n  checks: Partial<Record<NestedKeyOf<T>, (ShortRule<keyof typeof rules['names']> | Rule)[]>>,\n): T {\n  let hasErrors = false\n  const errorMessages: string[] = []\n\n  Object.keys(checks).forEach((path) => {\n    const value = getNestedValue(obj, path as NestedKeyOf<T>)\n    if (typeof value === 'string') {\n      setNestedValue(obj, path as NestedKeyOf<T>, value.trim())\n    }\n\n    checks[path as NestedKeyOf<T>]?.forEach((rule) => {\n      const result = (typeof rule === 'string') ? rules.parse(value, rule) : { ...rule }\n      if (result.check)\n        return\n      hasErrors = true\n      errorMessages.push(result.message)\n      util.appendError(result.message, 'ValidationError', null, { path, value })\n    })\n  })\n\n  if (hasErrors) {\n    util.error(errorMessages[0], 'ValidationError')\n  }\n\n  return obj\n}\n"],"mappings":"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"}
package/package.json ADDED
@@ -0,0 +1,51 @@
1
+ {
2
+ "name": "@sot1986/appsync-precognition",
3
+ "type": "module",
4
+ "version": "0.0.1",
5
+ "description": "JavaScript resolver validation utilities for AWS AppSync",
6
+ "author": "sot1986",
7
+ "license": "MIT",
8
+ "keywords": [
9
+ "appsync",
10
+ "validation",
11
+ "resolver",
12
+ "aws"
13
+ ],
14
+ "exports": {
15
+ ".": {
16
+ "types": "./dist/index.d.ts",
17
+ "import": "./dist/index.js"
18
+ }
19
+ },
20
+ "main": "./dist/index.js",
21
+ "types": "./dist/index.d.ts",
22
+ "publishConfig": {
23
+ "access": "public"
24
+ },
25
+ "files": [
26
+ "dist/**/*"
27
+ ],
28
+ "scripts": {
29
+ "build": "tsdown --format esm --config tsdown.config.ts",
30
+ "bundle": "cd playground && ./bundle-resolvers.sh && cd .. && eslint --ext playground/resolvers/**/*.{ts,js} . --fix",
31
+ "prepublishOnly": "pnpm run build",
32
+ "test": "vitest",
33
+ "lint:resolvers": "eslint --ext playground/resolvers/**/*.{ts,js} . --fix"
34
+ },
35
+ "peerDependencies": {
36
+ "@aws-appsync/utils": "^2.0.3"
37
+ },
38
+ "devDependencies": {
39
+ "@antfu/eslint-config": "^6.7.3",
40
+ "@aws-appsync/eslint-plugin": "^2.0.2",
41
+ "@types/node": "^25.0.3",
42
+ "@typescript-eslint/parser": "^8.50.1",
43
+ "esbuild": "^0.27.2",
44
+ "eslint": "^9.39.2",
45
+ "tsdown": "^0.18.3",
46
+ "tsx": "^4.21.0",
47
+ "typescript": "^5.0.0",
48
+ "typescript-eslint": "^8.50.1",
49
+ "vitest": "^4.0.16"
50
+ }
51
+ }