Files
kubevpn/pkg/daemon/action/quit.go
naison 211c9309b2 feat: handle local conn with gvisor (#665)
* feat: handle local conn with gvisor

* feat: remove udp route map

* feat: optimize code

* feat: length

* feat: works

* feat: should works

* feat: optimize code

* feat: optimize code

* feat: gudp not set remark

* feat: ut

* feat: set to default value 0

* feat: send reset to gvisor tcp forward request if error

* feat: not need to create firewall rule on windows

* feat: typo
2025-07-05 21:43:44 +08:00

76 lines
1.5 KiB
Go

package action
import (
"context"
"io"
"os"
log "github.com/sirupsen/logrus"
"github.com/wencaiwulue/kubevpn/v2/pkg/daemon/rpc"
"github.com/wencaiwulue/kubevpn/v2/pkg/dns"
"github.com/wencaiwulue/kubevpn/v2/pkg/handler"
plog "github.com/wencaiwulue/kubevpn/v2/pkg/log"
"github.com/wencaiwulue/kubevpn/v2/pkg/util"
)
func (svr *Server) Quit(resp rpc.Daemon_QuitServer) error {
defer svr.CleanupConfig()
logger := plog.GetLoggerForClient(int32(log.InfoLevel), io.MultiWriter(newQuitWarp(resp), svr.LogFile))
ctx := context.Background()
if resp != nil {
ctx = resp.Context()
}
ctx = plog.WithLogger(ctx, logger)
if svr.clone != nil {
err := svr.clone.Cleanup(ctx)
if err != nil {
plog.G(ctx).Errorf("Cleanup clone failed: %v", err)
}
svr.clone = nil
}
connects := handler.Connects(svr.secondaryConnect).Append(svr.connect)
for _, conn := range connects.Sort() {
if conn != nil {
conn.Cleanup(ctx)
}
}
svr.secondaryConnect = nil
svr.connect = nil
if svr.IsSudo {
_ = dns.CleanupHosts()
_ = os.RemoveAll("/etc/resolver")
}
// last step is to quit GRPC server
if svr.Cancel != nil {
svr.Cancel()
svr.Cancel = nil
}
_ = util.CleanupTempKubeConfigFile()
return nil
}
type quitWarp struct {
server rpc.Daemon_QuitServer
}
func (r *quitWarp) Write(p []byte) (n int, err error) {
if r.server == nil {
return len(p), nil
}
_ = r.server.Send(&rpc.QuitResponse{
Message: string(p),
})
return len(p), nil
}
func newQuitWarp(server rpc.Daemon_QuitServer) io.Writer {
return &quitWarp{server: server}
}