Skip to content

Commit

Permalink
Koperator can handle intermediate and leaf certificates in generated …
Browse files Browse the repository at this point in the history
…kafkaUser's TLS certificate (#843)
  • Loading branch information
bartam1 authored Aug 2, 2022
1 parent fcd3d02 commit ecce211
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 9 deletions.
8 changes: 7 additions & 1 deletion controllers/kafkauser_controller.go
Original file line number Diff line number Diff line change
Expand Up @@ -238,7 +238,13 @@ func (r *KafkaUserReconciler) Reconcile(ctx context.Context, request reconcile.R
return requeueWithError(reqLogger, "failed to reconcile user secret", err)
}
}
kafkaUser = user.DN()
kafkaUser, err = user.GetDistinguishedName()
if err != nil {
reqLogger.Error(err, "could not get Distinguished Name from the generated TLS certificate", "cert", string(user.Certificate))
return ctrl.Result{
Requeue: false,
}, err
}
// check if marked for deletion and remove created certs
if k8sutil.IsMarkedForDeletion(instance.ObjectMeta) {
reqLogger.Info("Kafka user is marked for deletion, revoking certificates")
Expand Down
4 changes: 1 addition & 3 deletions pkg/util/cert/certutil.go
Original file line number Diff line number Diff line change
Expand Up @@ -132,9 +132,7 @@ func DecodeCertificate(raw []byte) (cert *x509.Certificate, err error) {
if err != nil {
return nil, err
}
if len(certs) != 1 {
return nil, errors.New("only one certificate should be present, more found")
}

return certs[0].Certificate, nil
}

Expand Down
11 changes: 7 additions & 4 deletions pkg/util/pki/common.go
Original file line number Diff line number Diff line change
Expand Up @@ -93,11 +93,14 @@ type UserCertificate struct {
Password []byte
}

// DN returns the Distinguished Name of a TLS certificate
func (u *UserCertificate) DN() string {
// GetDistinguishedName returns the Distinguished Name of a TLS certificate
func (u *UserCertificate) GetDistinguishedName() (string, error) {
// cert has already been validated so we can assume no error
cert, _ := certutil.DecodeCertificate(u.Certificate)
return cert.Subject.String()
cert, err := certutil.DecodeCertificate(u.Certificate)
if err != nil {
return "", err
}
return cert.Subject.String(), nil
}

// GetInternalDNSNames returns all potential DNS names for a kafka cluster - including brokers
Expand Down
5 changes: 4 additions & 1 deletion pkg/util/pki/pki_common_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,10 @@ func TestDN(t *testing.T) {
userCert := &UserCertificate{
Certificate: cert,
}
dn := userCert.DN()
dn, err := userCert.GetDistinguishedName()
if err != nil {
t.Errorf("error should be nil, got: %s", err)
}
if dn != expected {
t.Error("Expected:", expected, "got:", dn)
}
Expand Down

0 comments on commit ecce211

Please sign in to comment.