renovate/lib/config/options/index.ts
Rhys Arkins 2735ac3e80 fix(automerge)!: default platformAutomerge to false ()
Flips platformAutomerge default to `false`.

BREAKING CHANGE: Platform automerge is no longer enabled by default.
2021-11-05 08:10:27 +01:00

2148 lines
54 KiB
TypeScript

import { PlatformId } from '../../constants';
import { getManagers } from '../../manager';
import { getPlatformList } from '../../platform';
import { getVersioningList } from '../../versioning';
import * as dockerVersioning from '../../versioning/docker';
import * as pep440Versioning from '../../versioning/pep440';
import type { RenovateOptions } from '../types';
const options: RenovateOptions[] = [
{
name: 'detectGlobalManagerConfig',
description:
'If true, Renovate will attempt to read global manager config from the file system.',
type: 'boolean',
default: false,
globalOnly: true,
},
{
name: 'detectHostRulesFromEnv',
description:
'If true, Renovate tries to detect host rules from environment variables.',
type: 'boolean',
default: false,
globalOnly: true,
},
{
name: 'allowPostUpgradeCommandTemplating',
description: 'If true allow templating for post-upgrade commands.',
type: 'boolean',
default: false,
globalOnly: true,
},
{
name: 'allowedPostUpgradeCommands',
description:
'A list of regular expressions that determine which post-upgrade tasks are allowed.',
type: 'array',
subType: 'string',
default: [],
globalOnly: true,
},
{
name: 'postUpgradeTasks',
description:
'Post-upgrade tasks that are executed before a commit is made by Renovate.',
type: 'object',
default: {
commands: [],
fileFilters: [],
executionMode: 'update',
},
},
{
name: 'commands',
description:
'A list of post-upgrade commands that are executed before a commit is made by Renovate.',
type: 'array',
subType: 'string',
parent: 'postUpgradeTasks',
default: [],
cli: false,
},
{
name: 'fileFilters',
description:
'Files that match these glob patterns will be committed if they are present after running a post-upgrade task.',
type: 'array',
subType: 'string',
parent: 'postUpgradeTasks',
default: [],
cli: false,
},
{
name: 'executionMode',
description:
'Controls whether the post upgrade tasks runs for every update or once per upgrade branch',
type: 'string',
parent: 'postUpgradeTasks',
allowedValues: ['update', 'branch'],
default: 'update',
cli: false,
},
{
name: 'onboardingBranch',
description:
'Change this value in order to override the default onboarding branch name.',
type: 'string',
default: 'renovate/configure',
globalOnly: true,
cli: false,
},
{
name: 'onboardingCommitMessage',
description:
'Change this value in order to override the default onboarding commit message.',
type: 'string',
default: null,
globalOnly: true,
cli: false,
},
{
name: 'onboardingConfigFileName',
description:
'Change this value in order to override the default onboarding config file name.',
type: 'string',
default: 'renovate.json',
globalOnly: true,
cli: false,
},
{
name: 'onboardingNoDeps',
description: 'Onboard repository even if no dependencies found.',
type: 'boolean',
default: false,
globalOnly: true,
},
{
name: 'onboardingPrTitle',
description:
'Change this value in order to override the default onboarding PR title.',
type: 'string',
default: 'Configure Renovate',
globalOnly: true,
cli: false,
},
{
name: 'productLinks',
description: 'Links which are embedded within PRs, issues, etc.',
type: 'object',
globalOnly: true,
mergeable: true,
default: {
documentation: 'https://docs.renovatebot.com/',
help: 'https://github.com/renovatebot/renovate/discussions',
homepage: 'https://github.com/renovatebot/renovate',
},
additionalProperties: {
type: 'string',
format: 'uri',
},
},
{
name: 'secrets',
description: 'Object containing secret name/value pairs',
type: 'object',
globalOnly: true,
mergeable: true,
default: {},
additionalProperties: {
type: 'string',
},
},
{
name: 'extends',
description:
'Configuration presets to use/extend. Note: does not work if configured in config.js.',
stage: 'package',
type: 'array',
subType: 'string',
allowString: true,
cli: false,
},
{
name: 'ignorePresets',
description:
'A list of presets to ignore, including nested ones inside `extends`.',
stage: 'package',
type: 'array',
subType: 'string',
allowString: true,
cli: false,
},
{
name: 'migratePresets',
description:
'Define presets here which have been removed or renamed and should be migrated automatically.',
type: 'object',
globalOnly: true,
default: {},
additionalProperties: {
type: 'string',
},
},
{
name: 'description',
description: 'Plain text description for a config or preset.',
type: 'array',
subType: 'string',
stage: 'repository',
allowString: true,
mergeable: true,
cli: false,
env: false,
},
{
name: 'enabled',
description: `Enable or disable the bot.`,
stage: 'package',
type: 'boolean',
cli: false,
env: false,
},
{
name: 'deepExtract',
description: `Enable extraction of dependencies using package managers.`,
type: 'boolean',
default: false,
cli: false,
env: false,
supportedManagers: ['gradle'],
},
{
name: 'repositoryCache',
description: 'Option to do repository extract caching.',
globalOnly: true,
type: 'string',
allowedValues: ['disabled', 'enabled', 'reset'],
stage: 'repository',
default: 'disabled',
},
{
name: 'force',
description:
'Any configuration defined within this object will force override existing settings.',
stage: 'package',
globalOnly: true,
type: 'object',
cli: false,
env: false,
},
{
name: 'forceCli',
description:
'Whether CLI configuration options should be moved to the `force` config section.',
stage: 'global',
type: 'boolean',
default: true,
},
{
name: 'draftPR',
description: 'If enabled, the PR created by Renovate is set to a draft.',
type: 'boolean',
default: false,
supportedPlatforms: ['github', 'gitlab', 'azure'],
},
{
name: 'dryRun',
description:
'If enabled, perform a dry run by logging messages instead of creating/updating/deleting branches and PRs.',
type: 'boolean',
globalOnly: true,
default: false,
},
{
name: 'printConfig',
description:
'If enabled, log the full resolved config for each repo, including resolved presets.',
type: 'boolean',
globalOnly: true,
default: false,
},
{
name: 'binarySource',
description:
'Controls whether third party tools like npm or Gradle are called directly, or via Docker sidecar containers.',
globalOnly: true,
type: 'string',
allowedValues: ['global', 'docker'],
default: 'global',
},
{
name: 'redisUrl',
description:
'If defined, this Redis URL will be used for caching instead of the file system.',
stage: 'global',
type: 'string',
},
{
name: 'baseDir',
description:
'The base directory for Renovate to store local files, including repository files and cache. If left empty, Renovate will create its own temporary directory to use.',
stage: 'global',
type: 'string',
},
{
name: 'cacheDir',
description:
'The directory for Renovate for storing caches. If left empty, Renovate will create a subdirectory within `baseDir` to use.',
globalOnly: true,
type: 'string',
},
{
name: 'customEnvVariables',
description:
'Custom environment variables for child processes and sidecar Docker containers.',
globalOnly: true,
type: 'object',
default: {},
},
{
name: 'dockerChildPrefix',
description:
'Change this value in order to add a prefix to the Renovate Docker sidecar container names and labels.',
type: 'string',
globalOnly: true,
default: 'renovate_',
},
{
name: 'dockerImagePrefix',
description:
'Change this value in order to override the default Renovate Docker sidecar image name prefix.',
type: 'string',
default: 'docker.io/renovate',
globalOnly: true,
},
{
name: 'dockerUser',
description:
'Specify UID and GID for Docker-based binaries when binarySource=docker is used.',
globalOnly: true,
type: 'string',
},
{
name: 'composerIgnorePlatformReqs',
description:
'Configure use of `--ignore-platform-reqs`/`--ignore-platform-req` for the Composer package manager.',
type: 'array',
subType: 'string',
default: [],
},
// Log options
{
name: 'logFile',
description: 'Log file path.',
stage: 'global',
type: 'string',
},
{
name: 'logFileLevel',
description: 'Log file log level.',
stage: 'global',
type: 'string',
default: 'debug',
},
{
name: 'logContext',
description: 'Add a global or per-repo log context to each log entry.',
globalOnly: true,
type: 'string',
default: null,
},
// Onboarding
{
name: 'onboarding',
description: 'Require a Configuration PR first.',
stage: 'repository',
type: 'boolean',
globalOnly: true,
},
{
name: 'onboardingConfig',
description: 'Configuration to use in onboarding PRs.',
stage: 'repository',
type: 'object',
default: { $schema: 'https://docs.renovatebot.com/renovate-schema.json' },
globalOnly: true,
mergeable: true,
},
{
name: 'includeForks',
description:
'Whether to process forked repositories or not. By default, all forked repositories are skipped.',
stage: 'repository',
type: 'boolean',
default: false,
},
{
name: 'forkMode',
description:
'Set to true to fork the source repository and create branches there instead.',
stage: 'repository',
type: 'boolean',
default: false,
globalOnly: true,
},
{
name: 'forkToken',
description:
'Will be used on GitHub when `forkMode` is set to `true` to clone the repositories.',
stage: 'repository',
type: 'string',
default: '',
globalOnly: true,
},
{
name: 'requireConfig',
description:
'Set to false if it is optional for repositories to contain a config.',
stage: 'repository',
type: 'boolean',
default: true,
globalOnly: true,
},
{
name: 'optimizeForDisabled',
description:
'Set to true to first check for disabling in config before cloning.',
stage: 'repository',
type: 'boolean',
default: false,
globalOnly: true,
},
// Dependency Dashboard
{
name: 'dependencyDashboard',
description:
'Whether to create a "Dependency Dashboard" issue within the repository.',
type: 'boolean',
default: false,
},
{
name: 'dependencyDashboardApproval',
description:
'Whether updates should require manual approval from within the Dependency Dashboard issue before creation.',
type: 'boolean',
default: false,
},
{
name: 'dependencyDashboardAutoclose',
description:
'Set to `true` and Renovate will autoclose the Dependency Dashboard issue if there are no updates.',
type: 'boolean',
default: false,
},
{
name: 'dependencyDashboardTitle',
description: 'Title to use for the Dependency Dashboard issue.',
type: 'string',
default: `Dependency Dashboard`,
},
{
name: 'dependencyDashboardHeader',
description:
'Any text added here will be placed first in the Dependency Dashboard issue body.',
type: 'string',
default:
'This issue provides visibility into Renovate updates and their statuses. [Learn more](https://docs.renovatebot.com/key-concepts/dashboard/)',
},
{
name: 'dependencyDashboardFooter',
description:
'Any text added here will be placed last in the Dependency Dashboard issue body, with a divider separator before it.',
type: 'string',
},
{
name: 'dependencyDashboardLabels',
description:
'These labels will always be applied on the Dependency Dashboard issue, even when they have been removed manually.',
type: 'array',
subType: 'string',
default: null,
},
{
name: 'configWarningReuseIssue',
description:
'Set this to false and Renovate will open each config warning in a new issue instead of reopening/reusing an existing issue.',
type: 'boolean',
default: true,
},
// encryption
{
name: 'privateKey',
description: 'Server-side private key.',
stage: 'repository',
type: 'string',
replaceLineReturns: true,
globalOnly: true,
},
{
name: 'privateKeyOld',
description: 'Secondary/old private key to try.',
stage: 'repository',
type: 'string',
replaceLineReturns: true,
globalOnly: true,
},
{
name: 'privateKeyPath',
description: 'Path to the Server-side private key.',
stage: 'repository',
type: 'string',
globalOnly: true,
},
{
name: 'privateKeyPathOld',
description: 'Path to the Server-side old private key.',
stage: 'repository',
type: 'string',
globalOnly: true,
},
{
name: 'encrypted',
description:
'A configuration object containing configuration encrypted with project key.',
stage: 'repository',
type: 'object',
default: null,
},
// Scheduling
{
name: 'timezone',
description:
'[IANA Time Zone](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones)',
type: 'string',
},
{
name: 'schedule',
description: 'Times of day/week to limit branch creation to.',
type: 'array',
subType: 'string',
allowString: true,
cli: true,
env: false,
default: ['at any time'],
},
{
name: 'updateNotScheduled',
description:
'Whether to update (but not create) branches when not scheduled.',
stage: 'branch',
type: 'boolean',
},
// Bot administration
{
name: 'persistRepoData',
description:
'If set to true, repository data will preserved between runs instead of deleted.',
type: 'boolean',
globalOnly: true,
default: false,
},
{
name: 'exposeAllEnv',
description:
'Configure this to true to allow passing of all env variables to package managers.',
globalOnly: true,
type: 'boolean',
default: false,
},
{
name: 'allowScripts',
description:
'Configure this to true if repositories are allowed to run install scripts.',
globalOnly: true,
type: 'boolean',
default: false,
},
{
name: 'allowCustomCrateRegistries',
description:
'Configure this to true if custom crate registries are allowed.',
globalOnly: true,
type: 'boolean',
default: false,
},
{
name: 'ignoreScripts',
description:
'Configure this to true if allowScripts=true but you wish to skip running scripts when updating lock files.',
type: 'boolean',
default: false,
supportedManagers: ['npm', 'composer'],
},
{
name: 'platform',
description: 'Platform type of repository.',
type: 'string',
allowedValues: getPlatformList(),
default: PlatformId.Github,
globalOnly: true,
},
{
name: 'endpoint',
description: 'Custom endpoint to use.',
type: 'string',
globalOnly: true,
default: null,
},
{
name: 'token',
description: 'Repository Auth Token.',
stage: 'repository',
type: 'string',
globalOnly: true,
},
{
name: 'username',
description: 'Username for authentication. Currently Bitbucket only.',
stage: 'repository',
type: 'string',
globalOnly: true,
},
{
name: 'password',
description:
'Password for authentication. Currently Bitbucket only (AppPassword).',
stage: 'repository',
type: 'string',
globalOnly: true,
},
{
name: 'npmrc',
description: 'String copy of npmrc file. Use \\n instead of line breaks.',
stage: 'branch',
type: 'string',
},
{
name: 'npmrcMerge',
description:
'Whether to merge config.npmrc with repo .npmrc content if both are found.',
stage: 'branch',
type: 'boolean',
default: false,
},
{
name: 'npmToken',
description: 'npm token used for authenticating with the default registry.',
stage: 'branch',
type: 'string',
},
{
name: 'updateLockFiles',
description: 'Set to false to disable lock file updating.',
type: 'boolean',
},
{
name: 'skipInstalls',
description:
'Skip installing modules/dependencies if lock file updating is possible alone.',
type: 'boolean',
default: null,
globalOnly: true,
},
{
name: 'autodiscover',
description: 'Autodiscover all repositories.',
stage: 'global',
type: 'boolean',
default: false,
},
{
name: 'autodiscoverFilter',
description: 'Filter the list of autodiscovered repositories.',
stage: 'global',
type: 'string',
default: null,
},
{
name: 'prCommitsPerRunLimit',
description:
'Set a maximum number of commits per Renovate run. Default is no limit.',
stage: 'global',
type: 'integer',
default: 0,
},
{
name: 'repositories',
description: 'List of Repositories.',
stage: 'global',
type: 'array',
cli: false,
},
{
name: 'baseBranches',
description:
'An array of one or more custom base branches to be processed. If left empty, the default branch will be chosen.',
type: 'array',
stage: 'package',
cli: false,
},
{
name: 'gitAuthor',
description: 'Author to use for Git commits. Must conform to RFC5322.',
type: 'string',
},
{
name: 'gitPrivateKey',
description: 'PGP key to use for signing Git commits.',
type: 'string',
cli: false,
globalOnly: true,
stage: 'global',
},
{
name: 'gitIgnoredAuthors',
description:
'Additional git authors which are ignored by Renovate. Must conform to RFC5322.',
type: 'array',
subType: 'string',
stage: 'repository',
},
{
name: 'enabledManagers',
description:
'A list of package managers to enable. If defined, then all managers not on the list are disabled.',
type: 'array',
stage: 'repository',
},
{
name: 'includePaths',
description: 'Include package files only within these defined paths.',
type: 'array',
subType: 'string',
stage: 'repository',
default: [],
},
{
name: 'ignorePaths',
description:
'Skip any package file whose path matches one of these. Can be a string or glob pattern.',
type: 'array',
subType: 'string',
stage: 'repository',
default: ['**/node_modules/**', '**/bower_components/**'],
},
{
name: 'excludeCommitPaths',
description:
'A file that matches any of these glob patterns will not be committed, even if it has been updated.',
type: 'array',
subType: 'string',
default: [],
},
{
name: 'aliases',
description: 'Aliases for registries, package manager specific.',
type: 'object',
default: {},
additionalProperties: {
type: 'string',
format: 'uri',
},
supportedManagers: ['helm-requirements', 'helmv3', 'helmfile'],
},
{
name: 'registryUrls',
description:
'List of URLs to try for dependency lookup. Package manager specific.',
type: 'array',
subType: 'string',
default: null,
stage: 'branch',
cli: false,
env: false,
},
{
name: 'extractVersion',
description:
"A regex (re2) to extract a version from a datasource's raw version string.",
type: 'string',
format: 'regex',
cli: false,
env: false,
},
{
name: 'versioning',
description: 'Versioning to use for filtering and comparisons.',
type: 'string',
allowedValues: getVersioningList(),
cli: false,
env: false,
},
{
name: 'azureWorkItemId',
description:
'The id of an existing work item on Azure Boards to link to each PR.',
type: 'integer',
default: 0,
supportedPlatforms: ['azure'],
},
{
name: 'azureAutoApprove',
description:
'If set to true, Azure DevOps PRs will be automatically approved.',
type: 'boolean',
default: false,
supportedPlatforms: ['azure'],
},
// depType
{
name: 'ignoreDeps',
description: 'Dependencies to ignore.',
type: 'array',
subType: 'string',
stage: 'package',
mergeable: true,
},
{
name: 'updateInternalDeps',
description:
'Whether to update internal dep versions in a monorepo (Lerna or Yarn Workspaces).',
type: 'boolean',
default: false,
stage: 'package',
},
{
name: 'packageRules',
description: 'Rules for matching package names.',
type: 'array',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchLanguages',
description:
'List of languages to match (e.g. ["python"]). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
parent: 'packageRules',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchBaseBranches',
description:
'List of branches to match (e.g. ["master"]). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
parent: 'packageRules',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchManagers',
description:
'List of package managers to match (e.g. ["pipenv"]). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
parent: 'packageRules',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchDatasources',
description:
'List of datasources to match (e.g. ["orb"]). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
parent: 'packageRules',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchDepTypes',
description:
'List of depTypes to match (e.g. [`peerDependencies`]). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
parent: 'packageRules',
stage: 'package',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchPackageNames',
description:
'Package names to match. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'excludePackageNames',
description:
'Package names to exclude. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchPackagePrefixes',
description:
'Package name prefixes to match. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'excludePackagePrefixes',
description:
'Package name prefixes to exclude. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchPackagePatterns',
description:
'Package name patterns to match. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
format: 'regex',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'excludePackagePatterns',
description:
'Package name patterns to exclude. Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
format: 'regex',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchCurrentVersion',
description:
'A version or version range to match against the current version of a package. Valid only within `packageRules` object.',
type: 'string',
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchSourceUrlPrefixes',
description:
'A list of source URL prefixes to match against, commonly used for grouping of monorepos or packages from the same organization.',
type: 'array',
subType: 'string',
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchUpdateTypes',
description:
'Update types to match against (major, minor, pin, etc). Valid only within `packageRules` object.',
type: 'array',
subType: 'string',
allowedValues: [
'major',
'minor',
'patch',
'pin',
'digest',
'lockFileMaintenance',
'rollback',
'bump',
],
allowString: true,
stage: 'package',
parent: 'packageRules',
mergeable: true,
cli: false,
env: false,
},
{
name: 'matchFiles',
description:
'List of strings to do an exact match against package files with full path. Applicable inside packageRules only.',
type: 'array',
subType: 'string',
stage: 'repository',
parent: 'packageRules',
cli: false,
env: false,
},
{
name: 'matchPaths',
description:
'List of strings or glob patterns to match against package files. Applicable inside packageRules only.',
type: 'array',
subType: 'string',
stage: 'repository',
parent: 'packageRules',
cli: false,
env: false,
},
// Version behaviour
{
name: 'allowedVersions',
description:
'A version range or regex pattern capturing allowed versions for dependencies.',
type: 'string',
parent: 'packageRules',
stage: 'package',
cli: false,
env: false,
},
{
name: 'pinDigests',
description: 'Whether to add digests to Dockerfile source images.',
type: 'boolean',
default: false,
},
{
name: 'separateMajorMinor',
description:
'If set to false, it will upgrade dependencies to latest release only, and not separate major/minor branches.',
type: 'boolean',
},
{
name: 'separateMultipleMajor',
description:
'If set to true, PRs will be raised separately for each available major upgrade version.',
stage: 'package',
type: 'boolean',
default: false,
},
{
name: 'separateMinorPatch',
description:
'If set to true, it will separate minor and patch updates into separate branches.',
type: 'boolean',
default: false,
},
{
name: 'ignoreUnstable',
description: 'Ignore versions with unstable SemVer.',
stage: 'package',
type: 'boolean',
},
{
name: 'ignoreDeprecated',
description:
'Ignore deprecated versions unless the current version is deprecated.',
stage: 'package',
type: 'boolean',
default: true,
},
{
name: 'followTag',
description: 'If defined, packages will follow this release tag exactly.',
stage: 'package',
type: 'string',
cli: false,
env: false,
},
{
name: 'respectLatest',
description: 'Ignore versions newer than npm "latest" version.',
stage: 'package',
type: 'boolean',
},
{
name: 'rangeStrategy',
description: 'Policy for how to modify/update existing ranges.',
type: 'string',
default: 'replace',
allowedValues: [
'auto',
'pin',
'bump',
'replace',
'widen',
'update-lockfile',
],
cli: false,
env: false,
},
{
name: 'branchPrefix',
description: 'Prefix to use for all branch names.',
stage: 'branch',
type: 'string',
default: `renovate/`,
},
{
name: 'bumpVersion',
description: 'Bump the version in the package file being updated.',
type: 'string',
allowedValues: ['major', 'minor', 'patch'],
supportedManagers: ['helmv3', 'npm', 'sbt'],
},
// Major/Minor/Patch
{
name: 'major',
description: 'Configuration to apply when an update type is major.',
stage: 'package',
type: 'object',
default: {},
cli: false,
mergeable: true,
},
{
name: 'minor',
description: 'Configuration to apply when an update type is minor.',
stage: 'package',
type: 'object',
default: {},
cli: false,
mergeable: true,
},
{
name: 'patch',
description: 'Configuration to apply when an update type is patch.',
stage: 'package',
type: 'object',
default: {},
cli: false,
mergeable: true,
},
{
name: 'pin',
description: 'Configuration to apply when an update type is pin.',
stage: 'package',
type: 'object',
default: {
rebaseWhen: 'behind-base-branch',
groupName: 'Pin Dependencies',
groupSlug: 'pin-dependencies',
commitMessageAction: 'Pin',
group: {
commitMessageTopic: 'dependencies',
commitMessageExtra: '',
},
},
cli: false,
mergeable: true,
},
{
name: 'digest',
description:
'Configuration to apply when updating a digest (no change in tag/version).',
stage: 'package',
type: 'object',
default: {
branchTopic: '{{{depNameSanitized}}}-digest',
commitMessageExtra: 'to {{newDigestShort}}',
commitMessageTopic: '{{{depName}}} commit hash',
},
cli: false,
mergeable: true,
},
{
name: 'rollback',
description: 'Configuration to apply when rolling back a version.',
stage: 'package',
type: 'object',
default: {
branchTopic: '{{{depNameSanitized}}}-rollback',
commitMessageAction: 'Roll back',
semanticCommitType: 'fix',
},
cli: false,
mergeable: true,
},
// Semantic commit / Semantic release
{
name: 'semanticCommits',
description: 'Enable Semantic Commit prefixes for commits and PR titles.',
type: 'string',
allowedValues: ['auto', 'enabled', 'disabled'],
default: 'auto',
},
{
name: 'semanticCommitType',
description: 'Commit type to use if Semantic Commits is enabled.',
type: 'string',
default: 'chore',
},
{
name: 'semanticCommitScope',
description: 'Commit scope to use if Semantic Commits are enabled.',
type: 'string',
default: 'deps',
},
// PR Behaviour
{
name: 'rollbackPrs',
description:
'Create PRs to roll back versions if the current version is not found in the registry.',
type: 'boolean',
default: false,
},
{
name: 'recreateClosed',
description: 'Recreate PRs even if same ones were closed previously.',
type: 'boolean',
default: false,
},
{
name: 'rebaseWhen',
description: 'Control when Renovate decides to rebase an existing branch.',
type: 'string',
allowedValues: ['auto', 'never', 'conflicted', 'behind-base-branch'],
default: 'auto',
},
{
name: 'rebaseLabel',
description: 'Label to use to request the bot to rebase a PR manually.',
type: 'string',
default: 'rebase',
},
{
name: 'stabilityDays',
description:
'Number of days required before a new release is considered to be stabilized.',
type: 'integer',
default: 0,
},
/*
* Undocumented experimental feature
{
name: 'minimumConfidence',
description:
'Minimum Merge confidence level to filter by. Requires authentication to work.',
type: 'string',
allowedValues: ['low', 'neutral', 'high', 'very high'],
default: 'low',
},
*/
{
name: 'internalChecksFilter',
description: 'When/how to filter based on internal checks.',
type: 'string',
allowedValues: ['strict', 'flexible', 'none'],
default: 'none',
},
{
name: 'prCreation',
description: 'When to create the PR for a branch.',
type: 'string',
allowedValues: ['immediate', 'not-pending', 'status-success', 'approval'],
default: 'immediate',
},
{
name: 'prNotPendingHours',
description: 'Timeout in hours for when prCreation=not-pending.',
type: 'integer',
default: 25,
},
{
name: 'prHourlyLimit',
description:
'Rate limit PRs to maximum x created per hour. 0 (default) means no limit.',
type: 'integer',
default: 0, // no limit
},
{
name: 'prConcurrentLimit',
description:
'Limit to a maximum of x concurrent branches/PRs. 0 (default) means no limit.',
type: 'integer',
default: 0, // no limit
},
{
name: 'branchConcurrentLimit',
description:
'Limit to a maximum of x concurrent branches. 0 means no limit, `null` (default) inherits value from `prConcurrentLimit`.',
type: 'integer',
default: null, // inherit prConcurrentLimit
},
{
name: 'prPriority',
description:
'Set sorting priority for PR creation. PRs with higher priority are created first, negative priority last.',
type: 'integer',
default: 0,
cli: false,
env: false,
},
{
name: 'bbUseDefaultReviewers',
description: 'Use the default reviewers (Bitbucket only).',
type: 'boolean',
default: true,
supportedPlatforms: ['bitbucket'],
},
// Automatic merging
{
name: 'automerge',
description:
'Whether to automerge branches/PRs automatically, without human intervention.',
type: 'boolean',
default: false,
},
{
name: 'automergeType',
description: 'How to automerge, if enabled.',
type: 'string',
allowedValues: ['branch', 'pr', 'pr-comment'],
default: 'pr',
},
{
name: 'automergeStrategy',
description:
'The merge strategy to use when automerging PRs. Used only if `automergeType=pr`.',
type: 'string',
allowedValues: ['auto', 'fast-forward', 'merge-commit', 'rebase', 'squash'],
default: 'auto',
supportedPlatforms: ['bitbucket'],
},
{
name: 'automergeComment',
description:
'PR comment to add to trigger automerge. Used only if automergeType=pr-comment.',
type: 'string',
default: 'automergeComment',
},
{
name: 'ignoreTests',
description: 'Set to true to enable automerging without tests.',
type: 'boolean',
default: false,
},
{
name: 'transitiveRemediation',
description: 'Enable remediation of transitive dependencies.',
type: 'boolean',
default: false,
supportedManagers: ['npm'],
supportedPlatforms: ['github'],
},
{
name: 'vulnerabilityAlerts',
description:
'Config to apply when a PR is necessary due to vulnerability of existing package version.',
type: 'object',
default: {
groupName: null,
schedule: [],
dependencyDashboardApproval: false,
rangeStrategy: 'update-lockfile',
commitMessageSuffix: '[SECURITY]',
branchTopic: `{{{datasource}}}-{{{depName}}}-vulnerability`,
prCreation: 'immediate',
},
mergeable: true,
cli: false,
env: false,
supportedPlatforms: ['github'],
},
// Default templates
{
name: 'branchName',
description: 'Branch name template.',
type: 'string',
default: '{{{branchPrefix}}}{{{additionalBranchPrefix}}}{{{branchTopic}}}',
cli: false,
},
{
name: 'additionalBranchPrefix',
description: 'Additional string value to be appended to branchPrefix.',
type: 'string',
default: '',
cli: false,
},
{
name: 'branchTopic',
description: 'Branch topic.',
type: 'string',
default:
'{{{depNameSanitized}}}-{{{newMajor}}}{{#if separateMinorPatch}}{{#if isPatch}}.{{{newMinor}}}{{/if}}{{/if}}.x{{#if isLockfileUpdate}}-lockfile{{/if}}',
cli: false,
},
{
name: 'commitMessage',
description: 'Message to use for commit messages and pull request titles.',
type: 'string',
default:
'{{{commitMessagePrefix}}} {{{commitMessageAction}}} {{{commitMessageTopic}}} {{{commitMessageExtra}}} {{{commitMessageSuffix}}}',
cli: false,
},
{
name: 'commitBody',
description:
'Commit message body template. Will be appended to commit message, separated by two line returns.',
type: 'string',
cli: false,
},
{
name: 'commitBodyTable',
description:
'If enabled, append a table in the commit message body describing all updates in the commit.',
type: 'boolean',
default: false,
},
{
name: 'commitMessagePrefix',
description:
'Prefix to add to start of commit messages and PR titles. Uses a semantic prefix if semanticCommits enabled.',
type: 'string',
cli: false,
},
{
name: 'commitMessageAction',
description: 'Action verb to use in commit messages and PR titles.',
type: 'string',
default: 'Update',
cli: false,
},
{
name: 'commitMessageTopic',
description:
'The upgrade topic/noun used in commit messages and PR titles.',
type: 'string',
default: 'dependency {{depName}}',
cli: false,
},
{
name: 'commitMessageExtra',
description:
'Extra description used after the commit message topic - typically the version.',
type: 'string',
default:
'to {{#if isMajor}}v{{{newMajor}}}{{else}}{{#if isSingleVersion}}v{{{newVersion}}}{{else}}{{{newValue}}}{{/if}}{{/if}}',
cli: false,
},
{
name: 'commitMessageSuffix',
description: 'Suffix to add to end of commit messages and PR titles.',
type: 'string',
cli: false,
},
{
name: 'prBodyTemplate',
description:
'Pull Request body template. Controls which sections are rendered in the body.',
type: 'string',
default:
'{{{header}}}{{{table}}}{{{notes}}}{{{changelogs}}}{{{configDescription}}}{{{controls}}}{{{footer}}}',
cli: false,
},
{
name: 'prTitle',
description:
'Pull Request title template (deprecated). Now uses commitMessage.',
type: 'string',
default: null,
cli: false,
},
{
name: 'prHeader',
description: 'Any text added here will be placed first in the PR body.',
type: 'string',
},
{
name: 'prFooter',
description:
'Any text added here will be placed last in the PR body, with a divider separator before it.',
type: 'string',
default: `This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate).`,
},
{
name: 'lockFileMaintenance',
description: 'Configuration for lock file maintenance.',
stage: 'branch',
type: 'object',
default: {
enabled: false,
recreateClosed: true,
rebaseStalePrs: true,
branchTopic: 'lock-file-maintenance',
commitMessageAction: 'Lock file maintenance',
commitMessageTopic: null,
commitMessageExtra: null,
schedule: ['before 5am on monday'],
groupName: null,
prBodyDefinitions: {
Change: 'All locks refreshed',
},
},
cli: false,
mergeable: true,
},
{
name: 'hashedBranchLength',
description:
'If enabled, branch names will use a hashing function to ensure each branch has that length.',
type: 'integer',
default: null,
cli: false,
},
// Dependency Groups
{
name: 'groupName',
description: 'Human understandable name for the dependency group.',
type: 'string',
default: null,
},
{
name: 'groupSlug',
description:
'Slug to use for group (e.g. in branch name). Will be calculated from groupName if null.',
type: 'string',
default: null,
cli: false,
env: false,
},
{
name: 'group',
description: 'Config if groupName is enabled.',
type: 'object',
default: {
branchTopic: '{{{groupSlug}}}',
commitMessageTopic: '{{{groupName}}}',
},
cli: false,
env: false,
mergeable: true,
},
// Pull Request options
{
name: 'labels',
description: 'Labels to set in Pull Request.',
type: 'array',
subType: 'string',
},
{
name: 'addLabels',
description: 'Labels to add to Pull Request.',
type: 'array',
subType: 'string',
mergeable: true,
},
{
name: 'assignees',
description:
'Assignees for Pull Request (either username or email address depending on the platform).',
type: 'array',
subType: 'string',
},
{
name: 'assigneesFromCodeOwners',
description:
'Determine assignees based on configured code owners and changes in PR.',
type: 'boolean',
default: false,
},
{
name: 'assigneesSampleSize',
description: 'Take a random sample of given size from assignees.',
type: 'integer',
default: null,
},
{
name: 'assignAutomerge',
description:
'Assign reviewers and assignees even if the PR is to be automerged.',
type: 'boolean',
default: false,
},
{
name: 'reviewers',
description:
'Requested reviewers for Pull Requests (either username or email address depending on the platform).',
type: 'array',
subType: 'string',
},
{
name: 'reviewersFromCodeOwners',
description:
'Determine reviewers based on configured code owners and changes in PR.',
type: 'boolean',
default: false,
},
{
name: 'filterUnavailableUsers',
description: 'Filter reviewers and assignees based on their availability.',
type: 'boolean',
default: false,
supportedPlatforms: ['gitlab'],
},
{
name: 'reviewersSampleSize',
description: 'Take a random sample of given size from reviewers.',
type: 'integer',
default: null,
},
{
name: 'additionalReviewers',
description:
'Additional reviewers for Pull Requests (in contrast to `reviewers`, this option adds to the existing reviewer list, rather than replacing it).',
type: 'array',
subType: 'string',
mergeable: true,
},
{
name: 'fileMatch',
description: 'RegEx (re2) pattern for matching manager files.',
type: 'array',
subType: 'string',
format: 'regex',
stage: 'repository',
allowString: true,
mergeable: true,
cli: false,
env: false,
},
{
name: 'js',
description: 'Configuration object for JavaScript language.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
},
{
name: 'golang',
description: 'Configuration object for Go language.',
stage: 'package',
type: 'object',
default: {
commitMessageTopic: 'module {{depName}}',
},
mergeable: true,
cli: false,
},
{
name: 'postUpdateOptions',
description:
'Enable post-update options to be run after package/artifact updating.',
type: 'array',
default: [],
allowedValues: [
'gomodUpdateImportPaths',
'gomodTidy',
'npmDedupe',
'yarnDedupeFewer',
'yarnDedupeHighest',
],
cli: false,
env: false,
mergeable: true,
},
{
name: 'ruby',
description: 'Configuration object for Ruby language.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
cli: false,
},
{
name: 'rust',
description: 'Configuration option for Rust package management.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
cli: false,
},
{
name: 'node',
description: 'Configuration object for Node version renovation.',
stage: 'package',
type: 'object',
default: {
commitMessageTopic: 'Node.js',
},
mergeable: true,
cli: false,
},
{
name: 'docker',
description: 'Configuration object for Docker language.',
stage: 'package',
type: 'object',
default: {
versioning: dockerVersioning.id,
},
mergeable: true,
cli: false,
},
{
name: 'php',
description: 'Configuration object for PHP.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
cli: false,
},
{
name: 'python',
description: 'Configuration object for Python.',
stage: 'package',
type: 'object',
default: {
versioning: pep440Versioning.id,
},
mergeable: true,
cli: false,
},
{
name: 'constraints',
description:
'Configuration object to define language or manager version constraints.',
type: 'object',
default: {},
mergeable: true,
cli: false,
supportedManagers: [
'bundler',
'composer',
'gomod',
'npm',
'pipenv',
'poetry',
],
},
{
name: 'java',
description: 'Configuration object for all Java package managers.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
cli: false,
},
{
name: 'dotnet',
description: 'Configuration object for .NET language.',
stage: 'package',
type: 'object',
default: {},
mergeable: true,
cli: false,
},
{
name: 'hostRules',
description: 'Host rules/configuration including credentials.',
type: 'array',
subType: 'object',
default: [
{
timeout: 60000,
},
],
stage: 'repository',
cli: true,
mergeable: true,
},
{
name: 'hostType',
description:
'hostType for a package rule. Can be a platform name or a datasource name.',
type: 'string',
stage: 'repository',
parent: 'hostRules',
cli: false,
env: false,
},
{
name: 'matchHost',
description: 'A domain name, host name or base URL to match against',
type: 'string',
stage: 'repository',
parent: 'hostRules',
cli: false,
env: false,
},
{
name: 'timeout',
description: 'Timeout (in milliseconds) for queries to external endpoints.',
type: 'integer',
stage: 'repository',
parent: 'hostRules',
cli: false,
env: false,
},
{
name: 'insecureRegistry',
description: 'Explicitly turn on insecure Docker registry access (HTTP).',
type: 'boolean',
stage: 'repository',
parent: 'hostRules',
cli: false,
env: false,
},
{
name: 'abortOnError',
description:
'If enabled, Renovate will abort its run when HTTP request errors occur.',
type: 'boolean',
stage: 'repository',
parent: 'hostRules',
default: false,
cli: false,
env: false,
},
{
name: 'abortIgnoreStatusCodes',
description:
'A list of HTTP status codes to ignore and *not* abort the run because of when abortOnError=true.',
type: 'array',
subType: 'number',
stage: 'repository',
parent: 'hostRules',
cli: false,
env: false,
},
{
name: 'enableHttp2',
description: 'Enable got HTTP/2 support.',
type: 'boolean',
stage: 'repository',
parent: 'hostRules',
default: false,
cli: false,
env: false,
},
{
name: 'concurrentRequestLimit',
description: 'Limit concurrent requests per host.',
type: 'integer',
stage: 'repository',
parent: 'hostRules',
default: null,
cli: false,
env: false,
},
{
name: 'authType',
description:
'Authentication type for http header. e.g. "Bearer" or "Basic". Use "Token-Only" to use only the token without an authorization type.',
type: 'string',
stage: 'repository',
parent: 'hostRules',
default: 'Bearer',
cli: false,
env: false,
},
{
name: 'prBodyDefinitions',
description: 'Table column definitions for use in PR tables.',
type: 'object',
freeChoice: true,
mergeable: true,
default: {
Package: '{{{depNameLinked}}}',
Type: '{{{depType}}}',
Update: '{{{updateType}}}',
'Current value': '{{{currentValue}}}',
'New value': '{{{newValue}}}',
Change: '`{{{displayFrom}}}` -> `{{{displayTo}}}`',
References: '{{{references}}}',
'Package file': '{{{packageFile}}}',
},
},
{
name: 'prBodyColumns',
description: 'List of columns to use in PR bodies.',
type: 'array',
subType: 'string',
default: ['Package', 'Type', 'Update', 'Change'],
},
{
name: 'prBodyNotes',
description:
'List of additional notes/templates to be included in the Pull Request bodies.',
type: 'array',
subType: 'string',
default: [],
allowString: true,
mergeable: true,
},
{
name: 'suppressNotifications',
description:
'Options to suppress various types of warnings and other notifications.',
type: 'array',
subType: 'string',
default: ['deprecationWarningIssues'],
allowedValues: [
'prIgnoreNotification',
'branchAutomergeFailure',
'lockFileErrors',
'artifactErrors',
'deprecationWarningIssues',
'onboardingClose',
],
cli: false,
env: false,
mergeable: true,
},
{
name: 'pruneStaleBranches',
description: `Enable or disable pruning of stale branches.`,
type: 'boolean',
default: true,
},
{
name: 'unicodeEmoji',
description: 'Enable or disable Unicode emoji.',
type: 'boolean',
default: true,
},
{
name: 'gitLabIgnoreApprovals',
description: `Ignore approval rules for MRs created by Renovate, which is useful for automerge.`,
type: 'boolean',
default: false,
},
{
name: 'regexManagers',
description: 'Custom managers using regex matching.',
type: 'array',
subType: 'object',
default: [],
stage: 'package',
cli: true,
mergeable: true,
},
{
name: 'matchStrings',
description:
'Regex capture rule to use. Valid only within a `regexManagers` object.',
type: 'array',
subType: 'string',
format: 'regex',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'matchStringsStrategy',
description: 'Strategy how to interpret matchStrings.',
type: 'string',
default: 'any',
allowedValues: ['any', 'recursive', 'combination'],
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'depNameTemplate',
description:
'Optional depName for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'lookupNameTemplate',
description:
'Optional lookupName for extracted dependencies, else defaults to depName value. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'datasourceTemplate',
description:
'Optional datasource for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'depTypeTemplate',
description:
'Optional depType for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'currentValueTemplate',
description:
'Optional currentValue for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'versioningTemplate',
description:
'Optional versioning for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'registryUrlTemplate',
description:
'Optional registry URL for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'extractVersionTemplate',
description:
'Optional extractVersion for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'autoReplaceStringTemplate',
description:
'Optional extractVersion for extracted dependencies. Valid only within a `regexManagers` object.',
type: 'string',
parent: 'regexManagers',
cli: false,
env: false,
},
{
name: 'fetchReleaseNotes',
description: 'Allow to disable release notes fetching.',
type: 'boolean',
default: true,
cli: false,
env: false,
},
{
name: 'cloneSubmodules',
description:
'Set to true to enable initialization of submodules during repository clone.',
type: 'boolean',
default: false,
},
{
name: 'ignorePrAuthor',
description:
'Set to true to fetch the entire list of PRs instead of only those authored by the Renovate user.',
type: 'boolean',
default: false,
},
{
name: 'gitNoVerify',
description:
'Which git commands will be run with the `--no-verify` option.',
type: 'array',
subType: 'string',
allowString: true,
allowedValues: ['commit', 'push'],
default: ['commit', 'push'],
stage: 'global',
globalOnly: true,
},
{
name: 'updatePinnedDependencies',
description:
'Whether to update pinned (single version) dependencies or not.',
type: 'boolean',
default: true,
},
{
name: 'gitUrl',
description:
'Overrides the default resolution for git remote, e.g. to switch GitLab from HTTPS to SSH-based.',
type: 'string',
allowedValues: ['default', 'ssh', 'endpoint'],
default: 'default',
stage: 'repository',
globalOnly: true,
},
{
name: 'writeDiscoveredRepos',
description: 'Writes discovered repositories to a JSON file and then exit.',
type: 'string',
globalOnly: true,
env: false,
},
{
name: 'platformAutomerge',
description: `Enable or disable usage of platform-native auto-merge capabilities when available.`,
type: 'boolean',
default: false,
},
];
export function getOptions(): RenovateOptions[] {
return options;
}
function loadManagerOptions(): void {
for (const [name, config] of getManagers().entries()) {
if (config.defaultConfig) {
const managerConfig: RenovateOptions = {
name,
description: `Configuration object for the ${name} manager`,
stage: 'package',
type: 'object',
default: config.defaultConfig,
mergeable: true,
cli: false,
autogenerated: true,
};
options.push(managerConfig);
}
}
}
loadManagerOptions();