Allow ca-signed client certs and self-signed server certs
This commit is contained in:
parent
ea5b79d8d8
commit
4d057cdb31
@ -11,7 +11,7 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
func MakeClientTls(name pkix.Name, serialNumber *big.Int) (*CertGen, error) {
|
func MakeClientTls(ca *CertGen, name pkix.Name, serialNumber *big.Int) (*CertGen, error) {
|
||||||
cert := &x509.Certificate{
|
cert := &x509.Certificate{
|
||||||
SerialNumber: serialNumber,
|
SerialNumber: serialNumber,
|
||||||
Subject: name,
|
Subject: name,
|
||||||
@ -27,7 +27,10 @@ func MakeClientTls(name pkix.Name, serialNumber *big.Int) (*CertGen, error) {
|
|||||||
log.Fatalln("Failed to generate client private key:", err)
|
log.Fatalln("Failed to generate client private key:", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
clientBytes, err := x509.CreateCertificate(rand.Reader, cert, cert, clientPrivKey.Public(), clientPrivKey)
|
if ca == nil {
|
||||||
|
ca = &CertGen{cert: cert, key: clientPrivKey}
|
||||||
|
}
|
||||||
|
clientBytes, err := x509.CreateCertificate(rand.Reader, cert, ca.cert, clientPrivKey.Public(), ca.key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalln("Failed to generate client certificate bytes:", err)
|
log.Fatalln("Failed to generate client certificate bytes:", err)
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,9 @@ func MakeServerTls(ca *CertGen, name pkix.Name, serialNumber *big.Int, dnsNames
|
|||||||
log.Fatalln("Failed to generate server private key:", err)
|
log.Fatalln("Failed to generate server private key:", err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ca == nil {
|
||||||
|
ca = &CertGen{cert: cert, key: serverPrivKey}
|
||||||
|
}
|
||||||
serverBytes, err := x509.CreateCertificate(rand.Reader, cert, ca.cert, serverPrivKey.Public(), ca.key)
|
serverBytes, err := x509.CreateCertificate(rand.Reader, cert, ca.cert, serverPrivKey.Public(), ca.key)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Fatalln("Failed to generate server certificate bytes:", err)
|
log.Fatalln("Failed to generate server certificate bytes:", err)
|
||||||
|
Loading…
Reference in New Issue
Block a user