tls.go 631 Bytes
Newer Older
1 2 3 4 5 6
package proxyd

import (
	"crypto/tls"
	"crypto/x509"
	"errors"
7
	"os"
8 9 10
)

func CreateTLSClient(ca string) (*tls.Config, error) {
11
	pem, err := os.ReadFile(ca)
12 13 14 15 16 17 18 19 20 21 22
	if err != nil {
		return nil, wrapErr(err, "error reading CA")
	}

	roots := x509.NewCertPool()
	ok := roots.AppendCertsFromPEM(pem)
	if !ok {
		return nil, errors.New("error parsing TLS client cert")
	}

	return &tls.Config{
23
		RootCAs: roots,
24 25 26 27 28 29 30 31 32
	}, nil
}

func ParseKeyPair(crt, key string) (tls.Certificate, error) {
	cert, err := tls.LoadX509KeyPair(crt, key)
	if err != nil {
		return tls.Certificate{}, wrapErr(err, "error loading x509 key pair")
	}
	return cert, nil
33
}