Skip to content

HTTPS certificate management

swoellauer edited this page Mar 14, 2023 · 5 revisions

For encrypted and certified RSDB HTTPS connections a valid certificate has to be provided to RSDB in the PKCS #12 format.
The certificate file needs to be places at the RSDB folder with filename keystore.
The encryption password of this file needs to be placed at the config file config.yamlat the server section at property keystore_password. (See config.yaml)


If you have the PKCS #12 certificate already, you may use the openssl commands to check your certificate for correctness, e.g. correct password.

How to create a suitable certificate file depends on the certificate you have. The following steps may guide you from a typically used X.509 certificate with separate certificate root chain to the encrypted PKCS #12 certificate file.

Following intput files are presumed:

  • key.pem private key
  • cert-NAME.pem certificate of the key
  • chain.pem root certificate chain of the certificate
# Show signed zertificate.
openssl x509 -in cert-NAME.pem -text -noout

# Show root zertificate chain.
openssl x509 -in chain.pem -text -noout > text.txt

# Verify certificate with chain.
openssl verify -CAfile chain.pem cert-NAME.pem

# Merge root zertificate chain and signed zertificate.
cat chain.pem cert-NAME.pem > cert-NAME-chain.pem

# Show certificate with root chain.
openssl x509 -in cert-NAME-chain.pem -text -noout

# Export to pkcs12.
openssl pkcs12 -export -clcerts -inkey key.pem -in cert-NAME-chain.pem -out cert-NAME-full.p12 -name "Name"

# Show pkcs12.
openssl pkcs12 -info -in cert-NAME-full.p12

# Rename the cert-NAME-full.p12 file to keystore and place it at RSDB folder.
# Write the password of the keystore into config.yaml.

Alternatively to HTTPS management inside of RSDB server, you may consider to use an external application to apply HTTPS to HTTP RSDB connections, e.g. with an application proxy Traefik.