Files
kubevpn/pkg/core/tcp.go
naison 38584da9d3 refactor: remove options netstack (#673)
* refactor: remove options netstack

* refactor: remove options netstack

* refactor: forward chain use gvisor tcp

* refactor: docs

* refactor: remove forwarder options

* refactor: optimize code

* refactor: remove node type "tcp://"

* hotfix: packet read from tun needs to handle by gvisor

* hotfix: fix charts

* refactor: remove parameter engine
2025-07-27 17:26:14 +08:00

68 lines
1.6 KiB
Go

package core
import (
"context"
"crypto/tls"
"errors"
"net"
"github.com/wencaiwulue/kubevpn/v2/pkg/config"
plog "github.com/wencaiwulue/kubevpn/v2/pkg/log"
"github.com/wencaiwulue/kubevpn/v2/pkg/util"
)
type tcpTransporter struct {
tlsConfig *tls.Config
}
func TCPTransporter(tlsInfo map[string][]byte) Transporter {
tlsConfig, err := util.GetTlsClientConfig(tlsInfo)
if err != nil {
if errors.Is(err, util.ErrNoTLSConfig) {
plog.G(context.Background()).Warn("tls config not found in config, use raw tcp mode")
return &tcpTransporter{}
}
plog.G(context.Background()).Errorf("failed to get tls client config: %v", err)
return &tcpTransporter{}
}
return &tcpTransporter{tlsConfig: tlsConfig}
}
func (tr *tcpTransporter) Dial(ctx context.Context, addr string) (net.Conn, error) {
dialer := &net.Dialer{Timeout: config.DialTimeout, KeepAlive: config.KeepAliveTime}
conn, err := dialer.DialContext(ctx, "tcp", addr)
if err != nil {
return nil, err
}
if tr.tlsConfig == nil {
plog.G(ctx).Debugf("tls config not found in config, use raw tcp mode")
return conn, nil
}
plog.G(ctx).Debugf("Use tls mode")
return tls.Client(conn, tr.tlsConfig), nil
}
type tcpKeepAliveListener struct {
*net.TCPListener
}
func (ln *tcpKeepAliveListener) Accept() (c net.Conn, err error) {
conn, err := ln.AcceptTCP()
if err != nil {
return
}
err = conn.SetKeepAlive(true)
if err != nil {
return nil, err
}
err = conn.SetKeepAlivePeriod(config.KeepAliveTime)
if err != nil {
return nil, err
}
err = conn.SetNoDelay(true)
if err != nil {
return nil, err
}
return conn, nil
}