next
Version:
The React Framework
55 lines (54 loc) • 1.75 kB
JavaScript
import { z } from 'next/dist/compiled/zod';
import { formatZodError } from '../../../shared/lib/zod';
/**
* The schema for the page segment config.
*/ const PagesSegmentConfigSchema = z.object({
/**
* The runtime to use for the page.
*/ runtime: z.enum([
'edge',
'experimental-edge',
'nodejs'
]).optional(),
/**
* The maximum duration for the page render.
*/ maxDuration: z.number().optional(),
/**
* The exported config object for the page.
*/ config: z.object({
/**
* Enables AMP for the page.
*/ amp: z.union([
z.boolean(),
z.literal('hybrid')
]).optional(),
/**
* The runtime to use for the page.
*/ runtime: z.enum([
'edge',
'experimental-edge',
'nodejs'
]).optional(),
/**
* The maximum duration for the page render.
*/ maxDuration: z.number().optional()
}).optional()
});
/**
* Parse the page segment config.
* @param data - The data to parse.
* @param route - The route of the page.
* @returns The parsed page segment config.
*/ export function parsePagesSegmentConfig(data, route) {
const parsed = PagesSegmentConfigSchema.safeParse(data, {});
if (!parsed.success) {
throw formatZodError(`Invalid segment configuration options detected for "${route}". Read more at https://nextjs.org/docs/messages/invalid-page-config`, parsed.error);
}
return parsed.data;
}
/**
* The keys of the configuration for a page.
*
* @internal - required to exclude zod types from the build
*/ export const PagesSegmentConfigSchemaKeys = PagesSegmentConfigSchema.keyof().options;
//# sourceMappingURL=pages-segment-config.js.map