mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-18 07:17:32 -05:00
change status to option
This commit is contained in:
parent
076f385e4b
commit
79c1087311
@ -15,11 +15,11 @@ const (
|
|||||||
SessionStatusKeep SessionStatus = 0x02
|
SessionStatusKeep SessionStatus = 0x02
|
||||||
SessionStatusEnd SessionStatus = 0x03
|
SessionStatusEnd SessionStatus = 0x03
|
||||||
SessionStatusKeepAlive SessionStatus = 0x04
|
SessionStatusKeepAlive SessionStatus = 0x04
|
||||||
SessionStatusError SessionStatus = 0x05
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
OptionData bitmask.Byte = 0x01
|
OptionData bitmask.Byte = 0x01
|
||||||
|
OptionError bitmask.Byte = 0x02
|
||||||
)
|
)
|
||||||
|
|
||||||
type TargetNetwork byte
|
type TargetNetwork byte
|
||||||
|
@ -10,8 +10,10 @@ import (
|
|||||||
|
|
||||||
"v2ray.com/core"
|
"v2ray.com/core"
|
||||||
"v2ray.com/core/app/proxyman"
|
"v2ray.com/core/app/proxyman"
|
||||||
|
"v2ray.com/core/common"
|
||||||
"v2ray.com/core/common/buf"
|
"v2ray.com/core/common/buf"
|
||||||
"v2ray.com/core/common/errors"
|
"v2ray.com/core/common/errors"
|
||||||
|
"v2ray.com/core/common/log"
|
||||||
"v2ray.com/core/common/net"
|
"v2ray.com/core/common/net"
|
||||||
"v2ray.com/core/common/protocol"
|
"v2ray.com/core/common/protocol"
|
||||||
"v2ray.com/core/common/signal"
|
"v2ray.com/core/common/signal"
|
||||||
@ -131,7 +133,7 @@ func (m *Client) monitor() {
|
|||||||
case <-timer.C:
|
case <-timer.C:
|
||||||
size := m.sessionManager.Size()
|
size := m.sessionManager.Size()
|
||||||
if size == 0 && m.sessionManager.CloseIfNoSession() {
|
if size == 0 && m.sessionManager.CloseIfNoSession() {
|
||||||
m.done.Close()
|
common.Must(m.done.Close())
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -151,10 +153,10 @@ func fetchInput(ctx context.Context, s *Session, output buf.Writer) {
|
|||||||
newError("dispatching request to ", dest).WithContext(ctx).WriteToLog()
|
newError("dispatching request to ", dest).WithContext(ctx).WriteToLog()
|
||||||
if err := buf.Copy(s.input, writer); err != nil {
|
if err := buf.Copy(s.input, writer); err != nil {
|
||||||
newError("failed to fetch all input").Base(err).WithContext(ctx).WriteToLog()
|
newError("failed to fetch all input").Base(err).WithContext(ctx).WriteToLog()
|
||||||
writer.Error()
|
writer.hasError = true
|
||||||
} else {
|
|
||||||
writer.Close()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writer.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Client) Dispatch(ctx context.Context, outboundRay ray.OutboundRay) bool {
|
func (m *Client) Dispatch(ctx context.Context, outboundRay ray.OutboundRay) bool {
|
||||||
@ -208,18 +210,10 @@ func (m *Client) handleStatusKeep(meta *FrameMetadata, reader *buf.BufferedReade
|
|||||||
|
|
||||||
func (m *Client) handleStatusEnd(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
func (m *Client) handleStatusEnd(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
||||||
if s, found := m.sessionManager.Get(meta.SessionID); found {
|
if s, found := m.sessionManager.Get(meta.SessionID); found {
|
||||||
s.Close()
|
if meta.Option.Has(OptionError) {
|
||||||
}
|
s.input.CloseError()
|
||||||
if meta.Option.Has(OptionData) {
|
s.output.CloseError()
|
||||||
return drain(reader)
|
}
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (m *Client) handleStatusError(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
|
||||||
if s, found := m.sessionManager.Get(meta.SessionID); found {
|
|
||||||
s.output.CloseError()
|
|
||||||
s.input.CloseError()
|
|
||||||
s.Close()
|
s.Close()
|
||||||
}
|
}
|
||||||
if meta.Option.Has(OptionData) {
|
if meta.Option.Has(OptionData) {
|
||||||
@ -251,8 +245,6 @@ func (m *Client) fetchOutput() {
|
|||||||
err = m.handleStatusNew(meta, reader)
|
err = m.handleStatusNew(meta, reader)
|
||||||
case SessionStatusKeep:
|
case SessionStatusKeep:
|
||||||
err = m.handleStatusKeep(meta, reader)
|
err = m.handleStatusKeep(meta, reader)
|
||||||
case SessionStatusError:
|
|
||||||
err = m.handleStatusError(meta, reader)
|
|
||||||
default:
|
default:
|
||||||
newError("unknown status: ", meta.SessionStatus).AtError().WriteToLog()
|
newError("unknown status: ", meta.SessionStatus).AtError().WriteToLog()
|
||||||
return
|
return
|
||||||
@ -310,10 +302,10 @@ func handle(ctx context.Context, s *Session, output buf.Writer) {
|
|||||||
writer := NewResponseWriter(s.ID, output, s.transferType)
|
writer := NewResponseWriter(s.ID, output, s.transferType)
|
||||||
if err := buf.Copy(s.input, writer); err != nil {
|
if err := buf.Copy(s.input, writer); err != nil {
|
||||||
newError("session ", s.ID, " ends.").Base(err).WithContext(ctx).WriteToLog()
|
newError("session ", s.ID, " ends.").Base(err).WithContext(ctx).WriteToLog()
|
||||||
writer.Error()
|
writer.hasError = true
|
||||||
} else {
|
|
||||||
writer.Close()
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
writer.Close()
|
||||||
s.Close()
|
s.Close()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -326,6 +318,17 @@ func (w *ServerWorker) handleStatusKeepAlive(meta *FrameMetadata, reader *buf.Bu
|
|||||||
|
|
||||||
func (w *ServerWorker) handleStatusNew(ctx context.Context, meta *FrameMetadata, reader *buf.BufferedReader) error {
|
func (w *ServerWorker) handleStatusNew(ctx context.Context, meta *FrameMetadata, reader *buf.BufferedReader) error {
|
||||||
newError("received request for ", meta.Target).WithContext(ctx).WriteToLog()
|
newError("received request for ", meta.Target).WithContext(ctx).WriteToLog()
|
||||||
|
{
|
||||||
|
msg := &log.AccessMessage{
|
||||||
|
To: meta.Target,
|
||||||
|
Status: log.AccessAccepted,
|
||||||
|
Reason: "",
|
||||||
|
}
|
||||||
|
if src, f := proxy.SourceFromContext(ctx); f {
|
||||||
|
msg.From = src
|
||||||
|
}
|
||||||
|
log.Record(msg)
|
||||||
|
}
|
||||||
inboundRay, err := w.dispatcher.Dispatch(ctx, meta.Target)
|
inboundRay, err := w.dispatcher.Dispatch(ctx, meta.Target)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
if meta.Option.Has(OptionData) {
|
if meta.Option.Has(OptionData) {
|
||||||
@ -363,18 +366,10 @@ func (w *ServerWorker) handleStatusKeep(meta *FrameMetadata, reader *buf.Buffere
|
|||||||
|
|
||||||
func (w *ServerWorker) handleStatusEnd(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
func (w *ServerWorker) handleStatusEnd(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
||||||
if s, found := w.sessionManager.Get(meta.SessionID); found {
|
if s, found := w.sessionManager.Get(meta.SessionID); found {
|
||||||
s.Close()
|
if meta.Option.Has(OptionError) {
|
||||||
}
|
s.input.CloseError()
|
||||||
if meta.Option.Has(OptionData) {
|
s.output.CloseError()
|
||||||
return drain(reader)
|
}
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (w *ServerWorker) handleStatusError(meta *FrameMetadata, reader *buf.BufferedReader) error {
|
|
||||||
if s, found := w.sessionManager.Get(meta.SessionID); found {
|
|
||||||
s.input.CloseError()
|
|
||||||
s.output.CloseError()
|
|
||||||
s.Close()
|
s.Close()
|
||||||
}
|
}
|
||||||
if meta.Option.Has(OptionData) {
|
if meta.Option.Has(OptionData) {
|
||||||
@ -398,8 +393,6 @@ func (w *ServerWorker) handleFrame(ctx context.Context, reader *buf.BufferedRead
|
|||||||
err = w.handleStatusNew(ctx, meta, reader)
|
err = w.handleStatusNew(ctx, meta, reader)
|
||||||
case SessionStatusKeep:
|
case SessionStatusKeep:
|
||||||
err = w.handleStatusKeep(meta, reader)
|
err = w.handleStatusKeep(meta, reader)
|
||||||
case SessionStatusError:
|
|
||||||
err = w.handleStatusError(meta, reader)
|
|
||||||
default:
|
default:
|
||||||
return newError("unknown status: ", meta.SessionStatus).AtError()
|
return newError("unknown status: ", meta.SessionStatus).AtError()
|
||||||
}
|
}
|
||||||
|
@ -13,6 +13,7 @@ type Writer struct {
|
|||||||
writer buf.Writer
|
writer buf.Writer
|
||||||
id uint16
|
id uint16
|
||||||
followup bool
|
followup bool
|
||||||
|
hasError bool
|
||||||
transferType protocol.TransferType
|
transferType protocol.TransferType
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -40,6 +41,7 @@ func (w *Writer) getNextFrameMeta() FrameMetadata {
|
|||||||
SessionID: w.id,
|
SessionID: w.id,
|
||||||
Target: w.dest,
|
Target: w.dest,
|
||||||
}
|
}
|
||||||
|
|
||||||
if w.followup {
|
if w.followup {
|
||||||
meta.SessionStatus = SessionStatusKeep
|
meta.SessionStatus = SessionStatusKeep
|
||||||
} else {
|
} else {
|
||||||
@ -105,18 +107,8 @@ func (w *Writer) Close() error {
|
|||||||
SessionID: w.id,
|
SessionID: w.id,
|
||||||
SessionStatus: SessionStatusEnd,
|
SessionStatus: SessionStatusEnd,
|
||||||
}
|
}
|
||||||
|
if w.hasError {
|
||||||
frame := buf.New()
|
meta.Option.Set(OptionError)
|
||||||
common.Must(meta.WriteTo(frame))
|
|
||||||
|
|
||||||
w.writer.WriteMultiBuffer(buf.NewMultiBufferValue(frame))
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (w *Writer) Error() error {
|
|
||||||
meta := FrameMetadata{
|
|
||||||
SessionID: w.id,
|
|
||||||
SessionStatus: SessionStatusError,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
frame := buf.New()
|
frame := buf.New()
|
||||||
|
Loading…
Reference in New Issue
Block a user