From 55248794313c50c94bb3ec0bdb2c46bb4c9599bb Mon Sep 17 00:00:00 2001 From: Matthew Phillips Date: Thu, 4 Apr 2024 14:34:56 -0400 Subject: [PATCH] Prevent errors in finding workspaceId from interrupting link prompts --- .changeset/khaki-turkeys-sip.md | 5 ++++ .../db/src/core/cli/commands/link/index.ts | 25 ++++++++++++------- 2 files changed, 21 insertions(+), 9 deletions(-) create mode 100644 .changeset/khaki-turkeys-sip.md diff --git a/.changeset/khaki-turkeys-sip.md b/.changeset/khaki-turkeys-sip.md new file mode 100644 index 000000000000..4bd4096b0006 --- /dev/null +++ b/.changeset/khaki-turkeys-sip.md @@ -0,0 +1,5 @@ +--- +"@astrojs/db": patch +--- + +Prevent errors in finding workspaceId from interrupting link prompts diff --git a/packages/db/src/core/cli/commands/link/index.ts b/packages/db/src/core/cli/commands/link/index.ts index b58dff2e75e1..42da563b0c97 100644 --- a/packages/db/src/core/cli/commands/link/index.ts +++ b/packages/db/src/core/cli/commands/link/index.ts @@ -16,18 +16,20 @@ export async function cmd() { console.error(MISSING_SESSION_ID_ERROR); process.exit(1); } - const getWorkspaceIdAsync = getWorkspaceId(); + const getWorkspaceIdAsync = getWorkspaceId().catch(err => { + return err as Error; + }); await promptBegin(); const isLinkExisting = await promptLinkExisting(); if (isLinkExisting) { - const workspaceId = await getWorkspaceIdAsync; + const workspaceId = unwrapWorkspaceId(await getWorkspaceIdAsync); const existingProjectData = await promptExistingProjectName({ workspaceId }); return await linkProject(existingProjectData.id); } const isLinkNew = await promptLinkNew(); if (isLinkNew) { - const workspaceId = await getWorkspaceIdAsync; + const workspaceId = unwrapWorkspaceId(await getWorkspaceIdAsync); const newProjectName = await promptNewProjectName(); const newProjectRegion = await promptNewProjectRegion(); const spinner = ora('Creating new project...').start(); @@ -64,26 +66,31 @@ async function getWorkspaceId(): Promise { (res) => { // Unauthorized if (res.status === 401) { - console.error( + throw new Error( `${bgRed('Unauthorized')}\n\n Are you logged in?\n Run ${cyan( 'astro db login' )} to authenticate and then try linking again.\n\n` ); - process.exit(1); } - console.error(`Failed to fetch user workspace: ${res.status} ${res.statusText}`); - process.exit(1); + throw new Error(`Failed to fetch user workspace: ${res.status} ${res.statusText}`); } ); const { data, success } = (await response.json()) as Result<{ id: string }[]>; if (!success) { - console.error(`Failed to fetch user's workspace.`); - process.exit(1); + throw new Error(`Failed to fetch user's workspace.`); } return data[0].id; } +function unwrapWorkspaceId(workspaceId: string | Error): string { + if(typeof workspaceId !== 'string') { + console.error(workspaceId.message); + process.exit(1); + } + return workspaceId; +} + export async function createNewProject({ workspaceId, name,