From 2afb6ffe2d5de49437a36f07265389bae0ab21a4 Mon Sep 17 00:00:00 2001 From: Peter Clement Date: Fri, 16 Jul 2021 10:51:58 +0100 Subject: [PATCH] Better error handling around config saving --- .../builder/portal/manage/auth/index.svelte | 56 ++++++++++++------- 1 file changed, 36 insertions(+), 20 deletions(-) diff --git a/packages/builder/src/pages/builder/portal/manage/auth/index.svelte b/packages/builder/src/pages/builder/portal/manage/auth/index.svelte index e89dd45f79..2c5f5c339f 100644 --- a/packages/builder/src/pages/builder/portal/manage/auth/index.svelte +++ b/packages/builder/src/pages/builder/portal/manage/auth/index.svelte @@ -123,37 +123,53 @@ // only if the user has provided an image, upload it. image && uploadLogo(image) let calls = [] + let completed = [] docs.forEach(element => { if (element.type === ConfigTypes.OIDC) { //Add a UUID here so each config is distinguishable when it arrives at the login page. element.config.configs.forEach(config => { !config.uuid && (config.uuid = uuid()) }) - oidcComplete && calls.push(api.post(`/api/admin/configs`, element)) + if (oidcComplete) { + calls.push(api.post(`/api/admin/configs`, element)) + completed.push(ConfigTypes.OIDC) + } else { + notifications.error( + `Please fill in all required ${ConfigTypes.OIDC} fields` + ) + } } if (element.type === ConfigTypes.Google) { - googleComplete && calls.push(api.post(`/api/admin/configs`, element)) + if (googleComplete) { + calls.push(api.post(`/api/admin/configs`, element)) + completed.push(ConfigTypes.OIDC) + } else { + notifications.error( + `Please fill in all required ${ConfigTypes.Google} fields` + ) + } } }) - Promise.all(calls) - .then(responses => { - return Promise.all( - responses.map(response => { - return response.json() - }) - ) - }) - .then(data => { - data.forEach(res => { - providers[res.type]._rev = res._rev - providers[res.type]._id = res._id + calls.length && + Promise.all(calls) + .then(responses => { + return Promise.all( + responses.map(response => { + return response.json() + }) + ) + }) + .then(data => { + data.forEach(res => { + providers[res.type]._rev = res._rev + providers[res.type]._id = res._id + }) + notifications.success(`Settings saved.`) + }) + .catch(err => { + notifications.error(`Failed to update OAuth settings. ${err}`) + throw new Error(err.message) }) - notifications.success(`Settings saved.`) - }) - .catch(err => { - notifications.error(`Failed to update OAuth settings. ${err}`) - throw new Error(err.message) - }) } onMount(async () => {