From 6dce0a88a45301867352c90f9c8e0ebb3dc06edc Mon Sep 17 00:00:00 2001 From: Peter Clement Date: Tue, 20 Jul 2021 09:27:12 +0100 Subject: [PATCH] Add activated toggle and login functionality to support this --- .../auth/_components/GoogleButton.svelte | 1 - .../builder/portal/manage/auth/index.svelte | 128 +++++++++++++++--- .../src/api/controllers/admin/configs.js | 13 +- .../worker/src/api/routes/admin/configs.js | 4 +- 4 files changed, 119 insertions(+), 27 deletions(-) diff --git a/packages/builder/src/pages/builder/auth/_components/GoogleButton.svelte b/packages/builder/src/pages/builder/auth/_components/GoogleButton.svelte index d895ab8fbc..c9a6aba218 100644 --- a/packages/builder/src/pages/builder/auth/_components/GoogleButton.svelte +++ b/packages/builder/src/pages/builder/auth/_components/GoogleButton.svelte @@ -4,7 +4,6 @@ import { organisation } from "stores/portal" $: show = $organisation.google - console.log(show) {#if show} 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 f2c7981a27..7f132b5638 100644 --- a/packages/builder/src/pages/builder/portal/manage/auth/index.svelte +++ b/packages/builder/src/pages/builder/portal/manage/auth/index.svelte @@ -17,6 +17,7 @@ Input, Body, Select, + Toggle, } from "@budibase/bbui" import { onMount } from "svelte" import api from "builderStore/api" @@ -90,21 +91,30 @@ let google let oidc const providers = { google, oidc } + let googleSaveButtonDisabled + let oidcSaveButtonDisabled + + $: googleSaveButtonDisabled = + providers.google?.config && !providers.google?.config.activated && true + $: oidcSaveButtonDisabled = + providers.oidc?.config.configs[0] && + !providers.oidc?.config.configs[0].activated && + true // Create a flag so that it will only try to save completed forms - $: trySaveGoogle = - providers.google?.config.clientID || - providers.google?.config.clientSecret || - providers.google?.config.callbackURL - $: trySaveOidc = + $: partialGoogle = + providers.google?.config?.clientID || + providers.google?.config?.clientSecret || + providers.google?.config?.callbackURL + $: partialOidc = providers.oidc?.config?.configs[0].configUrl || providers.oidc?.config?.configs[0].clientID || providers.oidc?.config?.configs[0].clientSecret $: googleComplete = - providers.google?.config.clientID && - providers.google?.config.clientSecret && - providers.google?.config.callbackURL + providers.google?.config?.clientID && + providers.google?.config?.clientSecret && + providers.google?.config?.callbackURL $: oidcComplete = providers.oidc?.config?.configs[0].configUrl && providers.oidc?.config?.configs[0].clientID && @@ -128,6 +138,22 @@ iconDropdownOptions.unshift({ label: fileName, value: fileName }) } + const toggleGoogle = ({ detail }) => { + // Only save on de-activation, as the user can save themselves when toggle is active + if (!detail) { + providers.google.config.activated = detail + save([providers.google]) + } + } + + const toggleOidc = ({ detail }) => { + // Only save on de-activation, as the user can save themselves when toggle is active + if (!detail) { + providers.oidc.config.configs[0].activated = detail + save([providers.oidc]) + } + } + async function save(docs) { // only if the user has provided an image, upload it. image && uploadLogo(image) @@ -139,7 +165,7 @@ element.config.configs.forEach(config => { !config.uuid && (config.uuid = uuid()) }) - if (trySaveOidc) { + if (partialOidc) { if (!oidcComplete) { notifications.error( `Please fill in all required ${ConfigTypes.OIDC} fields` @@ -151,7 +177,7 @@ } } if (element.type === ConfigTypes.Google) { - if (trySaveGoogle) { + if (partialGoogle) { if (!googleComplete) { notifications.error( `Please fill in all required ${ConfigTypes.Google} fields` @@ -196,7 +222,7 @@ if (!googleDoc._id) { providers.google = { type: ConfigTypes.Google, - config: {}, + config: { activated: true }, } } else { providers.google = googleDoc @@ -225,7 +251,7 @@ if (!oidcDoc._id) { providers.oidc = { type: ConfigTypes.OIDC, - config: { configs: [{}] }, + config: { configs: [{ activated: true }] }, } } else { providers.oidc = oidcDoc @@ -246,10 +272,20 @@ - +
Google - +
+
+ +
+
+
To allow users to authenticate using their Google accounts, fill out the @@ -263,17 +299,39 @@ {/each} +
+
+ + + + +
+
{/if} {#if providers.oidc} - +
OpenID Connect - - +
+
+ +
+
+
To allow users to authenticate using OIDC, fill out the fields below. @@ -313,15 +371,31 @@ bind:this={fileinput} />
+
+
+ + + + +
+
{/if} -
- -
diff --git a/packages/worker/src/api/controllers/admin/configs.js b/packages/worker/src/api/controllers/admin/configs.js index fe7c97f1e9..7dfb5b75be 100644 --- a/packages/worker/src/api/controllers/admin/configs.js +++ b/packages/worker/src/api/controllers/admin/configs.js @@ -149,9 +149,16 @@ exports.publicSettings = async function (ctx) { config = publicConfig } - config.config.oidc = !!oidcConfig - config.config.google = !!googleConfig - + config.config.google = !googleConfig + ? !!googleConfig + : !googleConfig.config.activated + ? false + : true + config.config.oidc = !oidcConfig + ? !!oidcConfig + : !oidcConfig.config.configs[0].activated + ? false + : true ctx.body = config } catch (err) { ctx.throw(err.status, err) diff --git a/packages/worker/src/api/routes/admin/configs.js b/packages/worker/src/api/routes/admin/configs.js index 66be9dd13b..6873d82757 100644 --- a/packages/worker/src/api/routes/admin/configs.js +++ b/packages/worker/src/api/routes/admin/configs.js @@ -38,6 +38,7 @@ function googleValidation() { clientID: Joi.string().required(), clientSecret: Joi.string().required(), callbackURL: Joi.string().required(), + activated: Joi.boolean().required(), }).unknown(true) } @@ -52,6 +53,7 @@ function oidcValidation() { logo: Joi.string().allow("", null), name: Joi.string().allow("", null), uuid: Joi.string().required(), + activated: Joi.boolean().required(), }) ).required(true) }).unknown(true) @@ -100,7 +102,7 @@ router buildConfigSaveValidation(), controller.save ) - .delete("/api/admin/configs/:id", adminOnly, controller.destroy) + .delete("/api/admin/configs/:id/:rev", adminOnly, controller.destroy) .get("/api/admin/configs", controller.fetch) .get("/api/admin/configs/checklist", controller.configChecklist) .get(