2019-07-17 08:14:56 +00:00
|
|
|
import is from '@sindresorhus/is';
|
2019-09-06 04:48:25 +00:00
|
|
|
import { clone } from '../util/clone';
|
2019-08-23 13:46:31 +00:00
|
|
|
import { getOptions } from './definitions';
|
2021-03-02 20:44:55 +00:00
|
|
|
import type { PackageRule, RenovateConfig, UpdateType } from './types';
|
2019-07-17 08:14:56 +00:00
|
|
|
|
2019-08-23 13:46:31 +00:00
|
|
|
const options = getOptions();
|
2017-08-11 05:29:16 +00:00
|
|
|
|
2019-08-23 13:46:31 +00:00
|
|
|
let allowedStrings: string[];
|
2017-08-11 05:29:16 +00:00
|
|
|
|
|
|
|
// Returns a massaged config
|
2019-08-23 13:46:31 +00:00
|
|
|
export function massageConfig(config: RenovateConfig): RenovateConfig {
|
2017-11-03 06:43:26 +00:00
|
|
|
if (!allowedStrings) {
|
|
|
|
allowedStrings = [];
|
2020-04-12 16:09:36 +00:00
|
|
|
options.forEach((option) => {
|
2017-11-03 06:43:26 +00:00
|
|
|
if (option.allowString) {
|
|
|
|
allowedStrings.push(option.name);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
2019-03-11 22:43:30 +00:00
|
|
|
const massagedConfig = clone(config);
|
2017-11-10 12:46:16 +00:00
|
|
|
for (const [key, val] of Object.entries(config)) {
|
2018-06-04 18:07:22 +00:00
|
|
|
if (allowedStrings.includes(key) && is.string(val)) {
|
2017-08-11 05:29:16 +00:00
|
|
|
massagedConfig[key] = [val];
|
2020-03-02 11:06:16 +00:00
|
|
|
} else if (key === 'npmToken' && is.string(val) && val.length < 50) {
|
2018-01-10 13:27:19 +00:00
|
|
|
massagedConfig.npmrc = `//registry.npmjs.org/:_authToken=${val}\n`;
|
2017-08-29 07:25:44 +00:00
|
|
|
delete massagedConfig.npmToken;
|
2018-06-04 18:07:22 +00:00
|
|
|
} else if (is.array(val)) {
|
2017-08-18 17:24:27 +00:00
|
|
|
massagedConfig[key] = [];
|
2020-04-12 16:09:36 +00:00
|
|
|
val.forEach((item) => {
|
2018-06-04 18:07:22 +00:00
|
|
|
if (is.object(item)) {
|
2020-03-02 11:06:16 +00:00
|
|
|
(massagedConfig[key] as RenovateConfig[]).push(
|
|
|
|
massageConfig(item as RenovateConfig)
|
|
|
|
);
|
2017-08-18 17:24:27 +00:00
|
|
|
} else {
|
2020-07-30 04:54:20 +00:00
|
|
|
(massagedConfig[key] as unknown[]).push(item);
|
2017-08-18 17:24:27 +00:00
|
|
|
}
|
|
|
|
});
|
2019-01-24 12:41:45 +00:00
|
|
|
} else if (is.object(val) && key !== 'encrypted') {
|
2020-03-02 11:06:16 +00:00
|
|
|
massagedConfig[key] = massageConfig(val as RenovateConfig);
|
2017-08-11 05:29:16 +00:00
|
|
|
}
|
|
|
|
}
|
2019-02-02 01:17:07 +00:00
|
|
|
if (is.nonEmptyArray(massagedConfig.packageRules)) {
|
2019-08-23 13:46:31 +00:00
|
|
|
const newRules: PackageRule[] = [];
|
|
|
|
const updateTypes: UpdateType[] = [
|
2018-11-13 08:29:53 +00:00
|
|
|
'major',
|
|
|
|
'minor',
|
|
|
|
'patch',
|
|
|
|
'pin',
|
|
|
|
'digest',
|
|
|
|
'lockFileMaintenance',
|
|
|
|
'rollback',
|
|
|
|
];
|
|
|
|
for (const rule of massagedConfig.packageRules) {
|
|
|
|
newRules.push(rule);
|
2019-08-23 13:46:31 +00:00
|
|
|
for (const [key, val] of Object.entries(rule) as [
|
|
|
|
UpdateType,
|
|
|
|
PackageRule
|
|
|
|
][]) {
|
2018-11-13 08:29:53 +00:00
|
|
|
if (updateTypes.includes(key)) {
|
2021-03-11 07:03:37 +00:00
|
|
|
let newRule = clone(rule);
|
2021-01-29 10:43:42 +00:00
|
|
|
newRule.matchUpdateTypes = rule.matchUpdateTypes || [];
|
|
|
|
newRule.matchUpdateTypes.push(key);
|
2021-03-11 07:03:37 +00:00
|
|
|
newRule = { ...newRule, ...val };
|
2018-11-13 08:29:53 +00:00
|
|
|
newRules.push(newRule);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for (const rule of newRules) {
|
2020-04-12 16:09:36 +00:00
|
|
|
updateTypes.forEach((updateType) => {
|
2018-11-13 08:29:53 +00:00
|
|
|
delete rule[updateType];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
massagedConfig.packageRules = newRules;
|
|
|
|
}
|
2017-08-11 05:29:16 +00:00
|
|
|
return massagedConfig;
|
|
|
|
}
|