Skip to content

Commit

Permalink
[server]: allow auth provider config to be passed in via file path
Browse files Browse the repository at this point in the history
This allows for the values to be injected via a Kubernetes secret, reducing the
exposure of sensitive data in configuration
  • Loading branch information
Simon Emms committed Dec 13, 2021
1 parent 28e3a5f commit 6f7e405
Showing 1 changed file with 21 additions and 4 deletions.
25 changes: 21 additions & 4 deletions components/server/src/config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import { RateLimiterConfig } from './auth/rate-limiter';
import { CodeSyncConfig } from './code-sync/code-sync-service';
import { ChargebeeProviderOptions, readOptionsFromFile } from "@gitpod/gitpod-payment-endpoint/lib/chargebee";
import * as fs from 'fs';
import * as yaml from 'js-yaml';
import { log, LogrusLogLevel } from '@gitpod/gitpod-protocol/lib/util/logging';
import { filePathTelepresenceAware, KubeStage, translateLegacyStagename } from '@gitpod/gitpod-protocol/lib/env';
import { BrandingParser } from './branding-parser';
Expand Down Expand Up @@ -86,6 +87,7 @@ export interface ConfigSerialized {
enableLocalApp: boolean;

authProviderConfigs: AuthProviderParams[];
authProviderConfigFiles: string[];
builtinAuthProvidersConfigured: boolean;
disableDynamicAuthProviderLogin: boolean;

Expand Down Expand Up @@ -170,10 +172,25 @@ export namespace ConfigFile {

function loadAndCompleteConfig(config: ConfigSerialized): Config {
const hostUrl = new GitpodHostUrl(config.hostUrl);
let authProviderConfigs = config.authProviderConfigs
if (authProviderConfigs) {
authProviderConfigs = normalizeAuthProviderParams(authProviderConfigs);
let authProviderConfigs: AuthProviderParams[] = []
const rawProviderConfigs = config.authProviderConfigs
if (rawProviderConfigs) {
/* Add raw provider data */
authProviderConfigs.push(...rawProviderConfigs);
}
const rawProviderConfigFiles = config.authProviderConfigFiles
if (rawProviderConfigFiles) {
/* Add providers from files */
const authProviderConfigFiles: AuthProviderParams[] = rawProviderConfigFiles.map<AuthProviderParams>((providerFile) => {
const rawProviderData = fs.readFileSync(providerFile, "utf-8")

return yaml.load(rawProviderData) as AuthProviderParams
});

authProviderConfigs.push(...authProviderConfigFiles);
}
authProviderConfigs = normalizeAuthProviderParams(authProviderConfigs)

const builtinAuthProvidersConfigured = authProviderConfigs.length > 0;
const chargebeeProviderOptions = readOptionsFromFile(filePathTelepresenceAware(config.chargebeeProviderOptionsFile || ""));
let brandingConfig = config.brandingConfig;
Expand All @@ -183,7 +200,7 @@ export namespace ConfigFile {
let license = config.license
const licenseFile = config.licenseFile
if (licenseFile) {
license = fs.readFileSync(licenseFile, "utf-8")
license = fs.readFileSync(licenseFile, "utf-8");
}
return {
...config,
Expand Down

0 comments on commit 6f7e405

Please sign in to comment.