1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
|
package main
import (
"errors"
"net"
"os"
"strings"
jww "github.com/spf13/jwalterweatherman"
)
type interfaceContext struct {
PrimaryIP *net.IP
MacAddr *net.HardwareAddr
PrimaryHostname *string
}
func interfaceIsUsable(i *net.Interface) bool {
if i.Flags&net.FlagLoopback != 0 {
return false
}
if i.Flags&net.FlagUp == 0 {
return false
}
addrs, err := i.Addrs()
if err != nil || len(addrs) == 0 {
return false
}
if strings.HasPrefix(i.Name, "docker") {
return false
}
return true
}
func getPrimaryInterface() (*net.Interface, error) {
ifaces, err := net.Interfaces()
if err != nil {
return nil, err
}
if len(ifaces) == 0 {
return nil, errors.New("no interfaces found")
}
var iface net.Interface
for _, iface = range ifaces {
if !interfaceIsUsable(&iface) {
continue
} else {
break
}
}
if interfaceIsUsable(&iface) {
return &iface, nil
} else {
return nil, errors.New("no usable interfaces found")
}
}
func getInterfaceContext() (*interfaceContext, error) {
iface, err := getPrimaryInterface()
if err != nil {
return nil, err
}
// Validated to have at least this in interfaceIsUsable
addrs, err := iface.Addrs()
if err != nil {
return nil, err
}
primaryAddr := addrs[0].String()
primaryIP, _, err := net.ParseCIDR(primaryAddr)
if err != nil {
return nil, err
}
name, err := os.Hostname()
if err != nil {
jww.ERROR.Printf("Unable to resolve hostname, using localhost: %s", err.Error())
name = "localhost"
}
return &interfaceContext{
PrimaryIP: &primaryIP,
MacAddr: &iface.HardwareAddr,
PrimaryHostname: &name,
}, nil
}
|