Merge branch 'master' into ts/notification-store
This commit is contained in:
commit
6f629a3e5b
|
@ -1,31 +0,0 @@
|
||||||
import { writable, get } from "svelte/store"
|
|
||||||
import { API } from "@/api"
|
|
||||||
import { auth } from "@/stores/portal"
|
|
||||||
|
|
||||||
const OIDC_CONFIG = {
|
|
||||||
logo: undefined,
|
|
||||||
name: undefined,
|
|
||||||
uuid: undefined,
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createOidcStore() {
|
|
||||||
const store = writable(OIDC_CONFIG)
|
|
||||||
const { set, subscribe } = store
|
|
||||||
return {
|
|
||||||
subscribe,
|
|
||||||
set,
|
|
||||||
init: async () => {
|
|
||||||
const tenantId = get(auth).tenantId
|
|
||||||
const config = await API.getOIDCConfig(tenantId)
|
|
||||||
if (Object.keys(config || {}).length) {
|
|
||||||
// Just use the first config for now.
|
|
||||||
// We will be support multiple logins buttons later on.
|
|
||||||
set(...config)
|
|
||||||
} else {
|
|
||||||
set(OIDC_CONFIG)
|
|
||||||
}
|
|
||||||
},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const oidc = createOidcStore()
|
|
|
@ -0,0 +1,21 @@
|
||||||
|
import { get } from "svelte/store"
|
||||||
|
import { API } from "@/api"
|
||||||
|
import { auth } from "@/stores/portal"
|
||||||
|
import { BudiStore } from "../BudiStore"
|
||||||
|
import { PublicOIDCConfig } from "@budibase/types"
|
||||||
|
|
||||||
|
class OIDCStore extends BudiStore<PublicOIDCConfig> {
|
||||||
|
constructor() {
|
||||||
|
super({})
|
||||||
|
}
|
||||||
|
|
||||||
|
async init() {
|
||||||
|
const tenantId = get(auth).tenantId
|
||||||
|
const configs = await API.getOIDCConfigs(tenantId)
|
||||||
|
// Just use the first config for now.
|
||||||
|
// We will be support multiple logins buttons later on.
|
||||||
|
this.set(configs[0] || {})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const oidc = new OIDCStore()
|
|
@ -1,66 +0,0 @@
|
||||||
import { writable, get } from "svelte/store"
|
|
||||||
import { API } from "@/api"
|
|
||||||
import { auth } from "@/stores/portal"
|
|
||||||
import _ from "lodash"
|
|
||||||
|
|
||||||
const DEFAULT_CONFIG = {
|
|
||||||
platformUrl: "",
|
|
||||||
logoUrl: undefined,
|
|
||||||
faviconUrl: undefined,
|
|
||||||
emailBrandingEnabled: true,
|
|
||||||
testimonialsEnabled: true,
|
|
||||||
platformTitle: "Budibase",
|
|
||||||
loginHeading: undefined,
|
|
||||||
loginButton: undefined,
|
|
||||||
metaDescription: undefined,
|
|
||||||
metaImageUrl: undefined,
|
|
||||||
metaTitle: undefined,
|
|
||||||
docsUrl: undefined,
|
|
||||||
company: "Budibase",
|
|
||||||
oidc: undefined,
|
|
||||||
google: undefined,
|
|
||||||
googleDatasourceConfigured: undefined,
|
|
||||||
oidcCallbackUrl: "",
|
|
||||||
googleCallbackUrl: "",
|
|
||||||
isSSOEnforced: false,
|
|
||||||
loaded: false,
|
|
||||||
}
|
|
||||||
|
|
||||||
export function createOrganisationStore() {
|
|
||||||
const store = writable(DEFAULT_CONFIG)
|
|
||||||
const { subscribe, set } = store
|
|
||||||
|
|
||||||
async function init() {
|
|
||||||
const tenantId = get(auth).tenantId
|
|
||||||
const settingsConfigDoc = await API.getTenantConfig(tenantId)
|
|
||||||
set({ ...DEFAULT_CONFIG, ...settingsConfigDoc.config, loaded: true })
|
|
||||||
}
|
|
||||||
|
|
||||||
async function save(config) {
|
|
||||||
// Delete non-persisted fields
|
|
||||||
const storeConfig = _.cloneDeep(get(store))
|
|
||||||
delete storeConfig.oidc
|
|
||||||
delete storeConfig.google
|
|
||||||
delete storeConfig.googleDatasourceConfigured
|
|
||||||
delete storeConfig.oidcCallbackUrl
|
|
||||||
delete storeConfig.googleCallbackUrl
|
|
||||||
|
|
||||||
// delete internal store field
|
|
||||||
delete storeConfig.loaded
|
|
||||||
|
|
||||||
await API.saveConfig({
|
|
||||||
type: "settings",
|
|
||||||
config: { ...storeConfig, ...config },
|
|
||||||
})
|
|
||||||
await init()
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
subscribe,
|
|
||||||
set,
|
|
||||||
save,
|
|
||||||
init,
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export const organisation = createOrganisationStore()
|
|
|
@ -0,0 +1,71 @@
|
||||||
|
import { get } from "svelte/store"
|
||||||
|
import { API } from "@/api"
|
||||||
|
import { auth } from "@/stores/portal"
|
||||||
|
import {
|
||||||
|
ConfigType,
|
||||||
|
PublicSettingsInnerConfig,
|
||||||
|
SettingsBrandingConfig,
|
||||||
|
SettingsInnerConfig,
|
||||||
|
} from "@budibase/types"
|
||||||
|
import { BudiStore } from "../BudiStore"
|
||||||
|
|
||||||
|
interface LocalOrganisationState {
|
||||||
|
loaded: boolean
|
||||||
|
}
|
||||||
|
|
||||||
|
type SavedOrganisationState = SettingsInnerConfig & SettingsBrandingConfig
|
||||||
|
type OrganisationState = SavedOrganisationState &
|
||||||
|
PublicSettingsInnerConfig &
|
||||||
|
LocalOrganisationState
|
||||||
|
|
||||||
|
const DEFAULT_STATE: OrganisationState = {
|
||||||
|
platformUrl: "",
|
||||||
|
emailBrandingEnabled: true,
|
||||||
|
testimonialsEnabled: true,
|
||||||
|
platformTitle: "Budibase",
|
||||||
|
company: "Budibase",
|
||||||
|
google: false,
|
||||||
|
googleDatasourceConfigured: false,
|
||||||
|
oidc: false,
|
||||||
|
oidcCallbackUrl: "",
|
||||||
|
googleCallbackUrl: "",
|
||||||
|
loaded: false,
|
||||||
|
}
|
||||||
|
|
||||||
|
class OrganisationStore extends BudiStore<OrganisationState> {
|
||||||
|
constructor() {
|
||||||
|
super(DEFAULT_STATE)
|
||||||
|
}
|
||||||
|
|
||||||
|
async init() {
|
||||||
|
const tenantId = get(auth).tenantId
|
||||||
|
const settingsConfigDoc = await API.getTenantConfig(tenantId)
|
||||||
|
this.set({ ...DEFAULT_STATE, ...settingsConfigDoc.config, loaded: true })
|
||||||
|
}
|
||||||
|
|
||||||
|
async save(changes: Partial<SavedOrganisationState>) {
|
||||||
|
// Strip non persisted fields
|
||||||
|
const {
|
||||||
|
oidc,
|
||||||
|
google,
|
||||||
|
googleDatasourceConfigured,
|
||||||
|
oidcCallbackUrl,
|
||||||
|
googleCallbackUrl,
|
||||||
|
loaded,
|
||||||
|
...config
|
||||||
|
} = get(this.store)
|
||||||
|
|
||||||
|
// Save new config
|
||||||
|
const newConfig: SavedOrganisationState = {
|
||||||
|
...config,
|
||||||
|
...changes,
|
||||||
|
}
|
||||||
|
await API.saveConfig({
|
||||||
|
type: ConfigType.SETTINGS,
|
||||||
|
config: newConfig,
|
||||||
|
})
|
||||||
|
await this.init()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export const organisation = new OrganisationStore()
|
|
@ -16,7 +16,7 @@ import { BaseAPIClient } from "./types"
|
||||||
export interface ConfigEndpoints {
|
export interface ConfigEndpoints {
|
||||||
getConfig: (type: ConfigType) => Promise<FindConfigResponse>
|
getConfig: (type: ConfigType) => Promise<FindConfigResponse>
|
||||||
getTenantConfig: (tentantId: string) => Promise<GetPublicSettingsResponse>
|
getTenantConfig: (tentantId: string) => Promise<GetPublicSettingsResponse>
|
||||||
getOIDCConfig: (tenantId: string) => Promise<GetPublicOIDCConfigResponse>
|
getOIDCConfigs: (tenantId: string) => Promise<GetPublicOIDCConfigResponse>
|
||||||
getOIDCLogos: () => Promise<Config<OIDCLogosConfig>>
|
getOIDCLogos: () => Promise<Config<OIDCLogosConfig>>
|
||||||
saveConfig: (config: SaveConfigRequest) => Promise<SaveConfigResponse>
|
saveConfig: (config: SaveConfigRequest) => Promise<SaveConfigResponse>
|
||||||
deleteConfig: (id: string, rev: string) => Promise<DeleteConfigResponse>
|
deleteConfig: (id: string, rev: string) => Promise<DeleteConfigResponse>
|
||||||
|
@ -73,7 +73,7 @@ export const buildConfigEndpoints = (API: BaseAPIClient): ConfigEndpoints => ({
|
||||||
* Gets the OIDC config for a certain tenant.
|
* Gets the OIDC config for a certain tenant.
|
||||||
* @param tenantId the tenant ID to get the config for
|
* @param tenantId the tenant ID to get the config for
|
||||||
*/
|
*/
|
||||||
getOIDCConfig: async tenantId => {
|
getOIDCConfigs: async tenantId => {
|
||||||
return await API.get({
|
return await API.get({
|
||||||
url: `/api/global/configs/public/oidc?tenantId=${tenantId}`,
|
url: `/api/global/configs/public/oidc?tenantId=${tenantId}`,
|
||||||
})
|
})
|
||||||
|
|
|
@ -26,13 +26,11 @@ export interface SMTPConfig extends Config<SMTPInnerConfig> {}
|
||||||
export interface SettingsBrandingConfig {
|
export interface SettingsBrandingConfig {
|
||||||
faviconUrl?: string
|
faviconUrl?: string
|
||||||
faviconUrlEtag?: string
|
faviconUrlEtag?: string
|
||||||
|
|
||||||
emailBrandingEnabled?: boolean
|
emailBrandingEnabled?: boolean
|
||||||
testimonialsEnabled?: boolean
|
testimonialsEnabled?: boolean
|
||||||
platformTitle?: string
|
platformTitle?: string
|
||||||
loginHeading?: string
|
loginHeading?: string
|
||||||
loginButton?: string
|
loginButton?: string
|
||||||
|
|
||||||
metaDescription?: string
|
metaDescription?: string
|
||||||
metaImageUrl?: string
|
metaImageUrl?: string
|
||||||
metaTitle?: string
|
metaTitle?: string
|
||||||
|
@ -42,6 +40,7 @@ export interface SettingsInnerConfig {
|
||||||
platformUrl?: string
|
platformUrl?: string
|
||||||
company?: string
|
company?: string
|
||||||
logoUrl?: string // Populated on read
|
logoUrl?: string // Populated on read
|
||||||
|
docsUrl?: string
|
||||||
logoUrlEtag?: string
|
logoUrlEtag?: string
|
||||||
uniqueTenantId?: string
|
uniqueTenantId?: string
|
||||||
analyticsEnabled?: boolean
|
analyticsEnabled?: boolean
|
||||||
|
|
Loading…
Reference in New Issue