mirror of
https://github.com/MetaCubeX/mihomo.git
synced 2025-01-05 17:13:32 +08:00
chore: replace zhangyunhao116/fastrand to our metacubex/randv2
This commit is contained in:
parent
d3fea909e9
commit
39eda257a7
@ -21,8 +21,8 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/sing-quic/hysteria2"
|
"github.com/metacubex/sing-quic/hysteria2"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
M "github.com/sagernet/sing/common/metadata"
|
M "github.com/sagernet/sing/common/metadata"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -165,7 +165,7 @@ func NewHysteria2(option Hysteria2Option) (*Hysteria2, error) {
|
|||||||
})
|
})
|
||||||
if len(serverAddress) > 0 {
|
if len(serverAddress) > 0 {
|
||||||
clientOptions.ServerAddress = func(ctx context.Context) (*net.UDPAddr, error) {
|
clientOptions.ServerAddress = func(ctx context.Context) (*net.UDPAddr, error) {
|
||||||
return resolveUDPAddrWithPrefer(ctx, "udp", serverAddress[fastrand.Intn(len(serverAddress))], C.NewDNSPrefer(option.IPVersion))
|
return resolveUDPAddrWithPrefer(ctx, "udp", serverAddress[randv2.IntN(len(serverAddress))], C.NewDNSPrefer(option.IPVersion))
|
||||||
}
|
}
|
||||||
|
|
||||||
if option.HopInterval == 0 {
|
if option.HopInterval == 0 {
|
||||||
|
@ -17,7 +17,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/component/proxydialer"
|
"github.com/metacubex/mihomo/component/proxydialer"
|
||||||
C "github.com/metacubex/mihomo/constant"
|
C "github.com/metacubex/mihomo/constant"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
"golang.org/x/crypto/ssh"
|
"golang.org/x/crypto/ssh"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -180,10 +180,10 @@ func NewSsh(option SshOption) (*Ssh, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
version := "SSH-2.0-OpenSSH_"
|
version := "SSH-2.0-OpenSSH_"
|
||||||
if fastrand.Intn(2) == 0 {
|
if randv2.IntN(2) == 0 {
|
||||||
version += "7." + strconv.Itoa(fastrand.Intn(10))
|
version += "7." + strconv.Itoa(randv2.IntN(10))
|
||||||
} else {
|
} else {
|
||||||
version += "8." + strconv.Itoa(fastrand.Intn(9))
|
version += "8." + strconv.Itoa(randv2.IntN(9))
|
||||||
}
|
}
|
||||||
config.ClientVersion = version
|
config.ClientVersion = version
|
||||||
|
|
||||||
|
@ -8,8 +8,8 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/mihomo/common/utils"
|
"github.com/metacubex/mihomo/common/utils"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
"github.com/metacubex/sing-shadowsocks/shadowimpl"
|
"github.com/metacubex/sing-shadowsocks/shadowimpl"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var hostsSuffix = []string{
|
var hostsSuffix = []string{
|
||||||
@ -302,11 +302,11 @@ func RandHost() string {
|
|||||||
prefix += string(buf[6:8]) + "-"
|
prefix += string(buf[6:8]) + "-"
|
||||||
prefix += string(buf[len(buf)-8:])
|
prefix += string(buf[len(buf)-8:])
|
||||||
|
|
||||||
return prefix + hostsSuffix[fastrand.Intn(hostsLen)]
|
return prefix + hostsSuffix[randv2.IntN(hostsLen)]
|
||||||
}
|
}
|
||||||
|
|
||||||
func RandUserAgent() string {
|
func RandUserAgent() string {
|
||||||
return userAgents[fastrand.Intn(uaLen)]
|
return userAgents[randv2.IntN(uaLen)]
|
||||||
}
|
}
|
||||||
|
|
||||||
func SetUserAgent(header http.Header) {
|
func SetUserAgent(header http.Header) {
|
||||||
|
@ -3,8 +3,8 @@ package pool
|
|||||||
import (
|
import (
|
||||||
"testing"
|
"testing"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
"github.com/stretchr/testify/assert"
|
"github.com/stretchr/testify/assert"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestAllocGet(t *testing.T) {
|
func TestAllocGet(t *testing.T) {
|
||||||
@ -43,6 +43,6 @@ func TestAllocPutThenGet(t *testing.T) {
|
|||||||
|
|
||||||
func BenchmarkMSB(b *testing.B) {
|
func BenchmarkMSB(b *testing.B) {
|
||||||
for i := 0; i < b.N; i++ {
|
for i := 0; i < b.N; i++ {
|
||||||
msb(fastrand.Int())
|
msb(randv2.Int())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2,19 +2,39 @@ package utils
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"github.com/gofrs/uuid/v5"
|
"github.com/gofrs/uuid/v5"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type fastRandReader struct{}
|
type unsafeRandReader struct{}
|
||||||
|
|
||||||
func (r fastRandReader) Read(p []byte) (int, error) {
|
func (r unsafeRandReader) Read(p []byte) (n int, err error) {
|
||||||
return fastrand.Read(p)
|
// modify from https://github.com/golang/go/blob/587c3847da81aa7cfc3b3db2677c8586c94df13a/src/runtime/rand.go#L70-L89
|
||||||
|
// Inspired by wyrand.
|
||||||
|
n = len(p)
|
||||||
|
v := randv2.Uint64()
|
||||||
|
for len(p) > 0 {
|
||||||
|
v ^= 0xa0761d6478bd642f
|
||||||
|
v *= 0xe7037ed1a0b428db
|
||||||
|
size := 8
|
||||||
|
if len(p) < 8 {
|
||||||
|
size = len(p)
|
||||||
|
}
|
||||||
|
for i := 0; i < size; i++ {
|
||||||
|
p[i] ^= byte(v >> (8 * i))
|
||||||
|
}
|
||||||
|
p = p[size:]
|
||||||
|
v = v>>32 | v<<32
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
var UnsafeUUIDGenerator = uuid.NewGenWithOptions(uuid.WithRandomReader(fastRandReader{}))
|
var UnsafeRandReader = unsafeRandReader{}
|
||||||
|
|
||||||
|
var UnsafeUUIDGenerator = uuid.NewGenWithOptions(uuid.WithRandomReader(UnsafeRandReader))
|
||||||
|
|
||||||
func NewUUIDV1() uuid.UUID {
|
func NewUUIDV1() uuid.UUID {
|
||||||
u, _ := UnsafeUUIDGenerator.NewV1() // fastrand.Read wouldn't cause error, so ignore err is safe
|
u, _ := UnsafeUUIDGenerator.NewV1() // unsafeRandReader wouldn't cause error, so ignore err is safe
|
||||||
return u
|
return u
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -23,7 +43,7 @@ func NewUUIDV3(ns uuid.UUID, name string) uuid.UUID {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewUUIDV4() uuid.UUID {
|
func NewUUIDV4() uuid.UUID {
|
||||||
u, _ := UnsafeUUIDGenerator.NewV4() // fastrand.Read wouldn't cause error, so ignore err is safe
|
u, _ := UnsafeUUIDGenerator.NewV4() // unsafeRandReader wouldn't cause error, so ignore err is safe
|
||||||
return u
|
return u
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -32,12 +52,12 @@ func NewUUIDV5(ns uuid.UUID, name string) uuid.UUID {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func NewUUIDV6() uuid.UUID {
|
func NewUUIDV6() uuid.UUID {
|
||||||
u, _ := UnsafeUUIDGenerator.NewV6() // fastrand.Read wouldn't cause error, so ignore err is safe
|
u, _ := UnsafeUUIDGenerator.NewV6() // unsafeRandReader wouldn't cause error, so ignore err is safe
|
||||||
return u
|
return u
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewUUIDV7() uuid.UUID {
|
func NewUUIDV7() uuid.UUID {
|
||||||
u, _ := UnsafeUUIDGenerator.NewV7() // fastrand.Read wouldn't cause error, so ignore err is safe
|
u, _ := UnsafeUUIDGenerator.NewV7() // unsafeRandReader wouldn't cause error, so ignore err is safe
|
||||||
return u
|
return u
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/common/utils"
|
"github.com/metacubex/mihomo/common/utils"
|
||||||
"github.com/metacubex/mihomo/component/resolver/hosts"
|
"github.com/metacubex/mihomo/component/resolver/hosts"
|
||||||
"github.com/metacubex/mihomo/component/trie"
|
"github.com/metacubex/mihomo/component/trie"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -125,5 +125,5 @@ func (hv HostValue) RandIP() (netip.Addr, error) {
|
|||||||
if hv.IsDomain {
|
if hv.IsDomain {
|
||||||
return netip.Addr{}, errors.New("value type is error")
|
return netip.Addr{}, errors.New("value type is error")
|
||||||
}
|
}
|
||||||
return hv.IPs[fastrand.Intn(len(hv.IPs))], nil
|
return hv.IPs[randv2.IntN(len(hv.IPs))], nil
|
||||||
}
|
}
|
||||||
|
@ -12,8 +12,8 @@ import (
|
|||||||
"github.com/metacubex/mihomo/common/utils"
|
"github.com/metacubex/mihomo/common/utils"
|
||||||
"github.com/metacubex/mihomo/component/trie"
|
"github.com/metacubex/mihomo/component/trie"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
"github.com/miekg/dns"
|
"github.com/miekg/dns"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -93,7 +93,7 @@ func ResolveIPv4WithResolver(ctx context.Context, host string, r Resolver) (neti
|
|||||||
} else if len(ips) == 0 {
|
} else if len(ips) == 0 {
|
||||||
return netip.Addr{}, fmt.Errorf("%w: %s", ErrIPNotFound, host)
|
return netip.Addr{}, fmt.Errorf("%w: %s", ErrIPNotFound, host)
|
||||||
}
|
}
|
||||||
return ips[fastrand.Intn(len(ips))], nil
|
return ips[randv2.IntN(len(ips))], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ResolveIPv4 with a host, return ipv4
|
// ResolveIPv4 with a host, return ipv4
|
||||||
@ -149,7 +149,7 @@ func ResolveIPv6WithResolver(ctx context.Context, host string, r Resolver) (neti
|
|||||||
} else if len(ips) == 0 {
|
} else if len(ips) == 0 {
|
||||||
return netip.Addr{}, fmt.Errorf("%w: %s", ErrIPNotFound, host)
|
return netip.Addr{}, fmt.Errorf("%w: %s", ErrIPNotFound, host)
|
||||||
}
|
}
|
||||||
return ips[fastrand.Intn(len(ips))], nil
|
return ips[randv2.IntN(len(ips))], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func ResolveIPv6(ctx context.Context, host string) (netip.Addr, error) {
|
func ResolveIPv6(ctx context.Context, host string) (netip.Addr, error) {
|
||||||
@ -200,9 +200,9 @@ func ResolveIPWithResolver(ctx context.Context, host string, r Resolver) (netip.
|
|||||||
}
|
}
|
||||||
ipv4s, ipv6s := SortationAddr(ips)
|
ipv4s, ipv6s := SortationAddr(ips)
|
||||||
if len(ipv4s) > 0 {
|
if len(ipv4s) > 0 {
|
||||||
return ipv4s[fastrand.Intn(len(ipv4s))], nil
|
return ipv4s[randv2.IntN(len(ipv4s))], nil
|
||||||
}
|
}
|
||||||
return ipv6s[fastrand.Intn(len(ipv6s))], nil
|
return ipv6s[randv2.IntN(len(ipv6s))], nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// ResolveIP with a host, return ip and priority return TypeA
|
// ResolveIP with a host, return ip and priority return TypeA
|
||||||
|
@ -22,8 +22,8 @@ import (
|
|||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
"github.com/metacubex/mihomo/ntp"
|
"github.com/metacubex/mihomo/ntp"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
utls "github.com/metacubex/utls"
|
utls "github.com/metacubex/utls"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
"golang.org/x/crypto/chacha20poly1305"
|
"golang.org/x/crypto/chacha20poly1305"
|
||||||
"golang.org/x/crypto/hkdf"
|
"golang.org/x/crypto/hkdf"
|
||||||
"golang.org/x/net/http2"
|
"golang.org/x/net/http2"
|
||||||
@ -138,13 +138,13 @@ func realityClientFallback(uConn net.Conn, serverName string, fingerprint utls.C
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
request.Header.Set("User-Agent", fingerprint.Client)
|
request.Header.Set("User-Agent", fingerprint.Client)
|
||||||
request.AddCookie(&http.Cookie{Name: "padding", Value: strings.Repeat("0", fastrand.Intn(32)+30)})
|
request.AddCookie(&http.Cookie{Name: "padding", Value: strings.Repeat("0", randv2.IntN(32)+30)})
|
||||||
response, err := client.Do(request)
|
response, err := client.Do(request)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
//_, _ = io.Copy(io.Discard, response.Body)
|
//_, _ = io.Copy(io.Discard, response.Body)
|
||||||
time.Sleep(time.Duration(5+fastrand.Int63n(10)) * time.Second)
|
time.Sleep(time.Duration(5+randv2.IntN(10)) * time.Second)
|
||||||
response.Body.Close()
|
response.Body.Close()
|
||||||
client.CloseIdleConnections()
|
client.CloseIdleConnections()
|
||||||
}
|
}
|
||||||
|
@ -14,8 +14,8 @@ import (
|
|||||||
C "github.com/metacubex/mihomo/constant"
|
C "github.com/metacubex/mihomo/constant"
|
||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
|
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
D "github.com/miekg/dns"
|
D "github.com/miekg/dns"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
@ -65,7 +65,7 @@ func (c *client) ExchangeContext(ctx context.Context, m *D.Msg) (*D.Msg, error)
|
|||||||
} else if len(ips) == 0 {
|
} else if len(ips) == 0 {
|
||||||
return nil, fmt.Errorf("%w: %s", resolver.ErrIPNotFound, c.host)
|
return nil, fmt.Errorf("%w: %s", resolver.ErrIPNotFound, c.host)
|
||||||
}
|
}
|
||||||
ip = ips[fastrand.Intn(len(ips))]
|
ip = ips[randv2.IntN(len(ips))]
|
||||||
}
|
}
|
||||||
|
|
||||||
network := "udp"
|
network := "udp"
|
||||||
|
2
go.mod
2
go.mod
@ -20,6 +20,7 @@ require (
|
|||||||
github.com/mdlayher/netlink v1.7.2
|
github.com/mdlayher/netlink v1.7.2
|
||||||
github.com/metacubex/gopacket v1.1.20-0.20230608035415-7e2f98a3e759
|
github.com/metacubex/gopacket v1.1.20-0.20230608035415-7e2f98a3e759
|
||||||
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22
|
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22
|
||||||
|
github.com/metacubex/randv2 v0.2.0
|
||||||
github.com/metacubex/sing-quic v0.0.0-20240518034124-7696d3f7da72
|
github.com/metacubex/sing-quic v0.0.0-20240518034124-7696d3f7da72
|
||||||
github.com/metacubex/sing-shadowsocks v0.2.6
|
github.com/metacubex/sing-shadowsocks v0.2.6
|
||||||
github.com/metacubex/sing-shadowsocks2 v0.2.0
|
github.com/metacubex/sing-shadowsocks2 v0.2.0
|
||||||
@ -44,7 +45,6 @@ require (
|
|||||||
github.com/sirupsen/logrus v1.9.3
|
github.com/sirupsen/logrus v1.9.3
|
||||||
github.com/stretchr/testify v1.9.0
|
github.com/stretchr/testify v1.9.0
|
||||||
github.com/wk8/go-ordered-map/v2 v2.1.8
|
github.com/wk8/go-ordered-map/v2 v2.1.8
|
||||||
github.com/zhangyunhao116/fastrand v0.4.0
|
|
||||||
go.uber.org/automaxprocs v1.5.3
|
go.uber.org/automaxprocs v1.5.3
|
||||||
go4.org/netipx v0.0.0-20231129151722-fdeea329fbba
|
go4.org/netipx v0.0.0-20231129151722-fdeea329fbba
|
||||||
golang.org/x/crypto v0.23.0
|
golang.org/x/crypto v0.23.0
|
||||||
|
4
go.sum
4
go.sum
@ -106,6 +106,8 @@ github.com/metacubex/gvisor v0.0.0-20240320004321-933faba989ec h1:HxreOiFTUrJXJa
|
|||||||
github.com/metacubex/gvisor v0.0.0-20240320004321-933faba989ec/go.mod h1:8BVmQ+3cxjqzWElafm24rb2Ae4jRI6vAXNXWqWjfrXw=
|
github.com/metacubex/gvisor v0.0.0-20240320004321-933faba989ec/go.mod h1:8BVmQ+3cxjqzWElafm24rb2Ae4jRI6vAXNXWqWjfrXw=
|
||||||
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22 h1:hsQ0b2A509b6ubnLtLOcUgZ8vOb+d/667zVEJ1T2fao=
|
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22 h1:hsQ0b2A509b6ubnLtLOcUgZ8vOb+d/667zVEJ1T2fao=
|
||||||
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22/go.mod h1:88wAATpevav4xdy5N8oejQ2cbbI6EcLYEklFeo+qywA=
|
github.com/metacubex/quic-go v0.44.1-0.20240521004242-fcd70d587e22/go.mod h1:88wAATpevav4xdy5N8oejQ2cbbI6EcLYEklFeo+qywA=
|
||||||
|
github.com/metacubex/randv2 v0.2.0 h1:uP38uBvV2SxYfLj53kuvAjbND4RUDfFJjwr4UigMiLs=
|
||||||
|
github.com/metacubex/randv2 v0.2.0/go.mod h1:kFi2SzrQ5WuneuoLLCMkABtiBu6VRrMrWFqSPyj2cxY=
|
||||||
github.com/metacubex/sing v0.0.0-20240518125217-e63d65a914d1 h1:7hDHLTmjgtRoAp59STwPQpe5Pinwi4cWex+FB3Ohvco=
|
github.com/metacubex/sing v0.0.0-20240518125217-e63d65a914d1 h1:7hDHLTmjgtRoAp59STwPQpe5Pinwi4cWex+FB3Ohvco=
|
||||||
github.com/metacubex/sing v0.0.0-20240518125217-e63d65a914d1/go.mod h1:+60H3Cm91RnL9dpVGWDPHt0zTQImO9Vfqt9a4rSambI=
|
github.com/metacubex/sing v0.0.0-20240518125217-e63d65a914d1/go.mod h1:+60H3Cm91RnL9dpVGWDPHt0zTQImO9Vfqt9a4rSambI=
|
||||||
github.com/metacubex/sing-quic v0.0.0-20240518034124-7696d3f7da72 h1:Wr4g1HCb5Z/QIFwFiVNjO2qL+dRu25+Mdn9xtAZZ+ew=
|
github.com/metacubex/sing-quic v0.0.0-20240518034124-7696d3f7da72 h1:Wr4g1HCb5Z/QIFwFiVNjO2qL+dRu25+Mdn9xtAZZ+ew=
|
||||||
@ -210,8 +212,6 @@ github.com/wk8/go-ordered-map/v2 v2.1.8 h1:5h/BUHu93oj4gIdvHHHGsScSTMijfx5PeYkE/
|
|||||||
github.com/wk8/go-ordered-map/v2 v2.1.8/go.mod h1:5nJHM5DyteebpVlHnWMV0rPz6Zp7+xBAnxjb1X5vnTw=
|
github.com/wk8/go-ordered-map/v2 v2.1.8/go.mod h1:5nJHM5DyteebpVlHnWMV0rPz6Zp7+xBAnxjb1X5vnTw=
|
||||||
github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0=
|
github.com/yusufpapurcu/wmi v1.2.4 h1:zFUKzehAFReQwLys1b/iSMl+JQGSCSjtVqQn9bBrPo0=
|
||||||
github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0=
|
github.com/yusufpapurcu/wmi v1.2.4/go.mod h1:SBZ9tNy3G9/m5Oi98Zks0QjeHVDvuK0qfxQmPyzfmi0=
|
||||||
github.com/zhangyunhao116/fastrand v0.4.0 h1:86QB6Y+GGgLZRFRDCjMmAS28QULwspK9sgL5d1Bx3H4=
|
|
||||||
github.com/zhangyunhao116/fastrand v0.4.0/go.mod h1:vIyo6EyBhjGKpZv6qVlkPl4JVAklpMM4DSKzbAkMguA=
|
|
||||||
gitlab.com/yawning/bsaes.git v0.0.0-20190805113838-0a714cd429ec h1:FpfFs4EhNehiVfzQttTuxanPIT43FtkkCFypIod8LHo=
|
gitlab.com/yawning/bsaes.git v0.0.0-20190805113838-0a714cd429ec h1:FpfFs4EhNehiVfzQttTuxanPIT43FtkkCFypIod8LHo=
|
||||||
gitlab.com/yawning/bsaes.git v0.0.0-20190805113838-0a714cd429ec/go.mod h1:BZ1RAoRPbCxum9Grlv5aeksu2H8BiKehBYooU2LFiOQ=
|
gitlab.com/yawning/bsaes.git v0.0.0-20190805113838-0a714cd429ec/go.mod h1:BZ1RAoRPbCxum9Grlv5aeksu2H8BiKehBYooU2LFiOQ=
|
||||||
go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8=
|
go.uber.org/automaxprocs v1.5.3 h1:kWazyxZUrS3Gs4qUpbwo5kEIMGe/DAvi5Z4tl2NW4j8=
|
||||||
|
@ -12,7 +12,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/transport/hysteria/obfs"
|
"github.com/metacubex/mihomo/transport/hysteria/obfs"
|
||||||
"github.com/metacubex/mihomo/transport/hysteria/utils"
|
"github.com/metacubex/mihomo/transport/hysteria/utils"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -86,7 +86,7 @@ func NewObfsUDPHopClientPacketConn(server string, serverPorts string, hopInterva
|
|||||||
serverAddrs: serverAddrs,
|
serverAddrs: serverAddrs,
|
||||||
hopInterval: hopInterval,
|
hopInterval: hopInterval,
|
||||||
obfs: obfs,
|
obfs: obfs,
|
||||||
addrIndex: fastrand.Intn(len(serverAddrs)),
|
addrIndex: randv2.IntN(len(serverAddrs)),
|
||||||
recvQueue: make(chan *udpPacket, packetQueueSize),
|
recvQueue: make(chan *udpPacket, packetQueueSize),
|
||||||
closeChan: make(chan struct{}),
|
closeChan: make(chan struct{}),
|
||||||
bufPool: sync.Pool{
|
bufPool: sync.Pool{
|
||||||
@ -177,7 +177,7 @@ func (c *ObfsUDPHopClientPacketConn) hop(dialer utils.PacketDialer, rAddr net.Ad
|
|||||||
_ = trySetPacketConnWriteBuffer(c.currentConn, c.writeBufferSize)
|
_ = trySetPacketConnWriteBuffer(c.currentConn, c.writeBufferSize)
|
||||||
}
|
}
|
||||||
go c.recvRoutine(c.currentConn)
|
go c.recvRoutine(c.currentConn)
|
||||||
c.addrIndex = fastrand.Intn(len(c.serverAddrs))
|
c.addrIndex = randv2.IntN(len(c.serverAddrs))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ObfsUDPHopClientPacketConn) ReadFrom(b []byte) (int, net.Addr, error) {
|
func (c *ObfsUDPHopClientPacketConn) ReadFrom(b []byte) (int, net.Addr, error) {
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
"github.com/metacubex/mihomo/transport/hysteria/obfs"
|
"github.com/metacubex/mihomo/transport/hysteria/obfs"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
const udpBufferSize = 65535
|
const udpBufferSize = 65535
|
||||||
@ -31,7 +31,7 @@ func NewObfsWeChatUDPConn(orig net.PacketConn, obfs obfs.Obfuscator) *ObfsWeChat
|
|||||||
obfs: obfs,
|
obfs: obfs,
|
||||||
readBuf: make([]byte, udpBufferSize),
|
readBuf: make([]byte, udpBufferSize),
|
||||||
writeBuf: make([]byte, udpBufferSize),
|
writeBuf: make([]byte, udpBufferSize),
|
||||||
sn: fastrand.Uint32() & 0xFFFF,
|
sn: randv2.Uint32() & 0xFFFF,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@ import (
|
|||||||
"github.com/lunixbochs/struc"
|
"github.com/lunixbochs/struc"
|
||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
"github.com/metacubex/quic-go/congestion"
|
"github.com/metacubex/quic-go/congestion"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -405,7 +405,7 @@ func (c *quicPktConn) WriteTo(p []byte, addr string) error {
|
|||||||
var errSize *quic.DatagramTooLargeError
|
var errSize *quic.DatagramTooLargeError
|
||||||
if errors.As(err, &errSize) {
|
if errors.As(err, &errSize) {
|
||||||
// need to frag
|
// need to frag
|
||||||
msg.MsgID = uint16(fastrand.Intn(0xFFFF)) + 1 // msgID must be > 0 when fragCount > 1
|
msg.MsgID = uint16(randv2.IntN(0xFFFF)) + 1 // msgID must be > 0 when fragCount > 1
|
||||||
fragMsgs := fragUDPMessage(msg, int(errSize.MaxDatagramPayloadSize))
|
fragMsgs := fragUDPMessage(msg, int(errSize.MaxDatagramPayloadSize))
|
||||||
for _, fragMsg := range fragMsgs {
|
for _, fragMsg := range fragMsgs {
|
||||||
msgBuf.Reset()
|
msgBuf.Reset()
|
||||||
|
@ -1,9 +1,8 @@
|
|||||||
package obfs
|
package obfs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/rand"
|
||||||
"crypto/sha256"
|
"crypto/sha256"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
// [salt][obfuscated payload]
|
// [salt][obfuscated payload]
|
||||||
@ -35,7 +34,7 @@ func (x *XPlusObfuscator) Deobfuscate(in []byte, out []byte) int {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (x *XPlusObfuscator) Obfuscate(in []byte, out []byte) int {
|
func (x *XPlusObfuscator) Obfuscate(in []byte, out []byte) int {
|
||||||
_, _ = fastrand.Read(out[:saltLen]) // salt
|
_, _ = rand.Read(out[:saltLen]) // salt
|
||||||
// Obfuscate the payload
|
// Obfuscate the payload
|
||||||
key := sha256.Sum256(append(x.Key, out[:saltLen]...))
|
key := sha256.Sum256(append(x.Key, out[:saltLen]...))
|
||||||
for i, c := range in {
|
for i, c := range in {
|
||||||
|
@ -2,6 +2,7 @@ package obfs
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"crypto/rand"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
@ -10,7 +11,7 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
// HTTPObfs is shadowsocks http simple-obfs implementation
|
// HTTPObfs is shadowsocks http simple-obfs implementation
|
||||||
@ -64,12 +65,12 @@ func (ho *HTTPObfs) Read(b []byte) (int, error) {
|
|||||||
func (ho *HTTPObfs) Write(b []byte) (int, error) {
|
func (ho *HTTPObfs) Write(b []byte) (int, error) {
|
||||||
if ho.firstRequest {
|
if ho.firstRequest {
|
||||||
randBytes := make([]byte, 16)
|
randBytes := make([]byte, 16)
|
||||||
fastrand.Read(randBytes)
|
rand.Read(randBytes)
|
||||||
req, err := http.NewRequest("GET", fmt.Sprintf("http://%s/", ho.host), bytes.NewBuffer(b[:]))
|
req, err := http.NewRequest("GET", fmt.Sprintf("http://%s/", ho.host), bytes.NewBuffer(b[:]))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
req.Header.Set("User-Agent", fmt.Sprintf("curl/7.%d.%d", fastrand.Int()%54, fastrand.Int()%2))
|
req.Header.Set("User-Agent", fmt.Sprintf("curl/7.%d.%d", randv2.Int()%54, randv2.Int()%2))
|
||||||
req.Header.Set("Upgrade", "websocket")
|
req.Header.Set("Upgrade", "websocket")
|
||||||
req.Header.Set("Connection", "Upgrade")
|
req.Header.Set("Connection", "Upgrade")
|
||||||
req.Host = ho.host
|
req.Host = ho.host
|
||||||
|
@ -2,14 +2,13 @@ package obfs
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"crypto/rand"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"io"
|
"io"
|
||||||
"net"
|
"net"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -127,8 +126,8 @@ func NewTLSObfs(conn net.Conn, server string) net.Conn {
|
|||||||
func makeClientHelloMsg(data []byte, server string) []byte {
|
func makeClientHelloMsg(data []byte, server string) []byte {
|
||||||
random := make([]byte, 28)
|
random := make([]byte, 28)
|
||||||
sessionID := make([]byte, 32)
|
sessionID := make([]byte, 32)
|
||||||
fastrand.Read(random)
|
rand.Read(random)
|
||||||
fastrand.Read(sessionID)
|
rand.Read(sessionID)
|
||||||
|
|
||||||
buf := &bytes.Buffer{}
|
buf := &bytes.Buffer{}
|
||||||
|
|
||||||
|
@ -10,7 +10,7 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -82,7 +82,7 @@ func (c *httpConn) Write(b []byte) (int, error) {
|
|||||||
bLength := len(b)
|
bLength := len(b)
|
||||||
headDataLength := bLength
|
headDataLength := bLength
|
||||||
if bLength-headLength > 64 {
|
if bLength-headLength > 64 {
|
||||||
headDataLength = headLength + fastrand.Intn(65)
|
headDataLength = headLength + randv2.IntN(65)
|
||||||
}
|
}
|
||||||
headData := b[:headDataLength]
|
headData := b[:headDataLength]
|
||||||
b = b[headDataLength:]
|
b = b[headDataLength:]
|
||||||
@ -100,7 +100,7 @@ func (c *httpConn) Write(b []byte) (int, error) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
hosts := strings.Split(host, ",")
|
hosts := strings.Split(host, ",")
|
||||||
host = hosts[fastrand.Intn(len(hosts))]
|
host = hosts[randv2.IntN(len(hosts))]
|
||||||
|
|
||||||
buf := pool.GetBuffer()
|
buf := pool.GetBuffer()
|
||||||
defer pool.PutBuffer(buf)
|
defer pool.PutBuffer(buf)
|
||||||
@ -119,7 +119,7 @@ func (c *httpConn) Write(b []byte) (int, error) {
|
|||||||
buf.WriteString(body + "\r\n\r\n")
|
buf.WriteString(body + "\r\n\r\n")
|
||||||
} else {
|
} else {
|
||||||
buf.WriteString("User-Agent: ")
|
buf.WriteString("User-Agent: ")
|
||||||
buf.WriteString(userAgent[fastrand.Intn(len(userAgent))])
|
buf.WriteString(userAgent[randv2.IntN(len(userAgent))])
|
||||||
buf.WriteString("\r\nAccept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\nAccept-Language: en-US,en;q=0.8\r\nAccept-Encoding: gzip, deflate\r\n")
|
buf.WriteString("\r\nAccept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8\r\nAccept-Language: en-US,en;q=0.8\r\nAccept-Encoding: gzip, deflate\r\n")
|
||||||
if c.post {
|
if c.post {
|
||||||
packBoundary(buf)
|
packBoundary(buf)
|
||||||
@ -147,7 +147,7 @@ func packBoundary(buf *bytes.Buffer) {
|
|||||||
buf.WriteString("Content-Type: multipart/form-data; boundary=")
|
buf.WriteString("Content-Type: multipart/form-data; boundary=")
|
||||||
set := "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
|
set := "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
|
||||||
for i := 0; i < 32; i++ {
|
for i := 0; i < 32; i++ {
|
||||||
buf.WriteByte(set[fastrand.Intn(62)])
|
buf.WriteByte(set[randv2.IntN(62)])
|
||||||
}
|
}
|
||||||
buf.WriteString("\r\n")
|
buf.WriteString("\r\n")
|
||||||
}
|
}
|
||||||
|
@ -1,13 +1,14 @@
|
|||||||
package obfs
|
package obfs
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"crypto/rand"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"hash/crc32"
|
"hash/crc32"
|
||||||
"net"
|
"net"
|
||||||
|
|
||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -54,10 +55,10 @@ func (c *randomHeadConn) Write(b []byte) (int, error) {
|
|||||||
c.buf = append(c.buf, b...)
|
c.buf = append(c.buf, b...)
|
||||||
if !c.hasSentHeader {
|
if !c.hasSentHeader {
|
||||||
c.hasSentHeader = true
|
c.hasSentHeader = true
|
||||||
dataLength := fastrand.Intn(96) + 4
|
dataLength := randv2.IntN(96) + 4
|
||||||
buf := pool.Get(dataLength + 4)
|
buf := pool.Get(dataLength + 4)
|
||||||
defer pool.Put(buf)
|
defer pool.Put(buf)
|
||||||
fastrand.Read(buf[:dataLength])
|
rand.Read(buf[:dataLength])
|
||||||
binary.LittleEndian.PutUint32(buf[dataLength:], 0xffffffff-crc32.ChecksumIEEE(buf[:dataLength]))
|
binary.LittleEndian.PutUint32(buf[dataLength:], 0xffffffff-crc32.ChecksumIEEE(buf[:dataLength]))
|
||||||
_, err := c.Conn.Write(buf)
|
_, err := c.Conn.Write(buf)
|
||||||
return len(b), err
|
return len(b), err
|
||||||
|
@ -3,6 +3,7 @@ package obfs
|
|||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"crypto/hmac"
|
"crypto/hmac"
|
||||||
|
"crypto/rand"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
"strings"
|
||||||
@ -11,7 +12,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
"github.com/metacubex/mihomo/transport/ssr/tools"
|
"github.com/metacubex/mihomo/transport/ssr/tools"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -26,7 +27,7 @@ type tls12Ticket struct {
|
|||||||
|
|
||||||
func newTLS12Ticket(b *Base) Obfs {
|
func newTLS12Ticket(b *Base) Obfs {
|
||||||
r := &tls12Ticket{Base: b, authData: &authData{}}
|
r := &tls12Ticket{Base: b, authData: &authData{}}
|
||||||
fastrand.Read(r.clientID[:])
|
rand.Read(r.clientID[:])
|
||||||
return r
|
return r
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -91,7 +92,7 @@ func (c *tls12TicketConn) Write(b []byte) (int, error) {
|
|||||||
buf := pool.GetBuffer()
|
buf := pool.GetBuffer()
|
||||||
defer pool.PutBuffer(buf)
|
defer pool.PutBuffer(buf)
|
||||||
for len(b) > 2048 {
|
for len(b) > 2048 {
|
||||||
size := fastrand.Intn(4096) + 100
|
size := randv2.IntN(4096) + 100
|
||||||
if len(b) < size {
|
if len(b) < size {
|
||||||
size = len(b)
|
size = len(b)
|
||||||
}
|
}
|
||||||
@ -197,7 +198,7 @@ func packSNIData(buf *bytes.Buffer, u string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (c *tls12TicketConn) packTicketBuf(buf *bytes.Buffer, u string) {
|
func (c *tls12TicketConn) packTicketBuf(buf *bytes.Buffer, u string) {
|
||||||
length := 16 * (fastrand.Intn(17) + 8)
|
length := 16 * (randv2.IntN(17) + 8)
|
||||||
buf.Write([]byte{0, 0x23})
|
buf.Write([]byte{0, 0x23})
|
||||||
binary.Write(buf, binary.BigEndian, uint16(length))
|
binary.Write(buf, binary.BigEndian, uint16(length))
|
||||||
tools.AppendRandBytes(buf, length)
|
tools.AppendRandBytes(buf, length)
|
||||||
@ -222,6 +223,6 @@ func (t *tls12Ticket) getHost() string {
|
|||||||
host = ""
|
host = ""
|
||||||
}
|
}
|
||||||
hosts := strings.Split(host, ",")
|
hosts := strings.Split(host, ",")
|
||||||
host = hosts[fastrand.Intn(len(hosts))]
|
host = hosts[randv2.IntN(len(hosts))]
|
||||||
return host
|
return host
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package protocol
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"bytes"
|
"bytes"
|
||||||
|
"crypto/rand"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"math"
|
"math"
|
||||||
"net"
|
"net"
|
||||||
@ -13,7 +14,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
"github.com/metacubex/mihomo/transport/ssr/tools"
|
"github.com/metacubex/mihomo/transport/ssr/tools"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
type (
|
||||||
@ -66,7 +67,7 @@ func (a *authAES128) initUserData() {
|
|||||||
}
|
}
|
||||||
if len(a.userKey) == 0 {
|
if len(a.userKey) == 0 {
|
||||||
a.userKey = a.Key
|
a.userKey = a.Key
|
||||||
fastrand.Read(a.userID[:])
|
rand.Read(a.userID[:])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -200,7 +201,7 @@ func (a *authAES128) packData(poolBuf *bytes.Buffer, data []byte, fullDataLength
|
|||||||
}
|
}
|
||||||
|
|
||||||
func trapezoidRandom(max int, d float64) int {
|
func trapezoidRandom(max int, d float64) int {
|
||||||
base := fastrand.Float64()
|
base := randv2.Float64()
|
||||||
if d-0 > 1e-6 {
|
if d-0 > 1e-6 {
|
||||||
a := 1 - d
|
a := 1 - d
|
||||||
base = (math.Sqrt(a*a+4*d*base) - a) / (2 * d)
|
base = (math.Sqrt(a*a+4*d*base) - a) / (2 * d)
|
||||||
@ -221,10 +222,10 @@ func (a *authAES128) getRandDataLengthForPackData(dataLength, fullDataLength int
|
|||||||
if revLength > -1460 {
|
if revLength > -1460 {
|
||||||
return trapezoidRandom(revLength+1460, -0.3)
|
return trapezoidRandom(revLength+1460, -0.3)
|
||||||
}
|
}
|
||||||
return fastrand.Intn(32)
|
return randv2.IntN(32)
|
||||||
}
|
}
|
||||||
if dataLength > 900 {
|
if dataLength > 900 {
|
||||||
return fastrand.Intn(revLength)
|
return randv2.IntN(revLength)
|
||||||
}
|
}
|
||||||
return trapezoidRandom(revLength, -0.3)
|
return trapezoidRandom(revLength, -0.3)
|
||||||
}
|
}
|
||||||
@ -249,7 +250,7 @@ func (a *authAES128) packAuthData(poolBuf *bytes.Buffer, data []byte) {
|
|||||||
copy(macKey, a.iv)
|
copy(macKey, a.iv)
|
||||||
copy(macKey[len(a.iv):], a.Key)
|
copy(macKey[len(a.iv):], a.Key)
|
||||||
|
|
||||||
poolBuf.WriteByte(byte(fastrand.Intn(256)))
|
poolBuf.WriteByte(byte(randv2.IntN(256)))
|
||||||
poolBuf.Write(a.hmac(macKey, poolBuf.Bytes())[:6])
|
poolBuf.Write(a.hmac(macKey, poolBuf.Bytes())[:6])
|
||||||
poolBuf.Write(a.userID[:])
|
poolBuf.Write(a.userID[:])
|
||||||
err := a.authData.putEncryptedData(poolBuf, a.userKey, [2]int{packedAuthDataLength, randDataLength}, a.salt)
|
err := a.authData.putEncryptedData(poolBuf, a.userKey, [2]int{packedAuthDataLength, randDataLength}, a.salt)
|
||||||
@ -265,9 +266,9 @@ func (a *authAES128) packAuthData(poolBuf *bytes.Buffer, data []byte) {
|
|||||||
|
|
||||||
func (a *authAES128) getRandDataLengthForPackAuthData(size int) int {
|
func (a *authAES128) getRandDataLengthForPackAuthData(size int) int {
|
||||||
if size > 400 {
|
if size > 400 {
|
||||||
return fastrand.Intn(512)
|
return randv2.IntN(512)
|
||||||
}
|
}
|
||||||
return fastrand.Intn(1024)
|
return randv2.IntN(1024)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *authAES128) packRandData(poolBuf *bytes.Buffer, size int) {
|
func (a *authAES128) packRandData(poolBuf *bytes.Buffer, size int) {
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/common/pool"
|
"github.com/metacubex/mihomo/common/pool"
|
||||||
"github.com/metacubex/mihomo/transport/ssr/tools"
|
"github.com/metacubex/mihomo/transport/ssr/tools"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
func init() {
|
func init() {
|
||||||
@ -178,7 +178,7 @@ func (a *authSHA1V4) getRandDataLength(size int) int {
|
|||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
if size > 400 {
|
if size > 400 {
|
||||||
return fastrand.Intn(256)
|
return randv2.IntN(256)
|
||||||
}
|
}
|
||||||
return fastrand.Intn(512)
|
return randv2.IntN(512)
|
||||||
}
|
}
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"bytes"
|
"bytes"
|
||||||
"crypto/aes"
|
"crypto/aes"
|
||||||
"crypto/cipher"
|
"crypto/cipher"
|
||||||
|
"crypto/rand"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"sync"
|
"sync"
|
||||||
@ -13,7 +14,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
"github.com/metacubex/mihomo/transport/shadowsocks/core"
|
"github.com/metacubex/mihomo/transport/shadowsocks/core"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type Base struct {
|
type Base struct {
|
||||||
@ -38,8 +39,8 @@ func (a *authData) next() *authData {
|
|||||||
a.mutex.Lock()
|
a.mutex.Lock()
|
||||||
defer a.mutex.Unlock()
|
defer a.mutex.Unlock()
|
||||||
if a.connectionID > 0xff000000 || a.connectionID == 0 {
|
if a.connectionID > 0xff000000 || a.connectionID == 0 {
|
||||||
fastrand.Read(a.clientID[:])
|
rand.Read(a.clientID[:])
|
||||||
a.connectionID = fastrand.Uint32() & 0xffffff
|
a.connectionID = randv2.Uint32() & 0xffffff
|
||||||
}
|
}
|
||||||
a.connectionID++
|
a.connectionID++
|
||||||
copy(r.clientID[:], a.clientID[:])
|
copy(r.clientID[:], a.clientID[:])
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
|
|
||||||
N "github.com/metacubex/mihomo/common/net"
|
N "github.com/metacubex/mihomo/common/net"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -71,7 +71,7 @@ func getHeadSize(b []byte, defaultValue int) int {
|
|||||||
|
|
||||||
func getDataLength(b []byte) int {
|
func getDataLength(b []byte) int {
|
||||||
bLength := len(b)
|
bLength := len(b)
|
||||||
dataLength := getHeadSize(b, 30) + fastrand.Intn(32)
|
dataLength := getHeadSize(b, 30) + randv2.IntN(32)
|
||||||
if bLength < dataLength {
|
if bLength < dataLength {
|
||||||
return bLength
|
return bLength
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
"github.com/metacubex/quic-go/congestion"
|
"github.com/metacubex/quic-go/congestion"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -716,7 +716,7 @@ func (b *bbrSender) EnterProbeBandwidthMode(now time.Time) {
|
|||||||
// Pick a random offset for the gain cycle out of {0, 2..7} range. 1 is
|
// Pick a random offset for the gain cycle out of {0, 2..7} range. 1 is
|
||||||
// excluded because in that case increased gain and decreased gain would not
|
// excluded because in that case increased gain and decreased gain would not
|
||||||
// follow each other.
|
// follow each other.
|
||||||
b.cycleCurrentOffset = fastrand.Int() % (GainCycleLength - 1)
|
b.cycleCurrentOffset = randv2.Int() % (GainCycleLength - 1)
|
||||||
if b.cycleCurrentOffset >= 1 {
|
if b.cycleCurrentOffset >= 1 {
|
||||||
b.cycleCurrentOffset += 1
|
b.cycleCurrentOffset += 1
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ import (
|
|||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
"github.com/metacubex/quic-go/congestion"
|
"github.com/metacubex/quic-go/congestion"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
// BbrSender implements BBR congestion control algorithm. BBR aims to estimate
|
// BbrSender implements BBR congestion control algorithm. BBR aims to estimate
|
||||||
@ -620,7 +620,7 @@ func (b *bbrSender) enterProbeBandwidthMode(now time.Time) {
|
|||||||
// Pick a random offset for the gain cycle out of {0, 2..7} range. 1 is
|
// Pick a random offset for the gain cycle out of {0, 2..7} range. 1 is
|
||||||
// excluded because in that case increased gain and decreased gain would not
|
// excluded because in that case increased gain and decreased gain would not
|
||||||
// follow each other.
|
// follow each other.
|
||||||
b.cycleCurrentOffset = int(fastrand.Int31n(congestion.PacketsPerConnectionID)) % (gainCycleLength - 1)
|
b.cycleCurrentOffset = int(randv2.Int32N(congestion.PacketsPerConnectionID)) % (gainCycleLength - 1)
|
||||||
if b.cycleCurrentOffset >= 1 {
|
if b.cycleCurrentOffset >= 1 {
|
||||||
b.cycleCurrentOffset += 1
|
b.cycleCurrentOffset += 1
|
||||||
}
|
}
|
||||||
|
@ -20,8 +20,8 @@ import (
|
|||||||
"github.com/metacubex/mihomo/transport/tuic/common"
|
"github.com/metacubex/mihomo/transport/tuic/common"
|
||||||
|
|
||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
"github.com/puzpuzpuz/xsync/v3"
|
"github.com/puzpuzpuz/xsync/v3"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ClientOption struct {
|
type ClientOption struct {
|
||||||
@ -367,7 +367,7 @@ func (t *clientImpl) ListenPacketWithDialer(ctx context.Context, metadata *C.Met
|
|||||||
pipe1, pipe2 := N.Pipe()
|
pipe1, pipe2 := N.Pipe()
|
||||||
var connId uint32
|
var connId uint32
|
||||||
for {
|
for {
|
||||||
connId = fastrand.Uint32()
|
connId = randv2.Uint32()
|
||||||
_, loaded := t.udpInputMap.LoadOrStore(connId, pipe1)
|
_, loaded := t.udpInputMap.LoadOrStore(connId, pipe1)
|
||||||
if !loaded {
|
if !loaded {
|
||||||
break
|
break
|
||||||
|
@ -20,8 +20,8 @@ import (
|
|||||||
"github.com/metacubex/mihomo/transport/tuic/common"
|
"github.com/metacubex/mihomo/transport/tuic/common"
|
||||||
|
|
||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
|
"github.com/metacubex/randv2"
|
||||||
"github.com/puzpuzpuz/xsync/v3"
|
"github.com/puzpuzpuz/xsync/v3"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ClientOption struct {
|
type ClientOption struct {
|
||||||
@ -351,7 +351,7 @@ func (t *clientImpl) ListenPacketWithDialer(ctx context.Context, metadata *C.Met
|
|||||||
pipe1, pipe2 := N.Pipe()
|
pipe1, pipe2 := N.Pipe()
|
||||||
var connId uint16
|
var connId uint16
|
||||||
for {
|
for {
|
||||||
connId = uint16(fastrand.Intn(0xFFFF))
|
connId = uint16(randv2.IntN(0xFFFF))
|
||||||
_, loaded := t.udpInputMap.LoadOrStore(connId, pipe1)
|
_, loaded := t.udpInputMap.LoadOrStore(connId, pipe1)
|
||||||
if !loaded {
|
if !loaded {
|
||||||
break
|
break
|
||||||
|
@ -12,7 +12,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/transport/tuic/common"
|
"github.com/metacubex/mihomo/transport/tuic/common"
|
||||||
|
|
||||||
"github.com/metacubex/quic-go"
|
"github.com/metacubex/quic-go"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type quicStreamPacketConn struct {
|
type quicStreamPacketConn struct {
|
||||||
@ -157,7 +157,7 @@ func (q *quicStreamPacketConn) WriteTo(p []byte, addr net.Addr) (n int, err erro
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
pktId := uint16(fastrand.Uint32())
|
pktId := uint16(randv2.Uint32())
|
||||||
packet := NewPacket(q.connId, pktId, 1, 0, uint16(len(p)), address, p)
|
packet := NewPacket(q.connId, pktId, 1, 0, uint16(len(p)), address, p)
|
||||||
switch q.udpRelayMode {
|
switch q.udpRelayMode {
|
||||||
case common.QUIC:
|
case common.QUIC:
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/log"
|
"github.com/metacubex/mihomo/log"
|
||||||
|
|
||||||
"github.com/gofrs/uuid/v5"
|
"github.com/gofrs/uuid/v5"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
@ -25,9 +25,9 @@ func WriteWithPadding(buffer *buf.Buffer, p []byte, command byte, userUUID *uuid
|
|||||||
if contentLen < 900 {
|
if contentLen < 900 {
|
||||||
if paddingTLS {
|
if paddingTLS {
|
||||||
//log.Debugln("long padding")
|
//log.Debugln("long padding")
|
||||||
paddingLen = fastrand.Int31n(500) + 900 - contentLen
|
paddingLen = randv2.Int32N(500) + 900 - contentLen
|
||||||
} else {
|
} else {
|
||||||
paddingLen = fastrand.Int31n(256)
|
paddingLen = randv2.Int32N(256)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if userUUID != nil {
|
if userUUID != nil {
|
||||||
@ -49,9 +49,9 @@ func ApplyPadding(buffer *buf.Buffer, command byte, userUUID *uuid.UUID, padding
|
|||||||
if contentLen < 900 {
|
if contentLen < 900 {
|
||||||
if paddingTLS {
|
if paddingTLS {
|
||||||
//log.Debugln("long padding")
|
//log.Debugln("long padding")
|
||||||
paddingLen = fastrand.Int31n(500) + 900 - contentLen
|
paddingLen = randv2.Int32N(500) + 900 - contentLen
|
||||||
} else {
|
} else {
|
||||||
paddingLen = fastrand.Int31n(256)
|
paddingLen = randv2.Int32N(256)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@ import (
|
|||||||
"crypto/cipher"
|
"crypto/cipher"
|
||||||
"crypto/hmac"
|
"crypto/hmac"
|
||||||
"crypto/md5"
|
"crypto/md5"
|
||||||
|
"crypto/rand"
|
||||||
"crypto/sha256"
|
"crypto/sha256"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"errors"
|
"errors"
|
||||||
@ -14,7 +15,7 @@ import (
|
|||||||
"net"
|
"net"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
"golang.org/x/crypto/chacha20poly1305"
|
"golang.org/x/crypto/chacha20poly1305"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -72,7 +73,7 @@ func (vc *Conn) sendRequest() error {
|
|||||||
buf.WriteByte(vc.respV)
|
buf.WriteByte(vc.respV)
|
||||||
buf.WriteByte(OptionChunkStream)
|
buf.WriteByte(OptionChunkStream)
|
||||||
|
|
||||||
p := fastrand.Intn(16)
|
p := randv2.IntN(16)
|
||||||
// P Sec Reserve Cmd
|
// P Sec Reserve Cmd
|
||||||
buf.WriteByte(byte(p<<4) | byte(vc.security))
|
buf.WriteByte(byte(p<<4) | byte(vc.security))
|
||||||
buf.WriteByte(0)
|
buf.WriteByte(0)
|
||||||
@ -90,7 +91,7 @@ func (vc *Conn) sendRequest() error {
|
|||||||
// padding
|
// padding
|
||||||
if p > 0 {
|
if p > 0 {
|
||||||
padding := make([]byte, p)
|
padding := make([]byte, p)
|
||||||
fastrand.Read(padding)
|
rand.Read(padding)
|
||||||
buf.Write(padding)
|
buf.Write(padding)
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -196,7 +197,7 @@ func hashTimestamp(t time.Time) []byte {
|
|||||||
// newConn return a Conn instance
|
// newConn return a Conn instance
|
||||||
func newConn(conn net.Conn, id *ID, dst *DstAddr, security Security, isAead bool) (*Conn, error) {
|
func newConn(conn net.Conn, id *ID, dst *DstAddr, security Security, isAead bool) (*Conn, error) {
|
||||||
randBytes := make([]byte, 33)
|
randBytes := make([]byte, 33)
|
||||||
fastrand.Read(randBytes)
|
rand.Read(randBytes)
|
||||||
reqBodyIV := make([]byte, 16)
|
reqBodyIV := make([]byte, 16)
|
||||||
reqBodyKey := make([]byte, 16)
|
reqBodyKey := make([]byte, 16)
|
||||||
copy(reqBodyIV[:], randBytes[:16])
|
copy(reqBodyIV[:], randBytes[:16])
|
||||||
|
@ -7,7 +7,7 @@ import (
|
|||||||
"net/http"
|
"net/http"
|
||||||
"net/url"
|
"net/url"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
"golang.org/x/net/http2"
|
"golang.org/x/net/http2"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -27,7 +27,7 @@ type H2Config struct {
|
|||||||
func (hc *h2Conn) establishConn() error {
|
func (hc *h2Conn) establishConn() error {
|
||||||
preader, pwriter := io.Pipe()
|
preader, pwriter := io.Pipe()
|
||||||
|
|
||||||
host := hc.cfg.Hosts[fastrand.Intn(len(hc.cfg.Hosts))]
|
host := hc.cfg.Hosts[randv2.IntN(len(hc.cfg.Hosts))]
|
||||||
path := hc.cfg.Path
|
path := hc.cfg.Path
|
||||||
// TODO: connect use VMess Host instead of H2 Host
|
// TODO: connect use VMess Host instead of H2 Host
|
||||||
req := http.Request{
|
req := http.Request{
|
||||||
|
@ -11,7 +11,7 @@ import (
|
|||||||
|
|
||||||
"github.com/metacubex/mihomo/common/utils"
|
"github.com/metacubex/mihomo/common/utils"
|
||||||
|
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type httpConn struct {
|
type httpConn struct {
|
||||||
@ -59,10 +59,10 @@ func (hc *httpConn) Write(b []byte) (int, error) {
|
|||||||
return -1, errors.New("path is empty")
|
return -1, errors.New("path is empty")
|
||||||
}
|
}
|
||||||
|
|
||||||
path := hc.cfg.Path[fastrand.Intn(len(hc.cfg.Path))]
|
path := hc.cfg.Path[randv2.IntN(len(hc.cfg.Path))]
|
||||||
host := hc.cfg.Host
|
host := hc.cfg.Host
|
||||||
if header := hc.cfg.Headers["Host"]; len(header) != 0 {
|
if header := hc.cfg.Headers["Host"]; len(header) != 0 {
|
||||||
host = header[fastrand.Intn(len(header))]
|
host = header[randv2.IntN(len(header))]
|
||||||
}
|
}
|
||||||
|
|
||||||
u := fmt.Sprintf("http://%s%s", net.JoinHostPort(host, "80"), path)
|
u := fmt.Sprintf("http://%s%s", net.JoinHostPort(host, "80"), path)
|
||||||
@ -71,7 +71,7 @@ func (hc *httpConn) Write(b []byte) (int, error) {
|
|||||||
return 0, err
|
return 0, err
|
||||||
}
|
}
|
||||||
for key, list := range hc.cfg.Headers {
|
for key, list := range hc.cfg.Headers {
|
||||||
req.Header.Set(key, list[fastrand.Intn(len(list))])
|
req.Header.Set(key, list[randv2.IntN(len(list))])
|
||||||
}
|
}
|
||||||
req.ContentLength = int64(len(b))
|
req.ContentLength = int64(len(b))
|
||||||
if err := req.Write(hc.Conn); err != nil {
|
if err := req.Write(hc.Conn); err != nil {
|
||||||
|
@ -8,7 +8,7 @@ import (
|
|||||||
"github.com/metacubex/mihomo/common/utils"
|
"github.com/metacubex/mihomo/common/utils"
|
||||||
|
|
||||||
"github.com/gofrs/uuid/v5"
|
"github.com/gofrs/uuid/v5"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
// Version of vmess
|
// Version of vmess
|
||||||
@ -78,7 +78,7 @@ type Config struct {
|
|||||||
|
|
||||||
// StreamConn return a Conn with net.Conn and DstAddr
|
// StreamConn return a Conn with net.Conn and DstAddr
|
||||||
func (c *Client) StreamConn(conn net.Conn, dst *DstAddr) (net.Conn, error) {
|
func (c *Client) StreamConn(conn net.Conn, dst *DstAddr) (net.Conn, error) {
|
||||||
r := fastrand.Intn(len(c.user))
|
r := randv2.IntN(len(c.user))
|
||||||
return newConn(conn, c.user[r], dst, c.security, c.isAead)
|
return newConn(conn, c.user[r], dst, c.security, c.isAead)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4,6 +4,7 @@ import (
|
|||||||
"bufio"
|
"bufio"
|
||||||
"bytes"
|
"bytes"
|
||||||
"context"
|
"context"
|
||||||
|
"crypto/rand"
|
||||||
"crypto/sha1"
|
"crypto/sha1"
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
@ -25,7 +26,7 @@ import (
|
|||||||
|
|
||||||
"github.com/gobwas/ws"
|
"github.com/gobwas/ws"
|
||||||
"github.com/gobwas/ws/wsutil"
|
"github.com/gobwas/ws/wsutil"
|
||||||
"github.com/zhangyunhao116/fastrand"
|
"github.com/metacubex/randv2"
|
||||||
)
|
)
|
||||||
|
|
||||||
type websocketConn struct {
|
type websocketConn struct {
|
||||||
@ -150,7 +151,7 @@ func (wsc *websocketConn) WriteBuffer(buffer *buf.Buffer) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if wsc.state.ClientSide() {
|
if wsc.state.ClientSide() {
|
||||||
maskKey := fastrand.Uint32()
|
maskKey := randv2.Uint32()
|
||||||
binary.LittleEndian.PutUint32(header[1+payloadBitLength:], maskKey)
|
binary.LittleEndian.PutUint32(header[1+payloadBitLength:], maskKey)
|
||||||
N.MaskWebSocket(maskKey, data)
|
N.MaskWebSocket(maskKey, data)
|
||||||
}
|
}
|
||||||
@ -398,7 +399,7 @@ func streamWebsocketConn(ctx context.Context, conn net.Conn, c *WebsocketConfig,
|
|||||||
const nonceKeySize = 16
|
const nonceKeySize = 16
|
||||||
// NOTE: bts does not escape.
|
// NOTE: bts does not escape.
|
||||||
bts := make([]byte, nonceKeySize)
|
bts := make([]byte, nonceKeySize)
|
||||||
if _, err = fastrand.Read(bts); err != nil {
|
if _, err = rand.Read(bts); err != nil {
|
||||||
return nil, fmt.Errorf("rand read error: %w", err)
|
return nil, fmt.Errorf("rand read error: %w", err)
|
||||||
}
|
}
|
||||||
secKey = base64.StdEncoding.EncodeToString(bts)
|
secKey = base64.StdEncoding.EncodeToString(bts)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user