server.ts — vue Source File
Architecture documentation for server.ts, a typescript file in the vue codebase. 4 imports, 0 dependents.
Entity Profile
Dependency Diagram
graph LR cd8987ca_a5b9_5c1b_a002_527ecdd456bf["server.ts"] a4aaa23d_d810_1245_8cde_5c37b4bd3875["util.ts"] cd8987ca_a5b9_5c1b_a002_527ecdd456bf --> a4aaa23d_d810_1245_8cde_5c37b4bd3875 165ad625_fe2f_2841_ca25_48bc6fda664f["validate"] cd8987ca_a5b9_5c1b_a002_527ecdd456bf --> 165ad625_fe2f_2841_ca25_48bc6fda664f 8c797278_c0eb_766a_663c_40edd789a258["getAssetName"] cd8987ca_a5b9_5c1b_a002_527ecdd456bf --> 8c797278_c0eb_766a_663c_40edd789a258 67bc246a_b935_05a8_c244_11f687e4f578["onEmit"] cd8987ca_a5b9_5c1b_a002_527ecdd456bf --> 67bc246a_b935_05a8_c244_11f687e4f578 style cd8987ca_a5b9_5c1b_a002_527ecdd456bf fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
import { validate, isJS, getAssetName, onEmit } from './util'
export default class VueSSRServerPlugin {
constructor(options = {}) {
//@ts-expect-error
this.options = Object.assign(
{
filename: 'vue-ssr-server-bundle.json'
},
options
)
}
apply(compiler) {
validate(compiler)
const stage = 'PROCESS_ASSETS_STAGE_OPTIMIZE_TRANSFER'
onEmit(compiler, 'vue-server-plugin', stage, (compilation, cb) => {
const stats = compilation.getStats().toJson()
const entryName = Object.keys(stats.entrypoints)[0]
const entryInfo = stats.entrypoints[entryName]
if (!entryInfo) {
// #5553
return cb()
}
const entryAssets = entryInfo.assets.map(getAssetName).filter(isJS)
if (entryAssets.length > 1) {
throw new Error(
`Server-side bundle should have one single entry file. ` +
`Avoid using CommonsChunkPlugin in the server config.`
)
}
const entry = entryAssets[0]
if (!entry || typeof entry !== 'string') {
throw new Error(
`Entry "${entryName}" not found. Did you specify the correct entry option?`
)
}
const bundle = {
entry,
files: {},
maps: {}
}
Object.keys(compilation.assets).forEach(name => {
if (isJS(name)) {
bundle.files[name] = compilation.assets[name].source()
} else if (name.match(/\.js\.map$/)) {
bundle.maps[name.replace(/\.map$/, '')] = JSON.parse(
compilation.assets[name].source()
)
}
// do not emit anything else for server
delete compilation.assets[name]
})
const json = JSON.stringify(bundle, null, 2)
//@ts-expect-error
const filename = this.options.filename
compilation.assets[filename] = {
source: () => json,
size: () => json.length
}
cb()
})
}
}
Domain
Subdomains
Classes
Dependencies
Source
Frequently Asked Questions
What does server.ts do?
server.ts is a source file in the vue codebase, written in typescript. It belongs to the ServerRenderer domain, BundleRenderer subdomain.
What does server.ts depend on?
server.ts imports 4 module(s): getAssetName, onEmit, util.ts, validate.
Where is server.ts in the architecture?
server.ts is located at packages/server-renderer/src/webpack-plugin/server.ts (domain: ServerRenderer, subdomain: BundleRenderer, directory: packages/server-renderer/src/webpack-plugin).
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free