|
@@ -86,23 +86,26 @@ func NewShadowTLS(ctx context.Context, router adapter.Router, logger log.Context
|
|
return outbound, nil
|
|
return outbound, nil
|
|
}
|
|
}
|
|
|
|
|
|
-func (s *ShadowTLS) DialContext(ctx context.Context, network string, destination M.Socksaddr) (net.Conn, error) {
|
|
|
|
|
|
+func (h *ShadowTLS) DialContext(ctx context.Context, network string, destination M.Socksaddr) (net.Conn, error) {
|
|
|
|
+ ctx, metadata := adapter.AppendContext(ctx)
|
|
|
|
+ metadata.Outbound = h.tag
|
|
|
|
+ metadata.Destination = destination
|
|
switch N.NetworkName(network) {
|
|
switch N.NetworkName(network) {
|
|
case N.NetworkTCP:
|
|
case N.NetworkTCP:
|
|
- return s.client.DialContext(ctx)
|
|
|
|
|
|
+ return h.client.DialContext(ctx)
|
|
default:
|
|
default:
|
|
return nil, os.ErrInvalid
|
|
return nil, os.ErrInvalid
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
-func (s *ShadowTLS) ListenPacket(ctx context.Context, destination M.Socksaddr) (net.PacketConn, error) {
|
|
|
|
|
|
+func (h *ShadowTLS) ListenPacket(ctx context.Context, destination M.Socksaddr) (net.PacketConn, error) {
|
|
return nil, os.ErrInvalid
|
|
return nil, os.ErrInvalid
|
|
}
|
|
}
|
|
|
|
|
|
-func (s *ShadowTLS) NewConnection(ctx context.Context, conn net.Conn, metadata adapter.InboundContext) error {
|
|
|
|
- return NewConnection(ctx, s, conn, metadata)
|
|
|
|
|
|
+func (h *ShadowTLS) NewConnection(ctx context.Context, conn net.Conn, metadata adapter.InboundContext) error {
|
|
|
|
+ return NewConnection(ctx, h, conn, metadata)
|
|
}
|
|
}
|
|
|
|
|
|
-func (s *ShadowTLS) NewPacketConnection(ctx context.Context, conn N.PacketConn, metadata adapter.InboundContext) error {
|
|
|
|
|
|
+func (h *ShadowTLS) NewPacketConnection(ctx context.Context, conn N.PacketConn, metadata adapter.InboundContext) error {
|
|
return os.ErrInvalid
|
|
return os.ErrInvalid
|
|
}
|
|
}
|