| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- package hub
- import (
- "crypto/tls"
- "errors"
- "net"
- "sync"
- "github.com/v2ray/v2ray-core/common/log"
- v2net "github.com/v2ray/v2ray-core/common/net"
- "github.com/v2ray/v2ray-core/proxy"
- "github.com/v2ray/v2ray-core/transport"
- )
- var (
- ErrorClosedConnection = errors.New("Connection already closed.")
- )
- type TCPHub struct {
- sync.Mutex
- listener net.Listener
- connCallback ConnectionHandler
- accepting bool
- }
- func ListenTCP(address v2net.Address, port v2net.Port, callback ConnectionHandler, tlsConfig *tls.Config) (*TCPHub, error) {
- listener, err := net.ListenTCP("tcp", &net.TCPAddr{
- IP: address.IP(),
- Port: int(port),
- Zone: "",
- })
- if err != nil {
- return nil, err
- }
- var hub *TCPHub
- if tlsConfig != nil {
- tlsListener := tls.NewListener(listener, tlsConfig)
- hub = &TCPHub{
- listener: tlsListener,
- connCallback: callback,
- }
- } else {
- hub = &TCPHub{
- listener: listener,
- connCallback: callback,
- }
- }
- go hub.start()
- return hub, nil
- }
- func ListenKCPhub(address v2net.Address, port v2net.Port, callback ConnectionHandler, tlsConfig *tls.Config) (*TCPHub, error) {
- listener, err := ListenKCP(address, port)
- if err != nil {
- return nil, err
- }
- var hub *TCPHub
- if tlsConfig != nil {
- tlsListener := tls.NewListener(listener, tlsConfig)
- hub = &TCPHub{
- listener: tlsListener,
- connCallback: callback,
- }
- } else {
- hub = &TCPHub{
- listener: listener,
- connCallback: callback,
- }
- }
- go hub.start()
- return hub, nil
- }
- func ListenTCP6(address v2net.Address, port v2net.Port, callback ConnectionHandler, proxyMeta *proxy.InboundHandlerMeta, tlsConfig *tls.Config) (*TCPHub, error) {
- if proxyMeta.KcpSupported && transport.IsKcpEnabled() {
- return ListenKCPhub(address, port, callback, tlsConfig)
- } else {
- return ListenTCP(address, port, callback, tlsConfig)
- }
- return nil, errors.New("ListenTCP6: Not Implemented")
- }
- func (this *TCPHub) Close() {
- this.accepting = false
- this.listener.Close()
- }
- func (this *TCPHub) start() {
- this.accepting = true
- for this.accepting {
- conn, err := this.listener.Accept()
- if err != nil {
- if this.accepting {
- log.Warning("Listener: Failed to accept new TCP connection: ", err)
- }
- continue
- }
- go this.connCallback(&Connection{
- dest: conn.RemoteAddr().String(),
- conn: conn,
- listener: this,
- })
- }
- }
- // @Private
- func (this *TCPHub) Recycle(dest string, conn net.Conn) {
- if this.accepting {
- go this.connCallback(&Connection{
- dest: dest,
- conn: conn,
- listener: this,
- })
- }
- }
|