123456789101112131415161718192021222324252627282930313233 |
- package schema1
- import (
- "crypto/x509"
- "github.com/Sirupsen/logrus"
- "github.com/docker/libtrust"
- )
- // Verify verifies the signature of the signed manifest returning the public
- // keys used during signing.
- func Verify(sm *SignedManifest) ([]libtrust.PublicKey, error) {
- js, err := libtrust.ParsePrettySignature(sm.all, "signatures")
- if err != nil {
- logrus.WithField("err", err).Debugf("(*SignedManifest).Verify")
- return nil, err
- }
- return js.Verify()
- }
- // VerifyChains verifies the signature of the signed manifest against the
- // certificate pool returning the list of verified chains. Signatures without
- // an x509 chain are not checked.
- func VerifyChains(sm *SignedManifest, ca *x509.CertPool) ([][]*x509.Certificate, error) {
- js, err := libtrust.ParsePrettySignature(sm.all, "signatures")
- if err != nil {
- return nil, err
- }
- return js.VerifyChains(ca)
- }
|