1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- package uot
- import (
- "context"
- "net"
- "net/netip"
- "github.com/sagernet/sing-box/adapter"
- E "github.com/sagernet/sing/common/exceptions"
- "github.com/sagernet/sing/common/logger"
- M "github.com/sagernet/sing/common/metadata"
- N "github.com/sagernet/sing/common/network"
- "github.com/sagernet/sing/common/uot"
- )
- var _ adapter.ConnectionRouterEx = (*Router)(nil)
- type Router struct {
- router adapter.ConnectionRouterEx
- logger logger.ContextLogger
- }
- func NewRouter(router adapter.ConnectionRouterEx, logger logger.ContextLogger) *Router {
- return &Router{router, logger}
- }
- func (r *Router) RouteConnection(ctx context.Context, conn net.Conn, metadata adapter.InboundContext) error {
- switch metadata.Destination.Fqdn {
- case uot.MagicAddress:
- request, err := uot.ReadRequest(conn)
- if err != nil {
- return E.Cause(err, "read UoT request")
- }
- if request.IsConnect {
- r.logger.InfoContext(ctx, "inbound UoT connect connection to ", request.Destination)
- } else {
- r.logger.InfoContext(ctx, "inbound UoT connection to ", request.Destination)
- }
- metadata.Domain = metadata.Destination.Fqdn
- metadata.Destination = request.Destination
- return r.router.RoutePacketConnection(ctx, uot.NewConn(conn, *request), metadata)
- case uot.LegacyMagicAddress:
- r.logger.InfoContext(ctx, "inbound legacy UoT connection")
- metadata.Domain = metadata.Destination.Fqdn
- metadata.Destination = M.Socksaddr{Addr: netip.IPv4Unspecified()}
- return r.RoutePacketConnection(ctx, uot.NewConn(conn, uot.Request{}), metadata)
- }
- return r.router.RouteConnection(ctx, conn, metadata)
- }
- func (r *Router) RoutePacketConnection(ctx context.Context, conn N.PacketConn, metadata adapter.InboundContext) error {
- return r.router.RoutePacketConnection(ctx, conn, metadata)
- }
- func (r *Router) RouteConnectionEx(ctx context.Context, conn net.Conn, metadata adapter.InboundContext, onClose N.CloseHandlerFunc) {
- switch metadata.Destination.Fqdn {
- case uot.MagicAddress:
- request, err := uot.ReadRequest(conn)
- if err != nil {
- err = E.Cause(err, "UoT read request")
- r.logger.ErrorContext(ctx, "process connection from ", metadata.Source, ": ", err)
- N.CloseOnHandshakeFailure(conn, onClose, err)
- return
- }
- if request.IsConnect {
- r.logger.InfoContext(ctx, "inbound UoT connect connection to ", request.Destination)
- } else {
- r.logger.InfoContext(ctx, "inbound UoT connection to ", request.Destination)
- }
- metadata.Domain = metadata.Destination.Fqdn
- metadata.Destination = request.Destination
- r.router.RoutePacketConnectionEx(ctx, uot.NewConn(conn, *request), metadata, onClose)
- return
- case uot.LegacyMagicAddress:
- r.logger.InfoContext(ctx, "inbound legacy UoT connection")
- metadata.Domain = metadata.Destination.Fqdn
- metadata.Destination = M.Socksaddr{Addr: netip.IPv4Unspecified()}
- r.RoutePacketConnectionEx(ctx, uot.NewConn(conn, uot.Request{}), metadata, onClose)
- return
- }
- r.router.RouteConnectionEx(ctx, conn, metadata, onClose)
- }
- func (r *Router) RoutePacketConnectionEx(ctx context.Context, conn N.PacketConn, metadata adapter.InboundContext, onClose N.CloseHandlerFunc) {
- r.router.RoutePacketConnectionEx(ctx, conn, metadata, onClose)
- }
|