* chore: Store expiresAt on UserAuthentications. This represents the time that the accessToken is no longer valid and should be exchanged using the refreshToken * feat: Check and expire Google SSO * fix: Better handling of multiple auth methods Added more docs * fix: Retry access validation with network errors * Small refactor, add Azure token validation support * doc * test * lint * OIDC refresh support * CheckSSOAccessTask -> ValidateSSOAccessTask Added lastValidatedAt column Skip checks if validated within 5min Some edge cases around encrypted columns
48 lines
1.1 KiB
TypeScript
48 lines
1.1 KiB
TypeScript
import Router from "koa-router";
|
|
import { sortBy } from "lodash";
|
|
import { signin } from "@shared/utils/urlHelpers";
|
|
import { requireDirectory } from "@server/utils/fs";
|
|
|
|
interface AuthenticationProviderConfig {
|
|
id: string;
|
|
name: string;
|
|
enabled: boolean;
|
|
authUrl: string;
|
|
router: Router;
|
|
}
|
|
|
|
const providers: AuthenticationProviderConfig[] = [];
|
|
|
|
requireDirectory(__dirname).forEach(([module, id]) => {
|
|
// @ts-expect-error ts-migrate(2339) FIXME: Property 'config' does not exist on type 'unknown'... Remove this comment to see the full error message
|
|
const { config, default: router } = module;
|
|
|
|
if (id === "index") {
|
|
return;
|
|
}
|
|
|
|
if (!config) {
|
|
throw new Error(
|
|
`Auth providers must export a 'config' object, missing in ${id}`
|
|
);
|
|
}
|
|
|
|
if (!router || !router.routes) {
|
|
throw new Error(
|
|
`Default export of an auth provider must be a koa-router, missing in ${id}`
|
|
);
|
|
}
|
|
|
|
if (config && config.enabled) {
|
|
providers.push({
|
|
id,
|
|
name: config.name,
|
|
enabled: config.enabled,
|
|
authUrl: signin(id),
|
|
router: router,
|
|
});
|
|
}
|
|
});
|
|
|
|
export default sortBy(providers, "id");
|