frp/client/proxy_manager.go

138 lines
2.7 KiB
Go
Raw Normal View History

2018-01-17 00:09:33 +07:00
package client
import (
"fmt"
"sync"
"github.com/fatedier/frp/models/config"
"github.com/fatedier/frp/models/msg"
"github.com/fatedier/frp/utils/log"
frpNet "github.com/fatedier/frp/utils/net"
2018-05-08 01:13:30 +07:00
"github.com/fatedier/golib/errors"
2018-01-17 00:09:33 +07:00
)
type ProxyManager struct {
sendCh chan (msg.Message)
2018-01-17 00:09:33 +07:00
proxies map[string]*ProxyWrapper
2018-12-07 16:05:36 +07:00
closed bool
mu sync.RWMutex
logPrefix string
2018-01-17 00:09:33 +07:00
log.Logger
}
2018-11-06 17:35:05 +07:00
func NewProxyManager(msgSendCh chan (msg.Message), logPrefix string) *ProxyManager {
2018-01-17 00:09:33 +07:00
return &ProxyManager{
2018-12-07 16:05:36 +07:00
proxies: make(map[string]*ProxyWrapper),
sendCh: msgSendCh,
closed: false,
logPrefix: logPrefix,
Logger: log.NewPrefixLogger(logPrefix),
2018-01-17 00:09:33 +07:00
}
}
2018-01-17 13:40:08 +07:00
func (pm *ProxyManager) StartProxy(name string, remoteAddr string, serverRespErr string) error {
2018-12-07 16:05:36 +07:00
pm.mu.RLock()
2018-01-17 00:09:33 +07:00
pxy, ok := pm.proxies[name]
2018-12-07 16:05:36 +07:00
pm.mu.RUnlock()
2018-01-17 00:09:33 +07:00
if !ok {
2018-12-07 16:05:36 +07:00
return fmt.Errorf("proxy [%s] not found", name)
2018-01-17 00:09:33 +07:00
}
2018-12-07 16:05:36 +07:00
err := pxy.SetRunningStatus(remoteAddr, serverRespErr)
if err != nil {
return err
2018-01-17 00:09:33 +07:00
}
return nil
}
2018-12-07 16:05:36 +07:00
func (pm *ProxyManager) Close() {
2018-01-17 00:09:33 +07:00
pm.mu.RLock()
defer pm.mu.RUnlock()
for _, pxy := range pm.proxies {
2018-12-07 16:05:36 +07:00
pxy.Stop()
2018-01-17 00:09:33 +07:00
}
}
2018-12-07 16:05:36 +07:00
func (pm *ProxyManager) HandleWorkConn(name string, workConn frpNet.Conn) {
2018-01-17 00:09:33 +07:00
pm.mu.RLock()
2018-12-07 16:05:36 +07:00
pw, ok := pm.proxies[name]
pm.mu.RUnlock()
if ok {
pw.InWorkConn(workConn)
} else {
workConn.Close()
2018-01-17 00:09:33 +07:00
}
2018-12-07 16:05:36 +07:00
}
func (pm *ProxyManager) HandleEvent(evType EventType, payload interface{}) error {
var m msg.Message
switch event := payload.(type) {
case *StartProxyPayload:
m = event.NewProxyMsg
case *CloseProxyPayload:
m = event.CloseProxyMsg
default:
return ErrPayloadType
}
err := errors.PanicToError(func() {
pm.sendCh <- m
})
return err
}
2018-01-17 00:09:33 +07:00
2018-12-07 16:05:36 +07:00
func (pm *ProxyManager) GetAllProxyStatus() []*ProxyStatus {
ps := make([]*ProxyStatus, 0)
pm.mu.RLock()
defer pm.mu.RUnlock()
2018-01-17 00:09:33 +07:00
for _, pxy := range pm.proxies {
2018-12-07 16:05:36 +07:00
ps = append(ps, pxy.GetStatus())
2018-01-17 00:09:33 +07:00
}
2018-12-07 16:05:36 +07:00
return ps
2018-01-17 00:09:33 +07:00
}
2018-12-07 16:05:36 +07:00
func (pm *ProxyManager) Reload(pxyCfgs map[string]config.ProxyConf) {
2018-01-17 00:09:33 +07:00
pm.mu.Lock()
2018-12-07 16:05:36 +07:00
defer pm.mu.Unlock()
2018-01-17 00:09:33 +07:00
delPxyNames := make([]string, 0)
for name, pxy := range pm.proxies {
del := false
cfg, ok := pxyCfgs[name]
if !ok {
del = true
} else {
if !pxy.Cfg.Compare(cfg) {
del = true
}
}
if del {
delPxyNames = append(delPxyNames, name)
delete(pm.proxies, name)
2018-12-07 16:05:36 +07:00
pxy.Stop()
2018-01-17 00:09:33 +07:00
}
}
2018-12-07 16:05:36 +07:00
if len(delPxyNames) > 0 {
pm.Info("proxy removed: %v", delPxyNames)
}
2018-01-17 00:09:33 +07:00
addPxyNames := make([]string, 0)
for name, cfg := range pxyCfgs {
if _, ok := pm.proxies[name]; !ok {
2018-12-07 16:05:36 +07:00
pxy := NewProxyWrapper(cfg, pm.HandleEvent, pm.logPrefix)
2018-01-17 00:09:33 +07:00
pm.proxies[name] = pxy
addPxyNames = append(addPxyNames, name)
2018-11-06 17:35:05 +07:00
2018-12-07 16:05:36 +07:00
pxy.Start()
}
2018-11-06 17:35:05 +07:00
}
2018-12-07 16:05:36 +07:00
if len(addPxyNames) > 0 {
pm.Info("proxy added: %v", addPxyNames)
2018-11-06 17:35:05 +07:00
}
}