Skip to content

Commit

Permalink
Move server certificates to /etc/pki
Browse files Browse the repository at this point in the history
  • Loading branch information
bdunne committed Dec 13, 2022
1 parent 2d7b43f commit 830338c
Show file tree
Hide file tree
Showing 3 changed files with 17 additions and 3 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -298,7 +298,7 @@ func PostgresqlDeployment(cr *miqv1alpha1.ManageIQ, client client.Client, scheme
},
}

addInternalCertificate(cr, deployment, client, "postgresql", "/opt/app-root/src/certificates")
addPkiCertificate(cr, deployment, client, "postgresql")

return nil
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -78,8 +78,8 @@ func postgresqlSslConf() string {
#------------------------------------------------------------------------------
ssl = on
ssl_cert_file = '/var/lib/pgsql/data/userdata/server.crt' # server certificate
ssl_key_file = '/var/lib/pgsql/data/userdata/server.key' # server private key
ssl_cert_file = '/etc/pki/tls/certs/server.crt' # server certificate
ssl_key_file = '/etc/pki/tls/private/server.key' # server private key
#ssl_ca_file # trusted certificate authorities
#ssl_crl_file # certificates revoked by certificate authorities
Expand Down
14 changes: 14 additions & 0 deletions manageiq-operator/api/v1alpha1/helpers/miq-components/util.go
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,20 @@ func addInternalCertificate(cr *miqv1alpha1.ManageIQ, d *appsv1.Deployment, clie
}
}

func addPkiCertificate(cr *miqv1alpha1.ManageIQ, d *appsv1.Deployment, client client.Client, name string) {
secret := InternalCertificatesSecret(cr, client)
if secret.Data[fmt.Sprintf("%s_crt", name)] != nil && secret.Data[fmt.Sprintf("%s_key", name)] != nil {
volumeName := fmt.Sprintf("%s-certificate", name)

volumeMount := corev1.VolumeMount{Name: volumeName, MountPath: "/etc/pki/tls", ReadOnly: true}
d.Spec.Template.Spec.Containers[0].VolumeMounts = addOrUpdateVolumeMount(d.Spec.Template.Spec.Containers[0].VolumeMounts, volumeMount)

var mode int32 = 0o440
secretVolumeSource := corev1.SecretVolumeSource{SecretName: secret.Name, Items: []corev1.KeyToPath{corev1.KeyToPath{Key: fmt.Sprintf("%s_crt", name), Path: "certs/server.crt", Mode: &mode}, corev1.KeyToPath{Key: fmt.Sprintf("%s_key", name), Path: "private/server.key", Mode: &mode}}}
d.Spec.Template.Spec.Volumes = addOrUpdateVolume(d.Spec.Template.Spec.Volumes, corev1.Volume{Name: volumeName, VolumeSource: corev1.VolumeSource{Secret: &secretVolumeSource}})
}
}

func addOrUpdateEnvVar(environment []corev1.EnvVar, variable corev1.EnvVar) []corev1.EnvVar {
index := -1
for i, env := range environment {
Expand Down

0 comments on commit 830338c

Please sign in to comment.