From 3a2ee632b4c431a5f9ea3c44fd7a8a0091b8a686 Mon Sep 17 00:00:00 2001 From: shreddedbacon Date: Mon, 23 Oct 2023 16:02:43 +1100 Subject: [PATCH] chore: duplicate organization name error --- services/api/src/resources/organization/resolvers.ts | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/services/api/src/resources/organization/resolvers.ts b/services/api/src/resources/organization/resolvers.ts index 9c03e2108e..d122556b14 100644 --- a/services/api/src/resources/organization/resolvers.ts +++ b/services/api/src/resources/organization/resolvers.ts @@ -33,7 +33,10 @@ export const addOrganization: ResolverFn = async ( isValidName(input.name) try { - await hasPermission('organization', 'add'); + await hasPermission('organization', 'add'); + const org = await query(sqlClientPool, Sql.selectOrganizationByName(input.name)); + // if no organization found, create it + if (R.length(org) == 0) { const { insertId } = await query(sqlClientPool, Sql.insertOrganization(input)); const rows = await query(sqlClientPool, Sql.selectOrganization(insertId)); @@ -49,8 +52,11 @@ export const addOrganization: ResolverFn = async ( }); return R.prop(0, rows); + } else { + throw new Error(`There was an error creating the organization, ${input.name} already exists`); + } } catch (err) { - throw new Error(`There was an error creating the organization ${input.name} ${err}`); + throw new Error(`There was an error creating the organization ${input.name} ${err}`); } };