diff --git a/.changeset/selfish-tigers-do.md b/.changeset/selfish-tigers-do.md new file mode 100644 index 000000000000..4502080213da --- /dev/null +++ b/.changeset/selfish-tigers-do.md @@ -0,0 +1,10 @@ +--- +'@astrojs/cloudflare': major +'@astrojs/deno': major +'@astrojs/image': minor +'@astrojs/netlify': major +'@astrojs/node': major +'@astrojs/vercel': major +--- + +Remove `astro:build:start` backwards compatibility code diff --git a/.changeset/tricky-rabbits-count.md b/.changeset/tricky-rabbits-count.md new file mode 100644 index 000000000000..a9d015b08ea6 --- /dev/null +++ b/.changeset/tricky-rabbits-count.md @@ -0,0 +1,36 @@ +--- +'astro': major +--- + +Remove deprecated `Astro` global APIs, including `Astro.resolve`, `Astro.fetchContent`, and `Astro.canonicalURL`. + +#### `Astro.resolve` + +You can resolve asset paths using `import` instead. For example: + +```astro +--- +import 'style.css' +import imageUrl from './image.png' +--- + + +``` + +See the [v0.25 migration guide](https://docs.astro.build/en/migrate/#deprecated-astroresolve) for more information. + +#### `Astro.fetchContent` + +Use `Astro.glob` instead to fetch markdown files, or migrate to the [Content Collections](https://docs.astro.build/en/guides/content-collections/) feature. + +```js +let allPosts = await Astro.glob('./posts/*.md'); +``` + +#### `Astro.canonicalURL` + +Use `Astro.url` instead to construct the canonical URL. + +```js +const canonicalURL = new URL(Astro.url.pathname, Astro.site); +``` diff --git a/.changeset/two-geese-eat.md b/.changeset/two-geese-eat.md new file mode 100644 index 000000000000..d626d331f3d6 --- /dev/null +++ b/.changeset/two-geese-eat.md @@ -0,0 +1,24 @@ +--- +'astro': major +--- + +Remove `buildConfig` option parameter from integration `astro:build:start` hook in favour of the `build.config` option in the `astro:config:setup` hook. + +```js +export default function myIntegration() { + return { + name: 'my-integration', + hooks: { + 'astro:config:setup': ({ updateConfig }) => { + updateConfig({ + build: { + client: '...', + server: '...', + serverEntry: '...', + }, + }); + }, + }, + }; +} +``` diff --git a/examples/integration/index.ts b/examples/integration/index.ts index 2c7249b837e5..8c6cb35bf12f 100644 --- a/examples/integration/index.ts +++ b/examples/integration/index.ts @@ -10,7 +10,7 @@ export default function createIntegration(): AstroIntegration { // See the @astrojs/react integration for an example // https://github.com/withastro/astro/blob/main/packages/integrations/react/src/index.ts }, - 'astro:build:start': ({ buildConfig }) => { + 'astro:build:setup': ({ config, updateConfig }) => { // See the @astrojs/netlify integration for an example // https://github.com/withastro/astro/blob/main/packages/integrations/netlify/src/integration-functions.ts }, diff --git a/packages/astro/src/@types/astro.ts b/packages/astro/src/@types/astro.ts index e20d0eeed677..1206c3431bfc 100644 --- a/packages/astro/src/@types/astro.ts +++ b/packages/astro/src/@types/astro.ts @@ -109,18 +109,6 @@ export interface BuildConfig { export interface AstroGlobal = Record> extends AstroGlobalPartial, AstroSharedContext { - /** - * Canonical URL of the current page. - * @deprecated Use `Astro.url` instead. - * - * Example: - * ```astro - * --- - * const canonicalURL = new URL(Astro.url.pathname, Astro.site); - * --- - * ``` - */ - canonicalURL: URL; /** * A full URL object of the request URL. * Equivalent to: `new URL(Astro.request.url)` @@ -254,12 +242,6 @@ export interface AstroGlobal = Record; /** * Fetch local files into your static site setup * @@ -1390,7 +1372,7 @@ export interface AstroIntegration { 'astro:server:start'?: (options: { address: AddressInfo }) => void | Promise; 'astro:server:done'?: () => void | Promise; 'astro:build:ssr'?: (options: { manifest: SerializedSSRManifest }) => void | Promise; - 'astro:build:start'?: (options: { buildConfig: BuildConfig }) => void | Promise; + 'astro:build:start'?: () => void | Promise; 'astro:build:setup'?: (options: { vite: vite.InlineConfig; pages: Map; diff --git a/packages/astro/src/core/build/index.ts b/packages/astro/src/core/build/index.ts index 34f84b40f65c..967723cc5587 100644 --- a/packages/astro/src/core/build/index.ts +++ b/packages/astro/src/core/build/index.ts @@ -90,7 +90,7 @@ class AstroBuilder { server: this.settings.config.build.server, serverEntry: this.settings.config.build.serverEntry, }; - await runHookBuildStart({ config: this.settings.config, buildConfig, logging: this.logging }); + await runHookBuildStart({ config: this.settings.config, logging: this.logging }); this.validateConfig(); info(this.logging, 'build', `output target: ${colors.green(this.settings.config.output)}`); diff --git a/packages/astro/src/core/render/result.ts b/packages/astro/src/core/render/result.ts index 5b1c870972b2..0bc054cd7ca8 100644 --- a/packages/astro/src/core/render/result.ts +++ b/packages/astro/src/core/render/result.ts @@ -183,7 +183,7 @@ export function createResult(args: CreateResultArgs): SSRResult { } } - return Reflect.get(request, clientAddressSymbol); + return Reflect.get(request, clientAddressSymbol) as string; }, get cookies() { if (cookies) { @@ -207,59 +207,10 @@ export function createResult(args: CreateResultArgs): SSRResult { }); } : onlyAvailableInSSR('Astro.redirect'), - resolve(path: string) { - let extra = `This can be replaced with a dynamic import like so: await import("${path}")`; - if (isCSSRequest(path)) { - extra = `It looks like you are resolving styles. If you are adding a link tag, replace with this: ---- -import "${path}"; ---- -`; - } else if (isScriptRequest(path)) { - extra = `It looks like you are resolving scripts. If you are adding a script tag, replace with this: - - - -or consider make it a module like so: - - -`; - } - - warn( - args.logging, - `deprecation`, - `${bold( - 'Astro.resolve()' - )} is deprecated. We see that you are trying to resolve ${path}. -${extra}` - ); - // Intentionally return an empty string so that it is not relied upon. - return ''; - }, response: response as AstroGlobal['response'], slots: astroSlots as unknown as AstroGlobal['slots'], }; - Object.defineProperty(Astro, 'canonicalURL', { - get: function () { - warn( - args.logging, - 'deprecation', - `${bold('Astro.canonicalURL')} is deprecated! Use \`Astro.url\` instead. -Example: - ---- -const canonicalURL = new URL(Astro.url.pathname, Astro.site); ---- -` - ); - return new URL(this.request.url.pathname, this.site); - }, - }); - Object.defineProperty(Astro, '__renderMarkdown', { // Ensure this API is not exposed to users enumerable: false, diff --git a/packages/astro/src/integrations/index.ts b/packages/astro/src/integrations/index.ts index e7ce7e51d629..3733c6b2d0c0 100644 --- a/packages/astro/src/integrations/index.ts +++ b/packages/astro/src/integrations/index.ts @@ -206,55 +206,18 @@ export async function runHookServerDone({ export async function runHookBuildStart({ config, - buildConfig, logging, }: { config: AstroConfig; - buildConfig: BuildConfig; logging: LogOptions; }) { - function warnDeprecated( - integration: AstroIntegration, - prop: 'server' | 'client' | 'serverEntry' - ) { - let value: any = Reflect.get(buildConfig, prop); - Object.defineProperty(buildConfig, prop, { - enumerable: true, - get() { - return value; - }, - set(newValue) { - value = newValue; - warn( - logging, - 'astro:build:start', - `Your adapter ${bold(integration.name)} is using a deprecated API, buildConfig. ${bold( - prop - )} config should be set via config.build.${prop} instead.` - ); - }, - }); - return () => { - Object.defineProperty(buildConfig, prop, { - enumerable: true, - value, - }); - }; - } - for (const integration of config.integrations) { if (integration?.hooks?.['astro:build:start']) { - const undoClientWarning = warnDeprecated(integration, 'client'); - const undoServerWarning = warnDeprecated(integration, 'server'); - const undoServerEntryWarning = warnDeprecated(integration, 'serverEntry'); await withTakingALongTimeMsg({ name: integration.name, - hookResult: integration.hooks['astro:build:start']({ buildConfig }), + hookResult: integration.hooks['astro:build:start'](), logging, }); - undoClientWarning(); - undoServerEntryWarning(); - undoServerWarning(); } } } diff --git a/packages/astro/src/runtime/server/astro-global.ts b/packages/astro/src/runtime/server/astro-global.ts index 5dd17afcef8e..3182026bf35b 100644 --- a/packages/astro/src/runtime/server/astro-global.ts +++ b/packages/astro/src/runtime/server/astro-global.ts @@ -1,13 +1,6 @@ import type { AstroGlobalPartial } from '../../@types/astro'; import { ASTRO_VERSION } from '../../core/constants.js'; -/** Create the Astro.fetchContent() runtime function. */ -function createDeprecatedFetchContentFn() { - return () => { - throw new Error('Deprecated: Astro.fetchContent() has been replaced with Astro.glob().'); - }; -} - /** Create the Astro.glob() runtime function. */ function createAstroGlobFn() { const globHandler = (importMetaGlobResult: Record, globValue: () => any) => { @@ -25,29 +18,15 @@ function createAstroGlobFn() { // This is used to create the top-level Astro global; the one that you can use // Inside of getStaticPaths. +// TODO: remove `_filePathname` and `_projectRootStr` from the compiler export function createAstro( - filePathname: string, - _site: string | undefined, - projectRootStr: string + _filePathname: string, + site: string | undefined, + _projectRootStr: string ): AstroGlobalPartial { - const site = _site ? new URL(_site) : undefined; - const referenceURL = new URL(filePathname, `http://localhost`); - const projectRoot = new URL(projectRootStr); return { - site, + site: site ? new URL(site) : undefined, generator: `Astro v${ASTRO_VERSION}`, - fetchContent: createDeprecatedFetchContentFn(), glob: createAstroGlobFn(), - // INVESTIGATE is there a use-case for multi args? - // TODO remove in 2.0 - resolve(...segments: string[]) { - let resolved = segments.reduce((u, segment) => new URL(segment, u), referenceURL).pathname; - // When inside of project root, remove the leading path so you are - // left with only `/src/images/tower.png` - if (resolved.startsWith(projectRoot.pathname)) { - resolved = '/' + resolved.slice(projectRoot.pathname.length); - } - return resolved; - }, }; } diff --git a/packages/astro/test/ssr-adapter-build-config.test.js b/packages/astro/test/ssr-adapter-build-config.test.js index ab0ccf3af42e..d739cee3cd09 100644 --- a/packages/astro/test/ssr-adapter-build-config.test.js +++ b/packages/astro/test/ssr-adapter-build-config.test.js @@ -1,5 +1,4 @@ import { expect } from 'chai'; -import { load as cheerioLoad } from 'cheerio'; import { loadFixture } from './test-utils.js'; import { viteID } from '../dist/core/util.js'; @@ -8,15 +7,18 @@ describe('Integration buildConfig hook', () => { let fixture; before(async () => { - let _config; fixture = await loadFixture({ root: './fixtures/ssr-request/', output: 'server', adapter: { name: 'my-ssr-adapter', hooks: { - 'astro:config:setup': ({ updateConfig }) => { + 'astro:config:setup': ({ config, updateConfig }) => { updateConfig({ + build: { + server: new URL('./dist/.root/server/', config.root), + client: new URL('./dist/.root/client/', config.root), + }, vite: { plugins: [ { @@ -40,12 +42,7 @@ describe('Integration buildConfig hook', () => { }, }); }, - 'astro:build:start': ({ buildConfig }) => { - buildConfig.server = new URL('./dist/.root/server/', _config.root); - buildConfig.client = new URL('./dist/.root/client/', _config.root); - }, - 'astro:config:done': ({ config, setAdapter }) => { - _config = config; + 'astro:config:done': ({ setAdapter }) => { setAdapter({ name: 'my-ssr-adapter', serverEntrypoint: '@my-ssr', diff --git a/packages/integrations/cloudflare/src/index.ts b/packages/integrations/cloudflare/src/index.ts index d39f0f8759f8..1df284fbbb19 100644 --- a/packages/integrations/cloudflare/src/index.ts +++ b/packages/integrations/cloudflare/src/index.ts @@ -39,14 +39,12 @@ const SERVER_BUILD_FOLDER = '/$server_build/'; export default function createIntegration(args?: Options): AstroIntegration { let _config: AstroConfig; let _buildConfig: BuildConfig; - let needsBuildConfig = false; const isModeDirectory = args?.mode === 'directory'; return { name: '@astrojs/cloudflare', hooks: { 'astro:config:setup': ({ config, updateConfig }) => { - needsBuildConfig = !config.build.client; updateConfig({ build: { client: new URL(`.${config.base}`, config.outDir), @@ -90,14 +88,6 @@ export default function createIntegration(args?: Options): AstroIntegration { vite.ssr.target = vite.ssr.target || 'webworker'; } }, - 'astro:build:start': ({ buildConfig }) => { - // Backwards compat - if (needsBuildConfig) { - buildConfig.client = new URL(`.${_config.base}`, _config.outDir); - buildConfig.server = new URL(`.${SERVER_BUILD_FOLDER}`, _config.outDir); - buildConfig.serverEntry = '_worker.js'; - } - }, 'astro:build:done': async () => { const entryPath = fileURLToPath(new URL(_buildConfig.serverEntry, _buildConfig.server)), entryUrl = new URL(_buildConfig.serverEntry, _config.outDir), diff --git a/packages/integrations/deno/src/index.ts b/packages/integrations/deno/src/index.ts index 968bec24af92..8907c489da01 100644 --- a/packages/integrations/deno/src/index.ts +++ b/packages/integrations/deno/src/index.ts @@ -31,12 +31,10 @@ export function getAdapter(args?: Options): AstroAdapter { export default function createIntegration(args?: Options): AstroIntegration { let _buildConfig: BuildConfig; let _vite: any; - let needsBuildConfig = false; return { name: '@astrojs/deno', hooks: { 'astro:config:done': ({ setAdapter, config }) => { - needsBuildConfig = !config.build.client; setAdapter(getAdapter(args)); _buildConfig = config.build; @@ -47,12 +45,6 @@ export default function createIntegration(args?: Options): AstroIntegration { ); } }, - 'astro:build:start': ({ buildConfig }) => { - // Backwards compat - if (needsBuildConfig) { - _buildConfig = buildConfig; - } - }, 'astro:build:setup': ({ vite, target }) => { if (target === 'server') { _vite = vite; diff --git a/packages/integrations/image/src/index.ts b/packages/integrations/image/src/index.ts index 43f64935be9c..c30ee31ede4b 100644 --- a/packages/integrations/image/src/index.ts +++ b/packages/integrations/image/src/index.ts @@ -53,7 +53,6 @@ export default function integration(options: IntegrationOptions = {}): AstroInte let _config: AstroConfig; let _buildConfig: BuildConfig; - let needsBuildConfig = false; // During SSG builds, this is used to track all transformed images required. const staticImages = new Map>(); @@ -80,7 +79,6 @@ export default function integration(options: IntegrationOptions = {}): AstroInte name: PKG_NAME, hooks: { 'astro:config:setup': async ({ command, config, updateConfig, injectRoute }) => { - needsBuildConfig = !config.build?.server; _config = config; updateConfig({ vite: getViteConfiguration(command === 'dev'), @@ -107,18 +105,13 @@ export default function integration(options: IntegrationOptions = {}): AstroInte _config = config; _buildConfig = config.build; }, - 'astro:build:start': ({ buildConfig }) => { + 'astro:build:start': () => { const adapterName = _config.adapter?.name; if (adapterName && UNSUPPORTED_ADAPTERS.has(adapterName)) { throw new Error( `@astrojs/image is not supported with the ${adapterName} adapter. Please choose a Node.js compatible adapter.` ); } - - // Backwards compat - if (needsBuildConfig) { - _buildConfig = buildConfig; - } }, 'astro:build:setup': async () => { // Used to cache all images rendered to HTML diff --git a/packages/integrations/netlify/src/integration-edge-functions.ts b/packages/integrations/netlify/src/integration-edge-functions.ts index 8e16e059570f..35b660e2cdd2 100644 --- a/packages/integrations/netlify/src/integration-edge-functions.ts +++ b/packages/integrations/netlify/src/integration-edge-functions.ts @@ -111,13 +111,11 @@ export function netlifyEdgeFunctions({ dist }: NetlifyEdgeFunctionsOptions = {}) let _config: AstroConfig; let entryFile: string; let _buildConfig: BuildConfig; - let needsBuildConfig = false; let _vite: any; return { name: '@astrojs/netlify/edge-functions', hooks: { 'astro:config:setup': ({ config, updateConfig }) => { - needsBuildConfig = !config.build.client; // Add a plugin that shims the global environment. const injectPlugin: VitePlugin = { name: '@astrojs/netlify/plugin-inject', @@ -156,15 +154,6 @@ export function netlifyEdgeFunctions({ dist }: NetlifyEdgeFunctionsOptions = {}) ); } }, - 'astro:build:start': ({ buildConfig }) => { - if (needsBuildConfig) { - buildConfig.client = _config.outDir; - buildConfig.server = new URL('./.netlify/edge-functions/', _config.root); - buildConfig.serverEntry = 'entry.js'; - _buildConfig = buildConfig; - entryFile = buildConfig.serverEntry.replace(/\.m?js/, ''); - } - }, 'astro:build:setup': ({ vite, target }) => { if (target === 'server') { _vite = vite; diff --git a/packages/integrations/netlify/src/integration-functions.ts b/packages/integrations/netlify/src/integration-functions.ts index e1d6de42046f..e8ff4bd1f899 100644 --- a/packages/integrations/netlify/src/integration-functions.ts +++ b/packages/integrations/netlify/src/integration-functions.ts @@ -22,12 +22,10 @@ function netlifyFunctions({ }: NetlifyFunctionsOptions = {}): AstroIntegration { let _config: AstroConfig; let entryFile: string; - let needsBuildConfig = false; return { name: '@astrojs/netlify', hooks: { 'astro:config:setup': ({ config, updateConfig }) => { - needsBuildConfig = !config.build.client; const outDir = dist ?? new URL('./dist/', config.root); updateConfig({ outDir, @@ -49,13 +47,6 @@ function netlifyFunctions({ ); } }, - 'astro:build:start': ({ buildConfig }) => { - if (needsBuildConfig) { - buildConfig.client = _config.outDir; - buildConfig.server = new URL('./.netlify/functions-internal/', _config.root); - entryFile = buildConfig.serverEntry.replace(/\.m?js/, ''); - } - }, 'astro:build:done': async ({ routes, dir }) => { await createRedirects(routes, dir, entryFile, false); }, diff --git a/packages/integrations/node/src/index.ts b/packages/integrations/node/src/index.ts index 0453ca9d9359..bbe5e44b4cb6 100644 --- a/packages/integrations/node/src/index.ts +++ b/packages/integrations/node/src/index.ts @@ -16,7 +16,6 @@ export default function createIntegration(userOptions: UserOptions): AstroIntegr throw new Error(`[@astrojs/node] Setting the 'mode' option is required.`); } - let needsBuildConfig = false; let _options: Options; return { name: '@astrojs/node', @@ -31,7 +30,6 @@ export default function createIntegration(userOptions: UserOptions): AstroIntegr }); }, 'astro:config:done': ({ setAdapter, config }) => { - needsBuildConfig = !config.build?.server; _options = { ...userOptions, client: config.build.client?.toString(), @@ -45,13 +43,6 @@ export default function createIntegration(userOptions: UserOptions): AstroIntegr console.warn(`[@astrojs/node] \`output: "server"\` is required to use this adapter.`); } }, - 'astro:build:start': ({ buildConfig }) => { - // Backwards compat - if (needsBuildConfig) { - _options.client = buildConfig.client.toString(); - _options.server = buildConfig.server.toString(); - } - }, }, }; } diff --git a/packages/integrations/vercel/src/edge/adapter.ts b/packages/integrations/vercel/src/edge/adapter.ts index 28a10cecdc0f..c4457ffdd1c2 100644 --- a/packages/integrations/vercel/src/edge/adapter.ts +++ b/packages/integrations/vercel/src/edge/adapter.ts @@ -30,13 +30,11 @@ export default function vercelEdge({ includeFiles = [] }: VercelEdgeConfig = {}) let buildTempFolder: URL; let functionFolder: URL; let serverEntry: string; - let needsBuildConfig = false; return { name: PACKAGE_NAME, hooks: { 'astro:config:setup': ({ config, updateConfig }) => { - needsBuildConfig = !config.build.client; const outDir = getVercelOutput(config.root); updateConfig({ outDir, @@ -61,13 +59,6 @@ export default function vercelEdge({ includeFiles = [] }: VercelEdgeConfig = {}) `); } }, - 'astro:build:start': ({ buildConfig }) => { - if (needsBuildConfig) { - buildConfig.client = new URL('./static/', _config.outDir); - buildTempFolder = buildConfig.server = new URL('./dist/', _config.root); - serverEntry = buildConfig.serverEntry = 'entry.mjs'; - } - }, 'astro:build:setup': ({ vite, target }) => { if (target === 'server') { vite.resolve ||= {}; diff --git a/packages/integrations/vercel/src/serverless/adapter.ts b/packages/integrations/vercel/src/serverless/adapter.ts index 61528679c105..3ff5eb3e57a9 100644 --- a/packages/integrations/vercel/src/serverless/adapter.ts +++ b/packages/integrations/vercel/src/serverless/adapter.ts @@ -29,13 +29,11 @@ export default function vercelServerless({ let buildTempFolder: URL; let functionFolder: URL; let serverEntry: string; - let needsBuildConfig = false; return { name: PACKAGE_NAME, hooks: { 'astro:config:setup': ({ config, updateConfig }) => { - needsBuildConfig = !config.build.client; const outDir = getVercelOutput(config.root); updateConfig({ outDir, @@ -60,13 +58,6 @@ export default function vercelServerless({ `); } }, - 'astro:build:start': ({ buildConfig }) => { - if (needsBuildConfig) { - buildConfig.client = new URL('./static/', _config.outDir); - buildTempFolder = buildConfig.server = new URL('./dist/', _config.root); - serverEntry = buildConfig.serverEntry = 'entry.js'; - } - }, 'astro:build:done': async ({ routes }) => { // Merge any includes from `vite.assetsInclude const inc = includeFiles?.map((file) => new URL(file, _config.root)) || [];