|
@@ -1,7 +1,6 @@
|
|
|
package server
|
|
|
|
|
|
import (
|
|
|
- "bufio"
|
|
|
"errors"
|
|
|
"fmt"
|
|
|
"github.com/astaxie/beego"
|
|
@@ -10,17 +9,31 @@ import (
|
|
|
"log"
|
|
|
"net"
|
|
|
"net/http"
|
|
|
- "net/http/httputil"
|
|
|
"strings"
|
|
|
- "sync"
|
|
|
)
|
|
|
|
|
|
-type process func(c *utils.Conn, s *TunnelModeServer) error
|
|
|
+//server base struct
|
|
|
+type server struct {
|
|
|
+ bridge *bridge.Tunnel
|
|
|
+ config *ServerConfig
|
|
|
+}
|
|
|
+
|
|
|
+func (s *server) GetTunnelAndWriteHost(connType string, cnf *ServerConfig, addr string) (*utils.Conn, error) {
|
|
|
+ var err error
|
|
|
+ link, err := s.bridge.GetTunnel(getverifyval(cnf.VerifyKey), cnf.CompressEncode, cnf.CompressDecode, cnf.Crypt, cnf.Mux)
|
|
|
+ if err != nil {
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ if _, err = link.WriteHost(connType, addr); err != nil {
|
|
|
+ link.Close()
|
|
|
+ return nil, err
|
|
|
+ }
|
|
|
+ return link, nil
|
|
|
+}
|
|
|
|
|
|
type TunnelModeServer struct {
|
|
|
+ server
|
|
|
process process
|
|
|
- bridge *bridge.Tunnel
|
|
|
- config *ServerConfig
|
|
|
listener *net.TCPListener
|
|
|
}
|
|
|
|
|
@@ -64,10 +77,6 @@ func (s *TunnelModeServer) auth(r *http.Request, c *utils.Conn, u, p string) err
|
|
|
return nil
|
|
|
}
|
|
|
|
|
|
-func (s *TunnelModeServer) dealClient2(c *utils.Conn, cnf *ServerConfig, addr string, method string, rb []byte) error {
|
|
|
- return nil
|
|
|
-}
|
|
|
-
|
|
|
//与客户端建立通道
|
|
|
func (s *TunnelModeServer) dealClient(c *utils.Conn, cnf *ServerConfig, addr string, method string, rb []byte) error {
|
|
|
var link *utils.Conn
|
|
@@ -77,7 +86,7 @@ func (s *TunnelModeServer) dealClient(c *utils.Conn, cnf *ServerConfig, addr str
|
|
|
s.bridge.ReturnTunnel(link, getverifyval(cnf.VerifyKey))
|
|
|
}
|
|
|
}()
|
|
|
- if link, err = s.GetTunnelAndWriteHost(c, cnf, addr); err != nil {
|
|
|
+ if link, err = s.GetTunnelAndWriteHost(utils.CONN_TCP, cnf, addr); err != nil {
|
|
|
log.Println("get bridge tunnel error: ", err)
|
|
|
return err
|
|
|
}
|
|
@@ -99,109 +108,9 @@ func (s *TunnelModeServer) Close() error {
|
|
|
return s.listener.Close()
|
|
|
}
|
|
|
|
|
|
-func (s *TunnelModeServer) GetTunnelAndWriteHost(c *utils.Conn, cnf *ServerConfig, addr string) (*utils.Conn, error) {
|
|
|
- var err error
|
|
|
- link, err := s.bridge.GetTunnel(getverifyval(cnf.VerifyKey), cnf.CompressEncode, cnf.CompressDecode, cnf.Crypt, cnf.Mux)
|
|
|
- if err != nil {
|
|
|
- return nil, err
|
|
|
- }
|
|
|
- if _, err = link.WriteHost(utils.CONN_TCP, addr); err != nil {
|
|
|
- link.Close()
|
|
|
- return nil, err
|
|
|
- }
|
|
|
- return link, nil
|
|
|
-}
|
|
|
-
|
|
|
-//tcp隧道模式
|
|
|
-func ProcessTunnel(c *utils.Conn, s *TunnelModeServer) error {
|
|
|
- _, _, rb, err, r := c.GetHost()
|
|
|
- if err == nil {
|
|
|
- if err := s.auth(r, c, s.config.U, s.config.P); err != nil {
|
|
|
- return err
|
|
|
- }
|
|
|
- }
|
|
|
- return s.dealClient(c, s.config, s.config.Target, "", rb)
|
|
|
-}
|
|
|
-
|
|
|
-//http代理模式
|
|
|
-func ProcessHttp(c *utils.Conn, s *TunnelModeServer) error {
|
|
|
- method, addr, rb, err, r := c.GetHost()
|
|
|
- if err != nil {
|
|
|
- log.Println(err)
|
|
|
- c.Close()
|
|
|
- return err
|
|
|
- }
|
|
|
- if err := s.auth(r, c, s.config.U, s.config.P); err != nil {
|
|
|
- return err
|
|
|
- }
|
|
|
- return s.dealClient(c, s.config, addr, method, rb)
|
|
|
-}
|
|
|
-
|
|
|
-//多客户端域名代理
|
|
|
-func ProcessHost(c *utils.Conn, s *TunnelModeServer) error {
|
|
|
- var (
|
|
|
- isConn = true
|
|
|
- link *utils.Conn
|
|
|
- cnf *ServerConfig
|
|
|
- host *HostList
|
|
|
- wg sync.WaitGroup
|
|
|
- )
|
|
|
- for {
|
|
|
- r, err := http.ReadRequest(bufio.NewReader(c))
|
|
|
- if err != nil {
|
|
|
- break
|
|
|
- }
|
|
|
- //首次获取conn
|
|
|
- if isConn {
|
|
|
- isConn = false
|
|
|
- if host, cnf, err = GetKeyByHost(r.Host); err != nil {
|
|
|
- log.Printf("the host %s is not found !", r.Host)
|
|
|
- break
|
|
|
- }
|
|
|
-
|
|
|
- if err = s.auth(r, c, cnf.U, cnf.P); err != nil {
|
|
|
- break
|
|
|
- }
|
|
|
-
|
|
|
- if link, err = s.GetTunnelAndWriteHost(c, cnf, host.Target); err != nil {
|
|
|
- log.Println("get bridge tunnel error: ", err)
|
|
|
- break
|
|
|
- }
|
|
|
-
|
|
|
- if flag, err := link.ReadFlag(); err != nil || flag == utils.CONN_ERROR {
|
|
|
- log.Printf("the host %s connection to %s error", r.Host, host.Target)
|
|
|
- break
|
|
|
- } else {
|
|
|
- wg.Add(1)
|
|
|
- go func() {
|
|
|
- utils.Relay(c.Conn, link.Conn, cnf.CompressDecode, cnf.Crypt, cnf.Mux)
|
|
|
- wg.Done()
|
|
|
- }()
|
|
|
- }
|
|
|
- }
|
|
|
- utils.ChangeHostAndHeader(r, host.HostChange, host.HeaderChange, c.Conn.RemoteAddr().String())
|
|
|
- b, err := httputil.DumpRequest(r, true)
|
|
|
- if err != nil {
|
|
|
- break
|
|
|
- }
|
|
|
- if _, err := link.WriteTo(b, cnf.CompressEncode, cnf.Crypt); err != nil {
|
|
|
- break
|
|
|
- }
|
|
|
- }
|
|
|
- wg.Wait()
|
|
|
- if cnf != nil && cnf.Mux && link != nil {
|
|
|
- link.WriteTo([]byte(utils.IO_EOF), cnf.CompressEncode, cnf.Crypt)
|
|
|
- s.bridge.ReturnTunnel(link, getverifyval(cnf.VerifyKey))
|
|
|
- } else if link != nil {
|
|
|
- link.Close()
|
|
|
- }
|
|
|
- c.Close()
|
|
|
- return nil
|
|
|
-}
|
|
|
-
|
|
|
//web管理方式
|
|
|
type WebServer struct {
|
|
|
- bridge *bridge.Tunnel
|
|
|
+ server
|
|
|
}
|
|
|
|
|
|
//开始
|
|
@@ -222,7 +131,7 @@ func NewWebServer(bridge *bridge.Tunnel) *WebServer {
|
|
|
|
|
|
//host
|
|
|
type HostServer struct {
|
|
|
- config *ServerConfig
|
|
|
+ server
|
|
|
}
|
|
|
|
|
|
//开始
|