From 764057808baef2d025f15ddf81a1873679a81353 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Mon, 13 May 2024 12:18:51 -0400 Subject: [PATCH 1/5] feat: throw error on missing server output --- packages/astro/src/actions/index.ts | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/packages/astro/src/actions/index.ts b/packages/astro/src/actions/index.ts index e251ed72f68d..406034bfad9a 100644 --- a/packages/astro/src/actions/index.ts +++ b/packages/astro/src/actions/index.ts @@ -3,12 +3,24 @@ import type { Plugin as VitePlugin } from 'vite'; import type { AstroIntegration } from '../@types/astro.js'; import { viteID } from '../core/util.js'; import { ACTIONS_TYPES_FILE, RESOLVED_VIRTUAL_MODULE_ID, VIRTUAL_MODULE_ID } from './consts.js'; +import { AstroUserError } from '../core/errors/errors.js'; + +const serverOutputs = ['server', 'hybrid']; export default function astroActions(): AstroIntegration { return { name: VIRTUAL_MODULE_ID, hooks: { async 'astro:config:setup'(params) { + if (!serverOutputs.includes(params.config.output)) { + const error = new AstroUserError( + 'Actions require a server output. Set the \`output\` property in your Astro config.', + 'Learn about on-demand rendering: https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered' + ); + error.stack = undefined; + throw error; + } + const stringifiedActionsImport = JSON.stringify( viteID(new URL('./actions', params.config.srcDir)) ); From 00a41caaa65328217236820216b84765cebf2ac8 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Mon, 13 May 2024 12:20:38 -0400 Subject: [PATCH 2/5] chore: changeset --- .changeset/many-news-rescue.md | 5 +++++ 1 file changed, 5 insertions(+) create mode 100644 .changeset/many-news-rescue.md diff --git a/.changeset/many-news-rescue.md b/.changeset/many-news-rescue.md new file mode 100644 index 000000000000..038ad499dea0 --- /dev/null +++ b/.changeset/many-news-rescue.md @@ -0,0 +1,5 @@ +--- +"astro": patch +--- + +Throw on missing server output when using Astro Actions. From 6a562e2e09e1adbfb38e97c5e9aacd0ef6865aa6 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Tue, 14 May 2024 11:02:37 -0400 Subject: [PATCH 3/5] refactor: use isServerLikeOutput --- packages/astro/src/actions/index.ts | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/packages/astro/src/actions/index.ts b/packages/astro/src/actions/index.ts index 406034bfad9a..581d25ba0d80 100644 --- a/packages/astro/src/actions/index.ts +++ b/packages/astro/src/actions/index.ts @@ -1,18 +1,16 @@ import { mkdir, readFile, writeFile } from 'node:fs/promises'; import type { Plugin as VitePlugin } from 'vite'; import type { AstroIntegration } from '../@types/astro.js'; -import { viteID } from '../core/util.js'; +import { viteID, isServerLikeOutput } from '../core/util.js'; import { ACTIONS_TYPES_FILE, RESOLVED_VIRTUAL_MODULE_ID, VIRTUAL_MODULE_ID } from './consts.js'; import { AstroUserError } from '../core/errors/errors.js'; -const serverOutputs = ['server', 'hybrid']; - export default function astroActions(): AstroIntegration { return { name: VIRTUAL_MODULE_ID, hooks: { async 'astro:config:setup'(params) { - if (!serverOutputs.includes(params.config.output)) { + if (!isServerLikeOutput(params.config)) { const error = new AstroUserError( 'Actions require a server output. Set the \`output\` property in your Astro config.', 'Learn about on-demand rendering: https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered' From f9f3614ad1474c08fa90804d118a473ce7951a8b Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Tue, 14 May 2024 11:11:48 -0400 Subject: [PATCH 4/5] feat: add errors-data on actions build output --- packages/astro/src/actions/index.ts | 8 +++----- packages/astro/src/core/errors/errors-data.ts | 7 +++++++ 2 files changed, 10 insertions(+), 5 deletions(-) diff --git a/packages/astro/src/actions/index.ts b/packages/astro/src/actions/index.ts index 581d25ba0d80..e2f58c2fba25 100644 --- a/packages/astro/src/actions/index.ts +++ b/packages/astro/src/actions/index.ts @@ -3,7 +3,8 @@ import type { Plugin as VitePlugin } from 'vite'; import type { AstroIntegration } from '../@types/astro.js'; import { viteID, isServerLikeOutput } from '../core/util.js'; import { ACTIONS_TYPES_FILE, RESOLVED_VIRTUAL_MODULE_ID, VIRTUAL_MODULE_ID } from './consts.js'; -import { AstroUserError } from '../core/errors/errors.js'; +import { AstroError } from '../core/errors/errors.js'; +import { ActionsWithoutServerOutputError } from '../core/errors/errors-data.js'; export default function astroActions(): AstroIntegration { return { @@ -11,10 +12,7 @@ export default function astroActions(): AstroIntegration { hooks: { async 'astro:config:setup'(params) { if (!isServerLikeOutput(params.config)) { - const error = new AstroUserError( - 'Actions require a server output. Set the \`output\` property in your Astro config.', - 'Learn about on-demand rendering: https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered' - ); + const error = new AstroError(ActionsWithoutServerOutputError); error.stack = undefined; throw error; } diff --git a/packages/astro/src/core/errors/errors-data.ts b/packages/astro/src/core/errors/errors-data.ts index 761160565cc5..3e58ea740a85 100644 --- a/packages/astro/src/core/errors/errors-data.ts +++ b/packages/astro/src/core/errors/errors-data.ts @@ -1493,6 +1493,13 @@ export const DuplicateContentEntrySlugError = { }, } satisfies ErrorData; +export const ActionsWithoutServerOutputError = { + name: 'ActionsWithoutServerOutputError', + title: 'Actions must be used with server output.', + message: 'Actions enabled without setting a server build output. A server is required to create callable backend functions. To deploy routes to a server, add a server adapter to your astro config.', + hint: 'Learn about on-demand rendering: https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered', +} satisfies ErrorData; + /** * @docs * @see From 8cb5bc88093e5494b209de1ce891552ca7faad54 Mon Sep 17 00:00:00 2001 From: bholmesdev Date: Tue, 14 May 2024 12:21:22 -0400 Subject: [PATCH 5/5] chore: add jsdoc --- packages/astro/src/core/errors/errors-data.ts | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/packages/astro/src/core/errors/errors-data.ts b/packages/astro/src/core/errors/errors-data.ts index 3e58ea740a85..cd75acc150ca 100644 --- a/packages/astro/src/core/errors/errors-data.ts +++ b/packages/astro/src/core/errors/errors-data.ts @@ -1493,10 +1493,18 @@ export const DuplicateContentEntrySlugError = { }, } satisfies ErrorData; +/** + * @docs + * @see + * - [On-demand rendering](https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered) + * @description + * Your project must have a server output to create backend functions with Actions. + */ export const ActionsWithoutServerOutputError = { name: 'ActionsWithoutServerOutputError', title: 'Actions must be used with server output.', - message: 'Actions enabled without setting a server build output. A server is required to create callable backend functions. To deploy routes to a server, add a server adapter to your astro config.', + message: + 'Actions enabled without setting a server build output. A server is required to create callable backend functions. To deploy routes to a server, add a server adapter to your astro config.', hint: 'Learn about on-demand rendering: https://docs.astro.build/en/basics/rendering-modes/#on-demand-rendered', } satisfies ErrorData;