Add activated toggle and login functionality to support this
This commit is contained in:
parent
3fbd762979
commit
6dce0a88a4
|
@ -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}
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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(
|
||||||
|
|
Loading…
Reference in New Issue