2020-12-10 16:10:15 -05:00
---
2022-05-29 20:08:35 -04:00
stage: Systems
2020-12-10 16:10:15 -05:00
group: Distribution
2022-03-08 04:17:44 -05:00
info: "To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/engineering/ux/technical-writing/#assignments"
2020-12-10 16:10:15 -05:00
type: reference
---
2021-01-28 01:08:59 -05:00
# Encrypted Configuration **(FREE SELF)**
2020-12-10 16:10:15 -05:00
> [Introduced](https://gitlab.com/gitlab-org/gitlab/-/merge_requests/45712) in GitLab 13.7.
GitLab can read settings for certain features from encrypted settings files. The supported features are:
2022-05-16 02:08:30 -04:00
- [LDAP `bind_dn` and `password` ](auth/ldap/index.md#use-encrypted-credentials ).
2021-09-08 17:10:58 -04:00
- [SMTP `user_name` and `password` ](raketasks/smtp.md#secrets ).
2020-12-10 16:10:15 -05:00
In order to enable the encrypted configuration settings, a new base key needs to be generated for
`encrypted_settings_key_base` . The secret can be generated in the following ways:
**Omnibus Installation**
2021-04-26 11:10:20 -04:00
Starting with 13.7 the new secret is automatically generated for you, but you need to ensure your
2020-12-10 16:10:15 -05:00
`/etc/gitlab/gitlab-secrets.json` contains the same values on all nodes.
**GitLab Cloud Native Helm Chart**
Starting with GitLab 13.7, the new secret is automatically generated if you have the `shared-secrets` chart enabled. Otherwise, you need
to follow the [secrets guide for adding the secret ](https://docs.gitlab.com/charts/installation/secrets.html#gitlab-rails-secret ).
**Source Installation**
The new secret can be generated by running:
```shell
bundle exec rake gitlab:env:info RAILS_ENV=production GITLAB_GENERATE_ENCRYPTED_SETTINGS_KEY_BASE=true
```
2021-09-08 17:10:58 -04:00
This prints general information on the GitLab instance, but also causes the key to be generated in `<path-to-gitlab-rails>/config/secrets.yml` .