2021-01-29 00:20:46 +05:30
---
2022-07-23 23:45:48 +05:30
stage: Systems
2021-02-22 17:27:13 +05:30
group: Distribution
2022-11-25 23:54:43 +05:30
info: To determine the technical writer assigned to the Stage/Group associated with this page, see https://about.gitlab.com/handbook/product/ux/technical-writing/#assignments
2021-01-29 00:20:46 +05:30
---
2021-09-04 01:27:46 +05:30
# Signing outgoing email with S/MIME **(FREE SELF)**
2019-12-04 20:38:33 +05:30
2019-12-21 20:55:43 +05:30
Notification emails sent by GitLab can be signed with S/MIME for improved
2019-12-04 20:38:33 +05:30
security.
2021-01-29 00:20:46 +05:30
Be aware that S/MIME certificates and TLS/SSL certificates are not the
2019-12-04 20:38:33 +05:30
same and are used for different purposes: TLS creates a secure channel, whereas
S/MIME signs and/or encrypts the message itself
## Enable S/MIME signing
This setting must be explicitly enabled and a single pair of key and certificate
files must be provided:
- Both files must be PEM-encoded.
- The key file must be unencrypted so that GitLab can read it without user
intervention.
- Only RSA keys are supported.
2020-05-24 23:13:21 +05:30
Optionally, you can also provide a bundle of CA certs (PEM-encoded) to be
2022-08-13 15:12:31 +05:30
included on each signature. This is typically an intermediate CA.
2020-05-24 23:13:21 +05:30
2021-02-22 17:27:13 +05:30
WARNING:
2020-07-28 23:09:34 +05:30
Be mindful of the access levels for your private keys and visibility to
2019-12-04 20:38:33 +05:30
third parties.
**For Omnibus installations:**
1. Edit `/etc/gitlab/gitlab.rb` and adapt the file paths:
```ruby
gitlab_rails['gitlab_email_smime_enabled'] = true
gitlab_rails['gitlab_email_smime_key_file'] = '/etc/gitlab/ssl/gitlab_smime.key'
gitlab_rails['gitlab_email_smime_cert_file'] = '/etc/gitlab/ssl/gitlab_smime.crt'
2020-05-24 23:13:21 +05:30
# Optional
gitlab_rails['gitlab_email_smime_ca_certs_file'] = '/etc/gitlab/ssl/gitlab_smime_cas.crt'
2019-12-04 20:38:33 +05:30
```
1. Save the file and [reconfigure GitLab ](restart_gitlab.md#omnibus-gitlab-reconfigure ) for the changes to take effect.
2022-08-13 15:12:31 +05:30
The key must be readable by the GitLab system user (`git` by default).
2019-12-04 20:38:33 +05:30
**For installations from source:**
1. Edit `config/gitlab.yml` :
```yaml
email_smime:
# Uncomment and set to true if you need to enable email S/MIME signing (default: false)
enabled: true
# S/MIME private key file in PEM format, unencrypted
# Default is '.gitlab_smime_key' relative to Rails.root (i.e. root of the GitLab app).
key_file: /etc/pki/smime/private/gitlab.key
# S/MIME public certificate key in PEM format, will be attached to signed messages
# Default is '.gitlab_smime_cert' relative to Rails.root (i.e. root of the GitLab app).
cert_file: /etc/pki/smime/certs/gitlab.crt
2020-05-24 23:13:21 +05:30
# S/MIME extra CA public certificates in PEM format, will be attached to signed messages
# Optional
ca_certs_file: /etc/pki/smime/certs/gitlab_cas.crt
2019-12-04 20:38:33 +05:30
```
1. Save the file and [restart GitLab ](restart_gitlab.md#installations-from-source ) for the changes to take effect.
2022-08-13 15:12:31 +05:30
The key must be readable by the GitLab system user (`git` by default).
2019-12-04 20:38:33 +05:30
2021-11-18 22:05:49 +05:30
### How to convert S/MIME PKCS #12 format to PEM encoding
2019-12-04 20:38:33 +05:30
2021-11-18 22:05:49 +05:30
Typically S/MIME certificates are handled in binary Public Key Cryptography Standards (PKCS) #12 format
(`.pfx` or `.p12` extensions), which contain the following in a single encrypted file:
2019-12-04 20:38:33 +05:30
- Public certificate
- Intermediate certificates (if any)
- Private key
2021-11-18 22:05:49 +05:30
To export the required files in PEM encoding from the PKCS #12 file, the
2021-01-03 14:25:43 +05:30
`openssl` command can be used:
2019-12-04 20:38:33 +05:30
2020-03-13 15:44:24 +05:30
```shell
2019-12-04 20:38:33 +05:30
#-- Extract private key in PEM encoding (no password, unencrypted)
$ openssl pkcs12 -in gitlab.p12 -nocerts -nodes -out gitlab.key
#-- Extract certificates in PEM encoding (full certs chain including CA)
$ openssl pkcs12 -in gitlab.p12 -nokeys -out gitlab.crt
```