Revert to custom file sending logic

This commit is contained in:
MICHAEL JACKSON 2017-08-26 20:38:31 -07:00
parent 5331120a84
commit dd8df34574
3 changed files with 36 additions and 19 deletions

View File

@ -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",

View File

@ -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',
console.error(`Cannot send file ${req.packageSpec}${req.filename}`) 'Last-Modified': req.stats.mtime.toUTCString(),
console.error(error) 'ETag': etag(req.stats),
// res.status(500).type('text').send(`Cannot send file ${req.packageSpec}${req.filename}`) 'Cache-Tag': tags.join(',')
res.sendStatus(500)
}
}) })
const stream = fs.createReadStream(file)
stream.on('error', function (error) {
console.error(`Cannot send file ${req.packageSpec}${req.filename}`)
console.error(error)
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)

View File

@ -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"