mirror of
https://github.com/wneessen/go-mail.git
synced 2024-11-22 22:00:49 +01:00
64 lines
1.8 KiB
Go
64 lines
1.8 KiB
Go
// SPDX-FileCopyrightText: 2022-2023 The go-mail Authors
|
|
//
|
|
// SPDX-License-Identifier: MIT
|
|
|
|
package mail
|
|
|
|
import (
|
|
"crypto/ecdsa"
|
|
"crypto/rsa"
|
|
"crypto/tls"
|
|
"crypto/x509"
|
|
)
|
|
|
|
const (
|
|
certRSAFilePath = "dummy-chain-cert-rsa.pem"
|
|
keyRSAFilePath = "dummy-child-key-rsa.pem"
|
|
|
|
certECDSAFilePath = "dummy-chain-cert-ecdsa.pem"
|
|
keyECDSAFilePath = "dummy-child-key-ecdsa.pem"
|
|
)
|
|
|
|
// getDummyRSACryptoMaterial loads a certificate (RSA) and the associated private key (ECDSA) form local disk for testing purposes
|
|
func getDummyRSACryptoMaterial() (*rsa.PrivateKey, *x509.Certificate, *x509.Certificate, error) {
|
|
keyPair, err := tls.LoadX509KeyPair(certRSAFilePath, keyRSAFilePath)
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
privateKey := keyPair.PrivateKey.(*rsa.PrivateKey)
|
|
|
|
certificate, err := x509.ParseCertificate(keyPair.Certificate[0])
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
intermediateCertificate, err := x509.ParseCertificate(keyPair.Certificate[1])
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
return privateKey, certificate, intermediateCertificate, nil
|
|
}
|
|
|
|
// getDummyECDSACryptoMaterial loads a certificate (ECDSA) and the associated private key (ECDSA) form local disk for testing purposes
|
|
func getDummyECDSACryptoMaterial() (*ecdsa.PrivateKey, *x509.Certificate, *x509.Certificate, error) {
|
|
keyPair, err := tls.LoadX509KeyPair(certECDSAFilePath, keyECDSAFilePath)
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
privateKey := keyPair.PrivateKey.(*ecdsa.PrivateKey)
|
|
|
|
certificate, err := x509.ParseCertificate(keyPair.Certificate[0])
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
intermediateCertificate, err := x509.ParseCertificate(keyPair.Certificate[1])
|
|
if err != nil {
|
|
return nil, nil, nil, err
|
|
}
|
|
|
|
return privateKey, certificate, intermediateCertificate, nil
|
|
}
|