mirror of
https://github.com/apernet/hysteria.git
synced 2025-04-03 04:27:39 +03:00
Merge pull request #1287 from apernet/fix-tun-ipv6-disable
fix: tun failed on linux when ipv6.disable=1
This commit is contained in:
commit
5520bcc405
4 changed files with 58 additions and 0 deletions
14
app/internal/tun/check_ipv6_others.go
Normal file
14
app/internal/tun/check_ipv6_others.go
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
//go:build !unix && !windows
|
||||||
|
|
||||||
|
package tun
|
||||||
|
|
||||||
|
import "net"
|
||||||
|
|
||||||
|
func isIPv6Supported() bool {
|
||||||
|
lis, err := net.ListenPacket("udp6", "[::1]:0")
|
||||||
|
if err != nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
_ = lis.Close()
|
||||||
|
return true
|
||||||
|
}
|
16
app/internal/tun/check_ipv6_unix.go
Normal file
16
app/internal/tun/check_ipv6_unix.go
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
//go:build unix
|
||||||
|
|
||||||
|
package tun
|
||||||
|
|
||||||
|
import (
|
||||||
|
"golang.org/x/sys/unix"
|
||||||
|
)
|
||||||
|
|
||||||
|
func isIPv6Supported() bool {
|
||||||
|
sock, err := unix.Socket(unix.AF_INET6, unix.SOCK_DGRAM, unix.IPPROTO_UDP)
|
||||||
|
if err != nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
_ = unix.Close(sock)
|
||||||
|
return true
|
||||||
|
}
|
24
app/internal/tun/check_ipv6_windows.go
Normal file
24
app/internal/tun/check_ipv6_windows.go
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
//go:build windows
|
||||||
|
|
||||||
|
package tun
|
||||||
|
|
||||||
|
import (
|
||||||
|
"golang.org/x/sys/windows"
|
||||||
|
)
|
||||||
|
|
||||||
|
func isIPv6Supported() bool {
|
||||||
|
var wsaData windows.WSAData
|
||||||
|
err := windows.WSAStartup(uint32(0x202), &wsaData)
|
||||||
|
if err != nil {
|
||||||
|
// Failing silently: it is not our duty to report such errors
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
defer windows.WSACleanup()
|
||||||
|
|
||||||
|
sock, err := windows.Socket(windows.AF_INET6, windows.SOCK_DGRAM, windows.IPPROTO_UDP)
|
||||||
|
if err != nil {
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
_ = windows.Closesocket(sock)
|
||||||
|
return true
|
||||||
|
}
|
|
@ -49,6 +49,10 @@ type EventLogger interface {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Server) Serve() error {
|
func (s *Server) Serve() error {
|
||||||
|
if !isIPv6Supported() {
|
||||||
|
s.Logger.Warn("tun-pre-check", zap.String("msg", "IPv6 is not supported or enabled on this system, TUN device is created without IPv6 support."))
|
||||||
|
s.Inet6Address = nil
|
||||||
|
}
|
||||||
tunOpts := tun.Options{
|
tunOpts := tun.Options{
|
||||||
Name: s.IfName,
|
Name: s.IfName,
|
||||||
Inet4Address: s.Inet4Address,
|
Inet4Address: s.Inet4Address,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue