frp/client/proxy/proxy_manager.go

145 lines
2.9 KiB
Go
Raw Normal View History

2018-12-09 14:06:22 +00:00
package proxy
2018-01-16 17:09:33 +00:00
import (
2019-10-12 12:13:12 +00:00
"context"
2018-01-16 17:09:33 +00:00
"fmt"
2019-10-12 12:13:12 +00:00
"net"
2018-01-16 17:09:33 +00:00
"sync"
2022-08-28 17:02:53 +00:00
"github.com/fatedier/golib/errors"
2018-12-09 14:06:22 +00:00
"github.com/fatedier/frp/client/event"
2020-09-23 05:49:14 +00:00
"github.com/fatedier/frp/pkg/config"
"github.com/fatedier/frp/pkg/msg"
"github.com/fatedier/frp/pkg/util/xlog"
2018-01-16 17:09:33 +00:00
)
2020-05-24 09:48:37 +00:00
type Manager struct {
sendCh chan (msg.Message)
2020-05-24 09:48:37 +00:00
proxies map[string]*Wrapper
2018-01-16 17:09:33 +00:00
2018-12-07 09:05:36 +00:00
closed bool
mu sync.RWMutex
clientCfg config.ClientCommonConf
// The UDP port that the server is listening on
serverUDPPort int
2019-10-12 12:13:12 +00:00
ctx context.Context
2018-01-16 17:09:33 +00:00
}
2020-05-24 09:48:37 +00:00
func NewManager(ctx context.Context, msgSendCh chan (msg.Message), clientCfg config.ClientCommonConf, serverUDPPort int) *Manager {
return &Manager{
sendCh: msgSendCh,
2020-05-24 09:48:37 +00:00
proxies: make(map[string]*Wrapper),
closed: false,
clientCfg: clientCfg,
serverUDPPort: serverUDPPort,
2019-10-12 12:13:12 +00:00
ctx: ctx,
2018-01-16 17:09:33 +00:00
}
}
2020-05-24 09:48:37 +00:00
func (pm *Manager) StartProxy(name string, remoteAddr string, serverRespErr string) error {
2018-12-07 09:05:36 +00:00
pm.mu.RLock()
2018-01-16 17:09:33 +00:00
pxy, ok := pm.proxies[name]
2018-12-07 09:05:36 +00:00
pm.mu.RUnlock()
2018-01-16 17:09:33 +00:00
if !ok {
2018-12-07 09:05:36 +00:00
return fmt.Errorf("proxy [%s] not found", name)
2018-01-16 17:09:33 +00:00
}
2018-12-07 09:05:36 +00:00
err := pxy.SetRunningStatus(remoteAddr, serverRespErr)
if err != nil {
return err
2018-01-16 17:09:33 +00:00
}
return nil
}
2020-05-24 09:48:37 +00:00
func (pm *Manager) Close() {
2018-12-11 07:06:54 +00:00
pm.mu.Lock()
defer pm.mu.Unlock()
2018-01-16 17:09:33 +00:00
for _, pxy := range pm.proxies {
2018-12-07 09:05:36 +00:00
pxy.Stop()
2018-01-16 17:09:33 +00:00
}
2020-05-24 09:48:37 +00:00
pm.proxies = make(map[string]*Wrapper)
2018-01-16 17:09:33 +00:00
}
2020-05-24 09:48:37 +00:00
func (pm *Manager) HandleWorkConn(name string, workConn net.Conn, m *msg.StartWorkConn) {
2018-01-16 17:09:33 +00:00
pm.mu.RLock()
2018-12-07 09:05:36 +00:00
pw, ok := pm.proxies[name]
pm.mu.RUnlock()
if ok {
2019-03-29 11:01:18 +00:00
pw.InWorkConn(workConn, m)
2018-12-07 09:05:36 +00:00
} else {
workConn.Close()
2018-01-16 17:09:33 +00:00
}
2018-12-07 09:05:36 +00:00
}
func (pm *Manager) HandleEvent(payload interface{}) error {
2018-12-07 09:05:36 +00:00
var m msg.Message
2018-12-09 14:06:22 +00:00
switch e := payload.(type) {
case *event.StartProxyPayload:
m = e.NewProxyMsg
case *event.CloseProxyPayload:
m = e.CloseProxyMsg
2018-12-07 09:05:36 +00:00
default:
2018-12-09 14:06:22 +00:00
return event.ErrPayloadType
2018-12-07 09:05:36 +00:00
}
err := errors.PanicToError(func() {
pm.sendCh <- m
})
return err
}
2018-01-16 17:09:33 +00:00
2020-05-24 09:48:37 +00:00
func (pm *Manager) GetAllProxyStatus() []*WorkingStatus {
ps := make([]*WorkingStatus, 0)
2018-12-07 09:05:36 +00:00
pm.mu.RLock()
defer pm.mu.RUnlock()
2018-01-16 17:09:33 +00:00
for _, pxy := range pm.proxies {
2018-12-07 09:05:36 +00:00
ps = append(ps, pxy.GetStatus())
2018-01-16 17:09:33 +00:00
}
2018-12-07 09:05:36 +00:00
return ps
2018-01-16 17:09:33 +00:00
}
2020-05-24 09:48:37 +00:00
func (pm *Manager) Reload(pxyCfgs map[string]config.ProxyConf) {
2019-10-12 12:13:12 +00:00
xl := xlog.FromContextSafe(pm.ctx)
2018-01-16 17:09:33 +00:00
pm.mu.Lock()
2018-12-07 09:05:36 +00:00
defer pm.mu.Unlock()
2018-01-16 17:09:33 +00:00
delPxyNames := make([]string, 0)
for name, pxy := range pm.proxies {
del := false
cfg, ok := pxyCfgs[name]
if !ok {
del = true
2022-08-28 17:02:53 +00:00
} else if !pxy.Cfg.Compare(cfg) {
del = true
2018-01-16 17:09:33 +00:00
}
if del {
delPxyNames = append(delPxyNames, name)
delete(pm.proxies, name)
2018-12-07 09:05:36 +00:00
pxy.Stop()
2018-01-16 17:09:33 +00:00
}
}
2018-12-07 09:05:36 +00:00
if len(delPxyNames) > 0 {
2019-10-12 12:13:12 +00:00
xl.Info("proxy removed: %v", delPxyNames)
2018-12-07 09:05:36 +00:00
}
2018-01-16 17:09:33 +00:00
addPxyNames := make([]string, 0)
for name, cfg := range pxyCfgs {
if _, ok := pm.proxies[name]; !ok {
2020-05-24 09:48:37 +00:00
pxy := NewWrapper(pm.ctx, cfg, pm.clientCfg, pm.HandleEvent, pm.serverUDPPort)
2018-01-16 17:09:33 +00:00
pm.proxies[name] = pxy
addPxyNames = append(addPxyNames, name)
2018-11-06 10:35:05 +00:00
2018-12-07 09:05:36 +00:00
pxy.Start()
}
2018-11-06 10:35:05 +00:00
}
2018-12-07 09:05:36 +00:00
if len(addPxyNames) > 0 {
2019-10-12 12:13:12 +00:00
xl.Info("proxy added: %v", addPxyNames)
2018-11-06 10:35:05 +00:00
}
}