2024-04-08 18:56:52 +02:00
|
|
|
//go:build !android
|
|
|
|
|
|
|
|
package net
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"syscall"
|
2024-11-19 14:14:58 +01:00
|
|
|
|
|
|
|
log "github.com/sirupsen/logrus"
|
2024-04-08 18:56:52 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// SetSocketMark sets the SO_MARK option on the given socket connection
|
|
|
|
func SetSocketMark(conn syscall.Conn) error {
|
2024-11-26 23:34:27 +01:00
|
|
|
if isSocketMarkDisabled() {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2024-04-08 18:56:52 +02:00
|
|
|
sysconn, err := conn.SyscallConn()
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("get raw conn: %w", err)
|
|
|
|
}
|
|
|
|
|
2024-11-26 23:34:27 +01:00
|
|
|
return setRawSocketMark(sysconn)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetSocketOpt sets the SO_MARK option on the given file descriptor
|
|
|
|
func SetSocketOpt(fd int) error {
|
|
|
|
if isSocketMarkDisabled() {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
return setSocketOptInt(fd)
|
2024-04-08 18:56:52 +02:00
|
|
|
}
|
|
|
|
|
2024-11-26 23:34:27 +01:00
|
|
|
func setRawSocketMark(conn syscall.RawConn) error {
|
2024-04-08 18:56:52 +02:00
|
|
|
var setErr error
|
|
|
|
|
|
|
|
err := conn.Control(func(fd uintptr) {
|
2024-11-26 23:34:27 +01:00
|
|
|
if isSocketMarkDisabled() {
|
|
|
|
return
|
|
|
|
}
|
|
|
|
setErr = setSocketOptInt(int(fd))
|
2024-04-08 18:56:52 +02:00
|
|
|
})
|
|
|
|
if err != nil {
|
|
|
|
return fmt.Errorf("control: %w", err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if setErr != nil {
|
|
|
|
return fmt.Errorf("set SO_MARK: %w", setErr)
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2024-04-12 16:53:11 +02:00
|
|
|
|
2024-11-26 23:34:27 +01:00
|
|
|
func setSocketOptInt(fd int) error {
|
|
|
|
return syscall.SetsockoptInt(fd, syscall.SOL_SOCKET, syscall.SO_MARK, NetbirdFwmark)
|
|
|
|
}
|
|
|
|
|
|
|
|
func isSocketMarkDisabled() bool {
|
2024-04-12 16:53:11 +02:00
|
|
|
if CustomRoutingDisabled() {
|
2024-11-19 14:14:58 +01:00
|
|
|
log.Infof("Custom routing is disabled, skipping SO_MARK")
|
2024-11-26 23:34:27 +01:00
|
|
|
return true
|
2024-11-19 14:14:58 +01:00
|
|
|
}
|
|
|
|
|
2024-11-26 23:34:27 +01:00
|
|
|
if SkipSocketMark() {
|
|
|
|
return true
|
2024-04-12 16:53:11 +02:00
|
|
|
}
|
2024-11-26 23:34:27 +01:00
|
|
|
return false
|
2024-04-12 16:53:11 +02:00
|
|
|
}
|