sync for tcp hub

pull/432/head
Darien Raymond 2017-02-19 22:29:31 +01:00
parent 7a97d73737
commit c220f9cb3e
No known key found for this signature in database
GPG Key ID: 7251FFA14BB18169
1 changed files with 22 additions and 14 deletions

View File

@ -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)