Nuxt/packages/nitro/src/rollup/config.ts

218 lines
7.0 KiB
TypeScript
Raw Normal View History

2020-11-01 23:17:44 +00:00
import Module from 'module'
2020-11-20 00:16:31 +00:00
import { dirname, join, relative, resolve } from 'upath'
2020-11-01 23:17:44 +00:00
import { InputOptions, OutputOptions } from 'rollup'
import { terser } from 'rollup-plugin-terser'
import commonjs from '@rollup/plugin-commonjs'
2020-11-05 15:36:31 +00:00
import nodeResolve from '@rollup/plugin-node-resolve'
2020-11-01 23:17:44 +00:00
import alias from '@rollup/plugin-alias'
import json from '@rollup/plugin-json'
import replace from '@rollup/plugin-replace'
import virtual from '@rollup/plugin-virtual'
2020-11-13 16:14:17 +00:00
import inject from '@rollup/plugin-inject'
2020-11-01 23:17:44 +00:00
import analyze from 'rollup-plugin-analyzer'
2020-11-20 00:16:31 +00:00
import * as un from '@nuxt/un'
import hasha from 'hasha'
2020-11-20 00:16:31 +00:00
import { SigmaContext } from '../context'
import { resolvePath, MODULE_DIR } from '../utils'
2020-11-15 00:52:18 +00:00
import { dynamicRequire } from './dynamic-require'
import { externals } from './externals'
2020-11-15 00:52:18 +00:00
import { timing } from './timing'
import { autoMock } from './automock'
2020-11-01 23:17:44 +00:00
export type RollupConfig = InputOptions & { output: OutputOptions }
2020-11-20 00:16:31 +00:00
export const getRollupConfig = (sigmaContext: SigmaContext) => {
const extensions: string[] = ['.ts', '.js', '.json', '.node']
2020-11-01 23:17:44 +00:00
const external: InputOptions['external'] = []
2020-11-13 16:14:17 +00:00
2020-11-20 00:16:31 +00:00
const presets = []
if (sigmaContext.node === false) {
presets.push(un.nodeless)
2020-11-01 23:17:44 +00:00
} else {
2020-11-20 00:16:31 +00:00
presets.push(un.node)
2020-11-01 23:17:44 +00:00
external.push(...Module.builtinModules)
}
2020-11-20 00:16:31 +00:00
const env = un.env(...presets, {
alias: {
depd: require.resolve('@nuxt/un/runtime/npm/depd')
}
})
const buildServerDir = join(sigmaContext._nuxt.buildDir, 'dist/server')
const runtimeAppDir = join(sigmaContext._internal.runtimeDir, 'app')
const rollupConfig: RollupConfig = {
2020-11-20 00:16:31 +00:00
input: resolvePath(sigmaContext, sigmaContext.entry),
2020-11-01 23:17:44 +00:00
output: {
2020-11-20 00:16:31 +00:00
dir: sigmaContext.output.serverDir,
entryFileNames: 'index.js',
2020-11-15 01:31:50 +00:00
chunkFileNames (chunkInfo) {
let prefix = ''
const modules = Object.keys(chunkInfo.modules)
const lastModule = modules[modules.length - 1]
2020-11-20 00:16:31 +00:00
if (lastModule.startsWith(buildServerDir)) {
prefix = join('app', relative(buildServerDir, dirname(lastModule)))
} else if (lastModule.startsWith(runtimeAppDir)) {
prefix = 'app'
} else if (lastModule.startsWith(sigmaContext._nuxt.buildDir)) {
prefix = 'nuxt'
} else if (lastModule.startsWith(sigmaContext._internal.runtimeDir)) {
prefix = 'sigma'
} else if (!prefix && sigmaContext.middleware.find(m => lastModule.startsWith(m.handle))) {
2020-11-15 01:31:50 +00:00
prefix = 'middleware'
}
2020-11-20 00:16:31 +00:00
return join('chunks', prefix, '[name].js')
2020-11-15 01:31:50 +00:00
},
2020-11-20 00:16:31 +00:00
inlineDynamicImports: sigmaContext.inlineChunks,
2020-11-01 23:17:44 +00:00
format: 'cjs',
exports: 'auto',
2020-11-01 23:17:44 +00:00
intro: '',
outro: '',
preferConst: true
},
external,
2020-11-20 21:04:48 +00:00
plugins: [],
onwarn (warning, rollupWarn) {
if (!['CIRCULAR_DEPENDENCY', 'EVAL'].includes(warning.code)) {
rollupWarn(warning)
}
}
2020-11-01 23:17:44 +00:00
}
2020-11-20 00:16:31 +00:00
if (sigmaContext.timing) {
2020-11-15 00:52:18 +00:00
rollupConfig.plugins.push(timing())
2020-11-02 14:42:27 +00:00
}
2020-11-02 00:31:43 +00:00
// https://github.com/rollup/plugins/tree/master/packages/replace
rollupConfig.plugins.push(replace({
2020-11-02 00:31:43 +00:00
values: {
2020-11-20 00:16:31 +00:00
'process.env.NODE_ENV': sigmaContext._nuxt.dev ? '"development"' : '"production"',
2020-11-05 18:53:17 +00:00
'typeof window': '"undefined"',
2020-11-20 00:16:31 +00:00
'process.env.ROUTER_BASE': JSON.stringify(sigmaContext._nuxt.routerBase),
'process.env.PUBLIC_PATH': JSON.stringify(sigmaContext._nuxt.publicPath),
'process.env.NUXT_STATIC_BASE': JSON.stringify(sigmaContext._nuxt.staticAssets.base),
'process.env.NUXT_STATIC_VERSION': JSON.stringify(sigmaContext._nuxt.staticAssets.version),
// @ts-ignore
2020-11-20 14:34:47 +00:00
'process.env.NUXT_FULL_STATIC': sigmaContext.fullStatic,
'process.env.SIGMA_PRESET': JSON.stringify(sigmaContext.preset)
2020-11-02 00:31:43 +00:00
}
}))
2020-11-03 19:55:36 +00:00
// Dynamic Require Support
rollupConfig.plugins.push(dynamicRequire({
2020-11-20 00:16:31 +00:00
dir: resolve(sigmaContext._nuxt.buildDir, 'dist/server'),
inline: sigmaContext.node === false || sigmaContext.inlineChunks,
2020-11-03 19:55:36 +00:00
globbyOptions: {
ignore: [
'server.js'
]
}
}))
2020-11-02 13:11:26 +00:00
2020-11-14 00:49:37 +00:00
// https://github.com/rollup/plugins/tree/master/packages/replace
// TODO: better fix for node-fetch issue
rollupConfig.plugins.push(replace({
2020-11-14 00:49:37 +00:00
delimiters: ['', ''],
values: {
'require(\'encoding\')': '{}'
}
}))
// Provide serverMiddleware
const getImportId = p => '_' + hasha(p).substr(0, 6)
rollupConfig.plugins.push(virtual({
'~serverMiddleware': `
2020-11-20 20:11:46 +00:00
${sigmaContext.middleware.filter(m => m.lazy === false).map(m => `import ${getImportId(m.handle)} from '${m.handle}';`).join('\n')}
2020-11-20 20:11:46 +00:00
${sigmaContext.middleware.filter(m => m.lazy !== false).map(m => `const ${getImportId(m.handle)} = () => import('${m.handle}');`).join('\n')}
export default [
2020-11-20 20:13:23 +00:00
${sigmaContext.middleware.map(m => `{ route: '${m.route}', handle: ${getImportId(m.handle)}, lazy: ${m.lazy || true}, promisify: ${m.promisify !== undefined ? m.promisify : true} }`).join(',\n')}
];
`
}))
2020-11-20 00:16:31 +00:00
// Polyfill
rollupConfig.plugins.push(virtual({
2020-11-20 12:14:16 +00:00
'~polyfill': env.polyfill.map(p => `import '${p}';`).join('\n')
2020-11-20 00:16:31 +00:00
}))
2020-11-02 00:31:43 +00:00
// https://github.com/rollup/plugins/tree/master/packages/alias
2020-11-20 00:16:31 +00:00
const renderer = sigmaContext.renderer || 'vue2'
rollupConfig.plugins.push(alias({
2020-11-02 00:31:43 +00:00
entries: {
2020-11-20 00:16:31 +00:00
'~runtime': sigmaContext._internal.runtimeDir,
'~renderer': require.resolve(resolve(sigmaContext._internal.runtimeDir, 'app', renderer)),
'~build': sigmaContext._nuxt.buildDir,
...env.alias
2020-11-02 00:31:43 +00:00
}
}))
// External Plugin
2020-11-20 00:16:31 +00:00
if (sigmaContext.externals) {
rollupConfig.plugins.push(externals({
2020-11-20 00:16:31 +00:00
relativeTo: sigmaContext.output.serverDir,
include: [
2020-11-20 00:16:31 +00:00
sigmaContext._internal.runtimeDir,
...sigmaContext.middleware.map(m => m.handle)
]
}))
}
2020-11-02 00:31:43 +00:00
// https://github.com/rollup/plugins/tree/master/packages/node-resolve
rollupConfig.plugins.push(nodeResolve({
2020-11-02 00:31:43 +00:00
extensions,
preferBuiltins: true,
2020-11-20 00:16:31 +00:00
rootDir: sigmaContext._nuxt.rootDir,
2020-11-02 12:12:39 +00:00
// https://www.npmjs.com/package/resolve
customResolveOptions: {
2020-11-20 00:16:31 +00:00
basedir: sigmaContext._nuxt.rootDir,
paths: [
2020-11-20 00:16:31 +00:00
resolve(sigmaContext._nuxt.rootDir, 'node_modules'),
resolve(MODULE_DIR, 'node_modules')
]
},
2020-11-02 00:31:43 +00:00
mainFields: ['main'] // Force resolve CJS (@vue/runtime-core ssrUtils)
}))
// Automatically mock unresolved externals
rollupConfig.plugins.push(autoMock())
2020-11-02 00:31:43 +00:00
// https://github.com/rollup/plugins/tree/master/packages/commonjs
rollupConfig.plugins.push(commonjs({
2020-11-02 13:11:26 +00:00
extensions: extensions.filter(ext => ext !== '.json')
2020-11-02 00:31:43 +00:00
}))
// https://github.com/rollup/plugins/tree/master/packages/json
rollupConfig.plugins.push(json())
2020-11-02 00:31:43 +00:00
// https://github.com/rollup/plugins/tree/master/packages/inject
2020-11-20 00:16:31 +00:00
rollupConfig.plugins.push(inject(env.inject))
2020-11-20 00:16:31 +00:00
if (sigmaContext.analyze) {
2020-11-01 23:17:44 +00:00
// https://github.com/doesdev/rollup-plugin-analyzer
rollupConfig.plugins.push(analyze())
2020-11-01 23:17:44 +00:00
}
// https://github.com/TrySound/rollup-plugin-terser
2020-11-20 00:16:31 +00:00
// https://github.com/terser/terser#minify-sigmaContext
if (sigmaContext.minify) {
rollupConfig.plugins.push(terser({
mangle: {
keep_fnames: true,
keep_classnames: true
},
format: {
comments: false
}
}))
2020-11-01 23:17:44 +00:00
}
return rollupConfig
2020-11-01 23:17:44 +00:00
}