mirror of https://github.com/v2ray/v2ray-core
Close http connection ASAP.
parent
a24b11af27
commit
56f08afd9c
|
@ -32,6 +32,7 @@ type Server struct {
|
|||
meta *proxy.InboundHandlerMeta
|
||||
}
|
||||
|
||||
// NewServer creates a new HTTP inbound handler.
|
||||
func NewServer(config *ServerConfig, packetDispatcher dispatcher.PacketDispatcher, meta *proxy.InboundHandlerMeta) *Server {
|
||||
return &Server{
|
||||
packetDispatcher: packetDispatcher,
|
||||
|
@ -40,10 +41,12 @@ func NewServer(config *ServerConfig, packetDispatcher dispatcher.PacketDispatche
|
|||
}
|
||||
}
|
||||
|
||||
// Port implements InboundHandler.Port().
|
||||
func (v *Server) Port() v2net.Port {
|
||||
return v.meta.Port
|
||||
}
|
||||
|
||||
// Close implements InboundHandler.Close().
|
||||
func (v *Server) Close() {
|
||||
v.accepting = false
|
||||
if v.tcpListener != nil {
|
||||
|
@ -54,6 +57,7 @@ func (v *Server) Close() {
|
|||
}
|
||||
}
|
||||
|
||||
// Start implements InboundHandler.Start().
|
||||
func (v *Server) Start() error {
|
||||
if v.accepting {
|
||||
return nil
|
||||
|
@ -145,7 +149,10 @@ func (v *Server) handleConnect(request *http.Request, session *proxy.SessionInfo
|
|||
ContentLength: 0,
|
||||
Close: false,
|
||||
}
|
||||
response.Write(writer)
|
||||
if err := response.Write(writer); err != nil {
|
||||
log.Warning("HTTP|Server: failed to write back OK response: ", err)
|
||||
return
|
||||
}
|
||||
|
||||
ray := v.packetDispatcher.DispatchToOutbound(session)
|
||||
v.transport(reader, writer, ray)
|
||||
|
@ -232,12 +239,11 @@ func (v *Server) handlePlainHTTP(request *http.Request, session *proxy.SessionIn
|
|||
StripHopByHopHeaders(request)
|
||||
|
||||
ray := v.packetDispatcher.DispatchToOutbound(session)
|
||||
defer ray.InboundInput().Close()
|
||||
defer ray.InboundOutput().Release()
|
||||
|
||||
var finish sync.WaitGroup
|
||||
finish.Add(1)
|
||||
go func() {
|
||||
defer ray.InboundInput().Close()
|
||||
defer finish.Done()
|
||||
requestWriter := bufio.NewWriter(buf.NewBytesWriter(ray.InboundInput()))
|
||||
err := request.Write(requestWriter)
|
||||
|
@ -250,6 +256,7 @@ func (v *Server) handlePlainHTTP(request *http.Request, session *proxy.SessionIn
|
|||
|
||||
finish.Add(1)
|
||||
go func() {
|
||||
defer ray.InboundOutput().Release()
|
||||
defer finish.Done()
|
||||
responseReader := bufio.OriginalReader(buf.NewBytesReader(ray.InboundOutput()))
|
||||
response, err := http.ReadResponse(responseReader, request)
|
||||
|
@ -265,17 +272,21 @@ func (v *Server) handlePlainHTTP(request *http.Request, session *proxy.SessionIn
|
|||
}
|
||||
responseWriter.Flush()
|
||||
}()
|
||||
|
||||
finish.Wait()
|
||||
}
|
||||
|
||||
// ServerFactory is a InboundHandlerFactory.
|
||||
type ServerFactory struct{}
|
||||
|
||||
// StreamCapability implements InboundHandlerFactory.StreamCapability().
|
||||
func (v *ServerFactory) StreamCapability() v2net.NetworkList {
|
||||
return v2net.NetworkList{
|
||||
Network: []v2net.Network{v2net.Network_RawTCP},
|
||||
}
|
||||
}
|
||||
|
||||
// Create implements InboundHandlerFactory.Create().
|
||||
func (v *ServerFactory) Create(space app.Space, rawConfig interface{}, meta *proxy.InboundHandlerMeta) (proxy.InboundHandler, error) {
|
||||
if !space.HasApp(dispatcher.APP_ID) {
|
||||
return nil, common.ErrBadConfiguration
|
||||
|
|
Loading…
Reference in New Issue