1
0
mirror of https://github.com/ehang-io/nps synced 2025-10-27 04:35:43 +08:00
nps/lib/crypt/tls.go
2019-08-10 11:15:25 +08:00

35 lines
578 B
Go

package crypt
import (
"crypto/tls"
"net"
"os"
"github.com/astaxie/beego/logs"
)
var pemPath, keyPath string
func InitTls(pem, key string) {
pemPath = pem
keyPath = key
}
func NewTlsServerConn(conn net.Conn) net.Conn {
cert, err := tls.LoadX509KeyPair(pemPath, keyPath)
if err != nil {
logs.Error(err)
os.Exit(0)
return nil
}
config := &tls.Config{Certificates: []tls.Certificate{cert}}
return tls.Server(conn, config)
}
func NewTlsClientConn(conn net.Conn) net.Conn {
conf := &tls.Config{
InsecureSkipVerify: true,
}
return tls.Client(conn, conf)
}