From ceecd85d7652e6a0d19a1fb43da4795b6a48b30c Mon Sep 17 00:00:00 2001 From: Dean Date: Fri, 23 Jun 2023 14:47:58 +0100 Subject: [PATCH 1/4] OIDC icon fix recreated on a new branch --- packages/backend-core/src/configs/configs.ts | 5 +++ packages/bbui/src/Form/Core/Picker.svelte | 16 ++++++-- .../auth/_components/OIDCButton.svelte | 5 ++- packages/types/src/documents/global/config.ts | 6 +++ .../src/api/controllers/global/configs.ts | 38 ++++++++++++++++++- 5 files changed, 63 insertions(+), 7 deletions(-) diff --git a/packages/backend-core/src/configs/configs.ts b/packages/backend-core/src/configs/configs.ts index 701b5bb329..49ace84d52 100644 --- a/packages/backend-core/src/configs/configs.ts +++ b/packages/backend-core/src/configs/configs.ts @@ -5,6 +5,7 @@ import { GoogleInnerConfig, OIDCConfig, OIDCInnerConfig, + OIDCLogosConfig, SCIMConfig, SCIMInnerConfig, SettingsConfig, @@ -191,6 +192,10 @@ export function getDefaultGoogleConfig(): GoogleInnerConfig | undefined { // OIDC +export async function getOIDCLogosDoc(): Promise { + return getConfig(ConfigType.OIDC_LOGOS) +} + async function getOIDCConfigDoc(): Promise { return getConfig(ConfigType.OIDC) } diff --git a/packages/bbui/src/Form/Core/Picker.svelte b/packages/bbui/src/Form/Core/Picker.svelte index bd575600b1..aada17b318 100644 --- a/packages/bbui/src/Form/Core/Picker.svelte +++ b/packages/bbui/src/Form/Core/Picker.svelte @@ -99,9 +99,15 @@ bind:this={button} > {#if fieldIcon} - - - + {#if !useOptionIconImage} + + + + {:else} + + icon + + {/if} {/if} {#if fieldColour} @@ -311,4 +317,8 @@ max-width: 170px; font-size: 12px; } + + .option-extra.icon.field-icon { + display: flex; + } diff --git a/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte b/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte index 1fa392610b..9d0ab515fb 100644 --- a/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte +++ b/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte @@ -12,6 +12,7 @@ export let samePage $: show = $organisation.oidc + $: oidcLogoCheck = $oidc.logo let preDefinedIcons = { Oidc: OidcLogo, @@ -29,9 +30,9 @@ } }) - $: src = !$oidc.logo + $: src = !oidcLogoCheck ? OidcLogo - : preDefinedIcons[$oidc.logo] || `/global/logos_oidc/${$oidc.logo}` + : preDefinedIcons[$oidc.logo] || oidcLogoCheck {#if show} diff --git a/packages/types/src/documents/global/config.ts b/packages/types/src/documents/global/config.ts index bebb4ae14f..3fd352aada 100644 --- a/packages/types/src/documents/global/config.ts +++ b/packages/types/src/documents/global/config.ts @@ -79,6 +79,12 @@ export interface OIDCConfigs { configs: OIDCInnerConfig[] } +export interface OIDCLogosInnerConfig { + [key: string]: string +} + +export interface OIDCLogosConfig extends Config {} + export interface OIDCInnerConfig { configUrl: string clientID: string diff --git a/packages/worker/src/api/controllers/global/configs.ts b/packages/worker/src/api/controllers/global/configs.ts index 0f22d4aae0..a7d5bac989 100644 --- a/packages/worker/src/api/controllers/global/configs.ts +++ b/packages/worker/src/api/controllers/global/configs.ts @@ -28,6 +28,7 @@ import { SSOConfig, SSOConfigType, UserCtx, + OIDCLogosConfig, } from "@budibase/types" import * as pro from "@budibase/pro" @@ -280,13 +281,39 @@ export async function save(ctx: UserCtx) { } } +function enrichOIDCLogos(oidcLogos: OIDCLogosConfig) { + if (!oidcLogos) { + return + } + oidcLogos.config = Object.keys(oidcLogos.config).reduce( + (acc: any, key: string) => { + if (!key.endsWith("Etag")) { + const etag = oidcLogos.config[`${key}Etag`] + const objectStoreUrl = objectStore.getGlobalFileUrl( + oidcLogos.type, + key, + etag + ) + acc[key] = objectStoreUrl + } else { + acc[key] = oidcLogos.config[key] + } + return acc + }, + {} + ) +} + export async function find(ctx: UserCtx) { try { // Find the config with the most granular scope based on context const type = ctx.params.type - const scopedConfig = await configs.getConfig(type) + let scopedConfig = await configs.getConfig(type) if (scopedConfig) { + if (type === ConfigType.OIDC_LOGOS) { + enrichOIDCLogos(scopedConfig) + } ctx.body = scopedConfig } else { // don't throw an error, there simply is nothing to return @@ -301,13 +328,20 @@ export async function publicOidc(ctx: Ctx) { try { // Find the config with the most granular scope based on context const config = await configs.getOIDCConfig() + const oidcLogoConfig = await configs.getOIDCLogosDoc() + + if (oidcLogoConfig) { + enrichOIDCLogos(oidcLogoConfig) + } if (!config) { ctx.body = [] } else { ctx.body = [ { - logo: config.logo, + logo: oidcLogoConfig + ? oidcLogoConfig.config[config.logo] + : config.logo, name: config.name, uuid: config.uuid, }, From 6f24772f49fc373678f6e62e9e6eacabb02bf226 Mon Sep 17 00:00:00 2001 From: Dean Date: Fri, 23 Jun 2023 16:40:40 +0100 Subject: [PATCH 2/4] PR Feedback --- .../builder/auth/_components/OIDCButton.svelte | 8 +++----- .../src/api/controllers/global/configs.ts | 18 ++++++++---------- 2 files changed, 11 insertions(+), 15 deletions(-) diff --git a/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte b/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte index 9d0ab515fb..f5dcbe7466 100644 --- a/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte +++ b/packages/builder/src/pages/builder/auth/_components/OIDCButton.svelte @@ -12,7 +12,6 @@ export let samePage $: show = $organisation.oidc - $: oidcLogoCheck = $oidc.logo let preDefinedIcons = { Oidc: OidcLogo, @@ -30,14 +29,13 @@ } }) - $: src = !oidcLogoCheck - ? OidcLogo - : preDefinedIcons[$oidc.logo] || oidcLogoCheck + $: oidcLogoImageURL = preDefinedIcons[$oidc.logo] ?? $oidc.logo + $: logoSrc = oidcLogoImageURL ?? OidcLogo {#if show} { const url = `/api/global/auth/${$auth.tenantId}/oidc/configs/${$oidc.uuid}` if (samePage) { diff --git a/packages/worker/src/api/controllers/global/configs.ts b/packages/worker/src/api/controllers/global/configs.ts index a7d5bac989..042fcb9393 100644 --- a/packages/worker/src/api/controllers/global/configs.ts +++ b/packages/worker/src/api/controllers/global/configs.ts @@ -327,23 +327,21 @@ export async function find(ctx: UserCtx) { export async function publicOidc(ctx: Ctx) { try { // Find the config with the most granular scope based on context - const config = await configs.getOIDCConfig() - const oidcLogoConfig = await configs.getOIDCLogosDoc() + const oidcConfig = await configs.getOIDCConfig() + const oidcCustomLogos = await configs.getOIDCLogosDoc() - if (oidcLogoConfig) { - enrichOIDCLogos(oidcLogoConfig) + if (oidcCustomLogos) { + enrichOIDCLogos(oidcCustomLogos) } - if (!config) { + if (!oidcConfig) { ctx.body = [] } else { ctx.body = [ { - logo: oidcLogoConfig - ? oidcLogoConfig.config[config.logo] - : config.logo, - name: config.name, - uuid: config.uuid, + logo: oidcCustomLogos?.config[oidcConfig.logo] ?? oidcConfig.logo, + name: oidcConfig.name, + uuid: oidcConfig.uuid, }, ] } From 10108fb543f1d62911920ddbb4e75e97c0a78272 Mon Sep 17 00:00:00 2001 From: Dean Date: Mon, 26 Jun 2023 10:22:03 +0100 Subject: [PATCH 3/4] Null checking logo configs --- packages/worker/src/api/controllers/global/configs.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/worker/src/api/controllers/global/configs.ts b/packages/worker/src/api/controllers/global/configs.ts index 042fcb9393..411beff554 100644 --- a/packages/worker/src/api/controllers/global/configs.ts +++ b/packages/worker/src/api/controllers/global/configs.ts @@ -282,7 +282,7 @@ export async function save(ctx: UserCtx) { } function enrichOIDCLogos(oidcLogos: OIDCLogosConfig) { - if (!oidcLogos) { + if (!oidcLogos?.config) { return } oidcLogos.config = Object.keys(oidcLogos.config).reduce( From 8f9a1d4bbaf232eb83b0e7bae54299140ac62f1c Mon Sep 17 00:00:00 2001 From: Dean Date: Mon, 26 Jun 2023 10:23:57 +0100 Subject: [PATCH 4/4] PR feedback --- packages/worker/src/api/controllers/global/configs.ts | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/worker/src/api/controllers/global/configs.ts b/packages/worker/src/api/controllers/global/configs.ts index 411beff554..b061d110f5 100644 --- a/packages/worker/src/api/controllers/global/configs.ts +++ b/packages/worker/src/api/controllers/global/configs.ts @@ -282,10 +282,10 @@ export async function save(ctx: UserCtx) { } function enrichOIDCLogos(oidcLogos: OIDCLogosConfig) { - if (!oidcLogos?.config) { + if (!oidcLogos) { return } - oidcLogos.config = Object.keys(oidcLogos.config).reduce( + oidcLogos.config = Object.keys(oidcLogos.config || {}).reduce( (acc: any, key: string) => { if (!key.endsWith("Etag")) { const etag = oidcLogos.config[`${key}Etag`]