2
0
Files
cal/calcom/packages/features/ee/sso/lib/jackson.ts
2024-08-09 00:39:27 +02:00

64 lines
1.8 KiB
TypeScript

import type {
IConnectionAPIController,
IOAuthController,
ISPSSOConfig,
JacksonOption,
IDirectorySyncController,
} from "@boxyhq/saml-jackson";
import { WEBAPP_URL } from "@calcom/lib/constants";
import { clientSecretVerifier, oidcPath, samlAudience, samlDatabaseUrl, samlPath } from "./saml";
// Set the required options. Refer to https://github.com/boxyhq/jackson#configuration for the full list
const opts: JacksonOption = {
externalUrl: WEBAPP_URL,
samlPath,
samlAudience,
oidcPath,
scimPath: "/api/scim/v2.0",
db: {
engine: "sql",
type: "postgres",
url: samlDatabaseUrl,
encryptionKey: process.env.CALENDSO_ENCRYPTION_KEY,
},
idpEnabled: true,
clientSecretVerifier,
ory: {
projectId: undefined,
sdkToken: undefined,
},
};
declare global {
/* eslint-disable no-var */
var connectionController: IConnectionAPIController | undefined;
var oauthController: IOAuthController | undefined;
var samlSPConfig: ISPSSOConfig | undefined;
var dsyncController: IDirectorySyncController | undefined;
/* eslint-enable no-var */
}
export default async function init() {
if (
!globalThis.connectionController ||
!globalThis.oauthController ||
!globalThis.samlSPConfig ||
!globalThis.dsyncController
) {
const ret = await (await import("@boxyhq/saml-jackson")).controllers(opts);
globalThis.connectionController = ret.connectionAPIController;
globalThis.oauthController = ret.oauthController;
globalThis.samlSPConfig = ret.spConfig;
globalThis.dsyncController = ret.directorySyncController;
}
return {
connectionController: globalThis.connectionController,
oauthController: globalThis.oauthController,
samlSPConfig: globalThis.samlSPConfig,
dsyncController: globalThis.dsyncController,
};
}