@sot1986/appsync-precognition 0.0.4 → 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 (2) hide show
  1. package/dist/index.js +3 -3
  2. package/package.json +8 -2
package/dist/index.js CHANGED
@@ -125,7 +125,7 @@ function emailRule(value) {
125
125
  message: ":attribute must be a valid email address",
126
126
  value
127
127
  };
128
- if (typeof value === "string") result.check = util.matches("^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$", result.value);
128
+ if (typeof value === "string") result.check = util.matches("^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\.[a-zA-Z]{2,}$", value);
129
129
  return result;
130
130
  }
131
131
  function urlRule(value) {
@@ -372,11 +372,11 @@ function precognitiveValidation(ctx, checks, options) {
372
372
  }
373
373
  function formatAttributeName(path) {
374
374
  return path.split(".").reduce((acc, part) => {
375
- if (util.matches("^d+$", part)) return acc;
375
+ if (util.matches("^\\d+$", part)) return acc;
376
376
  return acc ? `${acc} ${part.toLowerCase()}` : part.toLowerCase();
377
377
  }, "");
378
378
  }
379
379
 
380
380
  //#endregion
381
381
  export { formatAttributeName, precognitiveValidation, validate };
382
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","names":["parsed: string | null","result: Rule<T>","error: { msg?: string, errorType?: string, data?: any, errorInfo?: any }","rules.parse"],"sources":["../src/utils.ts","../src/rules.ts","../src/index.ts"],"sourcesContent":["import type { Context } from '@aws-appsync/utils'\nimport 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\nexport function getHeader(name: string, ctx: Context): string | null {\n  return Object.entries(ctx.request.headers)\n    .reduce((prev, [key, value]) => typeof prev === 'string'\n      ? prev\n      : (key.toLowerCase() === name.toLowerCase() && typeof value === 'string'\n          ? value\n          : null), null as string | null)\n}\n\nexport function isPrecognitiveRequest(ctx: Context): boolean {\n  return getHeader('precognition', ctx) === 'true'\n}\n\nexport function precognitiveKeys(ctx: Context): string[] | null {\n  const keys = getHeader('Precognition-Validate-Only', ctx)\n  return keys ? keys.split(',').map(key => key.trim()) : null\n}\n\nexport function cleanString(value: string, options?: {\n  trim?: boolean\n  allowEmptyString?: boolean\n}): string | null {\n  if (options?.trim === false)\n    return value\n\n  let parsed: string | null = value.trim()\n\n  if (options?.allowEmptyString)\n    return parsed\n\n  if (parsed === '')\n    parsed = null\n\n  return parsed\n}\n","import type { FullRule, Rule } from './types'\nimport { util } from '@aws-appsync/utils'\nimport { isArray } from './utils'\n\nexport function parse<T>(value: T, rule: FullRule): Rule<T> {\n  const [name, ...params] = typeof rule === 'string'\n    ? [rule, undefined]\n    : [rule[0], ...rule.slice(1)]\n\n  switch (name) {\n    case 'required':\n      return requiredRule(value)\n    case 'nullable':\n      return nullableRule(value)\n    case 'sometimes':\n      return sometimesRule(value)\n    case 'min':\n      return minRule(value, (params[0]! as number))\n    case 'max':\n      return maxRule(value, (params[0] as number))\n    case 'between':\n      return betweenRule(value, (params[0] as number), params[1] as number)\n    case 'email':\n      return emailRule(value)\n    case 'url':\n      return urlRule(value)\n    case 'uuid':\n      return uuidRule(value)\n    case 'ulid':\n      return ulidRule(value)\n    case 'regex':\n      return regexRule(value, params[0] as string)\n    case 'in':\n      return inRule(value, ...params)\n    case 'notIn':\n      return notInRule(value, ...params)\n    case 'array':\n      return arrayRule(value)\n    case 'object':\n      return objectRule(value)\n    case 'boolean':\n      return booleanRule(value)\n    case 'number':\n      return numberRule(value)\n    case 'string':\n      return stringRule(value)\n    case 'date':\n      return dateRule(value)\n    case 'before':\n      return beforeRule(value, params[0] as string)\n    case 'after':\n      return afterRule(value, params[0] as string)\n    case 'beforeOrEqual':\n      return beforeOrEqualRule(value, params[0] as string)\n    case 'afterOrEqual':\n      return afterOrEqualRule(value, params[0] as string)\n    default:\n      return { check: false, message: `Unknown rule ${name}`, value }\n  }\n}\n\nfunction minRule<T>(value: T, minValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.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, maxValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.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, minValue: number, maxValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.length >= minValue && value.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: ':attribute must be a valid email address',\n    value,\n  }\n\n  if (typeof value === 'string') {\n    result.check = util.matches('^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\\\.[a-zA-Z]{2,}$', 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: ':attribute must be a valid URL',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = util.matches(\n      '^https?:\\\\/\\\\/(www\\\\.)?[-a-zA-Z0-9@:%._\\\\+~#=]{1,256}\\\\.[a-zA-Z0-9()]{1,6}\\\\b([-a-zA-Z0-9()@:%_\\\\+.~#?&//=]*)$|^https?:\\\\/\\\\/(localhost|\\\\d{1,3}\\\\.\\\\d{1,3}\\\\.\\\\d{1,3}\\\\.\\\\d{1,3})(:\\\\d+)?(\\\\/.*)?$',\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: ':attribute must be a valid UUID',\n    value,\n  }\n  if (typeof 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 ulidRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a valid ULID',\n    value,\n  }\n  if (typeof value === 'string') {\n    // ULID format: 26 characters, base32 encoded (0-9, A-Z excluding I, L, O, U)\n    result.check = util.matches(\n      '^[0123456789ABCDEFGHJKMNPQRSTVWXYZ]{26}$',\n      value as string,\n    )\n  }\n  return result\n}\n\nfunction regexRule<T>(value: T, pattern: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must match the specified regular expression',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.value = value.trim() as T\n    result.check = util.matches(pattern, result.value as string)\n  }\n  return result\n}\n\nfunction inRule<T>(value: T, ...params: unknown[]): Rule<T> {\n  return {\n    check: params.includes(value),\n    message: ':attribute must be one of the specified values',\n    value,\n  }\n}\n\nfunction notInRule<T>(value: T, ...params: unknown[]): Rule<T> {\n  return {\n    check: !params.includes(value),\n    message: ':attribute must not be one of the specified values',\n    value,\n  }\n}\n\nexport function requiredRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: ':attribute is required',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = value.length > 0\n  }\n  if (isArray(value)) {\n    result.check = value.length > 0\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  if (typeof value === 'boolean') {\n    result.check = true\n  }\n  if (typeof value === 'object' && !result.value) {\n    result.message = ':attribute is not nullable'\n    result.check = false\n  }\n  if (typeof value === 'undefined') {\n    result.check = false\n  }\n  return result\n}\n\nfunction nullableRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: '',\n    value,\n  }\n  return result\n}\n\nfunction sometimesRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: '',\n    value,\n  }\n  if (typeof value === 'undefined') {\n    return result\n  }\n  if (typeof value === 'object' && !result.value) {\n    result.message = ':attribute is not nullable'\n    result.check = false\n  }\n  return requiredRule(value)\n}\n\nfunction arrayRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be an array',\n    value,\n  }\n  if (isArray(value)) {\n    result.check = true\n  }\n  return result\n}\n\nfunction objectRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be an object',\n    value,\n  }\n  if (typeof value === 'object' && !isArray(result.value)) {\n    result.check = true\n  }\n  return result\n}\n\nfunction booleanRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a boolean',\n    value,\n  }\n  if (typeof value === 'boolean') {\n    result.check = true\n  }\n  return result\n}\n\nfunction numberRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a number',\n    value,\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  return result\n}\n\nfunction stringRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a string',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = true\n  }\n  return result\n}\n\nfunction dateRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a date',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = util.matches(\n      '^\\\\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12]\\\\d|3[01])T([01]\\\\d|2[0-3]):[0-5]\\\\d:[0-5]\\\\d(\\\\.\\\\d{1,6})?Z$',\n      result.value as string,\n    )\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  return result\n}\n\nfunction beforeRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be before ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date < startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value < startValue\n  }\n  return result\n}\n\nfunction afterRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be after ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date > startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value > startValue\n  }\n  return result\n}\n\nfunction beforeOrEqualRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be before or equal to ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date <= startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value <= startValue\n  }\n  return result\n}\n\nfunction afterOrEqualRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be after or equal to ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date >= startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value >= startValue\n  }\n  return result\n}\n","import type { Context } from '@aws-appsync/utils'\nimport type { FullRule, NestedKeyOf, Rule } from './types'\nimport { runtime, util } from '@aws-appsync/utils'\nimport * as rules from './rules'\nimport { cleanString, getNestedValue, isArray, isPrecognitiveRequest, precognitiveKeys, setNestedValue } from './utils'\n\nexport function validate<T extends object>(\n  obj: T,\n  checks: Partial<Record<NestedKeyOf<T>, (FullRule | Rule)[]>>,\n  options?: {\n    trim?: boolean\n    allowEmptyString?: boolean\n  },\n): T {\n  let error: { msg?: string, errorType?: string, data?: any, errorInfo?: any } = {}\n\n  Object.keys(checks).forEach((path) => {\n    let value = getNestedValue(obj, path as NestedKeyOf<T>)\n    if (typeof value === 'string') {\n      value = cleanString(value, options)\n      setNestedValue(obj, path as NestedKeyOf<T>, value)\n    }\n\n    let skip = false\n    checks[path as NestedKeyOf<T>]?.forEach((rule) => {\n      if (skip) {\n        return\n      }\n\n      if (rule === 'nullable' && value === null)\n        skip = true\n\n      if (rule === 'sometimes' && typeof value === 'undefined')\n        skip = true\n\n      const result = (typeof rule === 'string' || isArray(rule))\n        ? rules.parse(value, rule)\n        : { ...rule }\n\n      if (result.check)\n        return\n\n      if (error.msg)\n        util.appendError(error.msg, error.errorType, error.data, error.errorInfo)\n\n      result.message = result.message.replace(':attribute', formatAttributeName(path))\n      error = {\n        msg: result.message,\n        errorType: 'ValidationError',\n        data: null,\n        errorInfo: { path, value },\n      }\n\n      skip = true\n    })\n  })\n\n  if (!error.msg) {\n    return obj\n  }\n\n  util.error(error.msg, error.errorType, error.data, error.errorInfo)\n}\n\nexport function precognitiveValidation<T extends object>(\n  ctx: Context<T>,\n  checks: Partial<Record<NestedKeyOf<T>, (FullRule | Rule)[]>>,\n  options?: {\n    trim?: boolean\n    allowEmptyString?: boolean\n    skipTo?: 'END' | 'NEXT'\n  },\n): T {\n  if (!isPrecognitiveRequest(ctx)) {\n    return validate(ctx.args, checks, options)\n  }\n  const validationKeys = precognitiveKeys(ctx)\n  util.http.addResponseHeader('Precognition', 'true')\n\n  if (!validationKeys) {\n    validate(ctx.args, checks, options)\n    util.http.addResponseHeader('Precognition-Success', 'true')\n    runtime.earlyReturn(null)\n  }\n\n  util.http.addResponseHeader('Precognition-Validate-Only', validationKeys.join(','))\n  const precognitionChecks = {} as Partial<typeof checks>\n  validationKeys.forEach((key) => {\n    precognitionChecks[key as NestedKeyOf<T>] = checks[key as NestedKeyOf<T>]\n  })\n\n  validate(ctx.args, precognitionChecks, options)\n  util.http.addResponseHeader('Precognition-Success', 'true')\n  runtime.earlyReturn(null, { skipTo: options?.skipTo ?? 'END' })\n}\n\nexport function formatAttributeName(path: string): string {\n  return path.split('.').reduce((acc, part) => {\n    if (util.matches('^\\d+$', part)) {\n      return acc\n    }\n    return acc ? `${acc} ${part.toLowerCase()}` : part.toLowerCase()\n  }, '')\n}\n"],"mappings":"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"}
382
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"index.js","names":["parsed: string | null","result: Rule<T>","error: { msg?: string, errorType?: string, data?: any, errorInfo?: any }","rules.parse"],"sources":["../src/utils.ts","../src/rules.ts","../src/index.ts"],"sourcesContent":["import type { Context } from '@aws-appsync/utils'\nimport 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\nexport function getHeader(name: string, ctx: Context): string | null {\n  return Object.entries(ctx.request.headers)\n    .reduce((prev, [key, value]) => typeof prev === 'string'\n      ? prev\n      : (key.toLowerCase() === name.toLowerCase() && typeof value === 'string'\n          ? value\n          : null), null as string | null)\n}\n\nexport function isPrecognitiveRequest(ctx: Context): boolean {\n  return getHeader('precognition', ctx) === 'true'\n}\n\nexport function precognitiveKeys(ctx: Context): string[] | null {\n  const keys = getHeader('Precognition-Validate-Only', ctx)\n  return keys ? keys.split(',').map(key => key.trim()) : null\n}\n\nexport function cleanString(value: string, options?: {\n  trim?: boolean\n  allowEmptyString?: boolean\n}): string | null {\n  if (options?.trim === false)\n    return value\n\n  let parsed: string | null = value.trim()\n\n  if (options?.allowEmptyString)\n    return parsed\n\n  if (parsed === '')\n    parsed = null\n\n  return parsed\n}\n","import type { FullRule, Rule } from './types'\nimport { util } from '@aws-appsync/utils'\nimport { isArray } from './utils'\n\nexport function parse<T>(value: T, rule: FullRule): Rule<T> {\n  const [name, ...params] = typeof rule === 'string'\n    ? [rule, undefined]\n    : [rule[0], ...rule.slice(1)]\n\n  switch (name) {\n    case 'required':\n      return requiredRule(value)\n    case 'nullable':\n      return nullableRule(value)\n    case 'sometimes':\n      return sometimesRule(value)\n    case 'min':\n      return minRule(value, (params[0]! as number))\n    case 'max':\n      return maxRule(value, (params[0] as number))\n    case 'between':\n      return betweenRule(value, (params[0] as number), params[1] as number)\n    case 'email':\n      return emailRule(value)\n    case 'url':\n      return urlRule(value)\n    case 'uuid':\n      return uuidRule(value)\n    case 'ulid':\n      return ulidRule(value)\n    case 'regex':\n      return regexRule(value, params[0] as string)\n    case 'in':\n      return inRule(value, ...params)\n    case 'notIn':\n      return notInRule(value, ...params)\n    case 'array':\n      return arrayRule(value)\n    case 'object':\n      return objectRule(value)\n    case 'boolean':\n      return booleanRule(value)\n    case 'number':\n      return numberRule(value)\n    case 'string':\n      return stringRule(value)\n    case 'date':\n      return dateRule(value)\n    case 'before':\n      return beforeRule(value, params[0] as string)\n    case 'after':\n      return afterRule(value, params[0] as string)\n    case 'beforeOrEqual':\n      return beforeOrEqualRule(value, params[0] as string)\n    case 'afterOrEqual':\n      return afterOrEqualRule(value, params[0] as string)\n    default:\n      return { check: false, message: `Unknown rule ${name}`, value }\n  }\n}\n\nfunction minRule<T>(value: T, minValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.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, maxValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.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, minValue: number, maxValue: number): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute 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 value === 'string') {\n    result.check = value.length >= minValue && value.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: ':attribute must be a valid email address',\n    value,\n  }\n\n  if (typeof value === 'string') {\n    result.check = util.matches('^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\\\\.[a-zA-Z]{2,}$', value)\n  }\n  return result\n}\n\nfunction urlRule<T>(value: T): Rule<T> {\n  const result = {\n    check: false,\n    message: ':attribute must be a valid URL',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = util.matches(\n      '^https?:\\\\/\\\\/(www\\\\.)?[-a-zA-Z0-9@:%._\\\\+~#=]{1,256}\\\\.[a-zA-Z0-9()]{1,6}\\\\b([-a-zA-Z0-9()@:%_\\\\+.~#?&//=]*)$|^https?:\\\\/\\\\/(localhost|\\\\d{1,3}\\\\.\\\\d{1,3}\\\\.\\\\d{1,3}\\\\.\\\\d{1,3})(:\\\\d+)?(\\\\/.*)?$',\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: ':attribute must be a valid UUID',\n    value,\n  }\n  if (typeof 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 ulidRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a valid ULID',\n    value,\n  }\n  if (typeof value === 'string') {\n    // ULID format: 26 characters, base32 encoded (0-9, A-Z excluding I, L, O, U)\n    result.check = util.matches(\n      '^[0123456789ABCDEFGHJKMNPQRSTVWXYZ]{26}$',\n      value as string,\n    )\n  }\n  return result\n}\n\nfunction regexRule<T>(value: T, pattern: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must match the specified regular expression',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.value = value.trim() as T\n    result.check = util.matches(pattern, result.value as string)\n  }\n  return result\n}\n\nfunction inRule<T>(value: T, ...params: unknown[]): Rule<T> {\n  return {\n    check: params.includes(value),\n    message: ':attribute must be one of the specified values',\n    value,\n  }\n}\n\nfunction notInRule<T>(value: T, ...params: unknown[]): Rule<T> {\n  return {\n    check: !params.includes(value),\n    message: ':attribute must not be one of the specified values',\n    value,\n  }\n}\n\nexport function requiredRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: ':attribute is required',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = value.length > 0\n  }\n  if (isArray(value)) {\n    result.check = value.length > 0\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  if (typeof value === 'boolean') {\n    result.check = true\n  }\n  if (typeof value === 'object' && !result.value) {\n    result.message = ':attribute is not nullable'\n    result.check = false\n  }\n  if (typeof value === 'undefined') {\n    result.check = false\n  }\n  return result\n}\n\nfunction nullableRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: '',\n    value,\n  }\n  return result\n}\n\nfunction sometimesRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: true,\n    message: '',\n    value,\n  }\n  if (typeof value === 'undefined') {\n    return result\n  }\n  if (typeof value === 'object' && !result.value) {\n    result.message = ':attribute is not nullable'\n    result.check = false\n  }\n  return requiredRule(value)\n}\n\nfunction arrayRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be an array',\n    value,\n  }\n  if (isArray(value)) {\n    result.check = true\n  }\n  return result\n}\n\nfunction objectRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be an object',\n    value,\n  }\n  if (typeof value === 'object' && !isArray(result.value)) {\n    result.check = true\n  }\n  return result\n}\n\nfunction booleanRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a boolean',\n    value,\n  }\n  if (typeof value === 'boolean') {\n    result.check = true\n  }\n  return result\n}\n\nfunction numberRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a number',\n    value,\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  return result\n}\n\nfunction stringRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a string',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = true\n  }\n  return result\n}\n\nfunction dateRule<T>(value: T): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: ':attribute must be a date',\n    value,\n  }\n  if (typeof value === 'string') {\n    result.check = util.matches(\n      '^\\\\d{4}-(0[1-9]|1[0-2])-(0[1-9]|[12]\\\\d|3[01])T([01]\\\\d|2[0-3]):[0-5]\\\\d:[0-5]\\\\d(\\\\.\\\\d{1,6})?Z$',\n      result.value as string,\n    )\n  }\n  if (typeof value === 'number') {\n    result.check = true\n  }\n  return result\n}\n\nfunction beforeRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be before ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date < startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value < startValue\n  }\n  return result\n}\n\nfunction afterRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be after ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date > startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value > startValue\n  }\n  return result\n}\n\nfunction beforeOrEqualRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be before or equal to ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date <= startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value <= startValue\n  }\n  return result\n}\n\nfunction afterOrEqualRule<T>(value: T, start: string): Rule<T> {\n  const result: Rule<T> = {\n    check: false,\n    message: `:attribute must be after or equal to ${start}`,\n    value,\n  }\n  const startValue = util.time.parseISO8601ToEpochMilliSeconds(start)\n\n  if (typeof value === 'string') {\n    const date = util.time.parseISO8601ToEpochMilliSeconds(value)\n    result.check = date >= startValue\n  }\n\n  if (typeof value === 'number') {\n    result.check = value >= startValue\n  }\n  return result\n}\n","import type { Context } from '@aws-appsync/utils'\nimport type { FullRule, NestedKeyOf, Rule } from './types'\nimport { runtime, util } from '@aws-appsync/utils'\nimport * as rules from './rules'\nimport { cleanString, getNestedValue, isArray, isPrecognitiveRequest, precognitiveKeys, setNestedValue } from './utils'\n\nexport function validate<T extends object>(\n  obj: T,\n  checks: Partial<Record<NestedKeyOf<T>, (FullRule | Rule)[]>>,\n  options?: {\n    trim?: boolean\n    allowEmptyString?: boolean\n  },\n): T {\n  let error: { msg?: string, errorType?: string, data?: any, errorInfo?: any } = {}\n\n  Object.keys(checks).forEach((path) => {\n    let value = getNestedValue(obj, path as NestedKeyOf<T>)\n    if (typeof value === 'string') {\n      value = cleanString(value, options)\n      setNestedValue(obj, path as NestedKeyOf<T>, value)\n    }\n\n    let skip = false\n    checks[path as NestedKeyOf<T>]?.forEach((rule) => {\n      if (skip) {\n        return\n      }\n\n      if (rule === 'nullable' && value === null)\n        skip = true\n\n      if (rule === 'sometimes' && typeof value === 'undefined')\n        skip = true\n\n      const result = (typeof rule === 'string' || isArray(rule))\n        ? rules.parse(value, rule)\n        : { ...rule }\n\n      if (result.check)\n        return\n\n      if (error.msg)\n        util.appendError(error.msg, error.errorType, error.data, error.errorInfo)\n\n      result.message = result.message.replace(':attribute', formatAttributeName(path))\n      error = {\n        msg: result.message,\n        errorType: 'ValidationError',\n        data: null,\n        errorInfo: { path, value },\n      }\n\n      skip = true\n    })\n  })\n\n  if (!error.msg) {\n    return obj\n  }\n\n  util.error(error.msg, error.errorType, error.data, error.errorInfo)\n}\n\nexport function precognitiveValidation<T extends object>(\n  ctx: Context<T>,\n  checks: Partial<Record<NestedKeyOf<T>, (FullRule | Rule)[]>>,\n  options?: {\n    trim?: boolean\n    allowEmptyString?: boolean\n    skipTo?: 'END' | 'NEXT'\n  },\n): T {\n  if (!isPrecognitiveRequest(ctx)) {\n    return validate(ctx.args, checks, options)\n  }\n  const validationKeys = precognitiveKeys(ctx)\n  util.http.addResponseHeader('Precognition', 'true')\n\n  if (!validationKeys) {\n    validate(ctx.args, checks, options)\n    util.http.addResponseHeader('Precognition-Success', 'true')\n    runtime.earlyReturn(null)\n  }\n\n  util.http.addResponseHeader('Precognition-Validate-Only', validationKeys.join(','))\n  const precognitionChecks = {} as Partial<typeof checks>\n  validationKeys.forEach((key) => {\n    precognitionChecks[key as NestedKeyOf<T>] = checks[key as NestedKeyOf<T>]\n  })\n\n  validate(ctx.args, precognitionChecks, options)\n  util.http.addResponseHeader('Precognition-Success', 'true')\n  runtime.earlyReturn(null, { skipTo: options?.skipTo ?? 'END' })\n}\n\nexport function formatAttributeName(path: string): string {\n  return path.split('.').reduce((acc, part) => {\n    if (util.matches('^\\\\d+$', part)) {\n      return acc\n    }\n    return acc ? `${acc} ${part.toLowerCase()}` : part.toLowerCase()\n  }, '')\n}\n"],"mappings":"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"}
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@sot1986/appsync-precognition",
3
3
  "type": "module",
4
- "version": "0.0.4",
4
+ "version": "0.1.0",
5
5
  "description": "JavaScript resolver validation utilities for AWS AppSync",
6
6
  "author": "sot1986",
7
7
  "license": "MIT",
@@ -34,7 +34,9 @@
34
34
  "build": "tsdown --format esm --config tsdown.config.ts",
35
35
  "bundle": "cd playground && ./bundle-resolvers.sh && cd .. && eslint --ext playground/resolvers/**/*.{ts,js} . --fix",
36
36
  "test": "vitest",
37
- "lint:resolvers": "eslint --ext playground/resolvers/**/*.{ts,js} . --fix"
37
+ "test:coverage": "vitest --coverage",
38
+ "lint:resolvers": "eslint --ext playground/resolvers/**/*.{ts,js} . --fix",
39
+ "semantic-release": "semantic-release"
38
40
  },
39
41
  "peerDependencies": {
40
42
  "@aws-appsync/utils": "^2.0.3"
@@ -42,10 +44,14 @@
42
44
  "devDependencies": {
43
45
  "@antfu/eslint-config": "^6.7.3",
44
46
  "@aws-appsync/eslint-plugin": "^2.0.2",
47
+ "@semantic-release/changelog": "^6.0.3",
48
+ "@semantic-release/git": "^10.0.1",
45
49
  "@types/node": "^25.0.3",
46
50
  "@typescript-eslint/parser": "^8.50.1",
51
+ "@vitest/coverage-v8": "^4.0.16",
47
52
  "esbuild": "^0.27.2",
48
53
  "eslint": "^9.39.2",
54
+ "semantic-release": "^25.0.2",
49
55
  "tsdown": "^0.18.3",
50
56
  "tsx": "^4.21.0",
51
57
  "typescript": "^5.0.0",