Fix tailscale destination
This commit is contained in:
@@ -456,20 +456,20 @@ func (t *Endpoint) NewPacketConnectionEx(ctx context.Context, conn N.PacketConn,
|
|||||||
metadata.Inbound = t.Tag()
|
metadata.Inbound = t.Tag()
|
||||||
metadata.InboundType = t.Type()
|
metadata.InboundType = t.Type()
|
||||||
metadata.Source = source
|
metadata.Source = source
|
||||||
metadata.Destination = destination
|
|
||||||
addr4, addr6 := t.server.TailscaleIPs()
|
addr4, addr6 := t.server.TailscaleIPs()
|
||||||
switch destination.Addr {
|
switch destination.Addr {
|
||||||
case addr4:
|
case addr4:
|
||||||
metadata.OriginDestination = destination
|
metadata.OriginDestination = destination
|
||||||
destination.Addr = netip.AddrFrom4([4]uint8{127, 0, 0, 1})
|
destination.Addr = netip.AddrFrom4([4]uint8{127, 0, 0, 1})
|
||||||
conn = bufio.NewNATPacketConn(bufio.NewNetPacketConn(conn), metadata.OriginDestination, metadata.Destination)
|
conn = bufio.NewNATPacketConn(bufio.NewNetPacketConn(conn), metadata.OriginDestination, destination)
|
||||||
case addr6:
|
case addr6:
|
||||||
metadata.OriginDestination = destination
|
metadata.OriginDestination = destination
|
||||||
destination.Addr = netip.IPv6Loopback()
|
destination.Addr = netip.IPv6Loopback()
|
||||||
conn = bufio.NewNATPacketConn(bufio.NewNetPacketConn(conn), metadata.OriginDestination, metadata.Destination)
|
conn = bufio.NewNATPacketConn(bufio.NewNetPacketConn(conn), metadata.OriginDestination, destination)
|
||||||
}
|
}
|
||||||
|
metadata.Destination = destination
|
||||||
t.logger.InfoContext(ctx, "inbound packet connection from ", source)
|
t.logger.InfoContext(ctx, "inbound packet connection from ", source)
|
||||||
t.logger.InfoContext(ctx, "inbound packet connection to ", destination)
|
t.logger.InfoContext(ctx, "inbound packet connection to ", metadata.Destination)
|
||||||
t.router.RoutePacketConnectionEx(ctx, conn, metadata, onClose)
|
t.router.RoutePacketConnectionEx(ctx, conn, metadata, onClose)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user