mirror of
				https://github.com/bestnite/sub2sing-box.git
				synced 2025-10-25 16:51:01 +00:00 
			
		
		
		
	update dependency
This commit is contained in:
		| @@ -136,7 +136,7 @@ func AddCountryGroup(proxies []model.Outbound, groupType string, sortKey string, | |||||||
| 						Outbound: option.Outbound{ | 						Outbound: option.Outbound{ | ||||||
| 							Tag:  country, | 							Tag:  country, | ||||||
| 							Type: groupType, | 							Type: groupType, | ||||||
| 							SelectorOptions: option.SelectorOutboundOptions{ | 							Options: option.SelectorOutboundOptions{ | ||||||
| 								Outbounds:                 []string{p.Tag}, | 								Outbounds:                 []string{p.Tag}, | ||||||
| 								InterruptExistConnections: true, | 								InterruptExistConnections: true, | ||||||
| 							}, | 							}, | ||||||
| @@ -147,7 +147,7 @@ func AddCountryGroup(proxies []model.Outbound, groupType string, sortKey string, | |||||||
| 						Outbound: option.Outbound{ | 						Outbound: option.Outbound{ | ||||||
| 							Tag:  country, | 							Tag:  country, | ||||||
| 							Type: groupType, | 							Type: groupType, | ||||||
| 							URLTestOptions: option.URLTestOutboundOptions{ | 							Options: option.URLTestOutboundOptions{ | ||||||
| 								Outbounds:                 []string{p.Tag}, | 								Outbounds:                 []string{p.Tag}, | ||||||
| 								InterruptExistConnections: true, | 								InterruptExistConnections: true, | ||||||
| 							}, | 							}, | ||||||
|   | |||||||
							
								
								
									
										103
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										103
									
								
								go.mod
									
									
									
									
									
								
							| @@ -3,105 +3,46 @@ module github.com/nitezs/sub2sing-box | |||||||
| go 1.23 | go 1.23 | ||||||
|  |  | ||||||
| require ( | require ( | ||||||
| 	github.com/sagernet/sing-box v1.10.1 | 	github.com/sagernet/sing v0.6.0-beta.12 | ||||||
|  | 	github.com/sagernet/sing-box v1.11.0-beta.24 | ||||||
| 	github.com/spf13/cobra v1.8.1 | 	github.com/spf13/cobra v1.8.1 | ||||||
| 	golang.org/x/text v0.19.0 | 	golang.org/x/text v0.21.0 | ||||||
| ) | ) | ||||||
|  |  | ||||||
| require ( | require ( | ||||||
| 	berty.tech/go-libtor v1.0.385 // indirect | 	github.com/bytedance/sonic v1.12.7 // indirect | ||||||
| 	github.com/andybalholm/brotli v1.0.6 // indirect | 	github.com/bytedance/sonic/loader v0.2.3 // indirect | ||||||
| 	github.com/bytedance/sonic v1.12.3 // indirect | 	github.com/cloudwego/base64x v0.1.5 // indirect | ||||||
| 	github.com/bytedance/sonic/loader v0.2.0 // indirect | 	github.com/gabriel-vasile/mimetype v1.4.8 // indirect | ||||||
| 	github.com/caddyserver/certmagic v0.20.0 // indirect | 	github.com/gin-contrib/sse v1.0.0 // indirect | ||||||
| 	github.com/cloudflare/circl v1.3.7 // indirect |  | ||||||
| 	github.com/cloudwego/base64x v0.1.4 // indirect |  | ||||||
| 	github.com/cloudwego/iasm v0.2.0 // indirect |  | ||||||
| 	github.com/cretz/bine v0.2.0 // indirect |  | ||||||
| 	github.com/fsnotify/fsnotify v1.7.0 // indirect |  | ||||||
| 	github.com/gabriel-vasile/mimetype v1.4.6 // indirect |  | ||||||
| 	github.com/gin-contrib/sse v0.1.0 // indirect |  | ||||||
| 	github.com/go-chi/chi/v5 v5.0.12 // indirect |  | ||||||
| 	github.com/go-ole/go-ole v1.3.0 // indirect |  | ||||||
| 	github.com/go-playground/locales v0.14.1 // indirect | 	github.com/go-playground/locales v0.14.1 // indirect | ||||||
| 	github.com/go-playground/universal-translator v0.18.1 // indirect | 	github.com/go-playground/universal-translator v0.18.1 // indirect | ||||||
| 	github.com/go-playground/validator/v10 v10.22.1 // indirect | 	github.com/go-playground/validator/v10 v10.24.0 // indirect | ||||||
| 	github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 // indirect | 	github.com/goccy/go-json v0.10.4 // indirect | ||||||
| 	github.com/gobwas/httphead v0.1.0 // indirect |  | ||||||
| 	github.com/gobwas/pool v0.2.1 // indirect |  | ||||||
| 	github.com/goccy/go-json v0.10.3 // indirect |  | ||||||
| 	github.com/gofrs/uuid/v5 v5.3.0 // indirect |  | ||||||
| 	github.com/google/btree v1.1.2 // indirect |  | ||||||
| 	github.com/google/go-cmp v0.6.0 // indirect |  | ||||||
| 	github.com/google/pprof v0.0.0-20231101202521-4ca4178f5c7a // indirect |  | ||||||
| 	github.com/hashicorp/yamux v0.1.1 // indirect |  | ||||||
| 	github.com/josharian/native v1.1.0 // indirect |  | ||||||
| 	github.com/json-iterator/go v1.1.12 // indirect | 	github.com/json-iterator/go v1.1.12 // indirect | ||||||
| 	github.com/klauspost/compress v1.17.4 // indirect | 	github.com/klauspost/cpuid/v2 v2.2.9 // indirect | ||||||
| 	github.com/klauspost/cpuid/v2 v2.2.8 // indirect |  | ||||||
| 	github.com/knz/go-libedit v1.10.1 // indirect |  | ||||||
| 	github.com/kr/text v0.2.0 // indirect | 	github.com/kr/text v0.2.0 // indirect | ||||||
| 	github.com/leodido/go-urn v1.4.0 // indirect | 	github.com/leodido/go-urn v1.4.0 // indirect | ||||||
| 	github.com/libdns/alidns v1.0.3 // indirect |  | ||||||
| 	github.com/libdns/cloudflare v0.1.1 // indirect |  | ||||||
| 	github.com/libdns/libdns v0.2.2 // indirect |  | ||||||
| 	github.com/logrusorgru/aurora v2.0.3+incompatible // indirect |  | ||||||
| 	github.com/mattn/go-isatty v0.0.20 // indirect | 	github.com/mattn/go-isatty v0.0.20 // indirect | ||||||
| 	github.com/mdlayher/netlink v1.7.2 // indirect |  | ||||||
| 	github.com/mdlayher/socket v0.4.1 // indirect |  | ||||||
| 	github.com/metacubex/tfo-go v0.0.0-20240821025650-e9be0afd5e7d // indirect |  | ||||||
| 	github.com/mholt/acmez v1.2.0 // indirect |  | ||||||
| 	github.com/miekg/dns v1.1.62 // indirect | 	github.com/miekg/dns v1.1.62 // indirect | ||||||
| 	github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect | 	github.com/modern-go/concurrent v0.0.0-20180306012644-bacd9c7ef1dd // indirect | ||||||
| 	github.com/modern-go/reflect2 v1.0.2 // indirect | 	github.com/modern-go/reflect2 v1.0.2 // indirect | ||||||
| 	github.com/onsi/ginkgo/v2 v2.9.7 // indirect |  | ||||||
| 	github.com/ooni/go-libtor v1.1.8 // indirect |  | ||||||
| 	github.com/oschwald/maxminddb-golang v1.12.0 // indirect |  | ||||||
| 	github.com/pelletier/go-toml/v2 v2.2.3 // indirect | 	github.com/pelletier/go-toml/v2 v2.2.3 // indirect | ||||||
| 	github.com/quic-go/qpack v0.4.0 // indirect | 	github.com/quic-go/qpack v0.5.1 // indirect | ||||||
| 	github.com/quic-go/qtls-go1-20 v0.4.1 // indirect | 	github.com/sagernet/sing-dns v0.4.0-beta.2 // indirect | ||||||
| 	github.com/sagernet/bbolt v0.0.0-20231014093535-ea5cb2fe9f0a // indirect |  | ||||||
| 	github.com/sagernet/cloudflare-tls v0.0.0-20231208171750-a4483c1b7cd1 // indirect |  | ||||||
| 	github.com/sagernet/fswatch v0.1.1 // indirect |  | ||||||
| 	github.com/sagernet/gvisor v0.0.0-20240428053021-e691de28565f // indirect |  | ||||||
| 	github.com/sagernet/netlink v0.0.0-20240612041022-b9a21c07ac6a // indirect |  | ||||||
| 	github.com/sagernet/nftables v0.3.0-beta.4 // indirect |  | ||||||
| 	github.com/sagernet/quic-go v0.47.0-beta.2 // indirect |  | ||||||
| 	github.com/sagernet/reality v0.0.0-20230406110435-ee17307e7691 // indirect |  | ||||||
| 	github.com/sagernet/sing v0.5.0-rc.4 // indirect |  | ||||||
| 	github.com/sagernet/sing-dns v0.3.0-rc.2 // indirect |  | ||||||
| 	github.com/sagernet/sing-mux v0.2.0 // indirect |  | ||||||
| 	github.com/sagernet/sing-quic v0.3.0-rc.1 // indirect |  | ||||||
| 	github.com/sagernet/sing-shadowsocks v0.2.7 // indirect |  | ||||||
| 	github.com/sagernet/sing-shadowsocks2 v0.2.0 // indirect |  | ||||||
| 	github.com/sagernet/sing-shadowtls v0.1.4 // indirect |  | ||||||
| 	github.com/sagernet/sing-tun v0.4.0-rc.4 // indirect |  | ||||||
| 	github.com/sagernet/sing-vmess v0.1.12 // indirect |  | ||||||
| 	github.com/sagernet/smux v0.0.0-20231208180855-7041f6ea79e7 // indirect |  | ||||||
| 	github.com/sagernet/utls v1.6.7 // indirect |  | ||||||
| 	github.com/sagernet/wireguard-go v0.0.0-20231215174105-89dec3b2f3e8 // indirect |  | ||||||
| 	github.com/sagernet/ws v0.0.0-20231204124109-acfe8907c854 // indirect |  | ||||||
| 	github.com/twitchyliquid64/golang-asm v0.15.1 // indirect | 	github.com/twitchyliquid64/golang-asm v0.15.1 // indirect | ||||||
| 	github.com/ugorji/go/codec v1.2.12 // indirect | 	github.com/ugorji/go/codec v1.2.12 // indirect | ||||||
| 	github.com/vishvananda/netns v0.0.4 // indirect |  | ||||||
| 	github.com/zeebo/blake3 v0.2.3 // indirect |  | ||||||
| 	go.uber.org/multierr v1.11.0 // indirect |  | ||||||
| 	go.uber.org/zap v1.27.0 // indirect |  | ||||||
| 	go4.org/netipx v0.0.0-20231129151722-fdeea329fbba // indirect | 	go4.org/netipx v0.0.0-20231129151722-fdeea329fbba // indirect | ||||||
| 	golang.org/x/arch v0.11.0 // indirect | 	golang.org/x/arch v0.13.0 // indirect | ||||||
| 	golang.org/x/crypto v0.28.0 // indirect | 	golang.org/x/crypto v0.32.0 // indirect | ||||||
| 	golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 // indirect | 	golang.org/x/exp v0.0.0-20250106191152-7588d65b2ba8 // indirect | ||||||
| 	golang.org/x/mod v0.21.0 // indirect | 	golang.org/x/mod v0.22.0 // indirect | ||||||
| 	golang.org/x/net v0.30.0 // indirect | 	golang.org/x/net v0.34.0 // indirect | ||||||
| 	golang.org/x/sync v0.8.0 // indirect | 	golang.org/x/sync v0.10.0 // indirect | ||||||
| 	golang.org/x/sys v0.26.0 // indirect | 	golang.org/x/sys v0.29.0 // indirect | ||||||
| 	golang.org/x/time v0.5.0 // indirect | 	golang.org/x/tools v0.29.0 // indirect | ||||||
| 	golang.org/x/tools v0.26.0 // indirect | 	google.golang.org/protobuf v1.36.3 // indirect | ||||||
| 	google.golang.org/genproto/googleapis/rpc v0.0.0-20240227224415-6ceb2ff114de // indirect |  | ||||||
| 	google.golang.org/grpc v1.63.2 // indirect |  | ||||||
| 	google.golang.org/protobuf v1.35.1 // indirect |  | ||||||
| 	gopkg.in/yaml.v3 v3.0.1 // indirect | 	gopkg.in/yaml.v3 v3.0.1 // indirect | ||||||
| 	lukechampine.com/blake3 v1.3.0 // indirect |  | ||||||
| ) | ) | ||||||
|  |  | ||||||
| require ( | require ( | ||||||
|   | |||||||
							
								
								
									
										255
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										255
									
								
								go.sum
									
									
									
									
									
								
							| @@ -1,108 +1,49 @@ | |||||||
| berty.tech/go-libtor v1.0.385 h1:RWK94C3hZj6Z2GdvePpHJLnWYobFr3bY/OdUJ5aoEXw= | github.com/bytedance/sonic v1.12.7 h1:CQU8pxOy9HToxhndH0Kx/S1qU/CuS9GnKYrGioDcU1Q= | ||||||
| berty.tech/go-libtor v1.0.385/go.mod h1:9swOOQVb+kmvuAlsgWUK/4c52pm69AdbJsxLzk+fJEw= | github.com/bytedance/sonic v1.12.7/go.mod h1:tnbal4mxOMju17EGfknm2XyYcpyCnIROYOEYuemj13I= | ||||||
| github.com/andybalholm/brotli v1.0.6 h1:Yf9fFpf49Zrxb9NlQaluyE92/+X7UVHlhMNJN2sxfOI= |  | ||||||
| github.com/andybalholm/brotli v1.0.6/go.mod h1:fO7iG3H7G2nSZ7m0zPUDn85XEX2GTukHGRSepvi9Eig= |  | ||||||
| github.com/bytedance/sonic v1.12.3 h1:W2MGa7RCU1QTeYRTPE3+88mVC0yXmsRQRChiyVocVjU= |  | ||||||
| github.com/bytedance/sonic v1.12.3/go.mod h1:B8Gt/XvtZ3Fqj+iSKMypzymZxw/FVwgIGKzMzT9r/rk= |  | ||||||
| github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU= | github.com/bytedance/sonic/loader v0.1.1/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU= | ||||||
| github.com/bytedance/sonic/loader v0.2.0 h1:zNprn+lsIP06C/IqCHs3gPQIvnvpKbbxyXQP1iU4kWM= | github.com/bytedance/sonic/loader v0.2.3 h1:yctD0Q3v2NOGfSWPLPvG2ggA2kV6TS6s4wioyEqssH0= | ||||||
| github.com/bytedance/sonic/loader v0.2.0/go.mod h1:ncP89zfokxS5LZrJxl5z0UJcsk4M4yY2JpfqGeCtNLU= | github.com/bytedance/sonic/loader v0.2.3/go.mod h1:N8A3vUdtUebEY2/VQC0MyhYeKUFosQU6FxH2JmUe6VI= | ||||||
| github.com/caddyserver/certmagic v0.20.0 h1:bTw7LcEZAh9ucYCRXyCpIrSAGplplI0vGYJ4BpCQ/Fc= | github.com/cloudwego/base64x v0.1.5 h1:XPciSp1xaq2VCSt6lF0phncD4koWyULpl5bUxbfCyP4= | ||||||
| github.com/caddyserver/certmagic v0.20.0/go.mod h1:N4sXgpICQUskEWpj7zVzvWD41p3NYacrNoZYiRM2jTg= | github.com/cloudwego/base64x v0.1.5/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w= | ||||||
| github.com/cloudflare/circl v1.3.7 h1:qlCDlTPz2n9fu58M0Nh1J/JzcFpfgkFHHX3O35r5vcU= |  | ||||||
| github.com/cloudflare/circl v1.3.7/go.mod h1:sRTcRWXGLrKw6yIGJ+l7amYJFfAXbZG0kBSc8r4zxgA= |  | ||||||
| github.com/cloudwego/base64x v0.1.4 h1:jwCgWpFanWmN8xoIUHa2rtzmkd5J2plF/dnLS6Xd/0Y= |  | ||||||
| github.com/cloudwego/base64x v0.1.4/go.mod h1:0zlkT4Wn5C6NdauXdJRhSKRlJvmclQ1hhJgA0rcu/8w= |  | ||||||
| github.com/cloudwego/iasm v0.2.0 h1:1KNIy1I1H9hNNFEEH3DVnI4UujN+1zjpuk6gwHLTssg= |  | ||||||
| github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY= | github.com/cloudwego/iasm v0.2.0/go.mod h1:8rXZaNYT2n95jn+zTI1sDr+IgcD2GVs0nlbbQPiEFhY= | ||||||
| github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | github.com/cpuguy83/go-md2man/v2 v2.0.4/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= | ||||||
| github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= | github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= | ||||||
| github.com/cretz/bine v0.1.0/go.mod h1:6PF6fWAvYtwjRGkAuDEJeWNOv3a2hUouSP/yRYXmvHw= |  | ||||||
| github.com/cretz/bine v0.2.0 h1:8GiDRGlTgz+o8H9DSnsl+5MeBK4HsExxgl6WgzOCuZo= |  | ||||||
| github.com/cretz/bine v0.2.0/go.mod h1:WU4o9QR9wWp8AVKtTM1XD5vUHkEqnf2vVSo6dBqbetI= |  | ||||||
| github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||||
| github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= | github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= | ||||||
| github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= | ||||||
| github.com/fsnotify/fsnotify v1.7.0 h1:8JEhPFa5W2WU7YfeZzPNqzMP6Lwt7L2715Ggo0nosvA= | github.com/gabriel-vasile/mimetype v1.4.8 h1:FfZ3gj38NjllZIeJAmMhr+qKL8Wu+nOoI3GqacKw1NM= | ||||||
| github.com/fsnotify/fsnotify v1.7.0/go.mod h1:40Bi/Hjc2AVfZrqy+aj+yEI+/bRxZnMJyTJwOpGvigM= | github.com/gabriel-vasile/mimetype v1.4.8/go.mod h1:ByKUIKGjh1ODkGM1asKUbQZOLGrPjydw3hYPU2YU9t8= | ||||||
| github.com/gabriel-vasile/mimetype v1.4.5 h1:J7wGKdGu33ocBOhGy0z653k/lFKLFDPJMG8Gql0kxn4= | github.com/gin-contrib/sse v1.0.0 h1:y3bT1mUWUxDpW4JLQg/HnTqV4rozuW4tC9eFKTxYI9E= | ||||||
| github.com/gabriel-vasile/mimetype v1.4.5/go.mod h1:ibHel+/kbxn9x2407k1izTA1S81ku1z/DlgOW2QE0M4= | github.com/gin-contrib/sse v1.0.0/go.mod h1:zNuFdwarAygJBht0NTKiSi3jRf6RbqeILZ9Sp6Slhe0= | ||||||
| github.com/gabriel-vasile/mimetype v1.4.6 h1:3+PzJTKLkvgjeTbts6msPJt4DixhT4YtFNf1gtGe3zc= |  | ||||||
| github.com/gabriel-vasile/mimetype v1.4.6/go.mod h1:JX1qVKqZd40hUPpAfiNTe0Sne7hdfKSbOqqmkq8GCXc= |  | ||||||
| github.com/gin-contrib/sse v0.1.0 h1:Y/yl/+YNO8GZSjAhjMsSuLt29uWRFHdHYUb5lYOV9qE= |  | ||||||
| github.com/gin-contrib/sse v0.1.0/go.mod h1:RHrZQHXnP2xjPF+u1gW/2HnVO7nvIa9PG3Gm+fLHvGI= |  | ||||||
| github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU= | github.com/gin-gonic/gin v1.10.0 h1:nTuyha1TYqgedzytsKYqna+DfLos46nTv2ygFy86HFU= | ||||||
| github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y= | github.com/gin-gonic/gin v1.10.0/go.mod h1:4PMNQiOhvDRa013RKVbsiNwoyezlm2rm0uX/T7kzp5Y= | ||||||
| github.com/go-chi/chi/v5 v5.0.12 h1:9euLV5sTrTNTRUU9POmDUvfxyj6LAABLUcEWO+JJb4s= |  | ||||||
| github.com/go-chi/chi/v5 v5.0.12/go.mod h1:DslCQbL2OYiznFReuXYUmQ2hGd1aDpCnlMNITLSKoi8= |  | ||||||
| github.com/go-ole/go-ole v1.3.0 h1:Dt6ye7+vXGIKZ7Xtk4s6/xVdGDQynvom7xCFEdWr6uE= |  | ||||||
| github.com/go-ole/go-ole v1.3.0/go.mod h1:5LS6F96DhAwUc7C+1HLexzMXY1xGRSryjyPPKW6zv78= |  | ||||||
| github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= | github.com/go-playground/assert/v2 v2.2.0 h1:JvknZsQTYeFEAhQwI4qEt9cyV5ONwRHC+lYKSsYSR8s= | ||||||
| github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= | github.com/go-playground/assert/v2 v2.2.0/go.mod h1:VDjEfimB/XKnb+ZQfWdccd7VUvScMdVu0Titje2rxJ4= | ||||||
| github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= | github.com/go-playground/locales v0.14.1 h1:EWaQ/wswjilfKLTECiXz7Rh+3BjFhfDFKv/oXslEjJA= | ||||||
| github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= | github.com/go-playground/locales v0.14.1/go.mod h1:hxrqLVvrK65+Rwrd5Fc6F2O76J/NuW9t0sjnWqG1slY= | ||||||
| github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= | github.com/go-playground/universal-translator v0.18.1 h1:Bcnm0ZwsGyWbCzImXv+pAJnYK9S473LQFuzCbDbfSFY= | ||||||
| github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= | github.com/go-playground/universal-translator v0.18.1/go.mod h1:xekY+UJKNuX9WP91TpwSH2VMlDf28Uj24BCp08ZFTUY= | ||||||
| github.com/go-playground/validator/v10 v10.22.1 h1:40JcKH+bBNGFczGuoBYgX4I6m/i27HYW8P9FDk5PbgA= | github.com/go-playground/validator/v10 v10.24.0 h1:KHQckvo8G6hlWnrPX4NJJ+aBfWNAE/HH+qdL2cBpCmg= | ||||||
| github.com/go-playground/validator/v10 v10.22.1/go.mod h1:dbuPbCMFw/DrkbEynArYaCwl3amGuJotoKCe95atGMM= | github.com/go-playground/validator/v10 v10.24.0/go.mod h1:GGzBIJMuE98Ic/kJsBXbz1x/7cByt++cQ+YOuDM5wus= | ||||||
| github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572 h1:tfuBGBXKqDEevZMzYi5KSi8KkcZtzBcTgAUUtapy0OI= | github.com/goccy/go-json v0.10.4 h1:JSwxQzIqKfmFX1swYPpUThQZp/Ka4wzJdK0LWVytLPM= | ||||||
| github.com/go-task/slim-sprig v0.0.0-20230315185526-52ccab3ef572/go.mod h1:9Pwr4B2jHnOSGXyyzV8ROjYa2ojvAY6HCGYYfMoC3Ls= | github.com/goccy/go-json v0.10.4/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M= | ||||||
| github.com/gobwas/httphead v0.1.0 h1:exrUm0f4YX0L7EBwZHuCF4GDp8aJfVeBrlLQrs6NqWU= |  | ||||||
| github.com/gobwas/httphead v0.1.0/go.mod h1:O/RXo79gxV8G+RqlR/otEwx4Q36zl9rqC5u12GKvMCM= |  | ||||||
| github.com/gobwas/pool v0.2.1 h1:xfeeEhW7pwmX8nuLVlqbzVc7udMDrwetjEv+TZIz1og= |  | ||||||
| github.com/gobwas/pool v0.2.1/go.mod h1:q8bcK0KcYlCgd9e7WYLm9LpyS+YeLd8JVDW6WezmKEw= |  | ||||||
| github.com/goccy/go-json v0.10.3 h1:KZ5WoDbxAIgm2HNbYckL0se1fHD6rz5j4ywS6ebzDqA= |  | ||||||
| github.com/goccy/go-json v0.10.3/go.mod h1:oq7eo15ShAhp70Anwd5lgX2pLfOS3QCiwU/PULtXL6M= |  | ||||||
| github.com/gofrs/uuid/v5 v5.3.0 h1:m0mUMr+oVYUdxpMLgSYCZiXe7PuVPnI94+OMeVBNedk= |  | ||||||
| github.com/gofrs/uuid/v5 v5.3.0/go.mod h1:CDOjlDMVAtN56jqyRUZh58JT31Tiw7/oQyEXZV+9bD8= |  | ||||||
| github.com/google/btree v1.1.2 h1:xf4v41cLI2Z6FxbKm+8Bu+m8ifhj15JuZ9sa0jZCMUU= |  | ||||||
| github.com/google/btree v1.1.2/go.mod h1:qOPhT0dTNdNzV6Z/lhRX0YXUafgPLFUh+gZMl761Gm4= |  | ||||||
| github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | github.com/google/go-cmp v0.6.0 h1:ofyhxvXcZhMsU5ulbFiLKl/XBFqE1GSq7atu8tAmTRI= | ||||||
| github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | github.com/google/go-cmp v0.6.0/go.mod h1:17dUlkBOakJ0+DkrSSNjCkIjxS6bF9zb3elmeNGIjoY= | ||||||
| github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= | ||||||
| github.com/google/pprof v0.0.0-20231101202521-4ca4178f5c7a h1:fEBsGL/sjAuJrgah5XqmmYsTLzJp/TO9Lhy39gkverk= |  | ||||||
| github.com/google/pprof v0.0.0-20231101202521-4ca4178f5c7a/go.mod h1:czg5+yv1E0ZGTi6S6vVK1mke0fV+FaUhNGcd6VRS9Ik= |  | ||||||
| github.com/hashicorp/yamux v0.1.1 h1:yrQxtgseBDrq9Y652vSRDvsKCJKOUD+GzTS4Y0Y8pvE= |  | ||||||
| github.com/hashicorp/yamux v0.1.1/go.mod h1:CtWFDAQgb7dxtzFs4tWbplKIe2jSi3+5vKbgIO0SLnQ= |  | ||||||
| github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= | github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= | ||||||
| github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= | github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= | ||||||
| github.com/josharian/native v1.1.0 h1:uuaP0hAbW7Y4l0ZRQ6C9zfb7Mg1mbFKry/xzDAfmtLA= |  | ||||||
| github.com/josharian/native v1.1.0/go.mod h1:7X/raswPFr05uY3HiLlYeyQntB6OO7E/d2Cu7qoaN2w= |  | ||||||
| github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= | github.com/json-iterator/go v1.1.12 h1:PV8peI4a0ysnczrg+LtxykD8LfKY9ML6u2jnxaEnrnM= | ||||||
| github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= | github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= | ||||||
| github.com/klauspost/compress v1.17.4 h1:Ej5ixsIri7BrIjBkRZLTo6ghwrEtHFk7ijlczPW4fZ4= |  | ||||||
| github.com/klauspost/compress v1.17.4/go.mod h1:/dCuZOvVtNoHsyb+cuJD3itjs3NbnF6KH9zAO4BDxPM= |  | ||||||
| github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= | github.com/klauspost/cpuid/v2 v2.0.9/go.mod h1:FInQzS24/EEf25PyTYn52gqo7WaD8xa0213Md/qVLRg= | ||||||
| github.com/klauspost/cpuid/v2 v2.0.12/go.mod h1:g2LTdtYhdyuGPqyWyv7qRAmj1WBqxuObKfj5c0PQa7c= | github.com/klauspost/cpuid/v2 v2.2.9 h1:66ze0taIn2H33fBvCkXuv9BmCwDfafmiIVpKV9kKGuY= | ||||||
| github.com/klauspost/cpuid/v2 v2.2.8 h1:+StwCXwm9PdpiEkPyzBXIy+M9KUb4ODm0Zarf1kS5BM= | github.com/klauspost/cpuid/v2 v2.2.9/go.mod h1:rqkxqrZ1EhYM9G+hXH7YdowN5R5RGN6NK4QwQ3WMXF8= | ||||||
| github.com/klauspost/cpuid/v2 v2.2.8/go.mod h1:Lcz8mBdAVJIBVzewtcLocK12l3Y+JytZYpaMropDUws= |  | ||||||
| github.com/knz/go-libedit v1.10.1 h1:0pHpWtx9vcvC0xGZqEQlQdfSQs7WRlAjuPvk3fOZDCo= |  | ||||||
| github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M= | github.com/knz/go-libedit v1.10.1/go.mod h1:MZTVkCWyz0oBc7JOWP3wNAzd002ZbM/5hgShxwh4x8M= | ||||||
| github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= | github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= | ||||||
| github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= | github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= | ||||||
| github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= | github.com/leodido/go-urn v1.4.0 h1:WT9HwE9SGECu3lg4d/dIA+jxlljEa1/ffXKmRjqdmIQ= | ||||||
| github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= | github.com/leodido/go-urn v1.4.0/go.mod h1:bvxc+MVxLKB4z00jd1z+Dvzr47oO32F/QSNjSBOlFxI= | ||||||
| github.com/libdns/alidns v1.0.3 h1:LFHuGnbseq5+HCeGa1aW8awyX/4M2psB9962fdD2+yQ= |  | ||||||
| github.com/libdns/alidns v1.0.3/go.mod h1:e18uAG6GanfRhcJj6/tps2rCMzQJaYVcGKT+ELjdjGE= |  | ||||||
| github.com/libdns/cloudflare v0.1.1 h1:FVPfWwP8zZCqj268LZjmkDleXlHPlFU9KC4OJ3yn054= |  | ||||||
| github.com/libdns/cloudflare v0.1.1/go.mod h1:9VK91idpOjg6v7/WbjkEW49bSCxj00ALesIFDhJ8PBU= |  | ||||||
| github.com/libdns/libdns v0.2.0/go.mod h1:yQCXzk1lEZmmCPa857bnk4TsOiqYasqpyOEeSObbb40= |  | ||||||
| github.com/libdns/libdns v0.2.2 h1:O6ws7bAfRPaBsgAYt8MDe2HcNBGC29hkZ9MX2eUSX3s= |  | ||||||
| github.com/libdns/libdns v0.2.2/go.mod h1:4Bj9+5CQiNMVGf87wjX4CY3HQJypUHRuLvlsfsZqLWQ= |  | ||||||
| github.com/logrusorgru/aurora v2.0.3+incompatible h1:tOpm7WcpBTn4fjmVfgpQq0EfczGlG91VSDkswnjF5A8= |  | ||||||
| github.com/logrusorgru/aurora v2.0.3+incompatible/go.mod h1:7rIyQOR62GCctdiQpZ/zOJlFyk6y+94wXzv6RNZgaR4= |  | ||||||
| github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= | github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWEY= | ||||||
| github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= | ||||||
| github.com/mdlayher/netlink v1.7.2 h1:/UtM3ofJap7Vl4QWCPDGXY8d3GIY2UGSDbK+QWmY8/g= |  | ||||||
| github.com/mdlayher/netlink v1.7.2/go.mod h1:xraEF7uJbxLhc5fpHL4cPe221LI2bdttWlU+ZGLfQSw= |  | ||||||
| github.com/mdlayher/socket v0.4.1 h1:eM9y2/jlbs1M615oshPQOHZzj6R6wMT7bX5NPiQvn2U= |  | ||||||
| github.com/mdlayher/socket v0.4.1/go.mod h1:cAqeGjoufqdxWkD7DkpyS+wcefOtmu5OQ8KuoJGIReA= |  | ||||||
| github.com/metacubex/tfo-go v0.0.0-20240821025650-e9be0afd5e7d h1:j9LtzkYstLFoNvXW824QQeN7Y26uPL5249kzWKbzO9U= |  | ||||||
| github.com/metacubex/tfo-go v0.0.0-20240821025650-e9be0afd5e7d/go.mod h1:c7bVFM9f5+VzeZ/6Kg77T/jrg1Xp8QpqlSHvG/aXVts= |  | ||||||
| github.com/mholt/acmez v1.2.0 h1:1hhLxSgY5FvH5HCnGUuwbKY2VQVo8IU7rxXKSnZ7F30= |  | ||||||
| github.com/mholt/acmez v1.2.0/go.mod h1:VT9YwH1xgNX1kmYY89gY8xPJC84BFAisjo8Egigt4kE= |  | ||||||
| github.com/miekg/dns v1.1.61 h1:nLxbwF3XxhwVSm8g9Dghm9MHPaUZuqhPiGL+675ZmEs= |  | ||||||
| github.com/miekg/dns v1.1.61/go.mod h1:mnAarhS3nWaW+NVP2wTkYVIZyHNJ098SJZUki3eykwQ= |  | ||||||
| github.com/miekg/dns v1.1.62 h1:cN8OuEF1/x5Rq6Np+h1epln8OiyPWV+lROx9LxcGgIQ= | github.com/miekg/dns v1.1.62 h1:cN8OuEF1/x5Rq6Np+h1epln8OiyPWV+lROx9LxcGgIQ= | ||||||
| github.com/miekg/dns v1.1.62/go.mod h1:mvDlcItzm+br7MToIKqkglaGhlFMHJ9DTNNWONWXbNQ= | github.com/miekg/dns v1.1.62/go.mod h1:mvDlcItzm+br7MToIKqkglaGhlFMHJ9DTNNWONWXbNQ= | ||||||
| github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= | github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= | ||||||
| @@ -112,72 +53,23 @@ github.com/modern-go/reflect2 v1.0.2 h1:xBagoLtFs94CBntxluKeaWgTMpvLxC4ur3nMaC9G | |||||||
| github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= | github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= | ||||||
| github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs= | github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e h1:fD57ERR4JtEqsWbfPhv4DMiApHyliiK5xCTNVSPiaAs= | ||||||
| github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= | github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= | ||||||
| github.com/onsi/ginkgo/v2 v2.9.7 h1:06xGQy5www2oN160RtEZoTvnP2sPhEfePYmCDc2szss= |  | ||||||
| github.com/onsi/ginkgo/v2 v2.9.7/go.mod h1:cxrmXWykAwTwhQsJOPfdIDiJ+l2RYq7U8hFU+M/1uw0= |  | ||||||
| github.com/ooni/go-libtor v1.1.8 h1:Wo3V3DVTxl5vZdxtQakqYP+DAHx7pPtAFSl1bnAa08w= |  | ||||||
| github.com/ooni/go-libtor v1.1.8/go.mod h1:q1YyLwRD9GeMyeerVvwc0vJ2YgwDLTp2bdVcrh/JXyI= |  | ||||||
| github.com/oschwald/maxminddb-golang v1.12.0 h1:9FnTOD0YOhP7DGxGsq4glzpGy5+w7pq50AS6wALUMYs= |  | ||||||
| github.com/oschwald/maxminddb-golang v1.12.0/go.mod h1:q0Nob5lTCqyQ8WT6FYgS1L7PXKVVbgiymefNwIjPzgY= |  | ||||||
| github.com/pelletier/go-toml/v2 v2.2.3 h1:YmeHyLY8mFWbdkNWwpr+qIL2bEqT0o95WSdkNHvL12M= | github.com/pelletier/go-toml/v2 v2.2.3 h1:YmeHyLY8mFWbdkNWwpr+qIL2bEqT0o95WSdkNHvL12M= | ||||||
| github.com/pelletier/go-toml/v2 v2.2.3/go.mod h1:MfCQTFTvCcUyyvvwm1+G6H/jORL20Xlb6rzQu9GuUkc= | github.com/pelletier/go-toml/v2 v2.2.3/go.mod h1:MfCQTFTvCcUyyvvwm1+G6H/jORL20Xlb6rzQu9GuUkc= | ||||||
| github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= | ||||||
| github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= | ||||||
| github.com/quic-go/qpack v0.4.0 h1:Cr9BXA1sQS2SmDUWjSofMPNKmvF6IiIfDRmgU0w1ZCo= | github.com/quic-go/qpack v0.5.1 h1:giqksBPnT/HDtZ6VhtFKgoLOWmlyo9Ei6u9PqzIMbhI= | ||||||
| github.com/quic-go/qpack v0.4.0/go.mod h1:UZVnYIfi5GRk+zI9UMaCPsmZ2xKJP7XBUvVyT1Knj9A= | github.com/quic-go/qpack v0.5.1/go.mod h1:+PC4XFrEskIVkcLzpEkbLqq1uCoxPhQuvK5rH1ZgaEg= | ||||||
| github.com/quic-go/qtls-go1-20 v0.4.1 h1:D33340mCNDAIKBqXuAvexTNMUByrYmFYVfKfDN5nfFs= | github.com/quic-go/qtls-go1-20 v0.4.1 h1:D33340mCNDAIKBqXuAvexTNMUByrYmFYVfKfDN5nfFs= | ||||||
| github.com/quic-go/qtls-go1-20 v0.4.1/go.mod h1:X9Nh97ZL80Z+bX/gUXMbipO6OxdiDi58b/fMC9mAL+k= | github.com/quic-go/qtls-go1-20 v0.4.1/go.mod h1:X9Nh97ZL80Z+bX/gUXMbipO6OxdiDi58b/fMC9mAL+k= | ||||||
| github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= | ||||||
| github.com/sagernet/bbolt v0.0.0-20231014093535-ea5cb2fe9f0a h1:+NkI2670SQpQWvkkD2QgdTuzQG263YZ+2emfpeyGqW0= | github.com/sagernet/quic-go v0.48.2-beta.1 h1:W0plrLWa1XtOWDTdX3CJwxmQuxkya12nN5BRGZ87kEg= | ||||||
| github.com/sagernet/bbolt v0.0.0-20231014093535-ea5cb2fe9f0a/go.mod h1:63s7jpZqcDAIpj8oI/1v4Izok+npJOHACFCU6+huCkM= | github.com/sagernet/quic-go v0.48.2-beta.1/go.mod h1:1WgdDIVD1Gybp40JTWketeSfKA/+or9YMLaG5VeTk4k= | ||||||
| github.com/sagernet/cloudflare-tls v0.0.0-20231208171750-a4483c1b7cd1 h1:YbmpqPQEMdlk9oFSKYWRqVuu9qzNiOayIonKmv1gCXY= | github.com/sagernet/sing v0.6.0-beta.12 h1:2DnTJcvypK3/PM/8JjmgG8wVK48gdcpRwU98c4J/a7s= | ||||||
| github.com/sagernet/cloudflare-tls v0.0.0-20231208171750-a4483c1b7cd1/go.mod h1:J2yAxTFPDjrDPhuAi9aWFz2L3ox9it4qAluBBbN0H5k= | github.com/sagernet/sing v0.6.0-beta.12/go.mod h1:ARkL0gM13/Iv5VCZmci/NuoOlePoIsW0m7BWfln/Hak= | ||||||
| github.com/sagernet/fswatch v0.1.1 h1:YqID+93B7VRfqIH3PArW/XpJv5H4OLEVWDfProGoRQs= | github.com/sagernet/sing-box v1.11.0-beta.24 h1:6rUl8t6Cb0p9ML1eUobWgODL75c5iszxNvVABcWCivU= | ||||||
| github.com/sagernet/fswatch v0.1.1/go.mod h1:nz85laH0mkQqJfaOrqPpkwtU1znMFNVTpT/5oRsVz/o= | github.com/sagernet/sing-box v1.11.0-beta.24/go.mod h1:DmL1WKyrfaAEu5z88CtUeQBfELaEdUyQzLS5nzmRg8o= | ||||||
| github.com/sagernet/gvisor v0.0.0-20240428053021-e691de28565f h1:NkhuupzH5ch7b/Y/6ZHJWrnNLoiNnSJaow6DPb8VW2I= | github.com/sagernet/sing-dns v0.4.0-beta.2 h1:HW94bUEp7K/vf5DlYz646LTZevQtJ0250jZa/UZRlbY= | ||||||
| github.com/sagernet/gvisor v0.0.0-20240428053021-e691de28565f/go.mod h1:KXmw+ouSJNOsuRpg4wgwwCQuunrGz4yoAqQjsLjc6N0= | github.com/sagernet/sing-dns v0.4.0-beta.2/go.mod h1:8wuFcoFkWM4vJuQyg8e97LyvDwe0/Vl7G839WLcKDs8= | ||||||
| github.com/sagernet/netlink v0.0.0-20240612041022-b9a21c07ac6a h1:ObwtHN2VpqE0ZNjr6sGeT00J8uU7JF4cNUdb44/Duis= |  | ||||||
| github.com/sagernet/netlink v0.0.0-20240612041022-b9a21c07ac6a/go.mod h1:xLnfdiJbSp8rNqYEdIW/6eDO4mVoogml14Bh2hSiFpM= |  | ||||||
| github.com/sagernet/nftables v0.3.0-beta.4 h1:kbULlAwAC3jvdGAC1P5Fa3GSxVwQJibNenDW2zaXr8I= |  | ||||||
| github.com/sagernet/nftables v0.3.0-beta.4/go.mod h1:OQXAjvjNGGFxaTgVCSTRIhYB5/llyVDeapVoENYBDS8= |  | ||||||
| github.com/sagernet/quic-go v0.47.0-beta.2 h1:1tCGWFOSaXIeuQaHrwOMJIYvlupjTcaVInGQw5ArULU= |  | ||||||
| github.com/sagernet/quic-go v0.47.0-beta.2/go.mod h1:bLVKvElSEMNv7pu7SZHscW02TYigzQ5lQu3Nh4wNh8Q= |  | ||||||
| github.com/sagernet/reality v0.0.0-20230406110435-ee17307e7691 h1:5Th31OC6yj8byLGkEnIYp6grlXfo1QYUfiYFGjewIdc= |  | ||||||
| github.com/sagernet/reality v0.0.0-20230406110435-ee17307e7691/go.mod h1:B8lp4WkQ1PwNnrVMM6KyuFR20pU8jYBD+A4EhJovEXU= |  | ||||||
| github.com/sagernet/sing v0.2.18/go.mod h1:OL6k2F0vHmEzXz2KW19qQzu172FDgSbUSODylighuVo= |  | ||||||
| github.com/sagernet/sing v0.5.0-beta.2 h1:V12EpwtsgYo5OLGjAiGoJobDJZeUsKv0b5y+yGAM6W0= |  | ||||||
| github.com/sagernet/sing v0.5.0-beta.2/go.mod h1:ARkL0gM13/Iv5VCZmci/NuoOlePoIsW0m7BWfln/Hak= |  | ||||||
| github.com/sagernet/sing v0.5.0-rc.4 h1:pnZQz9leyY2nckGvOG0AUcBIyHOCrapwBd63qmP1hSk= |  | ||||||
| github.com/sagernet/sing v0.5.0-rc.4/go.mod h1:ARkL0gM13/Iv5VCZmci/NuoOlePoIsW0m7BWfln/Hak= |  | ||||||
| github.com/sagernet/sing-box v1.10.0-beta.11 h1:SBQtW1WPoNEmTvBCwzngSaFrYfYCqjO/J6CHLZd5S/Q= |  | ||||||
| github.com/sagernet/sing-box v1.10.0-beta.11/go.mod h1:VkzoxRgxB87Z0F2vR00qjmezphU/GG9TtgaUYrAzdY8= |  | ||||||
| github.com/sagernet/sing-box v1.10.1 h1:J3H0TzF0LGC4uOR62TpSuAhhHkv3Bx5M5F5kK5JB+WA= |  | ||||||
| github.com/sagernet/sing-box v1.10.1/go.mod h1:Nk9Ww0M1ulUsbfd5d4dfMBfJ0Audmm6m5+YYdvdpcZQ= |  | ||||||
| github.com/sagernet/sing-dns v0.3.0-beta.14 h1:/s+fJzYKsvLaNDt/2rjpsrDcN8wmCO2JbX6OFrl8Nww= |  | ||||||
| github.com/sagernet/sing-dns v0.3.0-beta.14/go.mod h1:rscgSr5ixOPk8XM9ZMLuMXCyldEQ1nLvdl0nfv+lp00= |  | ||||||
| github.com/sagernet/sing-dns v0.3.0-rc.2 h1:z1yROBxd/6wik5h53Sz5df1DSmbPTaOu/Z0wAmyXGoQ= |  | ||||||
| github.com/sagernet/sing-dns v0.3.0-rc.2/go.mod h1:TqLIelI+FAbVEdiTRolhGLOwvhVjY7oT+wezlOJUQ7M= |  | ||||||
| github.com/sagernet/sing-mux v0.2.0 h1:4C+vd8HztJCWNYfufvgL49xaOoOHXty2+EAjnzN3IYo= |  | ||||||
| github.com/sagernet/sing-mux v0.2.0/go.mod h1:khzr9AOPocLa+g53dBplwNDz4gdsyx/YM3swtAhlkHQ= |  | ||||||
| github.com/sagernet/sing-quic v0.3.0-rc.1 h1:SlzL1yfEAKJyRduub8vzOVtbyTLAX7RZEEBZxO5utts= |  | ||||||
| github.com/sagernet/sing-quic v0.3.0-rc.1/go.mod h1:uX+aUHA0fgIN6U3WViseDpSdTQriViZ7qz0Wbsf1mNQ= |  | ||||||
| github.com/sagernet/sing-shadowsocks v0.2.7 h1:zaopR1tbHEw5Nk6FAkM05wCslV6ahVegEZaKMv9ipx8= |  | ||||||
| github.com/sagernet/sing-shadowsocks v0.2.7/go.mod h1:0rIKJZBR65Qi0zwdKezt4s57y/Tl1ofkaq6NlkzVuyE= |  | ||||||
| github.com/sagernet/sing-shadowsocks2 v0.2.0 h1:wpZNs6wKnR7mh1wV9OHwOyUr21VkS3wKFHi+8XwgADg= |  | ||||||
| github.com/sagernet/sing-shadowsocks2 v0.2.0/go.mod h1:RnXS0lExcDAovvDeniJ4IKa2IuChrdipolPYWBv9hWQ= |  | ||||||
| github.com/sagernet/sing-shadowtls v0.1.4 h1:aTgBSJEgnumzFenPvc+kbD9/W0PywzWevnVpEx6Tw3k= |  | ||||||
| github.com/sagernet/sing-shadowtls v0.1.4/go.mod h1:F8NBgsY5YN2beQavdgdm1DPlhaKQlaL6lpDdcBglGK4= |  | ||||||
| github.com/sagernet/sing-tun v0.4.0-rc.4 h1:EFz+UjLZTm+YS3ob1vpqjOga67wyvnxWcbQKfe5wE3Y= |  | ||||||
| github.com/sagernet/sing-tun v0.4.0-rc.4/go.mod h1:+lQdWhqD4atzrCgRhoyrxBCg1OBru/hAv2BT3kdgmGM= |  | ||||||
| github.com/sagernet/sing-vmess v0.1.12 h1:2gFD8JJb+eTFMoa8FIVMnknEi+vCSfaiTXTfEYAYAPg= |  | ||||||
| github.com/sagernet/sing-vmess v0.1.12/go.mod h1:luTSsfyBGAc9VhtCqwjR+dt1QgqBhuYBCONB/POhF8I= |  | ||||||
| github.com/sagernet/smux v0.0.0-20231208180855-7041f6ea79e7 h1:DImB4lELfQhplLTxeq2z31Fpv8CQqqrUwTbrIRumZqQ= |  | ||||||
| github.com/sagernet/smux v0.0.0-20231208180855-7041f6ea79e7/go.mod h1:FP9X2xjT/Az1EsG/orYYoC+5MojWnuI7hrffz8fGwwo= |  | ||||||
| github.com/sagernet/utls v1.6.7 h1:Ep3+aJ8FUGGta+II2IEVNUc3EDhaRCZINWkj/LloIA8= |  | ||||||
| github.com/sagernet/utls v1.6.7/go.mod h1:Uua1TKO/FFuAhLr9rkaVnnrTmmiItzDjv1BUb2+ERwM= |  | ||||||
| github.com/sagernet/wireguard-go v0.0.0-20231215174105-89dec3b2f3e8 h1:R0OMYAScomNAVpTfbHFpxqJpvwuhxSRi+g6z7gZhABs= |  | ||||||
| github.com/sagernet/wireguard-go v0.0.0-20231215174105-89dec3b2f3e8/go.mod h1:K4J7/npM+VAMUeUmTa2JaA02JmyheP0GpRBOUvn3ecc= |  | ||||||
| github.com/sagernet/ws v0.0.0-20231204124109-acfe8907c854 h1:6uUiZcDRnZSAegryaUGwPC/Fj13JSHwiTftrXhMmYOc= |  | ||||||
| github.com/sagernet/ws v0.0.0-20231204124109-acfe8907c854/go.mod h1:LtfoSK3+NG57tvnVEHgcuBW9ujgE8enPSgzgwStwCAA= |  | ||||||
| github.com/spf13/cobra v1.8.1 h1:e5/vxKd/rZsfSJMUX1agtjeTDf+qv1/JdBF8gg5k9ZM= | github.com/spf13/cobra v1.8.1 h1:e5/vxKd/rZsfSJMUX1agtjeTDf+qv1/JdBF8gg5k9ZM= | ||||||
| github.com/spf13/cobra v1.8.1/go.mod h1:wHxEcudfqmLYa8iTfL+OuZPbBZkmvliBWKIezN3kD9Y= | github.com/spf13/cobra v1.8.1/go.mod h1:wHxEcudfqmLYa8iTfL+OuZPbBZkmvliBWKIezN3kD9Y= | ||||||
| github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= | github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= | ||||||
| @@ -185,93 +77,46 @@ github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An | |||||||
| github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= | ||||||
| github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= | github.com/stretchr/objx v0.4.0/go.mod h1:YvHI0jy2hoMjB+UWwv71VJQ9isScKT/TqJzVSSt89Yw= | ||||||
| github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= | github.com/stretchr/objx v0.5.0/go.mod h1:Yh+to48EsGEfYuaHDzXPcE3xhTkx73EhmCGUpEOglKo= | ||||||
|  | github.com/stretchr/objx v0.5.2/go.mod h1:FRsXN1f5AsAjCGJKqEizvkpNtU+EGNCLh3NxZ/8L+MA= | ||||||
| github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= | github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= | ||||||
| github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= |  | ||||||
| github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= | github.com/stretchr/testify v1.7.0/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= | ||||||
| github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= | github.com/stretchr/testify v1.7.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= | ||||||
| github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= | github.com/stretchr/testify v1.8.0/go.mod h1:yNjHg4UonilssWZ8iaSj1OCr/vHnekPRkoO+kdMU+MU= | ||||||
| github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= | github.com/stretchr/testify v1.8.1/go.mod h1:w2LPCIKwWwSfY2zedu0+kehJoqGctiVI29o6fzry7u4= | ||||||
| github.com/stretchr/testify v1.9.0 h1:HtqpIVDClZ4nwg75+f6Lvsy/wHu+3BoSGCbBAcpTsTg= | github.com/stretchr/testify v1.8.4/go.mod h1:sz/lmYIOXD/1dqDmKjjqLyZ2RngseejIcXlSw2iwfAo= | ||||||
| github.com/stretchr/testify v1.9.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | github.com/stretchr/testify v1.10.0 h1:Xv5erBjTwe/5IxqUQTdXv5kgmIvbHo3QQyRwhJsOfJA= | ||||||
|  | github.com/stretchr/testify v1.10.0/go.mod h1:r2ic/lqez/lEtzL7wO/rwa5dbSLXVDPFyf8C91i36aY= | ||||||
| github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= | github.com/twitchyliquid64/golang-asm v0.15.1 h1:SU5vSMR7hnwNxj24w34ZyCi/FmDZTkS4MhqMhdFk5YI= | ||||||
| github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= | github.com/twitchyliquid64/golang-asm v0.15.1/go.mod h1:a1lVb/DtPvCB8fslRZhAngC2+aY1QWCk3Cedj/Gdt08= | ||||||
| github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= | github.com/ugorji/go/codec v1.2.12 h1:9LC83zGrHhuUA9l16C9AHXAqEV/2wBQ4nkvumAE65EE= | ||||||
| github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= | github.com/ugorji/go/codec v1.2.12/go.mod h1:UNopzCgEMSXjBc6AOMqYvWC1ktqTAfzJZUZgYf6w6lg= | ||||||
| github.com/vishvananda/netns v0.0.4 h1:Oeaw1EM2JMxD51g9uhtC0D7erkIjgmj8+JZc26m1YX8= |  | ||||||
| github.com/vishvananda/netns v0.0.4/go.mod h1:SpkAiCQRtJ6TvvxPnOSyH3BMl6unz3xZlaprSwhNNJM= |  | ||||||
| github.com/zeebo/assert v1.1.0/go.mod h1:Pq9JiuJQpG8JLJdtkwrJESF0Foym2/D9XMU5ciN/wJ0= |  | ||||||
| github.com/zeebo/blake3 v0.2.3 h1:TFoLXsjeXqRNFxSbk35Dk4YtszE/MQQGK10BH4ptoTg= |  | ||||||
| github.com/zeebo/blake3 v0.2.3/go.mod h1:mjJjZpnsyIVtVgTOSpJ9vmRE4wgDeyt2HU3qXvvKCaQ= |  | ||||||
| github.com/zeebo/pcg v1.0.1/go.mod h1:09F0S9iiKrwn9rlI5yjLkmrug154/YRW6KnnXVDM/l4= |  | ||||||
| go.uber.org/multierr v1.11.0 h1:blXXJkSxSSfBVBlC76pxqeO+LN3aDfLQo+309xJstO0= |  | ||||||
| go.uber.org/multierr v1.11.0/go.mod h1:20+QtiLqy0Nd6FdQB9TLXag12DsQkrbs3htMFfDN80Y= |  | ||||||
| go.uber.org/zap v1.27.0 h1:aJMhYGrd5QSmlpLMr2MftRKl7t8J8PTZPA732ud/XR8= |  | ||||||
| go.uber.org/zap v1.27.0/go.mod h1:GB2qFLM7cTU87MWRP2mPIjqfIDnGu+VIO4V/SdhGo2E= |  | ||||||
| go4.org/netipx v0.0.0-20231129151722-fdeea329fbba h1:0b9z3AuHCjxk0x/opv64kcgZLBseWJUpBw5I82+2U4M= | go4.org/netipx v0.0.0-20231129151722-fdeea329fbba h1:0b9z3AuHCjxk0x/opv64kcgZLBseWJUpBw5I82+2U4M= | ||||||
| go4.org/netipx v0.0.0-20231129151722-fdeea329fbba/go.mod h1:PLyyIXexvUFg3Owu6p/WfdlivPbZJsZdgWZlrGope/Y= | go4.org/netipx v0.0.0-20231129151722-fdeea329fbba/go.mod h1:PLyyIXexvUFg3Owu6p/WfdlivPbZJsZdgWZlrGope/Y= | ||||||
| golang.org/x/arch v0.10.0 h1:S3huipmSclq3PJMNe76NGwkBR504WFkQ5dhzWzP8ZW8= | golang.org/x/arch v0.13.0 h1:KCkqVVV1kGg0X87TFysjCJ8MxtZEIU4Ja/yXGeoECdA= | ||||||
| golang.org/x/arch v0.10.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= | golang.org/x/arch v0.13.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= | ||||||
| golang.org/x/arch v0.11.0 h1:KXV8WWKCXm6tRpLirl2szsO5j/oOODwZf4hATmGVNs4= | golang.org/x/crypto v0.32.0 h1:euUpcYgM8WcP71gNpTqQCn6rC2t6ULUPiOzfWaXVVfc= | ||||||
| golang.org/x/arch v0.11.0/go.mod h1:FEVrYAQjsQXMVJ1nsMoVVXPZg6p2JE2mx8psSWTDQys= | golang.org/x/crypto v0.32.0/go.mod h1:ZnnJkOaASj8g0AjIduWNlq2NRxL0PlBrbKVyZ6V/Ugc= | ||||||
| golang.org/x/crypto v0.0.0-20190404164418-38d8ce5564a5/go.mod h1:WFFai1msRO1wXaEeE5yQxYXgSfI8pQAWXbQop6sCtWE= | golang.org/x/exp v0.0.0-20250106191152-7588d65b2ba8 h1:yqrTHse8TCMW1M1ZCP+VAR/l0kKxwaAIqN/il7x4voA= | ||||||
| golang.org/x/crypto v0.0.0-20210513164829-c07d793c2f9a/go.mod h1:P+XmwS30IXTQdn5tA2iutPOUgjI07+tq3H3K9MVA1s8= | golang.org/x/exp v0.0.0-20250106191152-7588d65b2ba8/go.mod h1:tujkw807nyEEAamNbDrEGzRav+ilXA7PCRAd6xsmwiU= | ||||||
| golang.org/x/crypto v0.27.0 h1:GXm2NjJrPaiv/h1tb2UH8QfgC/hOf/+z0p6PT8o1w7A= | golang.org/x/mod v0.22.0 h1:D4nJWe9zXqHOmWqj4VMOJhvzj7bEZg4wEYa759z1pH4= | ||||||
| golang.org/x/crypto v0.27.0/go.mod h1:1Xngt8kV6Dvbssa53Ziq6Eqn0HqbZi5Z6R0ZpwQzt70= | golang.org/x/mod v0.22.0/go.mod h1:6SkKJ3Xj0I0BrPOZoBy3bdMptDDU9oJrpohJ3eWZ1fY= | ||||||
| golang.org/x/crypto v0.28.0 h1:GBDwsMXVQi34v5CCYUm2jkJvu4cbtru2U4TN2PSyQnw= | golang.org/x/net v0.34.0 h1:Mb7Mrk043xzHgnRM88suvJFwzVrRfHEHJEl5/71CKw0= | ||||||
| golang.org/x/crypto v0.28.0/go.mod h1:rmgy+3RHxRZMyY0jjAJShp2zgEdOqj2AO7U0pYmeQ7U= | golang.org/x/net v0.34.0/go.mod h1:di0qlW3YNM5oh6GqDGQr92MyTozJPmybPK4Ev/Gm31k= | ||||||
| golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56 h1:2dVuKD2vS7b0QIHQbpyTISPd0LeHDbnYEryqj5Q1ug8= | golang.org/x/sync v0.10.0 h1:3NQrjDixjgGwUOCaF8w2+VYHv0Ve/vGYSbdkTa98gmQ= | ||||||
| golang.org/x/exp v0.0.0-20240719175910-8a7402abbf56/go.mod h1:M4RDyNAINzryxdtnbRXRL/OHtkFuWGRjvuhBJpk2IlY= | golang.org/x/sync v0.10.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= | ||||||
| golang.org/x/mod v0.19.0 h1:fEdghXQSo20giMthA7cd28ZC+jts4amQ3YMXiP5oMQ8= |  | ||||||
| golang.org/x/mod v0.19.0/go.mod h1:hTbmBsO62+eylJbnUtE2MGJUyE7QWk4xUqPFrRgJ+7c= |  | ||||||
| golang.org/x/mod v0.21.0 h1:vvrHzRwRfVKSiLrG+d4FMl/Qi4ukBCE6kZlTUkDYRT0= |  | ||||||
| golang.org/x/mod v0.21.0/go.mod h1:6SkKJ3Xj0I0BrPOZoBy3bdMptDDU9oJrpohJ3eWZ1fY= |  | ||||||
| golang.org/x/net v0.0.0-20210226172049-e18ecbb05110/go.mod h1:m0MpNAwzfU5UDzcl9v0D8zg8gWTRqZa9RBIspLL5mdg= |  | ||||||
| golang.org/x/net v0.0.0-20210525063256-abc453219eb5/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= |  | ||||||
| golang.org/x/net v0.29.0 h1:5ORfpBpCs4HzDYoodCDBbwHzdR5UrLBZ3sOnUJmFoHo= |  | ||||||
| golang.org/x/net v0.29.0/go.mod h1:gLkgy8jTGERgjzMic6DS9+SP0ajcu6Xu3Orq/SpETg0= |  | ||||||
| golang.org/x/net v0.30.0 h1:AcW1SDZMkb8IpzCdQUaIq2sP4sZ4zw+55h6ynffypl4= |  | ||||||
| golang.org/x/net v0.30.0/go.mod h1:2wGyMJ5iFasEhkwi13ChkO/t1ECNC4X4eBKkVFyYFlU= |  | ||||||
| golang.org/x/sync v0.8.0 h1:3NFvSEYkUoMifnESzZl15y791HH1qU2xm6eCJU5ZPXQ= |  | ||||||
| golang.org/x/sync v0.8.0/go.mod h1:Czt+wKu1gCyEFDUtn0jG5QVvpJ6rzVqr5aXyt9drQfk= |  | ||||||
| golang.org/x/sys v0.0.0-20190403152447-81d4e9dc473e/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= |  | ||||||
| golang.org/x/sys v0.0.0-20201119102817-f84b799fce68/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= |  | ||||||
| golang.org/x/sys v0.0.0-20210423082822-04245dca01da/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs= |  | ||||||
| golang.org/x/sys v0.1.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |  | ||||||
| golang.org/x/sys v0.5.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= |  | ||||||
| golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= | ||||||
| golang.org/x/sys v0.14.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/sys v0.29.0 h1:TPYlXGxvx1MGTn2GiZDhnjPA9wZzZeGKHHmKhHYvgaU= | ||||||
| golang.org/x/sys v0.25.0 h1:r+8e+loiHxRqhXVl6ML1nO3l1+oFoWbnlu2Ehimmi34= | golang.org/x/sys v0.29.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | ||||||
| golang.org/x/sys v0.25.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/text v0.21.0 h1:zyQAAkrwaneQ066sspRyJaG9VNi/YJ1NfzcGB3hZ/qo= | ||||||
| golang.org/x/sys v0.26.0 h1:KHjCJyddX0LoSTb3J+vWpupP9p0oznkqVk/IfjymZbo= | golang.org/x/text v0.21.0/go.mod h1:4IBbMaMmOPCJ8SecivzSH54+73PCFmPWxNTLm+vZkEQ= | ||||||
| golang.org/x/sys v0.26.0/go.mod h1:/VUhepiaJMQUp4+oa/7Zr1D23ma6VTLIYjOOTFZPUcA= | golang.org/x/tools v0.29.0 h1:Xx0h3TtM9rzQpQuR4dKLrdglAmCEN5Oi+P74JdhdzXE= | ||||||
| golang.org/x/term v0.0.0-20201126162022-7de9c90e9dd1/go.mod h1:bj7SfCRtBDWHUb9snDiAeCFNEtKQo2Wmx5Cou7ajbmo= | golang.org/x/tools v0.29.0/go.mod h1:KMQVMRsVxU6nHCFXrBPhDB8XncLNLM0lIy/F14RP588= | ||||||
| golang.org/x/text v0.3.3/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | google.golang.org/protobuf v1.36.3 h1:82DV7MYdb8anAVi3qge1wSnMDrnKK7ebr+I0hHRN1BU= | ||||||
| golang.org/x/text v0.3.6/go.mod h1:5Zoc/QRtKVWzQhOtBMvqHzDpF6irO9z98xDceosuGiQ= | google.golang.org/protobuf v1.36.3/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE= | ||||||
| golang.org/x/text v0.18.0 h1:XvMDiNzPAl0jr17s6W9lcaIhGUfUORdGCNsuLmPG224= |  | ||||||
| golang.org/x/text v0.18.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= |  | ||||||
| golang.org/x/text v0.19.0 h1:kTxAhCbGbxhK0IwgSKiMO5awPoDQ0RpfiVYBfK860YM= |  | ||||||
| golang.org/x/text v0.19.0/go.mod h1:BuEKDfySbSR4drPmRPG/7iBdf8hvFMuRexcpahXilzY= |  | ||||||
| golang.org/x/time v0.5.0 h1:o7cqy6amK/52YcAKIPlM3a+Fpj35zvRj2TP+e1xFSfk= |  | ||||||
| golang.org/x/time v0.5.0/go.mod h1:3BpzKBy/shNhVucY/MWOyx10tF3SFh9QdLuxbVysPQM= |  | ||||||
| golang.org/x/tools v0.0.0-20180917221912-90fa682c2a6e/go.mod h1:n7NCudcB/nEzxVGmLbDWY5pfWTLqBcC2KZ6jyYvM4mQ= |  | ||||||
| golang.org/x/tools v0.23.0 h1:SGsXPZ+2l4JsgaCKkx+FQ9YZ5XEtA1GZYuoDjenLjvg= |  | ||||||
| golang.org/x/tools v0.23.0/go.mod h1:pnu6ufv6vQkll6szChhK3C3L/ruaIv5eBeztNG8wtsI= |  | ||||||
| golang.org/x/tools v0.26.0 h1:v/60pFQmzmT9ExmjDv2gGIfi3OqfKoEP6I5+umXlbnQ= |  | ||||||
| golang.org/x/tools v0.26.0/go.mod h1:TPVVj70c7JJ3WCazhD8OdXcZg/og+b9+tH/KxylGwH0= |  | ||||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240227224415-6ceb2ff114de h1:cZGRis4/ot9uVm639a+rHCUaG0JJHEsdyzSQTMX+suY= |  | ||||||
| google.golang.org/genproto/googleapis/rpc v0.0.0-20240227224415-6ceb2ff114de/go.mod h1:H4O17MA/PE9BsGx3w+a+W2VOLLD1Qf7oJneAoU6WktY= |  | ||||||
| google.golang.org/grpc v1.63.2 h1:MUeiw1B2maTVZthpU5xvASfTh3LDbxHd6IJ6QQVU+xM= |  | ||||||
| google.golang.org/grpc v1.63.2/go.mod h1:WAX/8DgncnokcFUldAxq7GeB5DXHDbMF+lLvDomNkRA= |  | ||||||
| google.golang.org/protobuf v1.34.2 h1:6xV6lTsCfpGD21XK49h7MhtcApnLqkfYgPcdHftf6hg= |  | ||||||
| google.golang.org/protobuf v1.34.2/go.mod h1:qYOHts0dSfpeUzUFpOMr/WGzszTmLH+DiWniOlNbLDw= |  | ||||||
| google.golang.org/protobuf v1.35.1 h1:m3LfL6/Ca+fqnjnlqQXNpFPABW1UD7mjh8KO2mKFytA= |  | ||||||
| google.golang.org/protobuf v1.35.1/go.mod h1:9fA7Ob0pmnwhb644+1+CVWFRbNajQ6iRojtC/QF5bRE= |  | ||||||
| gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | ||||||
| gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU= | gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f h1:BLraFXnmrev5lT+xlilqcH8XK9/i0At2xKjWk4p6zsU= | ||||||
| gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= | ||||||
| gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||||
| gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= | gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= | ||||||
| gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= | ||||||
| lukechampine.com/blake3 v1.3.0 h1:sJ3XhFINmHSrYCgl958hscfIa3bw8x4DqMP3u1YvoYE= |  | ||||||
| lukechampine.com/blake3 v1.3.0/go.mod h1:0OFRp7fBtAylGVCO40o87sbupkyIGgbpv1+M1k1LM6k= |  | ||||||
| nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= | nullprogram.com/x/optparse v1.0.0/go.mod h1:KdyPE+Igbe0jQUrVfMqDMeJQIJZEuyV7pjYmp6pbG50= | ||||||
|   | |||||||
| @@ -1,7 +1,6 @@ | |||||||
| package model | package model | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	C "github.com/nitezs/sub2sing-box/constant" |  | ||||||
| 	"github.com/sagernet/sing-box/option" | 	"github.com/sagernet/sing-box/option" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| @@ -10,20 +9,22 @@ type Outbound struct { | |||||||
| } | } | ||||||
|  |  | ||||||
| func (h *Outbound) GetOutbounds() []string { | func (h *Outbound) GetOutbounds() []string { | ||||||
| 	if h.Type == C.TypeSelector { | 	switch v := h.Options.(type) { | ||||||
| 		return h.SelectorOptions.Outbounds | 	case option.URLTestOutboundOptions: | ||||||
| 	} | 		return v.Outbounds | ||||||
| 	if h.Type == C.TypeURLTest { | 	case option.SelectorOutboundOptions: | ||||||
| 		return h.URLTestOptions.Outbounds | 		return v.Outbounds | ||||||
| 	} | 	} | ||||||
| 	return nil | 	return nil | ||||||
| } | } | ||||||
|  |  | ||||||
| func (h *Outbound) SetOutbounds(outbounds []string) { | func (h *Outbound) SetOutbounds(outbounds []string) { | ||||||
| 	if h.Type == C.TypeSelector { | 	switch v := h.Options.(type) { | ||||||
| 		h.SelectorOptions.Outbounds = outbounds | 	case option.URLTestOutboundOptions: | ||||||
| 	} | 		v.Outbounds = outbounds | ||||||
| 	if h.Type == C.TypeURLTest { | 		h.Options = v | ||||||
| 		h.URLTestOptions.Outbounds = outbounds | 	case option.SelectorOutboundOptions: | ||||||
|  | 		v.Outbounds = outbounds | ||||||
|  | 		h.Options = v | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| package model | package model | ||||||
|  |  | ||||||
| import ( | import ( | ||||||
| 	C "github.com/nitezs/sub2sing-box/constant" | 	"github.com/sagernet/sing-box/option" | ||||||
|  |  | ||||||
| 	"golang.org/x/text/collate" | 	"golang.org/x/text/collate" | ||||||
| 	"golang.org/x/text/language" | 	"golang.org/x/text/language" | ||||||
| @@ -13,17 +13,17 @@ func (a SortByNumber) Len() int      { return len(a) } | |||||||
| func (a SortByNumber) Swap(i, j int) { a[i], a[j] = a[j], a[i] } | func (a SortByNumber) Swap(i, j int) { a[i], a[j] = a[j], a[i] } | ||||||
| func (a SortByNumber) Less(i, j int) bool { | func (a SortByNumber) Less(i, j int) bool { | ||||||
| 	var size1, size2 int | 	var size1, size2 int | ||||||
| 	if a[i].Type == C.TypeSelector { | 	switch v := a[i].Options.(type) { | ||||||
| 		size1 = len(a[i].SelectorOptions.Outbounds) | 	case option.SelectorOutboundOptions: | ||||||
|  | 		size1 = len(v.Outbounds) | ||||||
|  | 	case option.URLTestOutboundOptions: | ||||||
|  | 		size1 = len(v.Outbounds) | ||||||
| 	} | 	} | ||||||
| 	if a[i].Type == C.TypeURLTest { | 	switch v := a[j].Options.(type) { | ||||||
| 		size1 = len(a[j].URLTestOptions.Outbounds) | 	case option.SelectorOutboundOptions: | ||||||
| 	} | 		size2 = len(v.Outbounds) | ||||||
| 	if a[j].Type == C.TypeSelector { | 	case option.URLTestOutboundOptions: | ||||||
| 		size2 = len(a[j].SelectorOptions.Outbounds) | 		size2 = len(v.Outbounds) | ||||||
| 	} |  | ||||||
| 	if a[j].Type == C.TypeURLTest { |  | ||||||
| 		size2 = len(a[j].URLTestOptions.Outbounds) |  | ||||||
| 	} | 	} | ||||||
| 	return size1 < size2 | 	return size1 < size2 | ||||||
| } | } | ||||||
|   | |||||||
| @@ -72,26 +72,28 @@ func ParseHysteria(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
| 	remarks = strings.TrimSpace(remarks) | 	remarks = strings.TrimSpace(remarks) | ||||||
|  |  | ||||||
| 	return model.Outbound{Outbound: option.Outbound{ | 	outboundOptions := option.HysteriaOutboundOptions{ | ||||||
| 		Type: "hysteria", | 		ServerOptions: option.ServerOptions{ | ||||||
| 		Tag:  remarks, | 			Server:     server, | ||||||
| 		HysteriaOptions: option.HysteriaOutboundOptions{ | 			ServerPort: port, | ||||||
| 			ServerOptions: option.ServerOptions{ | 		}, | ||||||
| 				Server:     server, | 		Up:      upmbps, | ||||||
| 				ServerPort: port, | 		Down:    downmbps, | ||||||
| 			}, | 		Auth:    []byte(auth), | ||||||
| 			Up:      upmbps, | 		Obfs:    obfs, | ||||||
| 			Down:    downmbps, | 		Network: option.NetworkList(protocol), | ||||||
| 			Auth:    []byte(auth), | 		OutboundTLSOptionsContainer: option.OutboundTLSOptionsContainer{ | ||||||
| 			Obfs:    obfs, | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 			Network: option.NetworkList(protocol), | 				Enabled:  enableTLS, | ||||||
| 			OutboundTLSOptionsContainer: option.OutboundTLSOptionsContainer{ | 				Insecure: insecureBool, | ||||||
| 				TLS: &option.OutboundTLSOptions{ | 				ALPN:     alpn, | ||||||
| 					Enabled:  enableTLS, |  | ||||||
| 					Insecure: insecureBool, |  | ||||||
| 					ALPN:     alpn, |  | ||||||
| 				}, |  | ||||||
| 			}, | 			}, | ||||||
| 		}, | 		}, | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  | 	return model.Outbound{Outbound: option.Outbound{ | ||||||
|  | 		Type:    "hysteria", | ||||||
|  | 		Tag:     remarks, | ||||||
|  | 		Options: outboundOptions, | ||||||
| 	}}, nil | 	}}, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -71,36 +71,40 @@ func ParseHysteria2(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
| 	remarks = strings.TrimSpace(remarks) | 	remarks = strings.TrimSpace(remarks) | ||||||
|  |  | ||||||
| 	result := model.Outbound{ | 	outboundOptions := option.Hysteria2OutboundOptions{ | ||||||
| 		Outbound: option.Outbound{ | 		ServerOptions: option.ServerOptions{ | ||||||
| 			Type: "hysteria2", | 			Server:     server, | ||||||
| 			Tag:  strings.TrimSpace(remarks), | 			ServerPort: port, | ||||||
| 			Hysteria2Options: option.Hysteria2OutboundOptions{ | 		}, | ||||||
| 				ServerOptions: option.ServerOptions{ | 		Password: password, | ||||||
| 					Server:     server, | 		OutboundTLSOptionsContainer: option.OutboundTLSOptionsContainer{ | ||||||
| 					ServerPort: port, | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				}, | 				Enabled:    enableTLS, | ||||||
| 				Password: password, | 				Insecure:   insecureBool, | ||||||
| 				OutboundTLSOptionsContainer: option.OutboundTLSOptionsContainer{ | 				ServerName: sni, | ||||||
| 					TLS: &option.OutboundTLSOptions{ | 				ALPN:       alpn, | ||||||
| 						Enabled:    enableTLS, |  | ||||||
| 						Insecure:   insecureBool, |  | ||||||
| 						ServerName: sni, |  | ||||||
| 						ALPN:       alpn, |  | ||||||
| 					}, |  | ||||||
| 				}, |  | ||||||
| 				Network: option.NetworkList(network), |  | ||||||
| 			}, | 			}, | ||||||
| 		}, | 		}, | ||||||
|  | 		Network: option.NetworkList(network), | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if pinSHA256 != "" { | 	if pinSHA256 != "" { | ||||||
| 		result.Hysteria2Options.OutboundTLSOptionsContainer.TLS.Certificate = []string{pinSHA256} | 		outboundOptions.TLS.Certificate = []string{pinSHA256} | ||||||
| 	} | 	} | ||||||
| 	if obfs != "" { | 	if obfs != "" { | ||||||
| 		result.Hysteria2Options.Obfs = &option.Hysteria2Obfs{ | 		outboundOptions.Obfs = &option.Hysteria2Obfs{ | ||||||
| 			Type:     obfs, | 			Type:     obfs, | ||||||
| 			Password: obfsPassword, | 			Password: obfsPassword, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	result := model.Outbound{ | ||||||
|  | 		Outbound: option.Outbound{ | ||||||
|  | 			Type:    "hysteria2", | ||||||
|  | 			Tag:     strings.TrimSpace(remarks), | ||||||
|  | 			Options: outboundOptions, | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	return result, nil | 	return result, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -107,20 +107,22 @@ func ParseShadowsocks(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
| 	remarks = strings.TrimSpace(remarks) | 	remarks = strings.TrimSpace(remarks) | ||||||
|  |  | ||||||
|  | 	outboundOptions := option.ShadowsocksOutboundOptions{ | ||||||
|  | 		ServerOptions: option.ServerOptions{ | ||||||
|  | 			Server:     server, | ||||||
|  | 			ServerPort: port, | ||||||
|  | 		}, | ||||||
|  | 		Method:        method, | ||||||
|  | 		Password:      password, | ||||||
|  | 		Plugin:        plugin, | ||||||
|  | 		PluginOptions: options, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	result := model.Outbound{ | 	result := model.Outbound{ | ||||||
| 		Outbound: option.Outbound{ | 		Outbound: option.Outbound{ | ||||||
| 			Type: "shadowsocks", | 			Type:    "shadowsocks", | ||||||
| 			Tag:  remarks, | 			Tag:     remarks, | ||||||
| 			ShadowsocksOptions: option.ShadowsocksOutboundOptions{ | 			Options: outboundOptions, | ||||||
| 				ServerOptions: option.ServerOptions{ |  | ||||||
| 					Server:     server, |  | ||||||
| 					ServerPort: port, |  | ||||||
| 				}, |  | ||||||
| 				Method:        method, |  | ||||||
| 				Password:      password, |  | ||||||
| 				Plugin:        plugin, |  | ||||||
| 				PluginOptions: options, |  | ||||||
| 			}, |  | ||||||
| 		}, | 		}, | ||||||
| 	} | 	} | ||||||
| 	return result, nil | 	return result, nil | ||||||
|   | |||||||
| @@ -70,18 +70,21 @@ func ParseSocks(proxy string) (model.Outbound, error) { | |||||||
| 			password = splitStr[1] | 			password = splitStr[1] | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	outboundOptions := option.SOCKSOutboundOptions{ | ||||||
|  | 		ServerOptions: option.ServerOptions{ | ||||||
|  | 			Server:     server, | ||||||
|  | 			ServerPort: port, | ||||||
|  | 		}, | ||||||
|  | 		Username: username, | ||||||
|  | 		Password: password, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	return model.Outbound{ | 	return model.Outbound{ | ||||||
| 		Outbound: option.Outbound{ | 		Outbound: option.Outbound{ | ||||||
| 			Type: "socks", | 			Type:    "socks", | ||||||
| 			Tag:  remarks, | 			Tag:     remarks, | ||||||
| 			SocksOptions: option.SocksOutboundOptions{ | 			Options: outboundOptions, | ||||||
| 				ServerOptions: option.ServerOptions{ |  | ||||||
| 					Server:     server, |  | ||||||
| 					ServerPort: port, |  | ||||||
| 				}, |  | ||||||
| 				Username: username, |  | ||||||
| 				Password: password, |  | ||||||
| 			}, |  | ||||||
| 		}, | 		}, | ||||||
| 	}, nil | 	}, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ import ( | |||||||
| 	"github.com/nitezs/sub2sing-box/constant" | 	"github.com/nitezs/sub2sing-box/constant" | ||||||
| 	"github.com/nitezs/sub2sing-box/model" | 	"github.com/nitezs/sub2sing-box/model" | ||||||
| 	"github.com/sagernet/sing-box/option" | 	"github.com/sagernet/sing-box/option" | ||||||
|  | 	"github.com/sagernet/sing/common/json/badoption" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func ParseTrojan(proxy string) (model.Outbound, error) { | func ParseTrojan(proxy string) (model.Outbound, error) { | ||||||
| @@ -69,21 +70,17 @@ func ParseTrojan(proxy string) (model.Outbound, error) { | |||||||
|  |  | ||||||
| 	enableUTLS := fp != "" | 	enableUTLS := fp != "" | ||||||
|  |  | ||||||
| 	result := model.Outbound{Outbound: option.Outbound{ | 	outboundOptions := option.TrojanOutboundOptions{ | ||||||
| 		Type: "trojan", | 		ServerOptions: option.ServerOptions{ | ||||||
| 		Tag:  remarks, | 			Server:     server, | ||||||
| 		TrojanOptions: option.TrojanOutboundOptions{ | 			ServerPort: port, | ||||||
| 			ServerOptions: option.ServerOptions{ |  | ||||||
| 				Server:     server, |  | ||||||
| 				ServerPort: port, |  | ||||||
| 			}, |  | ||||||
| 			Password: password, |  | ||||||
| 			Network:  option.NetworkList(network), |  | ||||||
| 		}, | 		}, | ||||||
| 	}} | 		Password: password, | ||||||
|  | 		Network:  option.NetworkList(network), | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if security == "xtls" || security == "tls" || sni != "" { | 	if security == "xtls" || security == "tls" || sni != "" { | ||||||
| 		result.TrojanOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | 		outboundOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | ||||||
| 			TLS: &option.OutboundTLSOptions{ | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				Enabled:    true, | 				Enabled:    true, | ||||||
| 				ALPN:       alpn, | 				ALPN:       alpn, | ||||||
| @@ -94,7 +91,7 @@ func ParseTrojan(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if security == "reality" { | 	if security == "reality" { | ||||||
| 		result.TrojanOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | 		outboundOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | ||||||
| 			TLS: &option.OutboundTLSOptions{ | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				Enabled:    true, | 				Enabled:    true, | ||||||
| 				ServerName: sni, | 				ServerName: sni, | ||||||
| @@ -113,11 +110,11 @@ func ParseTrojan(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if network == "ws" { | 	if network == "ws" { | ||||||
| 		result.TrojanOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "ws", | 			Type: "ws", | ||||||
| 			WebsocketOptions: option.V2RayWebsocketOptions{ | 			WebsocketOptions: option.V2RayWebsocketOptions{ | ||||||
| 				Path: path, | 				Path: path, | ||||||
| 				Headers: map[string]option.Listable[string]{ | 				Headers: badoption.HTTPHeader{ | ||||||
| 					"Host": {host}, | 					"Host": {host}, | ||||||
| 				}, | 				}, | ||||||
| 			}, | 			}, | ||||||
| @@ -125,7 +122,7 @@ func ParseTrojan(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if network == "http" { | 	if network == "http" { | ||||||
| 		result.TrojanOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "http", | 			Type: "http", | ||||||
| 			HTTPOptions: option.V2RayHTTPOptions{ | 			HTTPOptions: option.V2RayHTTPOptions{ | ||||||
| 				Host: []string{host}, | 				Host: []string{host}, | ||||||
| @@ -135,19 +132,26 @@ func ParseTrojan(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if network == "quic" { | 	if network == "quic" { | ||||||
| 		result.TrojanOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type:        "quic", | 			Type:        "quic", | ||||||
| 			QUICOptions: option.V2RayQUICOptions{}, | 			QUICOptions: option.V2RayQUICOptions{}, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if network == "grpc" { | 	if network == "grpc" { | ||||||
| 		result.TrojanOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "grpc", | 			Type: "grpc", | ||||||
| 			GRPCOptions: option.V2RayGRPCOptions{ | 			GRPCOptions: option.V2RayGRPCOptions{ | ||||||
| 				ServiceName: serviceName, | 				ServiceName: serviceName, | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	result := model.Outbound{Outbound: option.Outbound{ | ||||||
|  | 		Type:    "trojan", | ||||||
|  | 		Tag:     remarks, | ||||||
|  | 		Options: outboundOptions, | ||||||
|  | 	}} | ||||||
|  |  | ||||||
| 	return result, nil | 	return result, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -8,6 +8,7 @@ import ( | |||||||
| 	"github.com/nitezs/sub2sing-box/constant" | 	"github.com/nitezs/sub2sing-box/constant" | ||||||
| 	"github.com/nitezs/sub2sing-box/model" | 	"github.com/nitezs/sub2sing-box/model" | ||||||
| 	"github.com/sagernet/sing-box/option" | 	"github.com/sagernet/sing-box/option" | ||||||
|  | 	"github.com/sagernet/sing/common/json/badoption" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func ParseVless(proxy string) (model.Outbound, error) { | func ParseVless(proxy string) (model.Outbound, error) { | ||||||
| @@ -60,21 +61,17 @@ func ParseVless(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
| 	remarks = strings.TrimSpace(remarks) | 	remarks = strings.TrimSpace(remarks) | ||||||
|  |  | ||||||
| 	result := model.Outbound{Outbound: option.Outbound{ | 	outboundOptions := option.VLESSOutboundOptions{ | ||||||
| 		Type: "vless", | 		ServerOptions: option.ServerOptions{ | ||||||
| 		Tag:  remarks, | 			Server:     server, | ||||||
| 		VLESSOptions: option.VLESSOutboundOptions{ | 			ServerPort: port, | ||||||
| 			ServerOptions: option.ServerOptions{ |  | ||||||
| 				Server:     server, |  | ||||||
| 				ServerPort: port, |  | ||||||
| 			}, |  | ||||||
| 			UUID: uuid, |  | ||||||
| 			Flow: flow, |  | ||||||
| 		}, | 		}, | ||||||
| 	}} | 		UUID: uuid, | ||||||
|  | 		Flow: flow, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	if security == "tls" { | 	if security == "tls" { | ||||||
| 		result.VLESSOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | 		outboundOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | ||||||
| 			TLS: &option.OutboundTLSOptions{ | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				Enabled:    true, | 				Enabled:    true, | ||||||
| 				ALPN:       alpn, | 				ALPN:       alpn, | ||||||
| @@ -85,7 +82,7 @@ func ParseVless(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if security == "reality" { | 	if security == "reality" { | ||||||
| 		result.VLESSOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | 		outboundOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | ||||||
| 			TLS: &option.OutboundTLSOptions{ | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				Enabled:    true, | 				Enabled:    true, | ||||||
| 				ALPN:       alpn, | 				ALPN:       alpn, | ||||||
| @@ -105,29 +102,29 @@ func ParseVless(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if _type == "ws" { | 	if _type == "ws" { | ||||||
| 		result.VLESSOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "ws", | 			Type: "ws", | ||||||
| 			WebsocketOptions: option.V2RayWebsocketOptions{ | 			WebsocketOptions: option.V2RayWebsocketOptions{ | ||||||
| 				Path: path, | 				Path: path, | ||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 		if host != "" { | 		if host != "" { | ||||||
| 			if result.VLESSOptions.Transport.WebsocketOptions.Headers == nil { | 			if outboundOptions.Transport.WebsocketOptions.Headers == nil { | ||||||
| 				result.VLESSOptions.Transport.WebsocketOptions.Headers = make(map[string]option.Listable[string]) | 				outboundOptions.Transport.WebsocketOptions.Headers = badoption.HTTPHeader{} | ||||||
| 			} | 			} | ||||||
| 			result.VLESSOptions.Transport.WebsocketOptions.Headers["Host"] = option.Listable[string]{host} | 			outboundOptions.Transport.WebsocketOptions.Headers["Host"] = badoption.Listable[string]{host} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if _type == "quic" { | 	if _type == "quic" { | ||||||
| 		result.VLESSOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type:        "quic", | 			Type:        "quic", | ||||||
| 			QUICOptions: option.V2RayQUICOptions{}, | 			QUICOptions: option.V2RayQUICOptions{}, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if _type == "grpc" { | 	if _type == "grpc" { | ||||||
| 		result.VLESSOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "grpc", | 			Type: "grpc", | ||||||
| 			GRPCOptions: option.V2RayGRPCOptions{ | 			GRPCOptions: option.V2RayGRPCOptions{ | ||||||
| 				ServiceName: serviceName, | 				ServiceName: serviceName, | ||||||
| @@ -144,7 +141,7 @@ func ParseVless(proxy string) (model.Outbound, error) { | |||||||
| 				Message: err.Error(), | 				Message: err.Error(), | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 		result.VLESSOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "http", | 			Type: "http", | ||||||
| 			HTTPOptions: option.V2RayHTTPOptions{ | 			HTTPOptions: option.V2RayHTTPOptions{ | ||||||
| 				Host: strings.Split(hosts, ","), | 				Host: strings.Split(hosts, ","), | ||||||
| @@ -153,11 +150,17 @@ func ParseVless(proxy string) (model.Outbound, error) { | |||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if enableUTLS { | 	if enableUTLS { | ||||||
| 		result.VLESSOptions.OutboundTLSOptionsContainer.TLS.UTLS = &option.OutboundUTLSOptions{ | 		outboundOptions.OutboundTLSOptionsContainer.TLS.UTLS = &option.OutboundUTLSOptions{ | ||||||
| 			Enabled:     enableUTLS, | 			Enabled:     enableUTLS, | ||||||
| 			Fingerprint: fp, | 			Fingerprint: fp, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	result := model.Outbound{Outbound: option.Outbound{ | ||||||
|  | 		Type:    "vless", | ||||||
|  | 		Tag:     remarks, | ||||||
|  | 		Options: outboundOptions, | ||||||
|  | 	}} | ||||||
|  |  | ||||||
| 	return result, nil | 	return result, nil | ||||||
| } | } | ||||||
|   | |||||||
| @@ -10,6 +10,7 @@ import ( | |||||||
| 	"github.com/nitezs/sub2sing-box/model" | 	"github.com/nitezs/sub2sing-box/model" | ||||||
| 	"github.com/nitezs/sub2sing-box/util" | 	"github.com/nitezs/sub2sing-box/util" | ||||||
| 	"github.com/sagernet/sing-box/option" | 	"github.com/sagernet/sing-box/option" | ||||||
|  | 	"github.com/sagernet/sing/common/json/badoption" | ||||||
| ) | ) | ||||||
|  |  | ||||||
| func ParseVmess(proxy string) (model.Outbound, error) { | func ParseVmess(proxy string) (model.Outbound, error) { | ||||||
| @@ -64,20 +65,14 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 		name = vmess.Ps | 		name = vmess.Ps | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	result := model.Outbound{ | 	outboundOptions := option.VMessOutboundOptions{ | ||||||
| 		Outbound: option.Outbound{ | 		ServerOptions: option.ServerOptions{ | ||||||
| 			Type: "vmess", | 			Server:     vmess.Add, | ||||||
| 			Tag:  name, | 			ServerPort: port, | ||||||
| 			VMessOptions: option.VMessOutboundOptions{ |  | ||||||
| 				ServerOptions: option.ServerOptions{ |  | ||||||
| 					Server:     vmess.Add, |  | ||||||
| 					ServerPort: port, |  | ||||||
| 				}, |  | ||||||
| 				UUID:     vmess.Id, |  | ||||||
| 				AlterId:  aid, |  | ||||||
| 				Security: vmess.Scy, |  | ||||||
| 			}, |  | ||||||
| 		}, | 		}, | ||||||
|  | 		UUID:     vmess.Id, | ||||||
|  | 		AlterId:  aid, | ||||||
|  | 		Security: vmess.Scy, | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	if vmess.Tls == "tls" { | 	if vmess.Tls == "tls" { | ||||||
| @@ -87,7 +82,7 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 		} else { | 		} else { | ||||||
| 			alpn = nil | 			alpn = nil | ||||||
| 		} | 		} | ||||||
| 		result.VMessOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | 		outboundOptions.OutboundTLSOptionsContainer = option.OutboundTLSOptionsContainer{ | ||||||
| 			TLS: &option.OutboundTLSOptions{ | 			TLS: &option.OutboundTLSOptions{ | ||||||
| 				Enabled: true, | 				Enabled: true, | ||||||
| 				UTLS: &option.OutboundUTLSOptions{ | 				UTLS: &option.OutboundUTLSOptions{ | ||||||
| @@ -98,7 +93,7 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 			}, | 			}, | ||||||
| 		} | 		} | ||||||
| 		if vmess.Fp != "" { | 		if vmess.Fp != "" { | ||||||
| 			result.VMessOptions.OutboundTLSOptionsContainer.TLS.UTLS = &option.OutboundUTLSOptions{ | 			outboundOptions.OutboundTLSOptionsContainer.TLS.UTLS = &option.OutboundUTLSOptions{ | ||||||
| 				Enabled:     true, | 				Enabled:     true, | ||||||
| 				Fingerprint: vmess.Fp, | 				Fingerprint: vmess.Fp, | ||||||
| 			} | 			} | ||||||
| @@ -112,11 +107,11 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 		if vmess.Host == "" { | 		if vmess.Host == "" { | ||||||
| 			vmess.Host = vmess.Add | 			vmess.Host = vmess.Add | ||||||
| 		} | 		} | ||||||
| 		result.VMessOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type: "ws", | 			Type: "ws", | ||||||
| 			WebsocketOptions: option.V2RayWebsocketOptions{ | 			WebsocketOptions: option.V2RayWebsocketOptions{ | ||||||
| 				Path: vmess.Path, | 				Path: vmess.Path, | ||||||
| 				Headers: map[string]option.Listable[string]{ | 				Headers: badoption.HTTPHeader{ | ||||||
| 					"Host": {vmess.Host}, | 					"Host": {vmess.Host}, | ||||||
| 				}, | 				}, | ||||||
| 			}, | 			}, | ||||||
| @@ -125,7 +120,7 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
|  |  | ||||||
| 	if vmess.Net == "quic" { | 	if vmess.Net == "quic" { | ||||||
| 		quic := option.V2RayQUICOptions{} | 		quic := option.V2RayQUICOptions{} | ||||||
| 		result.VMessOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type:        "quic", | 			Type:        "quic", | ||||||
| 			QUICOptions: quic, | 			QUICOptions: quic, | ||||||
| 		} | 		} | ||||||
| @@ -136,7 +131,7 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 			ServiceName:         vmess.Path, | 			ServiceName:         vmess.Path, | ||||||
| 			PermitWithoutStream: true, | 			PermitWithoutStream: true, | ||||||
| 		} | 		} | ||||||
| 		result.VMessOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type:        "grpc", | 			Type:        "grpc", | ||||||
| 			GRPCOptions: grpc, | 			GRPCOptions: grpc, | ||||||
| 		} | 		} | ||||||
| @@ -147,11 +142,19 @@ func ParseVmess(proxy string) (model.Outbound, error) { | |||||||
| 			Host: strings.Split(vmess.Host, ","), | 			Host: strings.Split(vmess.Host, ","), | ||||||
| 			Path: vmess.Path, | 			Path: vmess.Path, | ||||||
| 		} | 		} | ||||||
| 		result.VMessOptions.Transport = &option.V2RayTransportOptions{ | 		outboundOptions.Transport = &option.V2RayTransportOptions{ | ||||||
| 			Type:        "http", | 			Type:        "http", | ||||||
| 			HTTPOptions: httpOps, | 			HTTPOptions: httpOps, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
|  | 	result := model.Outbound{ | ||||||
|  | 		Outbound: option.Outbound{ | ||||||
|  | 			Type:    "vmess", | ||||||
|  | 			Tag:     name, | ||||||
|  | 			Options: outboundOptions, | ||||||
|  | 		}, | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	return result, nil | 	return result, nil | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user