...
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17 package certloader
18
19 import (
20 "bytes"
21 "crypto/x509"
22 "fmt"
23 "io"
24 "io/ioutil"
25
26 "golang.org/x/crypto/openpgp"
27 "golang.org/x/crypto/openpgp/armor"
28 )
29
30 type AnyCerts struct {
31 X509Certs []*x509.Certificate
32 PGPCerts openpgp.EntityList
33 }
34
35
36 func LoadAnyCerts(paths []string) (any AnyCerts, err error) {
37 for _, path := range paths {
38 blob, err := ioutil.ReadFile(path)
39 if err != nil {
40 return any, err
41 }
42 x509certs, err := parseCertificates(blob)
43 if err == nil {
44 any.X509Certs = append(any.X509Certs, x509certs.Certificates...)
45 continue
46 } else if err != ErrNoCerts {
47 return any, fmt.Errorf("%s: %s", path, err)
48 }
49 pgpcerts, err := parsePGP(blob)
50 if err == nil {
51 any.PGPCerts = append(any.PGPCerts, pgpcerts...)
52 } else {
53 return any, fmt.Errorf("%s: %s", path, err)
54 }
55 }
56 return any, nil
57 }
58
59
60 func parsePGP(blob []byte) (openpgp.EntityList, error) {
61 reader := io.Reader(bytes.NewReader(blob))
62 if blob[0] == '-' {
63 block, err := armor.Decode(reader)
64 if err != nil {
65 return nil, err
66 }
67 reader = block.Body
68 }
69 return openpgp.ReadKeyRing(reader)
70 }
71
View as plain text