mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-12 14:19:01 +00:00
57 lines
1.7 KiB
TypeScript
57 lines
1.7 KiB
TypeScript
import { logger } from '../logger';
|
|
import { clone } from '../util/clone';
|
|
import { getHighestVulnerabilitySeverity } from '../util/vulnerability/utils';
|
|
import * as options from './options';
|
|
import type { RenovateConfig } from './types';
|
|
|
|
export function mergeChildConfig<
|
|
T extends Record<string, any>,
|
|
TChild extends Record<string, any> | undefined,
|
|
>(parent: T, child: TChild): T & TChild {
|
|
logger.trace({ parent, child }, `mergeChildConfig`);
|
|
if (!child) {
|
|
return parent as never;
|
|
}
|
|
const parentConfig = clone(parent);
|
|
const childConfig = clone(child);
|
|
const config: Record<string, any> = { ...parentConfig, ...childConfig };
|
|
|
|
// Ensure highest severity survives parent / child merge
|
|
if (config?.isVulnerabilityAlert) {
|
|
config.vulnerabilitySeverity = getHighestVulnerabilitySeverity(
|
|
parent,
|
|
child,
|
|
);
|
|
}
|
|
|
|
for (const option of options.getOptions()) {
|
|
if (
|
|
option.mergeable &&
|
|
childConfig[option.name] &&
|
|
parentConfig[option.name]
|
|
) {
|
|
logger.trace(`mergeable option: ${option.name}`);
|
|
|
|
if (option.name === 'constraints') {
|
|
config[option.name] = {
|
|
...parentConfig[option.name],
|
|
...childConfig[option.name],
|
|
};
|
|
} else if (option.type === 'array') {
|
|
config[option.name] = (parentConfig[option.name] as unknown[]).concat(
|
|
config[option.name],
|
|
);
|
|
} else {
|
|
config[option.name] = mergeChildConfig(
|
|
parentConfig[option.name] as RenovateConfig,
|
|
childConfig[option.name] as RenovateConfig,
|
|
);
|
|
}
|
|
logger.trace(
|
|
{ result: config[option.name] },
|
|
`Merged config.${option.name}`,
|
|
);
|
|
}
|
|
}
|
|
return { ...config, ...config.force };
|
|
}
|