Add activated toggle and login functionality to support this

This commit is contained in:
Peter Clement 2021-07-20 09:27:12 +01:00
parent 3fbd762979
commit 6dce0a88a4
4 changed files with 119 additions and 27 deletions

View File

@ -4,7 +4,6 @@
import { organisation } from "stores/portal" import { organisation } from "stores/portal"
$: show = $organisation.google $: show = $organisation.google
console.log(show)
</script> </script>
{#if show} {#if show}

View File

@ -17,6 +17,7 @@
Input, Input,
Body, Body,
Select, Select,
Toggle,
} from "@budibase/bbui" } from "@budibase/bbui"
import { onMount } from "svelte" import { onMount } from "svelte"
import api from "builderStore/api" import api from "builderStore/api"
@ -90,21 +91,30 @@
let google let google
let oidc let oidc
const providers = { google, 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 // Create a flag so that it will only try to save completed forms
$: trySaveGoogle = $: partialGoogle =
providers.google?.config.clientID || providers.google?.config?.clientID ||
providers.google?.config.clientSecret || providers.google?.config?.clientSecret ||
providers.google?.config.callbackURL providers.google?.config?.callbackURL
$: trySaveOidc = $: partialOidc =
providers.oidc?.config?.configs[0].configUrl || providers.oidc?.config?.configs[0].configUrl ||
providers.oidc?.config?.configs[0].clientID || providers.oidc?.config?.configs[0].clientID ||
providers.oidc?.config?.configs[0].clientSecret providers.oidc?.config?.configs[0].clientSecret
$: googleComplete = $: googleComplete =
providers.google?.config.clientID && providers.google?.config?.clientID &&
providers.google?.config.clientSecret && providers.google?.config?.clientSecret &&
providers.google?.config.callbackURL providers.google?.config?.callbackURL
$: oidcComplete = $: oidcComplete =
providers.oidc?.config?.configs[0].configUrl && providers.oidc?.config?.configs[0].configUrl &&
providers.oidc?.config?.configs[0].clientID && providers.oidc?.config?.configs[0].clientID &&
@ -128,6 +138,22 @@
iconDropdownOptions.unshift({ label: fileName, value: fileName }) 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) { async function save(docs) {
// only if the user has provided an image, upload it. // only if the user has provided an image, upload it.
image && uploadLogo(image) image && uploadLogo(image)
@ -139,7 +165,7 @@
element.config.configs.forEach(config => { element.config.configs.forEach(config => {
!config.uuid && (config.uuid = uuid()) !config.uuid && (config.uuid = uuid())
}) })
if (trySaveOidc) { if (partialOidc) {
if (!oidcComplete) { if (!oidcComplete) {
notifications.error( notifications.error(
`Please fill in all required ${ConfigTypes.OIDC} fields` `Please fill in all required ${ConfigTypes.OIDC} fields`
@ -151,7 +177,7 @@
} }
} }
if (element.type === ConfigTypes.Google) { if (element.type === ConfigTypes.Google) {
if (trySaveGoogle) { if (partialGoogle) {
if (!googleComplete) { if (!googleComplete) {
notifications.error( notifications.error(
`Please fill in all required ${ConfigTypes.Google} fields` `Please fill in all required ${ConfigTypes.Google} fields`
@ -196,7 +222,7 @@
if (!googleDoc._id) { if (!googleDoc._id) {
providers.google = { providers.google = {
type: ConfigTypes.Google, type: ConfigTypes.Google,
config: {}, config: { activated: true },
} }
} else { } else {
providers.google = googleDoc providers.google = googleDoc
@ -225,7 +251,7 @@
if (!oidcDoc._id) { if (!oidcDoc._id) {
providers.oidc = { providers.oidc = {
type: ConfigTypes.OIDC, type: ConfigTypes.OIDC,
config: { configs: [{}] }, config: { configs: [{ activated: true }] },
} }
} else { } else {
providers.oidc = oidcDoc providers.oidc = oidcDoc
@ -246,10 +272,20 @@
<Divider /> <Divider />
<Layout gap="XS" noPadding> <Layout gap="XS" noPadding>
<Heading size="S"> <Heading size="S">
<span> <div>
<GoogleLogo /> <GoogleLogo />
Google Google
</span> <div class="google-save-button">
<div>
<Button
disabled={googleSaveButtonDisabled}
size="s"
cta
on:click={() => save([providers.google])}>Save</Button
>
</div>
</div>
</div>
</Heading> </Heading>
<Body size="S"> <Body size="S">
To allow users to authenticate using their Google accounts, fill out the To allow users to authenticate using their Google accounts, fill out the
@ -263,17 +299,39 @@
<Input bind:value={providers.google.config[field]} /> <Input bind:value={providers.google.config[field]} />
</div> </div>
{/each} {/each}
<div class="form-row">
<div class="field">
<Label size="L">Activated</Label>
<span class="alignedToggle">
<Toggle
text=""
on:change={toggleGoogle}
bind:value={providers.google.config.activated}
/>
</span>
</div>
</div>
</Layout> </Layout>
{/if} {/if}
{#if providers.oidc} {#if providers.oidc}
<Divider /> <Divider />
<Layout gap="XS" noPadding> <Layout gap="XS" noPadding>
<Heading size="S"> <Heading size="S">
<span> <div>
<OidcLogo /> <OidcLogo />
OpenID Connect OpenID Connect
</span> <div class="oidc-save-button">
</Heading> <div>
<Button
disabled={oidcSaveButtonDisabled}
size="s"
cta
on:click={() => save([providers.oidc])}>Save</Button
>
</div>
</div>
</div></Heading
>
<Body size="S"> <Body size="S">
To allow users to authenticate using OIDC, fill out the fields below. To allow users to authenticate using OIDC, fill out the fields below.
</Body> </Body>
@ -313,15 +371,31 @@
bind:this={fileinput} bind:this={fileinput}
/> />
</Layout> </Layout>
<div class="form-row">
<div class="field">
<Label size="L">Activated</Label>
<span class="alignedToggle">
<Toggle
text=""
on:change={toggleOidc}
bind:value={providers.oidc.config.configs[0].activated}
/>
</span>
</div>
</div>
{/if} {/if}
<div>
<Button cta on:click={() => save([providers.google, providers.oidc])}
>Save</Button
>
</div>
</Layout> </Layout>
<style> <style>
.field {
display: flex;
align-items: center;
}
.alignedToggle {
margin-left: 63%;
}
.form-row { .form-row {
display: grid; display: grid;
grid-template-columns: 20% 1fr; grid-template-columns: 20% 1fr;
@ -337,4 +411,14 @@
input { input {
display: none; display: none;
} }
.google-save-button {
display: inline-block;
margin-left: 400px;
}
.oidc-save-button {
display: inline-block;
margin-left: 320px;
}
</style> </style>

View File

@ -149,9 +149,16 @@ exports.publicSettings = async function (ctx) {
config = publicConfig 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 ctx.body = config
} catch (err) { } catch (err) {
ctx.throw(err.status, err) ctx.throw(err.status, err)

View File

@ -38,6 +38,7 @@ function googleValidation() {
clientID: Joi.string().required(), clientID: Joi.string().required(),
clientSecret: Joi.string().required(), clientSecret: Joi.string().required(),
callbackURL: Joi.string().required(), callbackURL: Joi.string().required(),
activated: Joi.boolean().required(),
}).unknown(true) }).unknown(true)
} }
@ -52,6 +53,7 @@ function oidcValidation() {
logo: Joi.string().allow("", null), logo: Joi.string().allow("", null),
name: Joi.string().allow("", null), name: Joi.string().allow("", null),
uuid: Joi.string().required(), uuid: Joi.string().required(),
activated: Joi.boolean().required(),
}) })
).required(true) ).required(true)
}).unknown(true) }).unknown(true)
@ -100,7 +102,7 @@ router
buildConfigSaveValidation(), buildConfigSaveValidation(),
controller.save 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", controller.fetch)
.get("/api/admin/configs/checklist", controller.configChecklist) .get("/api/admin/configs/checklist", controller.configChecklist)
.get( .get(