keycloak-scim/js/apps/account-ui/src/environment.ts

56 lines
1.7 KiB
TypeScript
Raw Normal View History

export type Environment = {
/** The URL to the root of the auth server. */
authUrl: string;
/** Indicates if the application is running as a Keycloak theme. */
isRunningAsTheme: boolean;
/** The realm used to sign into. */
realm: string;
/** The URL to resources such as the files in the `public` directory. */
resourceUrl: string;
/** Indicates the src for the Brand image */
logo: string;
/** Indicates the url to be followed when Brand image is clicked */
logoUrl: string;
};
// The default environment, used during development.
const defaultEnvironment: Environment = {
authUrl: "http://localhost:8180",
isRunningAsTheme: false,
realm: "master",
resourceUrl: "http://localhost:8080",
logo: "/logo.svg",
logoUrl: "/",
};
// Merge the default and injected environment variables together.
const environment: Environment = {
...defaultEnvironment,
...getInjectedEnvironment(),
};
export { environment };
/**
* Extracts the environment variables that are passed if the application is running as a Keycloak theme.
* These variables are injected by Keycloak into the `index.ftl` as a script tag, the contents of which can be parsed as JSON.
*/
function getInjectedEnvironment(): Record<string, string | number | boolean> {
const element = document.getElementById("environment");
// If the element cannot be found, return an empty record.
if (!element?.textContent) {
return {};
}
// Attempt to parse the contents as JSON and return its value.
try {
return JSON.parse(element.textContent);
} catch (error) {
console.error("Unable to parse environment variables.");
}
// Otherwise, return an empty record.
return {};
}