Remove ResponseUtils

This commit is contained in:
MICHAEL JACKSON 2017-08-10 22:29:44 -07:00
parent 772897e71d
commit 3f50bda1dd
3 changed files with 28 additions and 91 deletions

View File

@ -1,88 +0,0 @@
const fs = require('fs')
const etag = require('etag')
const { getContentType } = require('./FileUtils')
const sendText = (res, statusCode, text) => {
res.writeHead(statusCode, {
'Content-Type': 'text/plain',
'Content-Length': Buffer.byteLength(text)
})
res.end(text)
}
const sendJSON = (res, json, maxAge = 0, statusCode = 200) => {
const text = JSON.stringify(json)
res.writeHead(statusCode, {
'Content-Type': 'application/json',
'Content-Length': Buffer.byteLength(text),
'Cache-Control': `public, max-age=${maxAge}`
})
res.end(text)
}
const sendInvalidURLError = (res, url) =>
sendText(res, 403, `Invalid URL: ${url}`)
const sendNotFoundError = (res, what) =>
sendText(res, 404, `Not found: ${what}`)
const sendServerError = (res, error) =>
sendText(res, 500, `Server error: ${error.message || error}`)
const sendHTML = (res, html, statusCode = 200) => {
res.writeHead(statusCode, {
'Content-Type': 'text/html',
'Content-Length': Buffer.byteLength(html)
})
res.end(html)
}
const sendRedirect = (res, relativeLocation, statusCode = 302) => {
const location = res.req && res.req.baseUrl ? res.req.baseUrl + relativeLocation : relativeLocation
const html = `<p>You are being redirected to <a href="${location}">${location}</a>`
res.writeHead(statusCode, {
'Content-Type': 'text/html',
'Content-Length': Buffer.byteLength(html),
'Location': encodeURI(location)
})
res.end(html)
}
const sendFile = (res, file, stats, maxAge = 0) => {
let contentType = getContentType(file)
if (contentType === 'text/html')
contentType = 'text/plain' // We can't serve HTML because bad people :(
res.writeHead(200, {
'Content-Type': contentType,
'Content-Length': stats.size,
'Cache-Control': `public, max-age=${maxAge}`,
'ETag': etag(stats)
})
const stream = fs.createReadStream(file)
stream.on('error', (error) => {
sendServerError(res, error)
})
stream.pipe(res)
}
module.exports = {
sendText,
sendJSON,
sendInvalidURLError,
sendNotFoundError,
sendServerError,
sendHTML,
sendRedirect,
sendFile
}

View File

@ -71,7 +71,7 @@ function findFile(req, res, next) {
if (queryMain) {
if (!(queryMain in packageConfig))
return res.status(404).send(`Cannot find field "${queryMain}" in ${req.packageSpec}/package.json`)
return res.status(404).send(`Cannot find field "${queryMain}" in ${req.packageSpec} package config`)
mainFilename = packageConfig[queryMain]
} else {

View File

@ -1,7 +1,32 @@
const fs = require('fs')
const path = require('path')
const etag = require('etag')
const { generateMetadata } = require('./MetadataUtils')
const { generateDirectoryIndexHTML } = require('./IndexUtils')
const { sendFile } = require('./ResponseUtils')
const { getContentType } = require('./FileUtils')
function sendFile(res, file, stats, maxAge = 0) {
let contentType = getContentType(file)
if (contentType === 'text/html')
contentType = 'text/plain' // We can't serve HTML because bad people :(
res.writeHead(200, {
'Content-Type': contentType,
'Content-Length': stats.size,
'Cache-Control': `public, max-age=${maxAge}`,
'ETag': etag(stats)
})
const stream = fs.createReadStream(file)
stream.on('error', (error) => {
console.error(error)
res.status(500).send('There was an error serving this file')
})
stream.pipe(res)
}
/**
* Send the file, JSON metadata, or HTML directory listing.
@ -18,7 +43,7 @@ function serveFile(autoIndex, maximumDepth) {
}
})
} else if (req.stats.isFile()) {
// TODO: use res.sendFile instead of our own custom function?
// TODO: use res.sendFile instead of our own sendFile?
sendFile(res, path.join(req.packageDir, req.file), req.stats, 31536000)
} else if (autoIndex && req.stats.isDirectory()) {
generateDirectoryIndexHTML(req.packageInfo, req.packageVersion, req.packageDir, req.file, function (error, html) {