import { Config, ConfigType, GetPublicOIDCConfigResponse, GetPublicSettingsResponse, OIDCLogosConfig, } from "@budibase/types" import { BaseAPIClient } from "./types" export interface ConfigEndpoints { saveConfig: ( config: Config ) => Promise<{ type: ConfigType; _id: string; _rev: string }> getConfig: (type: ConfigType) => Promise> deleteConfig: (id: string, rev: string) => Promise<{ message: string }> getTenantConfig: (tentantId: string) => Promise getOIDCConfig: (tenantId: string) => Promise getOIDCLogos: () => Promise> // Missing request or response types getChecklist: (tenantId: string) => Promise uploadLogo: (data: any) => Promise<{ message: string; url: string }> uploadFavicon: (data: any) => Promise<{ message: string; url: string }> uploadOIDCLogo: ( name: string, data: any ) => Promise<{ message: string; url: string }> } export const buildConfigEndpoints = (API: BaseAPIClient): ConfigEndpoints => ({ /** * Saves a global config. * @param config the config to save */ saveConfig: async config => { return await API.post({ url: "/api/global/configs", body: config, }) }, /** * Gets a global config of a certain type. * @param type the type to fetch */ getConfig: async type => { return await API.get({ url: `/api/global/configs/${type}`, }) }, /** * Deletes a global config * @param id the id of the config to delete * @param rev the revision of the config to delete */ deleteConfig: async (id, rev) => { return await API.delete({ url: `/api/global/configs/${id}/${rev}`, }) }, /** * Gets the config for a certain tenant. * @param tenantId the tenant ID to get the config for */ getTenantConfig: async tenantId => { return await API.get({ url: `/api/global/configs/public?tenantId=${tenantId}`, }) }, /** * Gets the OIDC config for a certain tenant. * @param tenantId the tenant ID to get the config for */ getOIDCConfig: async tenantId => { return await API.get({ url: `/api/global/configs/public/oidc?tenantId=${tenantId}`, }) }, /** * Gets the checklist for a specific tenant. * @param tenantId the tenant ID to get the checklist for */ getChecklist: async tenantId => { return await API.get({ url: `/api/global/configs/checklist?tenantId=${tenantId}`, }) }, /** * Updates the company logo for the environment. * @param data the logo form data */ uploadLogo: async data => { return await API.post({ url: "/api/global/configs/upload/settings/logoUrl", body: data, json: false, }) }, /** * Updates the company favicon for the environment. * @param data the favicon form data */ uploadFavicon: async data => { return await API.post({ url: "/api/global/configs/upload/settings/faviconUrl", body: data, json: false, }) }, /** * Uploads a logo for an OIDC provider. * @param name the name of the OIDC provider * @param data the logo form data to upload */ uploadOIDCLogo: async (name, data) => { return await API.post({ url: `/api/global/configs/upload/logos_oidc/${name}`, body: data, json: false, }) }, /** * Gets the list of OIDC logos. */ getOIDCLogos: async () => { return await API.get({ url: "/api/global/configs/logos_oidc", }) }, })