fleet/server/mdm/nanomdm/certverify/fallback.go
Victor Lyuboslavsky e4df954b0f
Update nanomdm dependency with latest bug fixes and improvements. (#23906)
#23905 

- Update with upstream nanomdm changes up to
825f2979a2
- Removed PostgeSQL folder from our nanomdm
- Added nanomdm MySQL test job to our CI

# Checklist for submitter

- [x] Changes file added for user-visible changes in `changes/`,
`orbit/changes/` or `ee/fleetd-chrome/changes`.
See [Changes
files](https://github.com/fleetdm/fleet/blob/main/docs/Contributing/Committing-Changes.md#changes-files)
for more information.
- [x] Added/updated tests
- [x] Manual QA for all new/changed functionality
2024-11-20 11:47:11 -06:00

41 lines
1.1 KiB
Go

package certverify
import (
"context"
"crypto/x509"
"errors"
"fmt"
"strings"
)
// CertVerifier is a simple interface for verifying a certificate.
type CertVerifier interface {
Verify(context.Context, *x509.Certificate) error
}
// FallbackVerifier verfies certificate validity using multiple verifiers.
type FallbackVerifier struct {
verifiers []CertVerifier
}
// NewFallbackVerifier creates a new verifier using other verifiers.
func NewFallbackVerifier(verifiers ...CertVerifier) *FallbackVerifier {
return &FallbackVerifier{verifiers: verifiers}
}
// Verify performs certificate verification.
// Any verifier returning nil ("passes") will pass (return nil) and not
// check any other verifier.
// If all verifiers return non-nil ("fail") then an error for all
// verifiers will be returned.
func (v *FallbackVerifier) Verify(ctx context.Context, cert *x509.Certificate) error {
var errs []string
for i, verifier := range v.verifiers {
err := verifier.Verify(ctx, cert)
if err == nil {
return nil
}
errs = append(errs, fmt.Sprintf("fallback error (%d): %v", i, err))
}
return errors.New(strings.Join(errs, "; "))
}