0
Fork 0
mirror of https://github.com/withastro/astro.git synced 2025-01-20 22:12:38 -05:00

fix(images): Return the proper content-type for the chosen format (#6741)

This commit is contained in:
Erika 2023-04-03 18:11:32 +02:00 committed by GitHub
parent 73fcc7627e
commit 4c347ab51e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 16 additions and 7 deletions

View file

@ -0,0 +1,5 @@
---
'astro': patch
---
Fix content-type header being wrong in dev on images from `astro:assets`

View file

@ -1,4 +1,4 @@
import mime from 'mime'; import mime from 'mime/lite.js';
import type { APIRoute } from '../@types/astro.js'; import type { APIRoute } from '../@types/astro.js';
import { isRemotePath } from '../core/path.js'; import { isRemotePath } from '../core/path.js';
import { getConfiguredImageService } from './internal.js'; import { getConfiguredImageService } from './internal.js';
@ -54,7 +54,7 @@ export const get: APIRoute = async ({ request }) => {
return new Response(data, { return new Response(data, {
status: 200, status: 200,
headers: { headers: {
'Content-Type': mime.getType(format) || '', 'Content-Type': mime.getType(format) ?? `image/${format}`,
'Cache-Control': 'public, max-age=31536000', 'Cache-Control': 'public, max-age=31536000',
ETag: etag(data.toString()), ETag: etag(data.toString()),
Date: new Date().toUTCString(), Date: new Date().toUTCString(),

View file

@ -1,6 +1,6 @@
import { bold } from 'kleur/colors'; import { bold } from 'kleur/colors';
import MagicString from 'magic-string'; import MagicString from 'magic-string';
import mime from 'mime'; import mime from 'mime/lite.js';
import fs from 'node:fs/promises'; import fs from 'node:fs/promises';
import { Readable } from 'node:stream'; import { Readable } from 'node:stream';
import { fileURLToPath } from 'node:url'; import { fileURLToPath } from 'node:url';
@ -133,10 +133,7 @@ export default function assets({
format = result.format; format = result.format;
} }
res.setHeader( res.setHeader('Content-Type', mime.getType(format) ?? `image/${format}`);
'Content-Type',
mime.getType(fileURLToPath(filePathURL)) || `image/${format}`
);
res.setHeader('Cache-Control', 'max-age=360000'); res.setHeader('Cache-Control', 'max-age=360000');
const stream = Readable.from(data); const stream = Readable.from(data);

View file

@ -97,6 +97,13 @@ describe('astro:image', () => {
expect(res.status).to.equal(200); expect(res.status).to.equal(200);
}); });
it('returns proper content-type', async () => {
let $img = $('#local img');
let src = $img.attr('src');
let res = await fixture.fetch(src);
expect(res.headers.get('content-type')).to.equal('image/webp');
});
it('errors on unsupported formats', async () => { it('errors on unsupported formats', async () => {
logs.length = 0; logs.length = 0;
let res = await fixture.fetch('/unsupported-format'); let res = await fixture.fetch('/unsupported-format');