mirror of
https://git.phreedom.club/localhost_frssoft/compy.git
synced 2025-01-24 17:56:43 +00:00
36 lines
730 B
Go
36 lines
730 B
Go
|
package proxy
|
||
|
|
||
|
import (
|
||
|
"crypto"
|
||
|
"crypto/tls"
|
||
|
"crypto/x509"
|
||
|
)
|
||
|
|
||
|
type certFaker struct {
|
||
|
ca *x509.Certificate
|
||
|
key crypto.PrivateKey
|
||
|
}
|
||
|
|
||
|
func newCertFaker(caPath, keyPath string) (*certFaker, error) {
|
||
|
certs, err := tls.LoadX509KeyPair(caPath, keyPath)
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
ca, err := x509.ParseCertificate(certs.Certificate[0])
|
||
|
if err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
return &certFaker{
|
||
|
ca: ca,
|
||
|
key: certs.PrivateKey,
|
||
|
}, nil
|
||
|
}
|
||
|
|
||
|
func (cf *certFaker) FakeCert(original *x509.Certificate) (*tls.Certificate, error) {
|
||
|
fakeCertData, err := x509.CreateCertificate(nil, original, cf.ca, cf.ca.PublicKey, cf.key)
|
||
|
return &tls.Certificate{
|
||
|
Certificate: [][]byte{fakeCertData},
|
||
|
PrivateKey: cf.key,
|
||
|
}, err
|
||
|
}
|