mirror of
https://github.com/fleetdm/fleet
synced 2026-05-24 09:28:54 +00:00
#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
41 lines
1.1 KiB
Go
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, "; "))
|
|
}
|