mirror of https://github.com/v2ray/v2ray-core
sync for tcp hub
parent
7a97d73737
commit
c220f9cb3e
|
@ -2,7 +2,6 @@ package internet
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"net"
|
"net"
|
||||||
"sync"
|
|
||||||
|
|
||||||
"v2ray.com/core/common/errors"
|
"v2ray.com/core/common/errors"
|
||||||
v2net "v2ray.com/core/common/net"
|
v2net "v2ray.com/core/common/net"
|
||||||
|
@ -34,10 +33,9 @@ type Listener interface {
|
||||||
}
|
}
|
||||||
|
|
||||||
type TCPHub struct {
|
type TCPHub struct {
|
||||||
sync.Mutex
|
|
||||||
listener Listener
|
listener Listener
|
||||||
connCallback ConnectionHandler
|
connCallback ConnectionHandler
|
||||||
accepting bool
|
closed chan bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func ListenTCP(address v2net.Address, port v2net.Port, callback ConnectionHandler, settings *StreamConfig) (*TCPHub, error) {
|
func ListenTCP(address v2net.Address, port v2net.Port, callback ConnectionHandler, settings *StreamConfig) (*TCPHub, error) {
|
||||||
|
@ -64,24 +62,34 @@ func ListenTCP(address v2net.Address, port v2net.Port, callback ConnectionHandle
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *TCPHub) Close() {
|
func (v *TCPHub) Close() {
|
||||||
v.accepting = false
|
select {
|
||||||
v.listener.Close()
|
case <-v.closed:
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
v.listener.Close()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *TCPHub) start() {
|
func (v *TCPHub) start() {
|
||||||
v.accepting = true
|
for {
|
||||||
for v.accepting {
|
select {
|
||||||
|
case <-v.closed:
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
}
|
||||||
var newConn Connection
|
var newConn Connection
|
||||||
err := retry.ExponentialBackoff(10, 500).On(func() error {
|
err := retry.ExponentialBackoff(10, 500).On(func() error {
|
||||||
if !v.accepting {
|
select {
|
||||||
|
case <-v.closed:
|
||||||
|
return nil
|
||||||
|
default:
|
||||||
|
conn, err := v.listener.Accept()
|
||||||
|
if err != nil {
|
||||||
|
return errors.Base(err).Message("Internet|Listener: Failed to accept new TCP connection.")
|
||||||
|
}
|
||||||
|
newConn = conn
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
conn, err := v.listener.Accept()
|
|
||||||
if err != nil {
|
|
||||||
return errors.Base(err).Message("Internet|Listener: Failed to accept new TCP connection.")
|
|
||||||
}
|
|
||||||
newConn = conn
|
|
||||||
return nil
|
|
||||||
})
|
})
|
||||||
if err == nil && newConn != nil {
|
if err == nil && newConn != nil {
|
||||||
go v.connCallback(newConn)
|
go v.connCallback(newConn)
|
||||||
|
|
Loading…
Reference in New Issue