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:
parent
73fcc7627e
commit
4c347ab51e
4 changed files with 16 additions and 7 deletions
5
.changeset/serious-ladybugs-eat.md
Normal file
5
.changeset/serious-ladybugs-eat.md
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
---
|
||||||
|
'astro': patch
|
||||||
|
---
|
||||||
|
|
||||||
|
Fix content-type header being wrong in dev on images from `astro:assets`
|
|
@ -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(),
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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');
|
||||||
|
|
Loading…
Add table
Reference in a new issue