@sugardarius/anzen 2.1.0 → 2.1.2
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.
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }var _chunkUDCVGQMHcjs = require('../chunk-UDCVGQMH.cjs');var S=class extends Error{constructor(o,n,t){super(`${o==="searchParams"?"Search params":"Segments"} validation error for ${t} server component '${n}`),this.name="ValidationError"}},f=class extends Error{constructor(o,n){super(`No segments provided for ${n} server component '${o}'`),this.name="NoSegmentsProvidedError"}},h=class extends Error{constructor(o,n){super(`No search params provided for ${n} server component '${o}'`),this.name="NoSearchParamsProvidedError"}};var x=e=>typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string"?!1:e.digest.startsWith("NEXT_REDIRECT;"),T=e=>{if(typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string")return!1;let o=e.digest;return o.endsWith(";404")||o.endsWith(";403")||o.endsWith(";401")},w=e=>x(e)||T(e),A="[unknown:page:server:component]";function L(e,o){let n=_chunkUDCVGQMHcjs.a.call(void 0, e.debug),t=_nullishCoalesce(e.id, () => (A)),v=_nullishCoalesce(e.onError, () => ((i=>{throw n.error(`\u{1F6D1} Unexpected error in page server component '${t}'`,i),i}))),l=_nullishCoalesce(e.onSegmentsValidationError, () => ((i=>{throw n.error(`\u{1F6D1} Invalid segments for page server component '${t}'`,i),new S("segments",t,"page")}))),C=_nullishCoalesce(e.onSearchParamsValidationError, () => ((i=>{throw n.error(`\u{1F6D1} Invalid search params for server component '${t}'`,i),new S("searchParams",t,"page")}))),p=_nullishCoalesce(e.authorize, () => ((async()=>{})));return async function(d){let s=_chunkUDCVGQMHcjs.b.call(void 0, );s.start(),n.info(`\u{1F504} Running page server component'${t}'`);let u;if(e.segments){let a=await d.params;if(a===void 0)throw new f(t,"page");let m=_chunkUDCVGQMHcjs.d.call(void 0, e.segments,a);m.issues?await l(m.issues):u=m.value}let r;if(e.searchParams){let a=await d.searchParams;if(a===void 0)throw new h(t,"page");let m=_chunkUDCVGQMHcjs.d.call(void 0, e.searchParams,a);m.issues?await C(m.issues):r=m.value}let c;try{let a={id:t,...u?{segments:u}:{},...r?{searchParams:r}:{}};c=await p(a)}catch(a){throw n.error(
|
|
1
|
+
"use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _nullishCoalesce(lhs, rhsFn) { if (lhs != null) { return lhs; } else { return rhsFn(); } }var _chunkUDCVGQMHcjs = require('../chunk-UDCVGQMH.cjs');var S=class extends Error{constructor(o,n,t){super(`${o==="searchParams"?"Search params":"Segments"} validation error for ${t} server component '${n}`),this.name="ValidationError"}},f=class extends Error{constructor(o,n){super(`No segments provided for ${n} server component '${o}'`),this.name="NoSegmentsProvidedError"}},h=class extends Error{constructor(o,n){super(`No search params provided for ${n} server component '${o}'`),this.name="NoSearchParamsProvidedError"}};var x=e=>typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string"?!1:e.digest.startsWith("NEXT_REDIRECT;"),T=e=>{if(typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string")return!1;let o=e.digest;return o.endsWith(";404")||o.endsWith(";403")||o.endsWith(";401")},w=e=>x(e)||T(e),A="[unknown:page:server:component]";function L(e,o){let n=_chunkUDCVGQMHcjs.a.call(void 0, e.debug),t=_nullishCoalesce(e.id, () => (A)),v=_nullishCoalesce(e.onError, () => ((i=>{throw n.error(`\u{1F6D1} Unexpected error in page server component '${t}'`,i),i}))),l=_nullishCoalesce(e.onSegmentsValidationError, () => ((i=>{throw n.error(`\u{1F6D1} Invalid segments for page server component '${t}'`,i),new S("segments",t,"page")}))),C=_nullishCoalesce(e.onSearchParamsValidationError, () => ((i=>{throw n.error(`\u{1F6D1} Invalid search params for server component '${t}'`,i),new S("searchParams",t,"page")}))),p=_nullishCoalesce(e.authorize, () => ((async()=>{})));return async function(d){let s=_chunkUDCVGQMHcjs.b.call(void 0, );s.start(),n.info(`\u{1F504} Running page server component'${t}'`);let u;if(e.segments){let a=await d.params;if(a===void 0)throw new f(t,"page");let m=_chunkUDCVGQMHcjs.d.call(void 0, e.segments,a);m.issues?await l(m.issues):u=m.value}let r;if(e.searchParams){let a=await d.searchParams;if(a===void 0)throw new h(t,"page");let m=_chunkUDCVGQMHcjs.d.call(void 0, e.searchParams,a);m.issues?await C(m.issues):r=m.value}let c;try{let a={id:t,...u?{segments:u}:{},...r?{searchParams:r}:{}};c=await p(a)}catch(a){throw n.error(`\u{1F6D1} Page server component '${t}' not authorized`),a}try{let a={id:t,...c?{auth:c}:{},...u?{segments:u}:{},...r?{searchParams:r}:{}},m=await o(a);return s.stop(),n.info(`\u2705 Page server component '${t}' executed successfully in ${s.get()}`),m}catch(a){if(s.stop(),w(a))throw n.info("\u2139\uFE0F Ignoring native Next.js error"),a;return n.error(`\u{1F6D1} Page server component '${t}' failed to execute after ${s.get()}`),await v(a)}}}var E="[unknown:layout:server:component]";function $(e,o){let n=_chunkUDCVGQMHcjs.a.call(void 0, e.debug),t=_nullishCoalesce(e.id, () => (E)),v=_nullishCoalesce(e.onError, () => ((p=>{throw n.error(`\u{1F6D1} Unexpected error in layout server component '${t}'`,p),p}))),l=_nullishCoalesce(e.onSegmentsValidationError, () => ((p=>{throw n.error(`\u{1F6D1} Invalid segments for layout server component '${t}'`,p),new S("segments",t,"page")}))),C=_nullishCoalesce(e.authorize, () => ((async()=>{})));return async function(i){let d=_chunkUDCVGQMHcjs.b.call(void 0, );d.start(),n.info(`\u{1F504} Running layout server component'${t}'`);let s;if(e.segments){let r=await i.params;if(r===void 0)throw new f(t,"page");let c=_chunkUDCVGQMHcjs.d.call(void 0, e.segments,r);c.issues?await l(c.issues):s=c.value}let u;try{let r={id:t,...s?{segments:s}:{}};u=await C(r)}catch(r){throw n.error(`\u{1F6D1} Layout server component '${t}' not authorized`),r}try{let r={id:t,...u?{auth:u}:{},...s?{segments:s}:{},children:i.children},c=await o(r);return d.stop(),n.info(`\u2705 Layout server component '${t}' executed successfully in ${d.get()}`),c}catch(r){if(d.stop(),w(r))throw n.info("\u2139\uFE0F Ignoring native Next.js error"),r;return n.error(`\u{1F6D1} Layout server component '${t}' failed to execute after ${d.get()}`),await v(r)}}}exports.createSafeLayoutServerComponent = $; exports.createSafePageServerComponent = L;
|
|
2
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import{a as P,b as y,d as g}from"../chunk-DT3TEL5X.js";var S=class extends Error{constructor(o,n,t){super(`${o==="searchParams"?"Search params":"Segments"} validation error for ${t} server component '${n}`),this.name="ValidationError"}},f=class extends Error{constructor(o,n){super(`No segments provided for ${n} server component '${o}'`),this.name="NoSegmentsProvidedError"}},h=class extends Error{constructor(o,n){super(`No search params provided for ${n} server component '${o}'`),this.name="NoSearchParamsProvidedError"}};var x=e=>typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string"?!1:e.digest.startsWith("NEXT_REDIRECT;"),T=e=>{if(typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string")return!1;let o=e.digest;return o.endsWith(";404")||o.endsWith(";403")||o.endsWith(";401")},w=e=>x(e)||T(e),A="[unknown:page:server:component]";function L(e,o){let n=P(e.debug),t=e.id??A,v=e.onError??(i=>{throw n.error(`\u{1F6D1} Unexpected error in page server component '${t}'`,i),i}),l=e.onSegmentsValidationError??(i=>{throw n.error(`\u{1F6D1} Invalid segments for page server component '${t}'`,i),new S("segments",t,"page")}),C=e.onSearchParamsValidationError??(i=>{throw n.error(`\u{1F6D1} Invalid search params for server component '${t}'`,i),new S("searchParams",t,"page")}),p=e.authorize??(async()=>{});return async function(d){let s=y();s.start(),n.info(`\u{1F504} Running page server component'${t}'`);let u;if(e.segments){let a=await d.params;if(a===void 0)throw new f(t,"page");let m=g(e.segments,a);m.issues?await l(m.issues):u=m.value}let r;if(e.searchParams){let a=await d.searchParams;if(a===void 0)throw new h(t,"page");let m=g(e.searchParams,a);m.issues?await C(m.issues):r=m.value}let c;try{let a={id:t,...u?{segments:u}:{},...r?{searchParams:r}:{}};c=await p(a)}catch(a){throw n.error(
|
|
1
|
+
import{a as P,b as y,d as g}from"../chunk-DT3TEL5X.js";var S=class extends Error{constructor(o,n,t){super(`${o==="searchParams"?"Search params":"Segments"} validation error for ${t} server component '${n}`),this.name="ValidationError"}},f=class extends Error{constructor(o,n){super(`No segments provided for ${n} server component '${o}'`),this.name="NoSegmentsProvidedError"}},h=class extends Error{constructor(o,n){super(`No search params provided for ${n} server component '${o}'`),this.name="NoSearchParamsProvidedError"}};var x=e=>typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string"?!1:e.digest.startsWith("NEXT_REDIRECT;"),T=e=>{if(typeof e!="object"||e===null||!("digest"in e)||typeof e.digest!="string")return!1;let o=e.digest;return o.endsWith(";404")||o.endsWith(";403")||o.endsWith(";401")},w=e=>x(e)||T(e),A="[unknown:page:server:component]";function L(e,o){let n=P(e.debug),t=e.id??A,v=e.onError??(i=>{throw n.error(`\u{1F6D1} Unexpected error in page server component '${t}'`,i),i}),l=e.onSegmentsValidationError??(i=>{throw n.error(`\u{1F6D1} Invalid segments for page server component '${t}'`,i),new S("segments",t,"page")}),C=e.onSearchParamsValidationError??(i=>{throw n.error(`\u{1F6D1} Invalid search params for server component '${t}'`,i),new S("searchParams",t,"page")}),p=e.authorize??(async()=>{});return async function(d){let s=y();s.start(),n.info(`\u{1F504} Running page server component'${t}'`);let u;if(e.segments){let a=await d.params;if(a===void 0)throw new f(t,"page");let m=g(e.segments,a);m.issues?await l(m.issues):u=m.value}let r;if(e.searchParams){let a=await d.searchParams;if(a===void 0)throw new h(t,"page");let m=g(e.searchParams,a);m.issues?await C(m.issues):r=m.value}let c;try{let a={id:t,...u?{segments:u}:{},...r?{searchParams:r}:{}};c=await p(a)}catch(a){throw n.error(`\u{1F6D1} Page server component '${t}' not authorized`),a}try{let a={id:t,...c?{auth:c}:{},...u?{segments:u}:{},...r?{searchParams:r}:{}},m=await o(a);return s.stop(),n.info(`\u2705 Page server component '${t}' executed successfully in ${s.get()}`),m}catch(a){if(s.stop(),w(a))throw n.info("\u2139\uFE0F Ignoring native Next.js error"),a;return n.error(`\u{1F6D1} Page server component '${t}' failed to execute after ${s.get()}`),await v(a)}}}var E="[unknown:layout:server:component]";function $(e,o){let n=P(e.debug),t=e.id??E,v=e.onError??(p=>{throw n.error(`\u{1F6D1} Unexpected error in layout server component '${t}'`,p),p}),l=e.onSegmentsValidationError??(p=>{throw n.error(`\u{1F6D1} Invalid segments for layout server component '${t}'`,p),new S("segments",t,"page")}),C=e.authorize??(async()=>{});return async function(i){let d=y();d.start(),n.info(`\u{1F504} Running layout server component'${t}'`);let s;if(e.segments){let r=await i.params;if(r===void 0)throw new f(t,"page");let c=g(e.segments,r);c.issues?await l(c.issues):s=c.value}let u;try{let r={id:t,...s?{segments:s}:{}};u=await C(r)}catch(r){throw n.error(`\u{1F6D1} Layout server component '${t}' not authorized`),r}try{let r={id:t,...u?{auth:u}:{},...s?{segments:s}:{},children:i.children},c=await o(r);return d.stop(),n.info(`\u2705 Layout server component '${t}' executed successfully in ${d.get()}`),c}catch(r){if(d.stop(),w(r))throw n.info("\u2139\uFE0F Ignoring native Next.js error"),r;return n.error(`\u{1F6D1} Layout server component '${t}' failed to execute after ${d.get()}`),await v(r)}}}export{$ as createSafeLayoutServerComponent,L as createSafePageServerComponent};
|
|
2
2
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/server-components/errors.ts","../../src/server-components/create-safe-server-component.ts"],"sourcesContent":["/**\n * Validation error for server components.\n */\nexport class ValidationError extends Error {\n constructor(\n validationType: 'segments' | 'searchParams',\n id: string,\n serverComponentType: 'page' | 'layout'\n ) {\n super(\n `${validationType === 'searchParams' ? 'Search params' : 'Segments'} validation error for ${serverComponentType} server component '${id}`\n )\n this.name = 'ValidationError'\n }\n}\n\n/**\n * No segments provided error for server components.\n */\nexport class NoSegmentsProvidedError extends Error {\n constructor(id: string, serverComponentType: 'page' | 'layout') {\n super(\n `No segments provided for ${serverComponentType} server component '${id}'`\n )\n this.name = 'NoSegmentsProvidedError'\n }\n}\n\n/**\n * No search params provided error for server components.\n */\nexport class NoSearchParamsProvidedError extends Error {\n constructor(id: string, serverComponentType: 'page' | 'layout') {\n super(\n `No search params provided for ${serverComponentType} server component '${id}'`\n )\n this.name = 'NoSearchParamsProvidedError'\n }\n}\n","import { createExecutionClock, createLogger } from '../utils'\nimport { parseWithDictionary, type StandardSchemaV1 } from '../standard-schema'\nimport type { Awaitable, AuthContext } from '../types'\nimport type {\n TSegmentsDict,\n TSearchParamsDict,\n PageAuthFunctionParams,\n PageProvidedProps,\n SafePageServerComponentContext,\n CreateSafePageServerComponentOptions,\n CreateSafePageServerComponentReturnType,\n SafePageServerComponent,\n CreateSafeLayoutServerComponentOptions,\n SafeLayoutServerComponent,\n CreateSafeLayoutServerComponentReturnType,\n LayoutProvidedProps,\n LayoutAuthFunctionParams,\n SafeLayoutServerComponentContext,\n} from './types'\nimport {\n ValidationError,\n NoSegmentsProvidedError,\n NoSearchParamsProvidedError,\n} from './errors'\n\n/**\n * @internal\n * Checks if an error is a Next.js redirect error.\n */\nconst isNextRedirectError = (error: unknown): boolean => {\n if (\n typeof error !== 'object' ||\n error === null ||\n !('digest' in error) ||\n typeof error.digest !== 'string'\n ) {\n return false\n }\n return error.digest.startsWith('NEXT_REDIRECT;')\n}\n\n/**\n * @internal\n * Checks if an error is a Next.js HTTP error (notFound, forbidden, unauthorized).\n */\nconst isNextHttpError = (error: unknown): boolean => {\n if (\n typeof error !== 'object' ||\n error === null ||\n !('digest' in error) ||\n typeof error.digest !== 'string'\n ) {\n return false\n }\n const digest = error.digest\n // Check for notFound (;404), forbidden (;403), or unauthorized (;401)\n return (\n digest.endsWith(';404') ||\n digest.endsWith(';403') ||\n digest.endsWith(';401')\n )\n}\n\n/**\n * @internal\n * Checks if an error is a Next.js native error that should not be logged.\n */\nconst isNextNativeError = (error: unknown): boolean => {\n return isNextRedirectError(error) || isNextHttpError(error)\n}\n\n/** @internal exported for testing only */\nexport const DEFAULT_PAGE_ID = '[unknown:page:server:component]'\n\n/**\n * Creates a safe page server component with data validation and error handling\n * for Next.js (>= 14) page server components.\n *\n * @param options - Options to configure the pageserver component.\n * @param pageServerComponentFn - The page server component function.\n *\n * @returns A Next.js page server component.\n */\nexport function createSafePageServerComponent<\n AC extends AuthContext | undefined = undefined,\n TSegments extends TSegmentsDict | undefined = undefined,\n TSearchParams extends TSearchParamsDict | undefined = undefined,\n>(\n options: CreateSafePageServerComponentOptions<AC, TSegments, TSearchParams>,\n pageServerComponentFn: SafePageServerComponent<AC, TSegments, TSearchParams>\n): CreateSafePageServerComponentReturnType {\n const log = createLogger(options.debug)\n const id = options.id ?? DEFAULT_PAGE_ID\n\n const onError =\n options.onError ??\n ((err: unknown): Awaitable<never> => {\n log.error(`🛑 Unexpected error in page server component '${id}'`, err)\n throw err\n })\n\n const onSegmentsValidationError =\n options.onSegmentsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(`🛑 Invalid segments for page server component '${id}'`, issues)\n throw new ValidationError('segments', id, 'page')\n })\n\n const onSearchParamsValidationError =\n options.onSearchParamsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(`🛑 Invalid search params for server component '${id}'`, issues)\n throw new ValidationError('searchParams', id, 'page')\n })\n\n const authorize = options.authorize ?? (async () => undefined)\n\n // Next.js page server component\n return async function SafePageServerComponent(\n props: PageProvidedProps\n ): Promise<React.ReactElement | never> {\n const executionClock = createExecutionClock()\n executionClock.start()\n\n log.info(`🔄 Running page server component'${id}'`)\n\n let segments = undefined\n if (options.segments) {\n const params_unsafe = await props.params\n if (params_unsafe === undefined) {\n throw new NoSegmentsProvidedError(id, 'page')\n }\n\n const parsedSegments = parseWithDictionary(\n options.segments,\n params_unsafe\n )\n if (parsedSegments.issues) {\n await onSegmentsValidationError(parsedSegments.issues)\n } else {\n segments = parsedSegments.value\n }\n }\n\n let searchParams = undefined\n if (options.searchParams) {\n const searchParams_unsafe = await props.searchParams\n if (searchParams_unsafe === undefined) {\n throw new NoSearchParamsProvidedError(id, 'page')\n }\n\n const parsedSearchParams = parseWithDictionary(\n options.searchParams,\n searchParams_unsafe\n )\n if (parsedSearchParams.issues) {\n await onSearchParamsValidationError(parsedSearchParams.issues)\n } else {\n searchParams = parsedSearchParams.value\n }\n }\n\n // Authorize the server component\n let auth = undefined\n try {\n // Build page auth function params\n const authParams = {\n id,\n ...(segments ? { segments } : {}),\n ...(searchParams ? { searchParams } : {}),\n } as PageAuthFunctionParams<TSegments, TSearchParams>\n\n auth = await authorize(authParams)\n } catch (err: unknown) {\n log.error(`Page server component '${id}' not authorized`)\n throw err\n }\n\n try {\n // Build safe page server component context\n const ctx = {\n id,\n ...(auth ? { auth } : {}),\n ...(segments ? { segments } : {}),\n ...(searchParams ? { searchParams } : {}),\n } as SafePageServerComponentContext<AC, TSegments, TSearchParams>\n\n // Execute the page server component\n const PageServerComponent = await pageServerComponentFn(ctx)\n\n // Stop the execution clock\n executionClock.stop()\n log.info(\n `✅ Page server component '${id}' executed successfully in ${executionClock.get()}`\n )\n\n return PageServerComponent\n } catch (err: unknown) {\n executionClock.stop()\n if (!isNextNativeError(err)) {\n log.error(\n `🛑 Page server component '${id}' failed to execute after ${executionClock.get()}`,\n err\n )\n }\n return await onError(err)\n }\n }\n}\n\n/** @internal exported for testing only */\nexport const DEFAULT_LAYOUT_ID = '[unknown:layout:server:component]'\n\n/**\n * Creates a safe layout server component with data validation and error handling\n * for Next.js (>= 14) layout server components.\n *\n * @param options - Options to configure the pageserver component.\n * @param layoutServerComponentFn - The layout server component function.\n *\n * @returns A Next.js layout server component.\n */\nexport function createSafeLayoutServerComponent<\n AC extends AuthContext | undefined = undefined,\n TSegments extends TSegmentsDict | undefined = undefined,\n>(\n options: CreateSafeLayoutServerComponentOptions<AC, TSegments>,\n layoutServerComponentFn: SafeLayoutServerComponent<AC, TSegments>\n): CreateSafeLayoutServerComponentReturnType {\n const log = createLogger(options.debug)\n const id = options.id ?? DEFAULT_LAYOUT_ID\n\n const onError =\n options.onError ??\n ((err: unknown): Awaitable<never> => {\n log.error(`🛑 Unexpected error in layout server component '${id}'`, err)\n throw err\n })\n\n const onSegmentsValidationError =\n options.onSegmentsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(\n `🛑 Invalid segments for layout server component '${id}'`,\n issues\n )\n throw new ValidationError('segments', id, 'page')\n })\n\n const authorize = options.authorize ?? (async () => undefined)\n\n // Next.js layout server component\n return async function SafeLayoutServerComponent(props: LayoutProvidedProps) {\n const executionClock = createExecutionClock()\n executionClock.start()\n\n log.info(`🔄 Running layout server component'${id}'`)\n\n let segments = undefined\n if (options.segments) {\n const params_unsafe = await props.params\n if (params_unsafe === undefined) {\n throw new NoSegmentsProvidedError(id, 'page')\n }\n\n const parsedSegments = parseWithDictionary(\n options.segments,\n params_unsafe\n )\n if (parsedSegments.issues) {\n await onSegmentsValidationError(parsedSegments.issues)\n } else {\n segments = parsedSegments.value\n }\n }\n\n // Authorize the server component\n let auth = undefined\n try {\n // Build layout auth function params\n const authParams = {\n id,\n ...(segments ? { segments } : {}),\n } as LayoutAuthFunctionParams<TSegments>\n\n auth = await authorize(authParams)\n } catch (err: unknown) {\n log.error(`Layout server component '${id}' not authorized`)\n throw err\n }\n\n try {\n // Build safe layout server component context\n const ctx = {\n id,\n ...(auth ? { auth } : {}),\n ...(segments ? { segments } : {}),\n children: props.children,\n } as SafeLayoutServerComponentContext<AC, TSegments>\n\n // Execute the layout server component\n const LayoutServerComponent = await layoutServerComponentFn(ctx)\n\n // Stop the execution clock\n executionClock.stop()\n log.info(\n `✅ Layout server component '${id}' executed successfully in ${executionClock.get()}`\n )\n\n return LayoutServerComponent\n } catch (err: unknown) {\n executionClock.stop()\n if (!isNextNativeError(err)) {\n log.error(\n `🛑 Layout server component '${id}' failed to execute after ${executionClock.get()}`,\n err\n )\n }\n return await onError(err)\n }\n }\n}\n"],"mappings":"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","names":["ValidationError","validationType","id","serverComponentType","NoSegmentsProvidedError","NoSearchParamsProvidedError","isNextRedirectError","error","isNextHttpError","digest","isNextNativeError","DEFAULT_PAGE_ID","createSafePageServerComponent","options","pageServerComponentFn","log","createLogger","id","onError","err","onSegmentsValidationError","issues","ValidationError","onSearchParamsValidationError","authorize","props","executionClock","createExecutionClock","segments","params_unsafe","NoSegmentsProvidedError","parsedSegments","parseWithDictionary","searchParams","searchParams_unsafe","NoSearchParamsProvidedError","parsedSearchParams","auth","authParams","ctx","PageServerComponent","DEFAULT_LAYOUT_ID","createSafeLayoutServerComponent","layoutServerComponentFn","LayoutServerComponent"]}
|
|
1
|
+
{"version":3,"sources":["../../src/server-components/errors.ts","../../src/server-components/create-safe-server-component.ts"],"sourcesContent":["/**\n * Validation error for server components.\n */\nexport class ValidationError extends Error {\n constructor(\n validationType: 'segments' | 'searchParams',\n id: string,\n serverComponentType: 'page' | 'layout'\n ) {\n super(\n `${validationType === 'searchParams' ? 'Search params' : 'Segments'} validation error for ${serverComponentType} server component '${id}`\n )\n this.name = 'ValidationError'\n }\n}\n\n/**\n * No segments provided error for server components.\n */\nexport class NoSegmentsProvidedError extends Error {\n constructor(id: string, serverComponentType: 'page' | 'layout') {\n super(\n `No segments provided for ${serverComponentType} server component '${id}'`\n )\n this.name = 'NoSegmentsProvidedError'\n }\n}\n\n/**\n * No search params provided error for server components.\n */\nexport class NoSearchParamsProvidedError extends Error {\n constructor(id: string, serverComponentType: 'page' | 'layout') {\n super(\n `No search params provided for ${serverComponentType} server component '${id}'`\n )\n this.name = 'NoSearchParamsProvidedError'\n }\n}\n","import { createExecutionClock, createLogger } from '../utils'\nimport { parseWithDictionary, type StandardSchemaV1 } from '../standard-schema'\nimport type { Awaitable, AuthContext } from '../types'\nimport type {\n TSegmentsDict,\n TSearchParamsDict,\n PageAuthFunctionParams,\n PageProvidedProps,\n SafePageServerComponentContext,\n CreateSafePageServerComponentOptions,\n CreateSafePageServerComponentReturnType,\n SafePageServerComponent,\n CreateSafeLayoutServerComponentOptions,\n SafeLayoutServerComponent,\n CreateSafeLayoutServerComponentReturnType,\n LayoutProvidedProps,\n LayoutAuthFunctionParams,\n SafeLayoutServerComponentContext,\n} from './types'\nimport {\n ValidationError,\n NoSegmentsProvidedError,\n NoSearchParamsProvidedError,\n} from './errors'\n\n/**\n * @internal\n * Checks if an error is a Next.js redirect error.\n */\nconst isNextRedirectError = (error: unknown): boolean => {\n if (\n typeof error !== 'object' ||\n error === null ||\n !('digest' in error) ||\n typeof error.digest !== 'string'\n ) {\n return false\n }\n return error.digest.startsWith('NEXT_REDIRECT;')\n}\n\n/**\n * @internal\n * Checks if an error is a Next.js HTTP error (notFound, forbidden, unauthorized).\n */\nconst isNextHttpError = (error: unknown): boolean => {\n if (\n typeof error !== 'object' ||\n error === null ||\n !('digest' in error) ||\n typeof error.digest !== 'string'\n ) {\n return false\n }\n const digest = error.digest\n // Check for notFound (;404), forbidden (;403), or unauthorized (;401)\n return (\n digest.endsWith(';404') ||\n digest.endsWith(';403') ||\n digest.endsWith(';401')\n )\n}\n\n/**\n * @internal\n * Checks if an error is a Next.js native error that should not be logged.\n */\nconst isNextNativeError = (error: unknown): boolean => {\n return isNextRedirectError(error) || isNextHttpError(error)\n}\n\n/** @internal exported for testing only */\nexport const DEFAULT_PAGE_ID = '[unknown:page:server:component]'\n\n/**\n * Creates a safe page server component with data validation and error handling\n * for Next.js (>= 14) page server components.\n *\n * @param options - Options to configure the pageserver component.\n * @param pageServerComponentFn - The page server component function.\n *\n * @returns A Next.js page server component.\n */\nexport function createSafePageServerComponent<\n AC extends AuthContext | undefined = undefined,\n TSegments extends TSegmentsDict | undefined = undefined,\n TSearchParams extends TSearchParamsDict | undefined = undefined,\n>(\n options: CreateSafePageServerComponentOptions<AC, TSegments, TSearchParams>,\n pageServerComponentFn: SafePageServerComponent<AC, TSegments, TSearchParams>\n): CreateSafePageServerComponentReturnType {\n const log = createLogger(options.debug)\n const id = options.id ?? DEFAULT_PAGE_ID\n\n const onError =\n options.onError ??\n ((err: unknown): Awaitable<never> => {\n log.error(`🛑 Unexpected error in page server component '${id}'`, err)\n throw err\n })\n\n const onSegmentsValidationError =\n options.onSegmentsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(`🛑 Invalid segments for page server component '${id}'`, issues)\n throw new ValidationError('segments', id, 'page')\n })\n\n const onSearchParamsValidationError =\n options.onSearchParamsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(`🛑 Invalid search params for server component '${id}'`, issues)\n throw new ValidationError('searchParams', id, 'page')\n })\n\n const authorize = options.authorize ?? (async () => undefined)\n\n // Next.js page server component\n return async function SafePageServerComponent(\n props: PageProvidedProps\n ): Promise<React.ReactElement | never> {\n const executionClock = createExecutionClock()\n executionClock.start()\n\n log.info(`🔄 Running page server component'${id}'`)\n\n let segments = undefined\n if (options.segments) {\n const params_unsafe = await props.params\n if (params_unsafe === undefined) {\n throw new NoSegmentsProvidedError(id, 'page')\n }\n\n const parsedSegments = parseWithDictionary(\n options.segments,\n params_unsafe\n )\n if (parsedSegments.issues) {\n await onSegmentsValidationError(parsedSegments.issues)\n } else {\n segments = parsedSegments.value\n }\n }\n\n let searchParams = undefined\n if (options.searchParams) {\n const searchParams_unsafe = await props.searchParams\n if (searchParams_unsafe === undefined) {\n throw new NoSearchParamsProvidedError(id, 'page')\n }\n\n const parsedSearchParams = parseWithDictionary(\n options.searchParams,\n searchParams_unsafe\n )\n if (parsedSearchParams.issues) {\n await onSearchParamsValidationError(parsedSearchParams.issues)\n } else {\n searchParams = parsedSearchParams.value\n }\n }\n\n // Authorize the server component\n let auth = undefined\n try {\n // Build page auth function params\n const authParams = {\n id,\n ...(segments ? { segments } : {}),\n ...(searchParams ? { searchParams } : {}),\n } as PageAuthFunctionParams<TSegments, TSearchParams>\n\n auth = await authorize(authParams)\n } catch (err: unknown) {\n log.error(`🛑 Page server component '${id}' not authorized`)\n throw err\n }\n\n try {\n // Build safe page server component context\n const ctx = {\n id,\n ...(auth ? { auth } : {}),\n ...(segments ? { segments } : {}),\n ...(searchParams ? { searchParams } : {}),\n } as SafePageServerComponentContext<AC, TSegments, TSearchParams>\n\n // Execute the page server component\n const PageServerComponent = await pageServerComponentFn(ctx)\n\n // Stop the execution clock\n executionClock.stop()\n log.info(\n `✅ Page server component '${id}' executed successfully in ${executionClock.get()}`\n )\n\n return PageServerComponent\n } catch (err: unknown) {\n executionClock.stop()\n\n if (!isNextNativeError(err)) {\n log.error(\n `🛑 Page server component '${id}' failed to execute after ${executionClock.get()}`\n )\n return await onError(err)\n } else {\n log.info('ℹ️ Ignoring native Next.js error')\n throw err\n }\n }\n }\n}\n\n/** @internal exported for testing only */\nexport const DEFAULT_LAYOUT_ID = '[unknown:layout:server:component]'\n\n/**\n * Creates a safe layout server component with data validation and error handling\n * for Next.js (>= 14) layout server components.\n *\n * @param options - Options to configure the pageserver component.\n * @param layoutServerComponentFn - The layout server component function.\n *\n * @returns A Next.js layout server component.\n */\nexport function createSafeLayoutServerComponent<\n AC extends AuthContext | undefined = undefined,\n TSegments extends TSegmentsDict | undefined = undefined,\n>(\n options: CreateSafeLayoutServerComponentOptions<AC, TSegments>,\n layoutServerComponentFn: SafeLayoutServerComponent<AC, TSegments>\n): CreateSafeLayoutServerComponentReturnType {\n const log = createLogger(options.debug)\n const id = options.id ?? DEFAULT_LAYOUT_ID\n\n const onError =\n options.onError ??\n ((err: unknown): Awaitable<never> => {\n log.error(`🛑 Unexpected error in layout server component '${id}'`, err)\n throw err\n })\n\n const onSegmentsValidationError =\n options.onSegmentsValidationError ??\n ((issues: readonly StandardSchemaV1.Issue[]): Awaitable<never> => {\n log.error(\n `🛑 Invalid segments for layout server component '${id}'`,\n issues\n )\n throw new ValidationError('segments', id, 'page')\n })\n\n const authorize = options.authorize ?? (async () => undefined)\n\n // Next.js layout server component\n return async function SafeLayoutServerComponent(props: LayoutProvidedProps) {\n const executionClock = createExecutionClock()\n executionClock.start()\n\n log.info(`🔄 Running layout server component'${id}'`)\n\n let segments = undefined\n if (options.segments) {\n const params_unsafe = await props.params\n if (params_unsafe === undefined) {\n throw new NoSegmentsProvidedError(id, 'page')\n }\n\n const parsedSegments = parseWithDictionary(\n options.segments,\n params_unsafe\n )\n if (parsedSegments.issues) {\n await onSegmentsValidationError(parsedSegments.issues)\n } else {\n segments = parsedSegments.value\n }\n }\n\n // Authorize the server component\n let auth = undefined\n try {\n // Build layout auth function params\n const authParams = {\n id,\n ...(segments ? { segments } : {}),\n } as LayoutAuthFunctionParams<TSegments>\n\n auth = await authorize(authParams)\n } catch (err: unknown) {\n log.error(`🛑 Layout server component '${id}' not authorized`)\n throw err\n }\n\n try {\n // Build safe layout server component context\n const ctx = {\n id,\n ...(auth ? { auth } : {}),\n ...(segments ? { segments } : {}),\n children: props.children,\n } as SafeLayoutServerComponentContext<AC, TSegments>\n\n // Execute the layout server component\n const LayoutServerComponent = await layoutServerComponentFn(ctx)\n\n // Stop the execution clock\n executionClock.stop()\n log.info(\n `✅ Layout server component '${id}' executed successfully in ${executionClock.get()}`\n )\n\n return LayoutServerComponent\n } catch (err: unknown) {\n executionClock.stop()\n\n if (!isNextNativeError(err)) {\n log.error(\n `🛑 Layout server component '${id}' failed to execute after ${executionClock.get()}`\n )\n return await onError(err)\n } else {\n log.info('ℹ️ Ignoring native Next.js error')\n throw err\n }\n }\n }\n}\n"],"mappings":"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","names":["ValidationError","validationType","id","serverComponentType","NoSegmentsProvidedError","NoSearchParamsProvidedError","isNextRedirectError","error","isNextHttpError","digest","isNextNativeError","DEFAULT_PAGE_ID","createSafePageServerComponent","options","pageServerComponentFn","log","createLogger","id","onError","err","onSegmentsValidationError","issues","ValidationError","onSearchParamsValidationError","authorize","props","executionClock","createExecutionClock","segments","params_unsafe","NoSegmentsProvidedError","parsedSegments","parseWithDictionary","searchParams","searchParams_unsafe","NoSearchParamsProvidedError","parsedSearchParams","auth","authParams","ctx","PageServerComponent","DEFAULT_LAYOUT_ID","createSafeLayoutServerComponent","layoutServerComponentFn","LayoutServerComponent"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sugardarius/anzen",
|
|
3
|
-
"version": "2.1.
|
|
3
|
+
"version": "2.1.2",
|
|
4
4
|
"description": "Fast, flexible, framework validation agnostic, type‑safe factories for creating route handlers, page and layout Server Component files in Next.js.",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"packageManager": "npm@11.3.0",
|
|
@@ -47,10 +47,10 @@
|
|
|
47
47
|
},
|
|
48
48
|
"repository": {
|
|
49
49
|
"type": "git",
|
|
50
|
-
"url": "
|
|
50
|
+
"url": "https://github.com/SugarDarius/anzen"
|
|
51
51
|
},
|
|
52
52
|
"bugs": {
|
|
53
|
-
"url": "https://github.com/
|
|
53
|
+
"url": "https://github.com/SugarDarius/anzen/issues"
|
|
54
54
|
},
|
|
55
55
|
"keywords": [
|
|
56
56
|
"nextjs",
|
|
@@ -83,20 +83,21 @@
|
|
|
83
83
|
},
|
|
84
84
|
"devDependencies": {
|
|
85
85
|
"@arethetypeswrong/cli": "^0.18.2",
|
|
86
|
-
"@eslint/
|
|
86
|
+
"@eslint/eslintrc": "^3.3.3",
|
|
87
|
+
"@eslint/js": "^9.39.2",
|
|
87
88
|
"@release-it/keep-a-changelog": "^7.0.0",
|
|
88
|
-
"@types/node": "^
|
|
89
|
-
"@types/react": "^19.2.
|
|
89
|
+
"@types/node": "^25.0.3",
|
|
90
|
+
"@types/react": "^19.2.7",
|
|
90
91
|
"decoders": "^2.7.5",
|
|
91
|
-
"eslint": "^9.39.
|
|
92
|
-
"prettier": "^3.
|
|
93
|
-
"publint": "^0.3.
|
|
94
|
-
"release-it": "^19.
|
|
92
|
+
"eslint": "^9.39.2",
|
|
93
|
+
"prettier": "^3.7.4",
|
|
94
|
+
"publint": "^0.3.16",
|
|
95
|
+
"release-it": "^19.2.1",
|
|
95
96
|
"tsup": "^8.5.1",
|
|
96
97
|
"turbo": "^2.5.6",
|
|
97
98
|
"typescript": "^5.9.3",
|
|
98
|
-
"typescript-eslint": "^8.
|
|
99
|
+
"typescript-eslint": "^8.50.1",
|
|
99
100
|
"vitest": "^3.2.4",
|
|
100
|
-
"zod": "^4.1
|
|
101
|
+
"zod": "^4.2.1"
|
|
101
102
|
}
|
|
102
103
|
}
|