mirror of
https://github.com/renovatebot/renovate.git
synced 2025-01-27 05:09:37 +00:00
8796843a22
Co-authored-by: Rhys Arkins <rhys@arkins.net> Co-authored-by: Birger J. Nordølum <contact@mindtooth.no> Co-authored-by: HonkingGoose <34918129+HonkingGoose@users.noreply.github.com>
295 lines
15 KiB
Markdown
295 lines
15 KiB
Markdown
# Renovate configuration overview
|
|
|
|
Each time Renovate runs on a repository it reads the configuration files listed below and creates a final config.
|
|
This final config describes what Renovate will do during its run.
|
|
|
|
The final config is internal to Renovate, and is _not_ saved or cached for a later run.
|
|
But you can always find the final config in Renovate's logs.
|
|
|
|
Renovate reads the configuration files in this order (from from top to bottom):
|
|
|
|
1. Default config
|
|
2. Global config
|
|
- File config
|
|
- Environment config
|
|
- CLI config
|
|
3. Inherited config
|
|
4. Resolved presets referenced in config
|
|
5. Repository config
|
|
|
|
Items with a higher number override items that have lower numbers.
|
|
If the item has the `mergeable` property, it will merge with lower numbers instead.
|
|
|
|
<!-- prettier-ignore -->
|
|
!!! note
|
|
If you use a Mend-hosted app, please read [Mend-hosted Apps Configuration](mend-hosted/hosted-apps-config.md) _after_ reading this page.
|
|
|
|
## Types of config
|
|
|
|
### Default config
|
|
|
|
Every Renovate config option has a default value/setting.
|
|
That default value/setting may even be `null`.
|
|
You can find the default values on the Renovate docs website.
|
|
|
|
For example:
|
|
|
|
- The default value for `onboarding` is `true`
|
|
- The option `labels` lacks a default value, which means that no labels will be added to Renovate's PRs
|
|
|
|
The default config is loaded first, and may be superseded/overridden by the configuration types listed below.
|
|
|
|
### Global config
|
|
|
|
Global config means: the config defined by the person or team responsible for running the bot.
|
|
This is also referred to as "bot config", because it's the config passed to the bot by the person running it.
|
|
Global config can contain config which is "global only" as well as any configuration options which are valid in Inherited config or Repository config.
|
|
|
|
If you are an end user of Renovate, for example if you're using the Mend Renovate App, then you don't need to care as much about any global config.
|
|
As a end-user you can not change some settings because those settings are global-only.
|
|
If you are an end user, you can skip the rest of this "Global config" section and proceed to "Inherited config".
|
|
|
|
Global config can be read from a file, environment variable, or CLI parameters.
|
|
You must configure at least one of these for Renovate to have the information it needs to run.
|
|
For example: you may need to give Renovate the correct credentials.
|
|
|
|
#### File config
|
|
|
|
Renovate first tries to read the global config from a file.
|
|
By default Renovate checks for a `config.js` file in the current working directory.
|
|
But you can override this by defining `RENOVATE_CONFIG_FILE` in env, for example: `RENOVATE_CONFIG_FILE=/tmp/my-renovate-config.js`.
|
|
|
|
By default Renovate allows the config file to be _missing_ and does not error if it cannot find it.
|
|
But if you have configured `RENOVATE_CONFIG_FILE` and the path you specified is not found then Renovate will error and exit, because it assumes you have a configuration problem.
|
|
If the file is found but cannot be parsed then Renovate will also error and exit.
|
|
|
|
Global config files can be `.js` or `.json` files.
|
|
You may use synchronous or asynchronous methods inside a `.js` file, including even to fetch config information from remote hosts.
|
|
|
|
#### Environment config
|
|
|
|
Global config can be defined using environment variables.
|
|
The config options that you can use in environment variables all have the prefix `RENOVATE_`.
|
|
For example, `RENOVATE_PLATFORM=gitlab` is the same as setting `"platform": "gitlab"` in File config.
|
|
|
|
Usually there's a clear mapping from configuration option name to the corresponding Environment config name.
|
|
But we recommend you still check the documentation for the field `env` for each option to make sure.
|
|
If the configuration option lacks a `env` field, the config option also lacks a Environment config variable name.
|
|
|
|
A special case for Environment config is the `RENOVATE_CONFIG` "meta" config option.
|
|
The `RENOVATE_CONFIG` option accepts a stringified full config, for example: `RENOVATE_CONFIG={"platform":"gitlab","onboarding":false}`.
|
|
Any additional Environment config variables take precedence over values in `RENOVATE_CONFIG`.
|
|
|
|
##### Environment variable examples
|
|
|
|
<!-- prettier-ignore -->
|
|
!!! warning
|
|
Make sure to escape any punctuation.
|
|
Be extra careful if you're passing stringified values.
|
|
|
|
Boolean:
|
|
|
|
- `RENOVATE_ONBOARDING=true`
|
|
|
|
String:
|
|
|
|
- `RENOVATE_BASE_DIR=/tmp/something`
|
|
- `RENOVATE_BASE_DIR="/tmp/some thing"`
|
|
|
|
Number:
|
|
|
|
- `RENOVATE_PR_HOURLY_LIMIT=1`
|
|
|
|
List with numbers or strings:
|
|
|
|
- `RENOVATE_LABELS="abc,def,label with space"`
|
|
|
|
Objects, or lists with objects:
|
|
|
|
- `RENOVATE_CONFIG="{platform\":\"gitlab\",\"onboarding\":false}"`
|
|
- `RENOVATE_PACKAGE_RULES="[{matchHost:\"gitlab\",token:\"$SOME_TOKEN\"}]"`
|
|
|
|
<!-- prettier-ignore -->
|
|
!!! tip
|
|
Use "stringify" ([Example online service](https://jsonformatter.org/json-stringify-online)) for strings and objects.
|
|
|
|
##### Experimental variables
|
|
|
|
Renovate has "experimental" environment variables, which start with `RENOVATE_X_`.
|
|
These variables are experimental, can be changed at any time, and are not parsed as part of regular configuration.
|
|
Read the [Self-hosted experimental environment variables](./self-hosted-experimental.md) docs to learn more.
|
|
|
|
##### Logging variables
|
|
|
|
Finally, there are some special environment variables that are loaded _before_ configuration parsing because they are used during logging initialization:
|
|
|
|
- `LOG_CONTEXT`: a unique identifier used in each log message to track context
|
|
- `LOG_FILE`: used to enable file logging and specify the log file path
|
|
- `LOG_FILE_LEVEL`: log file logging level, defaults to `debug`
|
|
- `LOG_FORMAT`: defaults to a "pretty" human-readable output, but can be changed to "json"
|
|
- `LOG_LEVEL`: most commonly used to change from the default `info` to `debug` logging
|
|
|
|
#### CLI config
|
|
|
|
The final way to configure Global config is through CLI parameters.
|
|
For example, the CLI parameter `--platform=gitlab` is the same as setting `"platform": "gitlab"` in File config or `RENOVATE_PLATFORM=gitlab` in Environment config.
|
|
|
|
CLI config is read last and takes precedence over Environment and File config.
|
|
For example, if you configure conflicting values in Environment, File config and CLI config, then the CLI config will be merged last and "win" if values conflict.
|
|
|
|
It is important that you:
|
|
|
|
- Always provide a value, even if the field is boolean (e.g. `--onboarding=true` and _not_ `--onboarding`), and
|
|
- Prefer `=` notation over spaces, e.g. `--onboarding=true` instead of `--onboarding true`
|
|
|
|
### Inherited config
|
|
|
|
#### Use cases
|
|
|
|
The primary purpose of Inherited config is to allow for default settings of an organization/group.
|
|
Two main use cases for Inherited config are:
|
|
|
|
- Controlling onboarding settings within an org (e.g. disabling onboarding, making config optional)
|
|
- Defining default config settings for repos within an org
|
|
|
|
We recommend that organizations use shared presets instead of Inherited config, if possible.
|
|
But default settings through Inherited config are useful if:
|
|
|
|
- You want to avoid setting Repository config in each repo, or
|
|
- You onboarded many repos prior to having a shared org config, and don't want to retrospectively edit each repo's config
|
|
|
|
#### How it's found
|
|
|
|
If `inheritConfig` is `true` in Global config then Renovate will look for Inherited config before processing each repository.
|
|
The repository and file name which Renovate looks for can be configured using the other `inheritConfig*` settings documented in Global config.
|
|
Default values are `{{parentOrg}}/renovate-config` for repository name and `org-inherited-config.json` for file name.
|
|
|
|
If found, Inherited config will be merged on top (i.e. override) Global config.
|
|
Avoid putting any global-only setting in a Inherited config, as doing so will result in an error.
|
|
|
|
Inherited config may use all Repository config settings, and any Global config options which have the "supportsInheritConfig" property in the docs.
|
|
|
|
For information on how the Mend Renovate App supports Inherited config, see the dedicated "Mend Renovate App Config" section toward the end of this page.
|
|
|
|
#### Presets handling
|
|
|
|
If the inherited config contains `extends` presets, then Renovate will:
|
|
|
|
1. Resolve the presets
|
|
1. Add the resolved preset config to the beginning of the inherited config
|
|
1. Merge the presets on top of the global config
|
|
|
|
##### You can not ignore presets from inherited config
|
|
|
|
You can _not_ use `ignorePresets` in your repository config to ignore presets _within_ inherited config.
|
|
This is because inherited config is resolved _before_ the repository config.
|
|
|
|
### Repository config
|
|
|
|
Repository config is the config loaded from a config file in the repository.
|
|
Alternative file names are supported, but the default is `renovate.json`.
|
|
If Renovate finds more than one configuration file in the same repository, then Renovate will use the _first_ configuration file it finds and ignores the other(s).
|
|
|
|
### Config precedence
|
|
|
|
Once Repository config is loaded, it is merged over the top of the previously loaded Global and Inherited config, meaning it takes precedence over them.
|
|
Presets referenced with an "extends" config are resolved first and take lower precedence over regular/raw config in the same file or config object.
|
|
|
|
## Onboarding
|
|
|
|
When Renovate processes a repository, one of the first decisions it makes is "Does this repository need to be onboarded?".
|
|
By default, Renovate will create an "Onboarding PR" with a default config if a repository does not have a Repository config file committed to the default branch.
|
|
|
|
### Onboarding Config
|
|
|
|
When Renovate creates an Onboarding PR it will propose a Repository config file to be merged.
|
|
By default, it is essentially an empty config with only the Renovate JSON schema referenced, but you can change this behavior if desired.
|
|
|
|
If you configure `onboardingConfig` in either Global config or Inherited config then Renovate will use that config directly instead of the default.
|
|
|
|
Alternatively if you follow Renovate's naming convention for shared presets then it can automatically detect those instead.
|
|
If the repository `{{parentOrg}}/renovate-config` has a `default.json` file then this will be treated as the organization's default preset and included in the Onboarding config.
|
|
Additionally for platforms which support nested Organization/Group hierarchies, Renovate will "hunt" up such hierarchies for a `renovate-config` repository with default config and stop when it finds the first.
|
|
|
|
<!-- prettier-ignore -->
|
|
!!! note
|
|
Renovate will also check for a `renovate.json` file if it cannot find a `default.json` file in a preset, however this option is deprecated and not recommended.
|
|
|
|
If a default config is not found in a `renovate-config` repository within the Organization, Renovate will also check for the presence of a `renovate-config.json` file within a `.{{platform}}` repository parallel to the current repository.
|
|
For example if the repository being onboarded is `abc/def` on a GitHub platform then Renovate will look for the existence of an `abc/.github` repository containing a `renovate-config.json` file.
|
|
|
|
### Changing default behavior
|
|
|
|
Default onboarding behavior for an Organization can be changed either in Global or Inherited config.
|
|
|
|
For example, if you set `onboarding=false` then Renovate will not onboard repositories, and skip any repositories without a Repository config.
|
|
In other words, users need to manually push a valid Repository config file to activate Renovate on the repository.
|
|
|
|
If you set `onboarding=false` plus `requireConfig=optional` then it means Renovate will skip onboarding and proceed to run on a repository, even if Renovate does not find any Repository config.
|
|
|
|
## Shared Presets
|
|
|
|
### Overview
|
|
|
|
The concept of shared configuration is covered in detail on the [Presets](./key-concepts/presets.md) page, so please read that first.
|
|
|
|
### Use of Presets in Global config
|
|
|
|
Presets should be used cautiously in Global config as they often lead to misunderstandings.
|
|
|
|
#### globalExtends
|
|
|
|
Sometimes you may not wish to put all settings within the Global config itself and instead commit it to a repository which is then referenced from the Global config.
|
|
In such cases, use `globalExtends` instead of `extends` so that it is resolved immediately and used as part of Global config.
|
|
|
|
#### extends
|
|
|
|
If you use `extends` within Global config then it's important to note that these are _not_ resolved/expanded during Global config processing and instead are passed through unresolved to be part of Repository config.
|
|
Passing `extends` through to be part of Repository config has two major consequences:
|
|
|
|
- It allows repository users to be able to use `ignorePresets` to ignore all or part of the `extends` presets, and
|
|
- Presets defined within `extends` in Global config will take _higher_ precedence that "regular" Global config, because it's resolved later
|
|
|
|
### Using a centralized config
|
|
|
|
Using "centralized" configs through Renovate presets is important in order to be able to:
|
|
|
|
- Save time by not repeating yourself in every repo with the same config, and
|
|
- Being able to change settings across an entire Organization or groups of repositories in one place
|
|
|
|
Once you've created a centralized preset config, there are multiple ways you can pass it through to repositories:
|
|
|
|
- Defining it in Global config (either `globalExtends` or `extends`)
|
|
- Using it as your Inherited config, or referencing it from Inherited config using `extends`
|
|
- Ensuring it's referenced in Onboarding config so that it's committed as part of the Repository config
|
|
|
|
The above possibilities go from least to most transparent when it comes to end users.
|
|
|
|
Global config may be invisible to developers without log access, meaning they could be confused by any settings you apply - via presets or directly - within Global config.
|
|
For example the developers wonder why Renovate is behaving differently to its documented default behavior and may even think it's a bug.
|
|
|
|
Inherited config is visible to developers (it's within a repository they can see) although it's _implicitly_ applied so without log access and if they're not aware to look for an Inherited config repository then they may again be a little confused as to why default behavior has changed.
|
|
|
|
The recommended approach for using a centralized preset is to explicitly "extend" it from every repository, which can be achieved easily if it's part of your `onboardingConfig`.
|
|
By having your centralized preset part of each Repository config `extends`, it has these two benefits:
|
|
|
|
- You still have the ability to change shared settings in a single location
|
|
- Any user viewing the repo can see the preset being extended and trace it back to understand which config is applied
|
|
|
|
## Other
|
|
|
|
The below contains edge cases which you should avoid if possible, and likely don't need to use.
|
|
They are included here because they can cause "exceptions" to some of the previously mentioned rules of config.
|
|
|
|
### Optimize for Disabled
|
|
|
|
The `optimizeForDisabled` option was designed for an edge case where a large percentage of repos are disabled by config.
|
|
If this option is set to `true`, Renovate will use a platform API call to see if a `renovate.json` exists and if it contains `"enabled": false`.
|
|
If so, the repository will be skipped without a clone necessary.
|
|
If the file is not present or does not disable Renovate, then Renovate continues as before (having "wasted" that extra API call).
|
|
|
|
### Force config
|
|
|
|
We recommend you avoid the `force` config option, if possible.
|
|
|
|
It can be used to "force" config over the top of other config or rules which might be merged later, so at times can cause confusion - especially if it's defined in Global config and overriding settings in Repository config.
|