nextlove 1.0.10 → 1.0.11
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.
|
@@ -57,13 +57,13 @@ var getZodObjectSchemaFromZodEffectSchema = (isZodEffect, schema) => {
|
|
|
57
57
|
}
|
|
58
58
|
return currentSchema;
|
|
59
59
|
};
|
|
60
|
-
var
|
|
61
|
-
const
|
|
62
|
-
const
|
|
63
|
-
const
|
|
64
|
-
return
|
|
60
|
+
var getZodDefFromZodSchemaHelpers = (schema) => {
|
|
61
|
+
const unsafe_def_maybe_optional_maybe_default_maybe_zod_effect = schema._def;
|
|
62
|
+
const unsafe_def_maybe_default_maybe_zod_effect = unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodOptional ? unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.innerType._def : unsafe_def_maybe_optional_maybe_default_maybe_zod_effect;
|
|
63
|
+
const unsafe_def_maybe_zod_effect = unsafe_def_maybe_default_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodDefault ? unsafe_def_maybe_default_maybe_zod_effect.innerType._def : unsafe_def_maybe_default_maybe_zod_effect;
|
|
64
|
+
return unsafe_def_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodEffects ? unsafe_def_maybe_zod_effect.schema._def : unsafe_def_maybe_zod_effect;
|
|
65
65
|
};
|
|
66
|
-
var
|
|
66
|
+
var parseQueryParams = (schema, input) => {
|
|
67
67
|
const parsed_input = Object.assign({}, input);
|
|
68
68
|
const isZodEffect = schema._def.typeName === import_zod.ZodFirstPartyTypeKind.ZodEffects;
|
|
69
69
|
const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema);
|
|
@@ -71,7 +71,9 @@ var parseCommaSeparateArrays = (schema, input) => {
|
|
|
71
71
|
if (isZodObject) {
|
|
72
72
|
const obj_schema = safe_schema;
|
|
73
73
|
for (const [key, value] of Object.entries(obj_schema.shape)) {
|
|
74
|
-
|
|
74
|
+
const def = getZodDefFromZodSchemaHelpers(value);
|
|
75
|
+
const isArray = def.typeName === import_zod.ZodFirstPartyTypeKind.ZodArray;
|
|
76
|
+
if (isArray) {
|
|
75
77
|
const array_input = input[key];
|
|
76
78
|
if (typeof array_input === "string") {
|
|
77
79
|
parsed_input[key] = array_input.split(",");
|
|
@@ -79,6 +81,14 @@ var parseCommaSeparateArrays = (schema, input) => {
|
|
|
79
81
|
if (Array.isArray(input[`${key}[]`])) {
|
|
80
82
|
parsed_input[key] = input[`${key}[]`];
|
|
81
83
|
}
|
|
84
|
+
continue;
|
|
85
|
+
}
|
|
86
|
+
const isBoolean = def.typeName === import_zod.ZodFirstPartyTypeKind.ZodBoolean;
|
|
87
|
+
if (isBoolean) {
|
|
88
|
+
const boolean_input = input[key];
|
|
89
|
+
if (typeof boolean_input === "string") {
|
|
90
|
+
parsed_input[key] = boolean_input === "true";
|
|
91
|
+
}
|
|
82
92
|
}
|
|
83
93
|
}
|
|
84
94
|
}
|
|
@@ -94,7 +104,7 @@ var zodIssueToString = (issue) => {
|
|
|
94
104
|
return `${issue.message} for "${issue.path.join(".")}"`;
|
|
95
105
|
};
|
|
96
106
|
var withValidation = (input) => (next) => async (req, res) => {
|
|
97
|
-
var _a, _b, _c, _d
|
|
107
|
+
var _a, _b, _c, _d;
|
|
98
108
|
if (input.formData && input.jsonBody || input.formData && input.commonParams) {
|
|
99
109
|
throw new Error("Cannot use formData with jsonBody or commonParams");
|
|
100
110
|
}
|
|
@@ -113,10 +123,12 @@ var withValidation = (input) => (next) => async (req, res) => {
|
|
|
113
123
|
try {
|
|
114
124
|
const original_combined_params = { ...req.query, ...req.body };
|
|
115
125
|
req.body = input.formData && req.method !== "GET" ? (_c = input.formData) == null ? void 0 : _c.parse(req.body) : (_d = input.jsonBody) == null ? void 0 : _d.parse(req.body);
|
|
116
|
-
|
|
126
|
+
if (input.queryParams) {
|
|
127
|
+
req.query = parseQueryParams(input.queryParams, req.query);
|
|
128
|
+
}
|
|
117
129
|
if (input.commonParams) {
|
|
118
130
|
;
|
|
119
|
-
req.commonParams =
|
|
131
|
+
req.commonParams = parseQueryParams(input.commonParams, original_combined_params);
|
|
120
132
|
}
|
|
121
133
|
} catch (error) {
|
|
122
134
|
if (error.name === "ZodError") {
|
|
@@ -194,4 +206,4 @@ var createWithRouteSpec = (setupParams) => {
|
|
|
194
206
|
checkRouteSpec,
|
|
195
207
|
createWithRouteSpec
|
|
196
208
|
});
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/with-route-spec/index.ts", "../../src/with-route-spec/middlewares/with-methods.ts", "../../src/with-route-spec/middlewares/with-validation.ts"],
  "sourcesContent": ["import { NextApiResponse, NextApiRequest } from \"next\"\nimport { withExceptionHandling } from \"nextjs-exception-middleware\"\nimport wrappers, { Middleware } from \"nextjs-middleware-wrappers\"\nimport { CreateWithRouteSpecFunction, RouteSpec } from \"../types\"\nimport withMethods, { HTTPMethods } from \"./middlewares/with-methods\"\nimport withValidation from \"./middlewares/with-validation\"\nimport { z } from \"zod\"\n\ntype ParamDef = z.ZodTypeAny | z.ZodEffects<z.ZodTypeAny>\n\nexport const checkRouteSpec = <\n  AuthType extends string = string,\n  Methods extends HTTPMethods[] = HTTPMethods[],\n  JsonBody extends ParamDef = z.ZodTypeAny,\n  QueryParams extends ParamDef = z.ZodTypeAny,\n  CommonParams extends ParamDef = z.ZodTypeAny,\n  Middlewares extends readonly Middleware<any, any>[] = readonly Middleware<\n    any,\n    any\n  >[],\n  FormData extends ParamDef = z.ZodTypeAny,\n  Spec extends RouteSpec<\n    AuthType,\n    Methods,\n    JsonBody,\n    QueryParams,\n    CommonParams,\n    Middlewares,\n    FormData\n  > = RouteSpec<\n    AuthType,\n    Methods,\n    JsonBody,\n    QueryParams,\n    CommonParams,\n    Middlewares,\n    FormData\n  >\n>(\n  spec: Spec\n): string extends Spec[\"auth\"]\n  ? `your route spec is underspecified, add \"as const\"`\n  : Spec => spec as any\n\nexport const createWithRouteSpec: CreateWithRouteSpecFunction = ((\n  setupParams\n) => {\n  const {\n    authMiddlewareMap = {},\n    globalMiddlewares = [],\n    exceptionHandlingMiddleware = withExceptionHandling({\n      addOkStatus: setupParams.addOkStatus,\n      exceptionHandlingOptions: {\n        getErrorContext: (req, error) => {\n          if (process.env.NODE_ENV === \"production\") {\n            return {}\n          }\n\n          return error\n        }\n      },\n    }) as any,\n  } = setupParams\n\n  const withRouteSpec = (spec: RouteSpec) => {\n    const createRouteExport = (userDefinedRouteFn) => {\n      const rootRequestHandler = async (\n        req: NextApiRequest,\n        res: NextApiResponse\n      ) => {\n        authMiddlewareMap[\"none\"] = (next) => next\n\n        const auth_middleware = authMiddlewareMap[spec.auth]\n        if (!auth_middleware) throw new Error(`Unknown auth type: ${spec.auth}`)\n\n        return wrappers(\n          ...((exceptionHandlingMiddleware\n            ? [exceptionHandlingMiddleware]\n            : []) as [any]),\n          ...((globalMiddlewares || []) as []),\n          auth_middleware,\n          ...((spec.middlewares || []) as []),\n          withMethods(spec.methods),\n          withValidation({\n            jsonBody: spec.jsonBody,\n            queryParams: spec.queryParams,\n            commonParams: spec.commonParams,\n            formData: spec.formData,\n          }),\n          userDefinedRouteFn\n        )(req as any, res)\n      }\n\n      rootRequestHandler._setupParams = setupParams\n      rootRequestHandler._routeSpec = spec\n\n      return rootRequestHandler\n    }\n\n    createRouteExport._setupParams = setupParams\n    createRouteExport._routeSpec = spec\n\n    return createRouteExport\n  }\n\n  withRouteSpec._setupParams = setupParams\n\n  return withRouteSpec\n}) as any\n", "import { MethodNotAllowedException } from \"nextjs-exception-middleware\"\n\nexport type HTTPMethods =\n  | \"GET\"\n  | \"POST\"\n  | \"DELETE\"\n  | \"PUT\"\n  | \"PATCH\"\n  | \"HEAD\"\n  | \"OPTIONS\"\n\nexport const withMethods = (methods: HTTPMethods[]) => (next) => (req, res) => {\n  if (!methods.includes(req.method)) {\n    throw new MethodNotAllowedException({\n      type: \"method_not_allowed\",\n      message: `only ${methods.join(\",\")} accepted`,\n    })\n  }\n  return next(req, res)\n}\n\nexport default withMethods\n", "import type { NextApiRequest, NextApiResponse } from \"next\"\nimport { z, ZodFirstPartyTypeKind } from \"zod\"\nimport { BadRequestException } from \"nextjs-exception-middleware\"\nimport { isEmpty } from \"lodash\"\n\nconst getZodObjectSchemaFromZodEffectSchema = (\n  isZodEffect: boolean,\n  schema: z.ZodTypeAny\n): z.ZodTypeAny | z.ZodObject<any> => {\n  if (!isZodEffect) {\n    return schema as z.ZodObject<any>\n  }\n\n  let currentSchema = schema\n\n  while (currentSchema instanceof z.ZodEffects) {\n    currentSchema = currentSchema._def.schema\n  }\n\n  return currentSchema as z.ZodObject<any>\n}\n\nconst isSchemaArrayc = (schema: z.ZodTypeAny) => {\n  const unsafe_def_maybe_optional_maybe_zod_effect = (schema as z.ZodTypeAny)\n    ._def\n  const unsafe_def_maybe_zod_effect =\n    unsafe_def_maybe_optional_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodOptional\n      ? unsafe_def_maybe_optional_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_optional_maybe_zod_effect\n  const safe_def =\n    unsafe_def_maybe_zod_effect.typeName === ZodFirstPartyTypeKind.ZodEffects\n      ? unsafe_def_maybe_zod_effect.schema._def\n      : unsafe_def_maybe_zod_effect\n\n  return safe_def.typeName === ZodFirstPartyTypeKind.ZodArray\n}\n\nconst parseCommaSeparateArrays = (\n  schema: z.ZodTypeAny,\n  input: Record<string, unknown>\n) => {\n  const parsed_input = Object.assign({}, input)\n  const isZodEffect = schema._def.typeName === ZodFirstPartyTypeKind.ZodEffects\n  const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema)\n  const isZodObject =\n    safe_schema._def.typeName === ZodFirstPartyTypeKind.ZodObject\n\n  if (isZodObject) {\n    const obj_schema = safe_schema as z.ZodObject<any>\n\n    for (const [key, value] of Object.entries(obj_schema.shape)) {\n      if (isSchemaArrayc(value as z.ZodTypeAny)) {\n        const array_input = input[key]\n\n        if (typeof array_input === \"string\") {\n          parsed_input[key] = array_input.split(\",\")\n        }\n\n        if (Array.isArray(input[`${key}[]`])) {\n          parsed_input[key] = input[`${key}[]`]\n        }\n      }\n    }\n  }\n\n  return schema.parse(parsed_input)\n}\n\nexport interface RequestInput<\n  JsonBody extends z.ZodTypeAny,\n  QueryParams extends z.ZodTypeAny,\n  CommonParams extends z.ZodTypeAny,\n  FormData extends z.ZodTypeAny\n> {\n  jsonBody?: JsonBody\n  queryParams?: QueryParams\n  commonParams?: CommonParams\n  formData?: FormData\n}\n\nconst zodIssueToString = (issue: z.ZodIssue) => {\n  if (issue.path.join(\".\") === \"\") {\n    return issue.message\n  }\n  if (issue.message === \"Required\") {\n    return `${issue.path.join(\".\")} is required`\n  }\n  return `${issue.message} for \"${issue.path.join(\".\")}\"`\n}\n\nexport const withValidation =\n  <\n    JsonBody extends z.ZodTypeAny,\n    QueryParams extends z.ZodTypeAny,\n    CommonParams extends z.ZodTypeAny,\n    FormData extends z.ZodTypeAny\n  >(\n    input: RequestInput<JsonBody, QueryParams, CommonParams, FormData>\n  ) =>\n  (next) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    if (\n      (input.formData && input.jsonBody) ||\n      (input.formData && input.commonParams)\n    ) {\n      throw new Error(\"Cannot use formData with jsonBody or commonParams\")\n    }\n\n    if (\n      (req.method === \"POST\" || req.method === \"PATCH\") &&\n      (input.jsonBody || input.commonParams) &&\n      !req.headers[\"content-type\"]?.includes(\"application/json\") &&\n      !isEmpty(req.body)\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `${req.method} requests must have Content-Type header with \"application/json\"`,\n      })\n    }\n\n    if (\n      input.formData &&\n      req.method !== \"GET\" &&\n      !req.headers[\"content-type\"]?.includes(\n        \"application/x-www-form-urlencoded\"\n      )\n      // TODO eventually we should support multipart/form-data\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `Must have Content-Type header with \"application/x-www-form-urlencoded\"`,\n      })\n    }\n\n    try {\n      const original_combined_params = { ...req.query, ...req.body }\n      req.body =\n        input.formData && req.method !== \"GET\"\n          ? input.formData?.parse(req.body)\n          : input.jsonBody?.parse(req.body)\n      req.query = input.queryParams?.parse(req.query)\n\n      if (input.commonParams) {\n        ;(req as any).commonParams = parseCommaSeparateArrays(\n          input.commonParams,\n          original_combined_params\n        )\n      }\n    } catch (error: any) {\n      if (error.name === \"ZodError\") {\n        let message\n        if (error.issues.length === 1) {\n          const issue = error.issues[0]\n          message = zodIssueToString(issue)\n        } else {\n          const message_components: string[] = []\n          for (const issue of error.issues) {\n            message_components.push(zodIssueToString(issue))\n          }\n          message =\n            `${error.issues.length} Input Errors: ` +\n            message_components.join(\", \")\n        }\n\n        throw new BadRequestException({\n          type: \"invalid_input\",\n          message,\n          validation_errors: error.format(),\n        })\n      }\n\n      throw new BadRequestException({\n        type: \"invalid_input\",\n        message: \"Error while parsing input\",\n      })\n    }\n\n    return next(req, res)\n  }\n\nexport default withValidation\n"],
  "mappings": "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",
  "names": []
}

|
|
209
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../src/with-route-spec/index.ts", "../../src/with-route-spec/middlewares/with-methods.ts", "../../src/with-route-spec/middlewares/with-validation.ts"],
  "sourcesContent": ["import { NextApiResponse, NextApiRequest } from \"next\"\nimport { withExceptionHandling } from \"nextjs-exception-middleware\"\nimport wrappers, { Middleware } from \"nextjs-middleware-wrappers\"\nimport { CreateWithRouteSpecFunction, RouteSpec } from \"../types\"\nimport withMethods, { HTTPMethods } from \"./middlewares/with-methods\"\nimport withValidation from \"./middlewares/with-validation\"\nimport { z } from \"zod\"\n\ntype ParamDef = z.ZodTypeAny | z.ZodEffects<z.ZodTypeAny>\n\nexport const checkRouteSpec = <\n  AuthType extends string = string,\n  Methods extends HTTPMethods[] = HTTPMethods[],\n  JsonBody extends ParamDef = z.ZodTypeAny,\n  QueryParams extends ParamDef = z.ZodTypeAny,\n  CommonParams extends ParamDef = z.ZodTypeAny,\n  Middlewares extends readonly Middleware<any, any>[] = readonly Middleware<\n    any,\n    any\n  >[],\n  FormData extends ParamDef = z.ZodTypeAny,\n  Spec extends RouteSpec<\n    AuthType,\n    Methods,\n    JsonBody,\n    QueryParams,\n    CommonParams,\n    Middlewares,\n    FormData\n  > = RouteSpec<\n    AuthType,\n    Methods,\n    JsonBody,\n    QueryParams,\n    CommonParams,\n    Middlewares,\n    FormData\n  >\n>(\n  spec: Spec\n): string extends Spec[\"auth\"]\n  ? `your route spec is underspecified, add \"as const\"`\n  : Spec => spec as any\n\nexport const createWithRouteSpec: CreateWithRouteSpecFunction = ((\n  setupParams\n) => {\n  const {\n    authMiddlewareMap = {},\n    globalMiddlewares = [],\n    exceptionHandlingMiddleware = withExceptionHandling({\n      addOkStatus: setupParams.addOkStatus,\n      exceptionHandlingOptions: {\n        getErrorContext: (req, error) => {\n          if (process.env.NODE_ENV === \"production\") {\n            return {}\n          }\n\n          return error\n        }\n      },\n    }) as any,\n  } = setupParams\n\n  const withRouteSpec = (spec: RouteSpec) => {\n    const createRouteExport = (userDefinedRouteFn) => {\n      const rootRequestHandler = async (\n        req: NextApiRequest,\n        res: NextApiResponse\n      ) => {\n        authMiddlewareMap[\"none\"] = (next) => next\n\n        const auth_middleware = authMiddlewareMap[spec.auth]\n        if (!auth_middleware) throw new Error(`Unknown auth type: ${spec.auth}`)\n\n        return wrappers(\n          ...((exceptionHandlingMiddleware\n            ? [exceptionHandlingMiddleware]\n            : []) as [any]),\n          ...((globalMiddlewares || []) as []),\n          auth_middleware,\n          ...((spec.middlewares || []) as []),\n          withMethods(spec.methods),\n          withValidation({\n            jsonBody: spec.jsonBody,\n            queryParams: spec.queryParams,\n            commonParams: spec.commonParams,\n            formData: spec.formData,\n          }),\n          userDefinedRouteFn\n        )(req as any, res)\n      }\n\n      rootRequestHandler._setupParams = setupParams\n      rootRequestHandler._routeSpec = spec\n\n      return rootRequestHandler\n    }\n\n    createRouteExport._setupParams = setupParams\n    createRouteExport._routeSpec = spec\n\n    return createRouteExport\n  }\n\n  withRouteSpec._setupParams = setupParams\n\n  return withRouteSpec\n}) as any\n", "import { MethodNotAllowedException } from \"nextjs-exception-middleware\"\n\nexport type HTTPMethods =\n  | \"GET\"\n  | \"POST\"\n  | \"DELETE\"\n  | \"PUT\"\n  | \"PATCH\"\n  | \"HEAD\"\n  | \"OPTIONS\"\n\nexport const withMethods = (methods: HTTPMethods[]) => (next) => (req, res) => {\n  if (!methods.includes(req.method)) {\n    throw new MethodNotAllowedException({\n      type: \"method_not_allowed\",\n      message: `only ${methods.join(\",\")} accepted`,\n    })\n  }\n  return next(req, res)\n}\n\nexport default withMethods\n", "import type { NextApiRequest, NextApiResponse } from \"next\"\nimport { z, ZodFirstPartyTypeKind } from \"zod\"\nimport { BadRequestException } from \"nextjs-exception-middleware\"\nimport { isEmpty } from \"lodash\"\n\nconst getZodObjectSchemaFromZodEffectSchema = (\n  isZodEffect: boolean,\n  schema: z.ZodTypeAny\n): z.ZodTypeAny | z.ZodObject<any> => {\n  if (!isZodEffect) {\n    return schema as z.ZodObject<any>\n  }\n\n  let currentSchema = schema\n\n  while (currentSchema instanceof z.ZodEffects) {\n    currentSchema = currentSchema._def.schema\n  }\n\n  return currentSchema as z.ZodObject<any>\n}\n\n/**\n * This function is used to get the correct schema from a ZodEffect | ZodDefault | ZodOptional schema.\n * TODO: this function should handle all special cases of ZodSchema and not just ZodEffect | ZodDefault | ZodOptional\n */\nconst getZodDefFromZodSchemaHelpers = (schema: z.ZodTypeAny) => {\n  const unsafe_def_maybe_optional_maybe_default_maybe_zod_effect = (\n    schema as z.ZodTypeAny\n  )._def\n  const unsafe_def_maybe_default_maybe_zod_effect =\n    unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodOptional\n      ? unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_optional_maybe_default_maybe_zod_effect\n  const unsafe_def_maybe_zod_effect =\n    unsafe_def_maybe_default_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodDefault\n      ? unsafe_def_maybe_default_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_default_maybe_zod_effect\n  return unsafe_def_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodEffects\n    ? unsafe_def_maybe_zod_effect.schema._def\n    : unsafe_def_maybe_zod_effect\n}\n\nconst parseQueryParams = (\n  schema: z.ZodTypeAny,\n  input: Record<string, unknown>\n) => {\n  const parsed_input = Object.assign({}, input)\n  const isZodEffect = schema._def.typeName === ZodFirstPartyTypeKind.ZodEffects\n  const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema)\n  const isZodObject =\n    safe_schema._def.typeName === ZodFirstPartyTypeKind.ZodObject\n\n  if (isZodObject) {\n    const obj_schema = safe_schema as z.ZodObject<any>\n\n    for (const [key, value] of Object.entries(obj_schema.shape)) {\n      const def = getZodDefFromZodSchemaHelpers(value as z.ZodTypeAny)\n      const isArray = def.typeName === ZodFirstPartyTypeKind.ZodArray\n      if (isArray) {\n        const array_input = input[key]\n\n        if (typeof array_input === \"string\") {\n          parsed_input[key] = array_input.split(\",\")\n        }\n\n        if (Array.isArray(input[`${key}[]`])) {\n          parsed_input[key] = input[`${key}[]`]\n        }\n\n        continue\n      }\n\n      const isBoolean = def.typeName === ZodFirstPartyTypeKind.ZodBoolean\n      if (isBoolean) {\n        const boolean_input = input[key]\n\n        if (typeof boolean_input === \"string\") {\n          parsed_input[key] = boolean_input === \"true\"\n        }\n      }\n    }\n  }\n\n  return schema.parse(parsed_input)\n}\n\nexport interface RequestInput<\n  JsonBody extends z.ZodTypeAny,\n  QueryParams extends z.ZodTypeAny,\n  CommonParams extends z.ZodTypeAny,\n  FormData extends z.ZodTypeAny\n> {\n  jsonBody?: JsonBody\n  queryParams?: QueryParams\n  commonParams?: CommonParams\n  formData?: FormData\n}\n\nconst zodIssueToString = (issue: z.ZodIssue) => {\n  if (issue.path.join(\".\") === \"\") {\n    return issue.message\n  }\n  if (issue.message === \"Required\") {\n    return `${issue.path.join(\".\")} is required`\n  }\n  return `${issue.message} for \"${issue.path.join(\".\")}\"`\n}\n\nexport const withValidation =\n  <\n    JsonBody extends z.ZodTypeAny,\n    QueryParams extends z.ZodTypeAny,\n    CommonParams extends z.ZodTypeAny,\n    FormData extends z.ZodTypeAny\n  >(\n    input: RequestInput<JsonBody, QueryParams, CommonParams, FormData>\n  ) =>\n  (next) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    if (\n      (input.formData && input.jsonBody) ||\n      (input.formData && input.commonParams)\n    ) {\n      throw new Error(\"Cannot use formData with jsonBody or commonParams\")\n    }\n\n    if (\n      (req.method === \"POST\" || req.method === \"PATCH\") &&\n      (input.jsonBody || input.commonParams) &&\n      !req.headers[\"content-type\"]?.includes(\"application/json\") &&\n      !isEmpty(req.body)\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `${req.method} requests must have Content-Type header with \"application/json\"`,\n      })\n    }\n\n    if (\n      input.formData &&\n      req.method !== \"GET\" &&\n      !req.headers[\"content-type\"]?.includes(\n        \"application/x-www-form-urlencoded\"\n      )\n      // TODO eventually we should support multipart/form-data\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `Must have Content-Type header with \"application/x-www-form-urlencoded\"`,\n      })\n    }\n\n    try {\n      const original_combined_params = { ...req.query, ...req.body }\n      req.body =\n        input.formData && req.method !== \"GET\"\n          ? input.formData?.parse(req.body)\n          : input.jsonBody?.parse(req.body)\n\n      if (input.queryParams) {\n        req.query = parseQueryParams(input.queryParams, req.query)\n      }\n\n      if (input.commonParams) {\n        /**\n         * as commonParams includes query params, we can use the parseQueryParams function\n         */\n        ;(req as any).commonParams = parseQueryParams(\n          input.commonParams,\n          original_combined_params\n        )\n      }\n    } catch (error: any) {\n      if (error.name === \"ZodError\") {\n        let message\n        if (error.issues.length === 1) {\n          const issue = error.issues[0]\n          message = zodIssueToString(issue)\n        } else {\n          const message_components: string[] = []\n          for (const issue of error.issues) {\n            message_components.push(zodIssueToString(issue))\n          }\n          message =\n            `${error.issues.length} Input Errors: ` +\n            message_components.join(\", \")\n        }\n\n        throw new BadRequestException({\n          type: \"invalid_input\",\n          message,\n          validation_errors: error.format(),\n        })\n      }\n\n      throw new BadRequestException({\n        type: \"invalid_input\",\n        message: \"Error while parsing input\",\n      })\n    }\n\n    return next(req, res)\n  }\n\nexport default withValidation\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -37,13 +37,13 @@ var getZodObjectSchemaFromZodEffectSchema = (isZodEffect, schema) => {
|
|
|
37
37
|
}
|
|
38
38
|
return currentSchema;
|
|
39
39
|
};
|
|
40
|
-
var
|
|
41
|
-
const
|
|
42
|
-
const
|
|
43
|
-
const
|
|
44
|
-
return
|
|
40
|
+
var getZodDefFromZodSchemaHelpers = (schema) => {
|
|
41
|
+
const unsafe_def_maybe_optional_maybe_default_maybe_zod_effect = schema._def;
|
|
42
|
+
const unsafe_def_maybe_default_maybe_zod_effect = unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodOptional ? unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.innerType._def : unsafe_def_maybe_optional_maybe_default_maybe_zod_effect;
|
|
43
|
+
const unsafe_def_maybe_zod_effect = unsafe_def_maybe_default_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodDefault ? unsafe_def_maybe_default_maybe_zod_effect.innerType._def : unsafe_def_maybe_default_maybe_zod_effect;
|
|
44
|
+
return unsafe_def_maybe_zod_effect.typeName === import_zod.ZodFirstPartyTypeKind.ZodEffects ? unsafe_def_maybe_zod_effect.schema._def : unsafe_def_maybe_zod_effect;
|
|
45
45
|
};
|
|
46
|
-
var
|
|
46
|
+
var parseQueryParams = (schema, input) => {
|
|
47
47
|
const parsed_input = Object.assign({}, input);
|
|
48
48
|
const isZodEffect = schema._def.typeName === import_zod.ZodFirstPartyTypeKind.ZodEffects;
|
|
49
49
|
const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema);
|
|
@@ -51,7 +51,9 @@ var parseCommaSeparateArrays = (schema, input) => {
|
|
|
51
51
|
if (isZodObject) {
|
|
52
52
|
const obj_schema = safe_schema;
|
|
53
53
|
for (const [key, value] of Object.entries(obj_schema.shape)) {
|
|
54
|
-
|
|
54
|
+
const def = getZodDefFromZodSchemaHelpers(value);
|
|
55
|
+
const isArray = def.typeName === import_zod.ZodFirstPartyTypeKind.ZodArray;
|
|
56
|
+
if (isArray) {
|
|
55
57
|
const array_input = input[key];
|
|
56
58
|
if (typeof array_input === "string") {
|
|
57
59
|
parsed_input[key] = array_input.split(",");
|
|
@@ -59,6 +61,14 @@ var parseCommaSeparateArrays = (schema, input) => {
|
|
|
59
61
|
if (Array.isArray(input[`${key}[]`])) {
|
|
60
62
|
parsed_input[key] = input[`${key}[]`];
|
|
61
63
|
}
|
|
64
|
+
continue;
|
|
65
|
+
}
|
|
66
|
+
const isBoolean = def.typeName === import_zod.ZodFirstPartyTypeKind.ZodBoolean;
|
|
67
|
+
if (isBoolean) {
|
|
68
|
+
const boolean_input = input[key];
|
|
69
|
+
if (typeof boolean_input === "string") {
|
|
70
|
+
parsed_input[key] = boolean_input === "true";
|
|
71
|
+
}
|
|
62
72
|
}
|
|
63
73
|
}
|
|
64
74
|
}
|
|
@@ -74,7 +84,7 @@ var zodIssueToString = (issue) => {
|
|
|
74
84
|
return `${issue.message} for "${issue.path.join(".")}"`;
|
|
75
85
|
};
|
|
76
86
|
var withValidation = (input) => (next) => async (req, res) => {
|
|
77
|
-
var _a, _b, _c, _d
|
|
87
|
+
var _a, _b, _c, _d;
|
|
78
88
|
if (input.formData && input.jsonBody || input.formData && input.commonParams) {
|
|
79
89
|
throw new Error("Cannot use formData with jsonBody or commonParams");
|
|
80
90
|
}
|
|
@@ -93,10 +103,12 @@ var withValidation = (input) => (next) => async (req, res) => {
|
|
|
93
103
|
try {
|
|
94
104
|
const original_combined_params = { ...req.query, ...req.body };
|
|
95
105
|
req.body = input.formData && req.method !== "GET" ? (_c = input.formData) == null ? void 0 : _c.parse(req.body) : (_d = input.jsonBody) == null ? void 0 : _d.parse(req.body);
|
|
96
|
-
|
|
106
|
+
if (input.queryParams) {
|
|
107
|
+
req.query = parseQueryParams(input.queryParams, req.query);
|
|
108
|
+
}
|
|
97
109
|
if (input.commonParams) {
|
|
98
110
|
;
|
|
99
|
-
req.commonParams =
|
|
111
|
+
req.commonParams = parseQueryParams(input.commonParams, original_combined_params);
|
|
100
112
|
}
|
|
101
113
|
} catch (error) {
|
|
102
114
|
if (error.name === "ZodError") {
|
|
@@ -129,4 +141,4 @@ var with_validation_default = withValidation;
|
|
|
129
141
|
0 && (module.exports = {
|
|
130
142
|
withValidation
|
|
131
143
|
});
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/with-route-spec/middlewares/with-validation.ts"],
  "sourcesContent": ["import type { NextApiRequest, NextApiResponse } from \"next\"\nimport { z, ZodFirstPartyTypeKind } from \"zod\"\nimport { BadRequestException } from \"nextjs-exception-middleware\"\nimport { isEmpty } from \"lodash\"\n\nconst getZodObjectSchemaFromZodEffectSchema = (\n  isZodEffect: boolean,\n  schema: z.ZodTypeAny\n): z.ZodTypeAny | z.ZodObject<any> => {\n  if (!isZodEffect) {\n    return schema as z.ZodObject<any>\n  }\n\n  let currentSchema = schema\n\n  while (currentSchema instanceof z.ZodEffects) {\n    currentSchema = currentSchema._def.schema\n  }\n\n  return currentSchema as z.ZodObject<any>\n}\n\nconst isSchemaArrayc = (schema: z.ZodTypeAny) => {\n  const unsafe_def_maybe_optional_maybe_zod_effect = (schema as z.ZodTypeAny)\n    ._def\n  const unsafe_def_maybe_zod_effect =\n    unsafe_def_maybe_optional_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodOptional\n      ? unsafe_def_maybe_optional_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_optional_maybe_zod_effect\n  const safe_def =\n    unsafe_def_maybe_zod_effect.typeName === ZodFirstPartyTypeKind.ZodEffects\n      ? unsafe_def_maybe_zod_effect.schema._def\n      : unsafe_def_maybe_zod_effect\n\n  return safe_def.typeName === ZodFirstPartyTypeKind.ZodArray\n}\n\nconst parseCommaSeparateArrays = (\n  schema: z.ZodTypeAny,\n  input: Record<string, unknown>\n) => {\n  const parsed_input = Object.assign({}, input)\n  const isZodEffect = schema._def.typeName === ZodFirstPartyTypeKind.ZodEffects\n  const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema)\n  const isZodObject =\n    safe_schema._def.typeName === ZodFirstPartyTypeKind.ZodObject\n\n  if (isZodObject) {\n    const obj_schema = safe_schema as z.ZodObject<any>\n\n    for (const [key, value] of Object.entries(obj_schema.shape)) {\n      if (isSchemaArrayc(value as z.ZodTypeAny)) {\n        const array_input = input[key]\n\n        if (typeof array_input === \"string\") {\n          parsed_input[key] = array_input.split(\",\")\n        }\n\n        if (Array.isArray(input[`${key}[]`])) {\n          parsed_input[key] = input[`${key}[]`]\n        }\n      }\n    }\n  }\n\n  return schema.parse(parsed_input)\n}\n\nexport interface RequestInput<\n  JsonBody extends z.ZodTypeAny,\n  QueryParams extends z.ZodTypeAny,\n  CommonParams extends z.ZodTypeAny,\n  FormData extends z.ZodTypeAny\n> {\n  jsonBody?: JsonBody\n  queryParams?: QueryParams\n  commonParams?: CommonParams\n  formData?: FormData\n}\n\nconst zodIssueToString = (issue: z.ZodIssue) => {\n  if (issue.path.join(\".\") === \"\") {\n    return issue.message\n  }\n  if (issue.message === \"Required\") {\n    return `${issue.path.join(\".\")} is required`\n  }\n  return `${issue.message} for \"${issue.path.join(\".\")}\"`\n}\n\nexport const withValidation =\n  <\n    JsonBody extends z.ZodTypeAny,\n    QueryParams extends z.ZodTypeAny,\n    CommonParams extends z.ZodTypeAny,\n    FormData extends z.ZodTypeAny\n  >(\n    input: RequestInput<JsonBody, QueryParams, CommonParams, FormData>\n  ) =>\n  (next) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    if (\n      (input.formData && input.jsonBody) ||\n      (input.formData && input.commonParams)\n    ) {\n      throw new Error(\"Cannot use formData with jsonBody or commonParams\")\n    }\n\n    if (\n      (req.method === \"POST\" || req.method === \"PATCH\") &&\n      (input.jsonBody || input.commonParams) &&\n      !req.headers[\"content-type\"]?.includes(\"application/json\") &&\n      !isEmpty(req.body)\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `${req.method} requests must have Content-Type header with \"application/json\"`,\n      })\n    }\n\n    if (\n      input.formData &&\n      req.method !== \"GET\" &&\n      !req.headers[\"content-type\"]?.includes(\n        \"application/x-www-form-urlencoded\"\n      )\n      // TODO eventually we should support multipart/form-data\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `Must have Content-Type header with \"application/x-www-form-urlencoded\"`,\n      })\n    }\n\n    try {\n      const original_combined_params = { ...req.query, ...req.body }\n      req.body =\n        input.formData && req.method !== \"GET\"\n          ? input.formData?.parse(req.body)\n          : input.jsonBody?.parse(req.body)\n      req.query = input.queryParams?.parse(req.query)\n\n      if (input.commonParams) {\n        ;(req as any).commonParams = parseCommaSeparateArrays(\n          input.commonParams,\n          original_combined_params\n        )\n      }\n    } catch (error: any) {\n      if (error.name === \"ZodError\") {\n        let message\n        if (error.issues.length === 1) {\n          const issue = error.issues[0]\n          message = zodIssueToString(issue)\n        } else {\n          const message_components: string[] = []\n          for (const issue of error.issues) {\n            message_components.push(zodIssueToString(issue))\n          }\n          message =\n            `${error.issues.length} Input Errors: ` +\n            message_components.join(\", \")\n        }\n\n        throw new BadRequestException({\n          type: \"invalid_input\",\n          message,\n          validation_errors: error.format(),\n        })\n      }\n\n      throw new BadRequestException({\n        type: \"invalid_input\",\n        message: \"Error while parsing input\",\n      })\n    }\n\n    return next(req, res)\n  }\n\nexport default withValidation\n"],
  "mappings": "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",
  "names": []
}

|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../../../src/with-route-spec/middlewares/with-validation.ts"],
  "sourcesContent": ["import type { NextApiRequest, NextApiResponse } from \"next\"\nimport { z, ZodFirstPartyTypeKind } from \"zod\"\nimport { BadRequestException } from \"nextjs-exception-middleware\"\nimport { isEmpty } from \"lodash\"\n\nconst getZodObjectSchemaFromZodEffectSchema = (\n  isZodEffect: boolean,\n  schema: z.ZodTypeAny\n): z.ZodTypeAny | z.ZodObject<any> => {\n  if (!isZodEffect) {\n    return schema as z.ZodObject<any>\n  }\n\n  let currentSchema = schema\n\n  while (currentSchema instanceof z.ZodEffects) {\n    currentSchema = currentSchema._def.schema\n  }\n\n  return currentSchema as z.ZodObject<any>\n}\n\n/**\n * This function is used to get the correct schema from a ZodEffect | ZodDefault | ZodOptional schema.\n * TODO: this function should handle all special cases of ZodSchema and not just ZodEffect | ZodDefault | ZodOptional\n */\nconst getZodDefFromZodSchemaHelpers = (schema: z.ZodTypeAny) => {\n  const unsafe_def_maybe_optional_maybe_default_maybe_zod_effect = (\n    schema as z.ZodTypeAny\n  )._def\n  const unsafe_def_maybe_default_maybe_zod_effect =\n    unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodOptional\n      ? unsafe_def_maybe_optional_maybe_default_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_optional_maybe_default_maybe_zod_effect\n  const unsafe_def_maybe_zod_effect =\n    unsafe_def_maybe_default_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodDefault\n      ? unsafe_def_maybe_default_maybe_zod_effect.innerType._def\n      : unsafe_def_maybe_default_maybe_zod_effect\n  return unsafe_def_maybe_zod_effect.typeName ===\n    ZodFirstPartyTypeKind.ZodEffects\n    ? unsafe_def_maybe_zod_effect.schema._def\n    : unsafe_def_maybe_zod_effect\n}\n\nconst parseQueryParams = (\n  schema: z.ZodTypeAny,\n  input: Record<string, unknown>\n) => {\n  const parsed_input = Object.assign({}, input)\n  const isZodEffect = schema._def.typeName === ZodFirstPartyTypeKind.ZodEffects\n  const safe_schema = getZodObjectSchemaFromZodEffectSchema(isZodEffect, schema)\n  const isZodObject =\n    safe_schema._def.typeName === ZodFirstPartyTypeKind.ZodObject\n\n  if (isZodObject) {\n    const obj_schema = safe_schema as z.ZodObject<any>\n\n    for (const [key, value] of Object.entries(obj_schema.shape)) {\n      const def = getZodDefFromZodSchemaHelpers(value as z.ZodTypeAny)\n      const isArray = def.typeName === ZodFirstPartyTypeKind.ZodArray\n      if (isArray) {\n        const array_input = input[key]\n\n        if (typeof array_input === \"string\") {\n          parsed_input[key] = array_input.split(\",\")\n        }\n\n        if (Array.isArray(input[`${key}[]`])) {\n          parsed_input[key] = input[`${key}[]`]\n        }\n\n        continue\n      }\n\n      const isBoolean = def.typeName === ZodFirstPartyTypeKind.ZodBoolean\n      if (isBoolean) {\n        const boolean_input = input[key]\n\n        if (typeof boolean_input === \"string\") {\n          parsed_input[key] = boolean_input === \"true\"\n        }\n      }\n    }\n  }\n\n  return schema.parse(parsed_input)\n}\n\nexport interface RequestInput<\n  JsonBody extends z.ZodTypeAny,\n  QueryParams extends z.ZodTypeAny,\n  CommonParams extends z.ZodTypeAny,\n  FormData extends z.ZodTypeAny\n> {\n  jsonBody?: JsonBody\n  queryParams?: QueryParams\n  commonParams?: CommonParams\n  formData?: FormData\n}\n\nconst zodIssueToString = (issue: z.ZodIssue) => {\n  if (issue.path.join(\".\") === \"\") {\n    return issue.message\n  }\n  if (issue.message === \"Required\") {\n    return `${issue.path.join(\".\")} is required`\n  }\n  return `${issue.message} for \"${issue.path.join(\".\")}\"`\n}\n\nexport const withValidation =\n  <\n    JsonBody extends z.ZodTypeAny,\n    QueryParams extends z.ZodTypeAny,\n    CommonParams extends z.ZodTypeAny,\n    FormData extends z.ZodTypeAny\n  >(\n    input: RequestInput<JsonBody, QueryParams, CommonParams, FormData>\n  ) =>\n  (next) =>\n  async (req: NextApiRequest, res: NextApiResponse) => {\n    if (\n      (input.formData && input.jsonBody) ||\n      (input.formData && input.commonParams)\n    ) {\n      throw new Error(\"Cannot use formData with jsonBody or commonParams\")\n    }\n\n    if (\n      (req.method === \"POST\" || req.method === \"PATCH\") &&\n      (input.jsonBody || input.commonParams) &&\n      !req.headers[\"content-type\"]?.includes(\"application/json\") &&\n      !isEmpty(req.body)\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `${req.method} requests must have Content-Type header with \"application/json\"`,\n      })\n    }\n\n    if (\n      input.formData &&\n      req.method !== \"GET\" &&\n      !req.headers[\"content-type\"]?.includes(\n        \"application/x-www-form-urlencoded\"\n      )\n      // TODO eventually we should support multipart/form-data\n    ) {\n      throw new BadRequestException({\n        type: \"invalid_content_type\",\n        message: `Must have Content-Type header with \"application/x-www-form-urlencoded\"`,\n      })\n    }\n\n    try {\n      const original_combined_params = { ...req.query, ...req.body }\n      req.body =\n        input.formData && req.method !== \"GET\"\n          ? input.formData?.parse(req.body)\n          : input.jsonBody?.parse(req.body)\n\n      if (input.queryParams) {\n        req.query = parseQueryParams(input.queryParams, req.query)\n      }\n\n      if (input.commonParams) {\n        /**\n         * as commonParams includes query params, we can use the parseQueryParams function\n         */\n        ;(req as any).commonParams = parseQueryParams(\n          input.commonParams,\n          original_combined_params\n        )\n      }\n    } catch (error: any) {\n      if (error.name === \"ZodError\") {\n        let message\n        if (error.issues.length === 1) {\n          const issue = error.issues[0]\n          message = zodIssueToString(issue)\n        } else {\n          const message_components: string[] = []\n          for (const issue of error.issues) {\n            message_components.push(zodIssueToString(issue))\n          }\n          message =\n            `${error.issues.length} Input Errors: ` +\n            message_components.join(\", \")\n        }\n\n        throw new BadRequestException({\n          type: \"invalid_input\",\n          message,\n          validation_errors: error.format(),\n        })\n      }\n\n      throw new BadRequestException({\n        type: \"invalid_input\",\n        message: \"Error while parsing input\",\n      })\n    }\n\n    return next(req, res)\n  }\n\nexport default withValidation\n"],
  "mappings": "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",
  "names": []
}

|