rsnext/packages/next/next-server/server/serve-static.ts
Steven d3741d5ec5
Add support for Image Optimizer (#17749)
Co-authored-by: JJ Kasper <jj@jjsweb.site>
2020-10-16 13:10:01 +02:00

41 lines
1,020 B
TypeScript

import { IncomingMessage, ServerResponse } from 'http'
import send from 'next/dist/compiled/send'
export function serveStatic(
req: IncomingMessage,
res: ServerResponse,
path: string
): Promise<void> {
return new Promise((resolve, reject) => {
send(req, path)
.on('directory', () => {
// We don't allow directories to be read.
const err: any = new Error('No directory access')
err.code = 'ENOENT'
reject(err)
})
.on('error', reject)
.pipe(res)
.on('finish', resolve)
})
}
export function getContentType(extWithoutDot: string): string | null {
const { mime } = send
if ('getType' in mime) {
// 2.0
return mime.getType(extWithoutDot)
}
// 1.0
return (mime as any).lookup(extWithoutDot)
}
export function getExtension(contentType: string): string | null {
const { mime } = send
if ('getExtension' in mime) {
// 2.0
return mime.getExtension(contentType)
}
// 1.0
return (mime as any).extension(contentType)
}