mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-04-22 02:42:49 -04:00
simplify code
This commit is contained in:
parent
0d68293ef8
commit
d270a99d4f
@ -27,7 +27,30 @@ type ConnectionWithError struct {
|
|||||||
err error
|
err error
|
||||||
}
|
}
|
||||||
|
|
||||||
type WSListener struct {
|
type requestHandler struct {
|
||||||
|
path string
|
||||||
|
conns chan *ConnectionWithError
|
||||||
|
}
|
||||||
|
|
||||||
|
func (h *requestHandler) ServeHTTP(writer http.ResponseWriter, request *http.Request) {
|
||||||
|
if request.URL.Path != h.path {
|
||||||
|
writer.WriteHeader(http.StatusNotFound)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
conn, err := converttovws(writer, request)
|
||||||
|
if err != nil {
|
||||||
|
log.Info("WebSocket|Listener: Failed to convert to WebSocket connection: ", err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
select {
|
||||||
|
case h.conns <- &ConnectionWithError{conn: conn}:
|
||||||
|
default:
|
||||||
|
conn.Close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
type Listener struct {
|
||||||
sync.Mutex
|
sync.Mutex
|
||||||
acccepting bool
|
acccepting bool
|
||||||
awaitingConns chan *ConnectionWithError
|
awaitingConns chan *ConnectionWithError
|
||||||
@ -43,7 +66,7 @@ func ListenWS(address v2net.Address, port v2net.Port, options internet.ListenOpt
|
|||||||
}
|
}
|
||||||
wsSettings := networkSettings.(*Config)
|
wsSettings := networkSettings.(*Config)
|
||||||
|
|
||||||
l := &WSListener{
|
l := &Listener{
|
||||||
acccepting: true,
|
acccepting: true,
|
||||||
awaitingConns: make(chan *ConnectionWithError, 32),
|
awaitingConns: make(chan *ConnectionWithError, 32),
|
||||||
config: wsSettings,
|
config: wsSettings,
|
||||||
@ -65,51 +88,35 @@ func ListenWS(address v2net.Address, port v2net.Port, options internet.ListenOpt
|
|||||||
return l, err
|
return l, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (wsl *WSListener) listenws(address v2net.Address, port v2net.Port) error {
|
func (ln *Listener) listenws(address v2net.Address, port v2net.Port) error {
|
||||||
http.HandleFunc("/"+wsl.config.Path, func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
conn, err := wsl.converttovws(w, r)
|
|
||||||
if err != nil {
|
|
||||||
log.Warning("WebSocket|Listener: Failed to convert connection: ", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
select {
|
|
||||||
case wsl.awaitingConns <- &ConnectionWithError{
|
|
||||||
conn: conn,
|
|
||||||
}:
|
|
||||||
default:
|
|
||||||
if conn != nil {
|
|
||||||
conn.Close()
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return
|
|
||||||
})
|
|
||||||
|
|
||||||
netAddr := address.String() + ":" + strconv.Itoa(int(port.Value()))
|
netAddr := address.String() + ":" + strconv.Itoa(int(port.Value()))
|
||||||
var listener net.Listener
|
var listener net.Listener
|
||||||
if wsl.tlsConfig == nil {
|
if ln.tlsConfig == nil {
|
||||||
l, err := net.Listen("tcp", netAddr)
|
l, err := net.Listen("tcp", netAddr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Base(err).Message("WebSocket|Listener: Failed to listen TCP ", netAddr)
|
return errors.Base(err).Message("WebSocket|Listener: Failed to listen TCP ", netAddr)
|
||||||
}
|
}
|
||||||
listener = l
|
listener = l
|
||||||
} else {
|
} else {
|
||||||
l, err := tls.Listen("tcp", netAddr, wsl.tlsConfig)
|
l, err := tls.Listen("tcp", netAddr, ln.tlsConfig)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return errors.Base(err).Message("WebSocket|Listener: Failed to listen TLS ", netAddr)
|
return errors.Base(err).Message("WebSocket|Listener: Failed to listen TLS ", netAddr)
|
||||||
}
|
}
|
||||||
listener = l
|
listener = l
|
||||||
}
|
}
|
||||||
wsl.listener = listener
|
ln.listener = listener
|
||||||
|
|
||||||
go func() {
|
go func() {
|
||||||
http.Serve(listener, nil)
|
http.Serve(listener, &requestHandler{
|
||||||
|
path: "/" + ln.config.Path,
|
||||||
|
conns: ln.awaitingConns,
|
||||||
|
})
|
||||||
}()
|
}()
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (wsl *WSListener) converttovws(w http.ResponseWriter, r *http.Request) (*wsconn, error) {
|
func converttovws(w http.ResponseWriter, r *http.Request) (*wsconn, error) {
|
||||||
var upgrader = websocket.Upgrader{
|
var upgrader = websocket.Upgrader{
|
||||||
ReadBufferSize: 32 * 1024,
|
ReadBufferSize: 32 * 1024,
|
||||||
WriteBufferSize: 32 * 1024,
|
WriteBufferSize: 32 * 1024,
|
||||||
@ -123,49 +130,49 @@ func (wsl *WSListener) converttovws(w http.ResponseWriter, r *http.Request) (*ws
|
|||||||
return &wsconn{wsc: conn}, nil
|
return &wsconn{wsc: conn}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *WSListener) Accept() (internet.Connection, error) {
|
func (ln *Listener) Accept() (internet.Connection, error) {
|
||||||
for v.acccepting {
|
for ln.acccepting {
|
||||||
select {
|
select {
|
||||||
case connErr, open := <-v.awaitingConns:
|
case connErr, open := <-ln.awaitingConns:
|
||||||
if !open {
|
if !open {
|
||||||
return nil, ErrClosedListener
|
return nil, ErrClosedListener
|
||||||
}
|
}
|
||||||
if connErr.err != nil {
|
if connErr.err != nil {
|
||||||
return nil, connErr.err
|
return nil, connErr.err
|
||||||
}
|
}
|
||||||
return internal.NewConnection(internal.ConnectionID{}, connErr.conn, v, internal.ReuseConnection(v.config.IsConnectionReuse())), nil
|
return internal.NewConnection(internal.ConnectionID{}, connErr.conn, ln, internal.ReuseConnection(ln.config.IsConnectionReuse())), nil
|
||||||
case <-time.After(time.Second * 2):
|
case <-time.After(time.Second * 2):
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return nil, ErrClosedListener
|
return nil, ErrClosedListener
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *WSListener) Put(id internal.ConnectionID, conn net.Conn) {
|
func (ln *Listener) Put(id internal.ConnectionID, conn net.Conn) {
|
||||||
v.Lock()
|
ln.Lock()
|
||||||
defer v.Unlock()
|
defer ln.Unlock()
|
||||||
if !v.acccepting {
|
if !ln.acccepting {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
select {
|
select {
|
||||||
case v.awaitingConns <- &ConnectionWithError{conn: conn}:
|
case ln.awaitingConns <- &ConnectionWithError{conn: conn}:
|
||||||
default:
|
default:
|
||||||
conn.Close()
|
conn.Close()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *WSListener) Addr() net.Addr {
|
func (ln *Listener) Addr() net.Addr {
|
||||||
return nil
|
return ln.listener.Addr()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *WSListener) Close() error {
|
func (ln *Listener) Close() error {
|
||||||
v.Lock()
|
ln.Lock()
|
||||||
defer v.Unlock()
|
defer ln.Unlock()
|
||||||
v.acccepting = false
|
ln.acccepting = false
|
||||||
|
|
||||||
v.listener.Close()
|
ln.listener.Close()
|
||||||
|
|
||||||
close(v.awaitingConns)
|
close(ln.awaitingConns)
|
||||||
for connErr := range v.awaitingConns {
|
for connErr := range ln.awaitingConns {
|
||||||
if connErr.conn != nil {
|
if connErr.conn != nil {
|
||||||
connErr.conn.Close()
|
connErr.conn.Close()
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user