package util
import (
"errors"
"fmt"
"net"
"runtime"
"strings"
"os"
"io/ioutil"
"regexp"
"github.com/sirupsen/logrus"
"github.com/tidwall/gjson"
)
func Source(l *logrus.Entry) *logrus.Entry {
_, file, line, ok := runtime.Caller(2)
if !ok {
file = "<???>"
line = 1
} else {
slash := strings.LastIndex(file, "/")
file = file[slash+1:]
}
return l.WithField("source", fmt.Sprintf("%s:%d", file, line))
}
func ExternalIP() (net.IP, error) {
ifaces, err := net.Interfaces()
if err != nil {
return nil, err
}
for _, iface := range ifaces {
if iface.Flags&net.FlagUp == 0 {
continue
}
if iface.Flags&net.FlagLoopback != 0 {
continue
}
addrs, err := iface.Addrs()
if err != nil {
return nil, err
}
for _, addr := range addrs {
var ip net.IP
switch v := addr.(type) {
case *net.IPNet:
ip = v.IP
case *net.IPAddr:
ip = v.IP
}
if ip == nil || ip.IsLoopback() {
continue
}
ip = ip.To4()
if ip == nil {
continue
}
return ip, nil
}
}
return nil, errors.New("are you connected to the network?")
}
func GetHostID(nodeIDFile string) (string, error) {
_, err := os.Stat(nodeIDFile)
if err != nil {
return "", err
}
body, err := ioutil.ReadFile(nodeIDFile)
if err != nil {
return "", err
}
info := strings.Split(strings.TrimSpace(string(body)), "=")
if len(info) == 2 {
return info[1], nil
}
return "", fmt.Errorf("Invalid host uuid from file")
}
var rex *regexp.Regexp
func Format(source map[string]gjson.Result) map[string]interface{} {
defer func() {
if r := recover(); r != nil {
logrus.Warnf("error deal with source msg %v", source)
}
}()
if rex == nil {
var err error
rex, err = regexp.Compile(`\d+\.\d{3,}`)
if err != nil {
logrus.Error("create regexp error.", err.Error())
return nil
}
}
var data = make(map[string]interface{})
for k, v := range source {
if rex.MatchString(v.String()) {
d := strings.Split(v.String(), ".")
data[k] = fmt.Sprintf("%s.%s", d[0], d[1][0:2])
} else {
data[k] = v.String()
}
}
return data
}