mirror of
https://github.com/tailscale/tailscale.git
synced 2025-01-10 18:13:41 +00:00
2c07f5dfcd
Remove the platform specificity, it is unnecessary complexity. Deduplicate repeated code as a result of reduced complexity. Split out error identification code. Update call-sites and tests. Updates #14551 Updates tailscale/corp#25648 Signed-off-by: James Tucker <james@tailscale.com>
32 lines
1.0 KiB
Go
32 lines
1.0 KiB
Go
// Copyright (c) Tailscale Inc & AUTHORS
|
|
// SPDX-License-Identifier: BSD-3-Clause
|
|
|
|
//go:build !plan9
|
|
|
|
package magicsock
|
|
|
|
import (
|
|
"errors"
|
|
"syscall"
|
|
)
|
|
|
|
// shouldRebind returns if the error is one that is known to be healed by a
|
|
// rebind, and if so also returns a resason string for the rebind.
|
|
func shouldRebind(err error) (ok bool, reason string) {
|
|
switch {
|
|
// EPIPE/ENOTCONN are common errors when a send fails due to a closed
|
|
// socket. There is some platform and version inconsistency in which
|
|
// error is returned, but the meaning is the same.
|
|
case errors.Is(err, syscall.EPIPE), errors.Is(err, syscall.ENOTCONN):
|
|
return true, "broken-pipe"
|
|
|
|
// EPERM is typically caused by EDR software, and has been observed to be
|
|
// transient, it seems that some versions of some EDR lose track of sockets
|
|
// at times, and return EPERM, but reconnects will establish appropriate
|
|
// rights associated with a new socket.
|
|
case errors.Is(err, syscall.EPERM):
|
|
return true, "operation-not-permitted"
|
|
}
|
|
return false, ""
|
|
}
|