Revert to custom file sending logic
This commit is contained in:
parent
5331120a84
commit
dd8df34574
|
@ -14,6 +14,7 @@
|
||||||
"countries-list": "^1.3.2",
|
"countries-list": "^1.3.2",
|
||||||
"csso": "^3.1.1",
|
"csso": "^3.1.1",
|
||||||
"date-fns": "^1.28.1",
|
"date-fns": "^1.28.1",
|
||||||
|
"etag": "^1.8.0",
|
||||||
"express": "^4.15.2",
|
"express": "^4.15.2",
|
||||||
"gunzip-maybe": "^1.4.0",
|
"gunzip-maybe": "^1.4.0",
|
||||||
"invariant": "^2.2.2",
|
"invariant": "^2.2.2",
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const path = require('path')
|
const path = require('path')
|
||||||
|
const etag = require('etag')
|
||||||
const babel = require('babel-core')
|
const babel = require('babel-core')
|
||||||
const unpkgRewrite = require('babel-plugin-unpkg-rewrite')
|
const unpkgRewrite = require('babel-plugin-unpkg-rewrite')
|
||||||
const getMetadata = require('./utils/getMetadata')
|
const getMetadata = require('./utils/getMetadata')
|
||||||
|
@ -35,6 +36,7 @@ const FileTransforms = {
|
||||||
*/
|
*/
|
||||||
function serveFile(req, res, next) {
|
function serveFile(req, res, next) {
|
||||||
if (req.query.meta != null) {
|
if (req.query.meta != null) {
|
||||||
|
// Serve JSON metadata.
|
||||||
getMetadata(req.packageDir, req.filename, req.stats, MaximumDepth, function (error, metadata) {
|
getMetadata(req.packageDir, req.filename, req.stats, MaximumDepth, function (error, metadata) {
|
||||||
if (error) {
|
if (error) {
|
||||||
console.error(error)
|
console.error(error)
|
||||||
|
@ -48,6 +50,7 @@ function serveFile(req, res, next) {
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} else if (req.stats.isFile()) {
|
} else if (req.stats.isFile()) {
|
||||||
|
// Serve a file.
|
||||||
const file = path.join(req.packageDir, req.filename)
|
const file = path.join(req.packageDir, req.filename)
|
||||||
|
|
||||||
let contentType = getFileContentType(file)
|
let contentType = getFileContentType(file)
|
||||||
|
@ -55,13 +58,8 @@ function serveFile(req, res, next) {
|
||||||
if (contentType === 'text/html')
|
if (contentType === 'text/html')
|
||||||
contentType = 'text/plain' // We can't serve HTML because bad people :(
|
contentType = 'text/plain' // We can't serve HTML because bad people :(
|
||||||
|
|
||||||
// Cache files for 1 year.
|
|
||||||
res.set({
|
|
||||||
'Content-Type': contentType,
|
|
||||||
'Cache-Control': 'public, max-age=31536000'
|
|
||||||
})
|
|
||||||
|
|
||||||
if (contentType === 'application/javascript' && req.query.module != null) {
|
if (contentType === 'application/javascript' && req.query.module != null) {
|
||||||
|
// Serve a JavaScript module.
|
||||||
const dependencies = Object.assign({},
|
const dependencies = Object.assign({},
|
||||||
req.packageConfig.peerDependencies,
|
req.packageConfig.peerDependencies,
|
||||||
req.packageConfig.dependencies
|
req.packageConfig.dependencies
|
||||||
|
@ -72,28 +70,46 @@ function serveFile(req, res, next) {
|
||||||
console.error(error)
|
console.error(error)
|
||||||
res.status(500).type('text').send(`Cannot generate index page for ${req.packageSpec}${req.filename}`)
|
res.status(500).type('text').send(`Cannot generate index page for ${req.packageSpec}${req.filename}`)
|
||||||
} else {
|
} else {
|
||||||
|
// Cache modules for 1 year.
|
||||||
res.set({
|
res.set({
|
||||||
'Cache-Tag': 'file,module'
|
'Content-Type': contentType,
|
||||||
|
'Content-Length': Buffer.byteLength(code),
|
||||||
|
'Cache-Control': 'public, max-age=31536000',
|
||||||
|
'Cache-Tag': 'file,js-file,js-module'
|
||||||
}).send(code)
|
}).send(code)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
const options = {
|
// Serve some other static file.
|
||||||
dotfiles: 'allow'
|
const tags = [ 'file' ]
|
||||||
}
|
|
||||||
|
|
||||||
|
const ext = path.extname(req.filename).substr(1)
|
||||||
|
|
||||||
|
if (ext)
|
||||||
|
tags.push(`${ext}-file`)
|
||||||
|
|
||||||
|
// Cache files for 1 year.
|
||||||
res.set({
|
res.set({
|
||||||
'Cache-Tag': 'file'
|
'Content-Type': contentType,
|
||||||
}).sendFile(file, options, function (error) {
|
'Content-Length': req.stats.size,
|
||||||
if (error) {
|
'Cache-Control': 'public, max-age=31536000',
|
||||||
|
'Last-Modified': req.stats.mtime.toUTCString(),
|
||||||
|
'ETag': etag(req.stats),
|
||||||
|
'Cache-Tag': tags.join(',')
|
||||||
|
})
|
||||||
|
|
||||||
|
const stream = fs.createReadStream(file)
|
||||||
|
|
||||||
|
stream.on('error', function (error) {
|
||||||
console.error(`Cannot send file ${req.packageSpec}${req.filename}`)
|
console.error(`Cannot send file ${req.packageSpec}${req.filename}`)
|
||||||
console.error(error)
|
console.error(error)
|
||||||
// res.status(500).type('text').send(`Cannot send file ${req.packageSpec}${req.filename}`)
|
|
||||||
res.sendStatus(500)
|
res.sendStatus(500)
|
||||||
}
|
|
||||||
})
|
})
|
||||||
|
|
||||||
|
stream.pipe(res)
|
||||||
}
|
}
|
||||||
} else if (AutoIndex && req.stats.isDirectory()) {
|
} else if (AutoIndex && req.stats.isDirectory()) {
|
||||||
|
// Serve an HTML directory listing.
|
||||||
getIndexHTML(req.packageInfo, req.packageVersion, req.packageDir, req.filename, function (error, html) {
|
getIndexHTML(req.packageInfo, req.packageVersion, req.packageDir, req.filename, function (error, html) {
|
||||||
if (error) {
|
if (error) {
|
||||||
console.error(error)
|
console.error(error)
|
||||||
|
|
|
@ -1983,7 +1983,7 @@ esutils@^2.0.2:
|
||||||
version "2.0.2"
|
version "2.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b"
|
resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b"
|
||||||
|
|
||||||
etag@~1.8.0:
|
etag@^1.8.0, etag@~1.8.0:
|
||||||
version "1.8.0"
|
version "1.8.0"
|
||||||
resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.0.tgz#6f631aef336d6c46362b51764044ce216be3c051"
|
resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.0.tgz#6f631aef336d6c46362b51764044ce216be3c051"
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue