From ca53cb6a4f82d7862a7227b3b9dd56ea1d903eb8 Mon Sep 17 00:00:00 2001 From: Princesseuh Date: Thu, 7 Sep 2023 16:53:11 +0200 Subject: [PATCH 1/4] feat: pass our domains and remote config to Vercel'S --- .../integrations/vercel/src/image/shared.ts | 23 +++++++++++-------- .../vercel/src/serverless/adapter.ts | 10 +++++--- .../integrations/vercel/src/static/adapter.ts | 10 +++++--- 3 files changed, 28 insertions(+), 15 deletions(-) diff --git a/packages/integrations/vercel/src/image/shared.ts b/packages/integrations/vercel/src/image/shared.ts index ad6b45bd0a7c..f6cace2a24ee 100644 --- a/packages/integrations/vercel/src/image/shared.ts +++ b/packages/integrations/vercel/src/image/shared.ts @@ -1,9 +1,13 @@ -import type { ImageMetadata, ImageQualityPreset, ImageTransform } from 'astro'; - -export const defaultImageConfig: VercelImageConfig = { - sizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840], - domains: [], -}; +import type { AstroConfig, ImageMetadata, ImageQualityPreset, ImageTransform } from 'astro'; + +export function getDefaultImageConfig(astroImageConfig: AstroConfig['image']): VercelImageConfig { + return { + sizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840], + domains: astroImageConfig.domains ?? [], + // Cast is necessary here because Vercel's types are slightly different from ours regarding allowed protocols. Behavior should be the same, however. + remotePatterns: (astroImageConfig.remotePatterns as VercelImageConfig['remotePatterns']) ?? [], + }; +} export function isESMImportedImage(src: ImageMetadata | string): src is ImageMetadata { return typeof src === 'object'; @@ -56,10 +60,11 @@ export const qualityTable: Record = { max: 100, }; -export function getImageConfig( +export function getAstroImageConfig( images: boolean | undefined, imagesConfig: VercelImageConfig | undefined, - command: string + command: string, + astroImageConfig: AstroConfig['image'] ) { if (images) { return { @@ -69,7 +74,7 @@ export function getImageConfig( command === 'dev' ? '@astrojs/vercel/dev-image-service' : '@astrojs/vercel/build-image-service', - config: imagesConfig ? imagesConfig : defaultImageConfig, + config: imagesConfig ? imagesConfig : getDefaultImageConfig(astroImageConfig), }, }, }; diff --git a/packages/integrations/vercel/src/serverless/adapter.ts b/packages/integrations/vercel/src/serverless/adapter.ts index a1d8b18bf3ac..df298cd0fe5a 100644 --- a/packages/integrations/vercel/src/serverless/adapter.ts +++ b/packages/integrations/vercel/src/serverless/adapter.ts @@ -9,7 +9,11 @@ import { AstroError } from 'astro/errors'; import glob from 'fast-glob'; import { basename } from 'node:path'; import { fileURLToPath, pathToFileURL } from 'node:url'; -import { defaultImageConfig, getImageConfig, type VercelImageConfig } from '../image/shared.js'; +import { + getAstroImageConfig, + getDefaultImageConfig, + type VercelImageConfig, +} from '../image/shared.js'; import { exposeEnv } from '../lib/env.js'; import { getVercelOutput, removeDir, writeJson } from '../lib/fs.js'; import { copyDependenciesToFunction } from '../lib/nft.js'; @@ -143,7 +147,7 @@ export default function vercelServerless({ external: ['@vercel/nft'], }, }, - ...getImageConfig(imageService, imagesConfig, command), + ...getAstroImageConfig(imageService, imagesConfig, command, config.image), }); }, 'astro:config:done': ({ setAdapter, config, logger }) => { @@ -250,7 +254,7 @@ You can set functionPerRoute: false to prevent surpassing the limit.` ...routeDefinitions, ], ...(imageService || imagesConfig - ? { images: imagesConfig ? imagesConfig : defaultImageConfig } + ? { images: imagesConfig ? imagesConfig : getDefaultImageConfig(_config.image) } : {}), }); diff --git a/packages/integrations/vercel/src/static/adapter.ts b/packages/integrations/vercel/src/static/adapter.ts index 0a63dc33368a..dd6e6dc6c203 100644 --- a/packages/integrations/vercel/src/static/adapter.ts +++ b/packages/integrations/vercel/src/static/adapter.ts @@ -1,6 +1,10 @@ import type { AstroAdapter, AstroConfig, AstroIntegration } from 'astro'; -import { defaultImageConfig, getImageConfig, type VercelImageConfig } from '../image/shared.js'; +import { + getAstroImageConfig, + getDefaultImageConfig, + type VercelImageConfig, +} from '../image/shared.js'; import { exposeEnv } from '../lib/env.js'; import { emptyDir, getVercelOutput, writeJson } from '../lib/fs.js'; import { isServerLikeOutput } from '../lib/prerender.js'; @@ -59,7 +63,7 @@ export default function vercelStatic({ vite: { define: viteDefine, }, - ...getImageConfig(imageService, imagesConfig, command), + ...getAstroImageConfig(imageService, imagesConfig, command, config.image), }); }, 'astro:config:done': ({ setAdapter, config }) => { @@ -91,7 +95,7 @@ export default function vercelStatic({ { handle: 'filesystem' }, ], ...(imageService || imagesConfig - ? { images: imagesConfig ? imagesConfig : defaultImageConfig } + ? { images: imagesConfig ? imagesConfig : getDefaultImageConfig(_config.image) } : {}), }); }, From 4cbb9dbf8248af6b4dc74881497a803e80bd9e8b Mon Sep 17 00:00:00 2001 From: Princesseuh Date: Thu, 7 Sep 2023 16:53:59 +0200 Subject: [PATCH 2/4] chore: changeset --- .changeset/forty-hotels-itch.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/forty-hotels-itch.md diff --git a/.changeset/forty-hotels-itch.md b/.changeset/forty-hotels-itch.md new file mode 100644 index 000000000000..b13c6db35b5a --- /dev/null +++ b/.changeset/forty-hotels-itch.md @@ -0,0 +1,5 @@ +--- +'@astrojs/vercel': patch +--- + +Fix Astro's `domains` and `remotePatterns` not being used by Vercel when using Vercel Image Optimization From 9b9baec857349aa45a78fadf7c5dd57e51f02370 Mon Sep 17 00:00:00 2001 From: Princesseuh Date: Thu, 7 Sep 2023 17:02:06 +0200 Subject: [PATCH 3/4] test: update test to test for this --- .../vercel/test/fixtures/image/astro.config.mjs | 5 +++++ packages/integrations/vercel/test/image.test.js | 8 +++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/packages/integrations/vercel/test/fixtures/image/astro.config.mjs b/packages/integrations/vercel/test/fixtures/image/astro.config.mjs index 2a343d03577b..78923f2cbb9b 100644 --- a/packages/integrations/vercel/test/fixtures/image/astro.config.mjs +++ b/packages/integrations/vercel/test/fixtures/image/astro.config.mjs @@ -6,5 +6,10 @@ export default defineConfig({ adapter: vercel({imageService: true}), image: { service: testImageService(), + domains: ['astro.build'], + remotePatterns: [{ + protocol: 'https', + hostname: '**.amazonaws.com', + }], }, }); diff --git a/packages/integrations/vercel/test/image.test.js b/packages/integrations/vercel/test/image.test.js index 834b6d69b181..c5153cc6e622 100644 --- a/packages/integrations/vercel/test/image.test.js +++ b/packages/integrations/vercel/test/image.test.js @@ -32,7 +32,13 @@ describe('Image', () => { expect(vercelConfig.images).to.deep.equal({ sizes: [640, 750, 828, 1080, 1200, 1920, 2048, 3840], - domains: [], + domains: ['astro.build'], + remotePatterns: [ + { + protocol: 'https', + hostname: '**.amazonaws.com', + }, + ], }); }); From 64555e42d6601102f650c18ed3077c8e7566a3ec Mon Sep 17 00:00:00 2001 From: Princesseuh Date: Thu, 7 Sep 2023 17:30:07 +0200 Subject: [PATCH 4/4] docs: update README --- packages/integrations/vercel/README.md | 2 ++ .../integrations/vercel/src/serverless/adapter.ts | 13 ++++++++++++- packages/integrations/vercel/src/static/adapter.ts | 13 ++++++++++++- 3 files changed, 26 insertions(+), 2 deletions(-) diff --git a/packages/integrations/vercel/README.md b/packages/integrations/vercel/README.md index e16d98390ebe..00c2a18cfe0b 100644 --- a/packages/integrations/vercel/README.md +++ b/packages/integrations/vercel/README.md @@ -114,6 +114,8 @@ export default defineConfig({ Configuration options for [Vercel's Image Optimization API](https://vercel.com/docs/concepts/image-optimization). See [Vercel's image configuration documentation](https://vercel.com/docs/build-output-api/v3/configuration#images) for a complete list of supported parameters. +The `domains` and `remotePatterns` properties will automatically be filled using [the Astro corresponding `image` settings](https://docs.astro.build/en/reference/configuration-reference/#image-options). + ```js // astro.config.mjs import { defineConfig } from 'astro/config'; diff --git a/packages/integrations/vercel/src/serverless/adapter.ts b/packages/integrations/vercel/src/serverless/adapter.ts index df298cd0fe5a..1c0eb9530d8b 100644 --- a/packages/integrations/vercel/src/serverless/adapter.ts +++ b/packages/integrations/vercel/src/serverless/adapter.ts @@ -254,7 +254,18 @@ You can set functionPerRoute: false to prevent surpassing the limit.` ...routeDefinitions, ], ...(imageService || imagesConfig - ? { images: imagesConfig ? imagesConfig : getDefaultImageConfig(_config.image) } + ? { + images: imagesConfig + ? { + ...imagesConfig, + domains: [...imagesConfig.domains, ..._config.image.domains], + remotePatterns: [ + ...(imagesConfig.remotePatterns ?? []), + ..._config.image.remotePatterns, + ], + } + : getDefaultImageConfig(_config.image), + } : {}), }); diff --git a/packages/integrations/vercel/src/static/adapter.ts b/packages/integrations/vercel/src/static/adapter.ts index dd6e6dc6c203..2908dbf58529 100644 --- a/packages/integrations/vercel/src/static/adapter.ts +++ b/packages/integrations/vercel/src/static/adapter.ts @@ -95,7 +95,18 @@ export default function vercelStatic({ { handle: 'filesystem' }, ], ...(imageService || imagesConfig - ? { images: imagesConfig ? imagesConfig : getDefaultImageConfig(_config.image) } + ? { + images: imagesConfig + ? { + ...imagesConfig, + domains: [...imagesConfig.domains, ..._config.image.domains], + remotePatterns: [ + ...(imagesConfig.remotePatterns ?? []), + ..._config.image.remotePatterns, + ], + } + : getDefaultImageConfig(_config.image), + } : {}), }); },