46e7658f7e
Follow up to #27376 so users can disable keep-alive. See comment https://github.com/vercel/next.js/pull/27376#issuecomment-885415623
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import { buildStaticPaths } from '../../build/utils'
|
|
import { setHttpAgentOptions } from '../config'
|
|
import { NextConfigComplete } from '../config-shared'
|
|
import { loadComponents } from '../load-components'
|
|
import '../node-polyfill-fetch'
|
|
|
|
type RuntimeConfig = any
|
|
|
|
let workerWasUsed = false
|
|
|
|
// we call getStaticPaths in a separate process to ensure
|
|
// side-effects aren't relied on in dev that will break
|
|
// during a production build
|
|
export async function loadStaticPaths(
|
|
distDir: string,
|
|
pathname: string,
|
|
serverless: boolean,
|
|
config: RuntimeConfig,
|
|
httpAgentOptions: NextConfigComplete['httpAgentOptions'],
|
|
locales?: string[],
|
|
defaultLocale?: string
|
|
) {
|
|
// we only want to use each worker once to prevent any invalid
|
|
// caches
|
|
if (workerWasUsed) {
|
|
process.exit(1)
|
|
}
|
|
|
|
// update work memory runtime-config
|
|
require('../../shared/lib/runtime-config').setConfig(config)
|
|
setHttpAgentOptions(httpAgentOptions)
|
|
|
|
const components = await loadComponents(distDir, pathname, serverless)
|
|
|
|
if (!components.getStaticPaths) {
|
|
// we shouldn't get to this point since the worker should
|
|
// only be called for SSG pages with getStaticPaths
|
|
throw new Error(
|
|
`Invariant: failed to load page with getStaticPaths for ${pathname}`
|
|
)
|
|
}
|
|
|
|
workerWasUsed = true
|
|
return buildStaticPaths(
|
|
pathname,
|
|
components.getStaticPaths,
|
|
locales,
|
|
defaultLocale
|
|
)
|
|
}
|