2019-02-09 09:07:47 +00:00
|
|
|
package common
|
2019-01-09 12:33:00 +00:00
|
|
|
|
|
|
|
import (
|
2019-02-09 09:07:47 +00:00
|
|
|
"bytes"
|
2019-01-09 12:33:00 +00:00
|
|
|
"encoding/base64"
|
2019-02-09 09:07:47 +00:00
|
|
|
"encoding/binary"
|
|
|
|
"github.com/cnlh/nps/lib/crypt"
|
2019-02-23 15:29:48 +00:00
|
|
|
"github.com/cnlh/nps/lib/pool"
|
2019-03-07 10:07:53 +00:00
|
|
|
"html/template"
|
2019-02-23 15:29:48 +00:00
|
|
|
"io"
|
2019-01-25 04:10:12 +00:00
|
|
|
"io/ioutil"
|
2019-01-09 12:33:00 +00:00
|
|
|
"net"
|
|
|
|
"net/http"
|
2019-01-25 04:10:12 +00:00
|
|
|
"os"
|
2019-01-09 12:33:00 +00:00
|
|
|
"regexp"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
2019-03-29 07:21:30 +00:00
|
|
|
"sync"
|
2019-01-09 12:33:00 +00:00
|
|
|
)
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Get the corresponding IP address through domain name
|
2019-01-15 12:59:50 +00:00
|
|
|
func GetHostByName(hostname string) string {
|
2019-01-09 12:33:00 +00:00
|
|
|
if !DomainCheck(hostname) {
|
|
|
|
return hostname
|
|
|
|
}
|
|
|
|
ips, _ := net.LookupIP(hostname)
|
|
|
|
if ips != nil {
|
|
|
|
for _, v := range ips {
|
|
|
|
if v.To4() != nil {
|
|
|
|
return v.String()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Check the legality of domain
|
2019-01-09 12:33:00 +00:00
|
|
|
func DomainCheck(domain string) bool {
|
|
|
|
var match bool
|
|
|
|
IsLine := "^((http://)|(https://))?([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,6}(/)"
|
|
|
|
NotLine := "^((http://)|(https://))?([a-zA-Z0-9]([a-zA-Z0-9\\-]{0,61}[a-zA-Z0-9])?\\.)+[a-zA-Z]{2,6}"
|
|
|
|
match, _ = regexp.MatchString(IsLine, domain)
|
|
|
|
if !match {
|
|
|
|
match, _ = regexp.MatchString(NotLine, domain)
|
|
|
|
}
|
|
|
|
return match
|
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Check if the Request request is validated
|
2019-01-09 12:33:00 +00:00
|
|
|
func CheckAuth(r *http.Request, user, passwd string) bool {
|
|
|
|
s := strings.SplitN(r.Header.Get("Authorization"), " ", 2)
|
|
|
|
if len(s) != 2 {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
b, err := base64.StdEncoding.DecodeString(s[1])
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
pair := strings.SplitN(string(b), ":", 2)
|
|
|
|
if len(pair) != 2 {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return pair[0] == user && pair[1] == passwd
|
|
|
|
}
|
|
|
|
|
|
|
|
//get bool by str
|
|
|
|
func GetBoolByStr(s string) bool {
|
|
|
|
switch s {
|
|
|
|
case "1", "true":
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
//get str by bool
|
|
|
|
func GetStrByBool(b bool) string {
|
|
|
|
if b {
|
|
|
|
return "1"
|
|
|
|
}
|
|
|
|
return "0"
|
|
|
|
}
|
|
|
|
|
|
|
|
//int
|
2019-01-15 12:59:50 +00:00
|
|
|
func GetIntNoErrByStr(str string) int {
|
2019-03-15 06:03:49 +00:00
|
|
|
i, _ := strconv.Atoi(strings.TrimSpace(str))
|
2019-01-09 12:33:00 +00:00
|
|
|
return i
|
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Get verify value
|
2019-01-09 12:33:00 +00:00
|
|
|
func Getverifyval(vkey string) string {
|
2019-02-09 09:07:47 +00:00
|
|
|
return crypt.Md5(vkey)
|
2019-01-09 12:33:00 +00:00
|
|
|
}
|
2019-01-12 16:09:12 +00:00
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Change headers and host of request
|
2019-01-12 16:09:12 +00:00
|
|
|
func ChangeHostAndHeader(r *http.Request, host string, header string, addr string) {
|
|
|
|
if host != "" {
|
|
|
|
r.Host = host
|
|
|
|
}
|
|
|
|
if header != "" {
|
|
|
|
h := strings.Split(header, "\n")
|
|
|
|
for _, v := range h {
|
|
|
|
hd := strings.Split(v, ":")
|
|
|
|
if len(hd) == 2 {
|
|
|
|
r.Header.Set(hd[0], hd[1])
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
addr = strings.Split(addr, ":")[0]
|
|
|
|
r.Header.Set("X-Forwarded-For", addr)
|
|
|
|
r.Header.Set("X-Real-IP", addr)
|
|
|
|
}
|
2019-01-25 04:10:12 +00:00
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Read file content by file path
|
2019-01-31 18:06:30 +00:00
|
|
|
func ReadAllFromFile(filePath string) ([]byte, error) {
|
|
|
|
f, err := os.Open(filePath)
|
2019-01-25 04:10:12 +00:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return ioutil.ReadAll(f)
|
|
|
|
}
|
2019-02-02 16:54:43 +00:00
|
|
|
|
|
|
|
// FileExists reports whether the named file or directory exists.
|
|
|
|
func FileExists(name string) bool {
|
|
|
|
if _, err := os.Stat(name); err != nil {
|
|
|
|
if os.IsNotExist(err) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
2019-02-05 16:35:23 +00:00
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Judge whether the TCP port can open normally
|
|
|
|
func TestTcpPort(port int) bool {
|
|
|
|
l, err := net.ListenTCP("tcp", &net.TCPAddr{net.ParseIP("0.0.0.0"), port, ""})
|
2019-02-12 19:54:00 +00:00
|
|
|
defer func() {
|
|
|
|
if l != nil {
|
|
|
|
l.Close()
|
|
|
|
}
|
|
|
|
}()
|
2019-02-09 09:07:47 +00:00
|
|
|
if err != nil {
|
|
|
|
return false
|
2019-02-05 16:35:23 +00:00
|
|
|
}
|
2019-02-09 09:07:47 +00:00
|
|
|
return true
|
2019-02-05 16:35:23 +00:00
|
|
|
}
|
|
|
|
|
2019-02-09 09:07:47 +00:00
|
|
|
//Judge whether the UDP port can open normally
|
|
|
|
func TestUdpPort(port int) bool {
|
|
|
|
l, err := net.ListenUDP("udp", &net.UDPAddr{net.ParseIP("0.0.0.0"), port, ""})
|
2019-02-12 19:54:00 +00:00
|
|
|
defer func() {
|
|
|
|
if l != nil {
|
|
|
|
l.Close()
|
|
|
|
}
|
|
|
|
}()
|
2019-02-05 16:35:23 +00:00
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
2019-02-09 09:07:47 +00:00
|
|
|
|
|
|
|
//Write length and individual byte data
|
|
|
|
//Length prevents sticking
|
|
|
|
//# Characters are used to separate data
|
|
|
|
func BinaryWrite(raw *bytes.Buffer, v ...string) {
|
|
|
|
buffer := new(bytes.Buffer)
|
|
|
|
var l int32
|
|
|
|
for _, v := range v {
|
2019-02-12 19:54:00 +00:00
|
|
|
l += int32(len([]byte(v))) + int32(len([]byte(CONN_DATA_SEQ)))
|
2019-02-09 09:07:47 +00:00
|
|
|
binary.Write(buffer, binary.LittleEndian, []byte(v))
|
2019-02-12 19:54:00 +00:00
|
|
|
binary.Write(buffer, binary.LittleEndian, []byte(CONN_DATA_SEQ))
|
2019-02-09 09:07:47 +00:00
|
|
|
}
|
2019-02-12 19:54:00 +00:00
|
|
|
binary.Write(raw, binary.LittleEndian, l)
|
2019-02-09 09:07:47 +00:00
|
|
|
binary.Write(raw, binary.LittleEndian, buffer.Bytes())
|
|
|
|
}
|
2019-02-12 19:54:00 +00:00
|
|
|
|
2019-03-01 09:23:14 +00:00
|
|
|
//inArray str interface
|
2019-02-17 17:05:05 +00:00
|
|
|
func InStrArr(arr []string, val string) bool {
|
2019-02-12 19:54:00 +00:00
|
|
|
for _, v := range arr {
|
|
|
|
if v == val {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
2019-03-01 09:23:14 +00:00
|
|
|
//inArray int interface
|
2019-02-12 19:54:00 +00:00
|
|
|
func InIntArr(arr []int, val int) bool {
|
|
|
|
for _, v := range arr {
|
|
|
|
if v == val {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
2019-02-15 14:59:28 +00:00
|
|
|
}
|
|
|
|
|
2019-03-01 09:23:14 +00:00
|
|
|
//format ports str to a int array
|
2019-02-15 14:59:28 +00:00
|
|
|
func GetPorts(p string) []int {
|
|
|
|
var ps []int
|
|
|
|
arr := strings.Split(p, ",")
|
|
|
|
for _, v := range arr {
|
|
|
|
fw := strings.Split(v, "-")
|
|
|
|
if len(fw) == 2 {
|
|
|
|
if IsPort(fw[0]) && IsPort(fw[1]) {
|
|
|
|
start, _ := strconv.Atoi(fw[0])
|
|
|
|
end, _ := strconv.Atoi(fw[1])
|
|
|
|
for i := start; i <= end; i++ {
|
|
|
|
ps = append(ps, i)
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
} else if IsPort(v) {
|
|
|
|
p, _ := strconv.Atoi(v)
|
|
|
|
ps = append(ps, p)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ps
|
|
|
|
}
|
2019-02-17 17:05:05 +00:00
|
|
|
|
2019-02-15 14:59:28 +00:00
|
|
|
func IsPort(p string) bool {
|
|
|
|
pi, err := strconv.Atoi(p)
|
|
|
|
if err != nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if pi > 65536 || pi < 1 {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func FormatAddress(s string) string {
|
|
|
|
if strings.Contains(s, ":") {
|
|
|
|
return s
|
|
|
|
}
|
|
|
|
return "127.0.0.1:" + s
|
|
|
|
}
|
2019-02-16 12:43:26 +00:00
|
|
|
|
|
|
|
func GetIpByAddr(addr string) string {
|
|
|
|
arr := strings.Split(addr, ":")
|
|
|
|
return arr[0]
|
|
|
|
}
|
2019-02-23 15:29:48 +00:00
|
|
|
|
|
|
|
func CopyBuffer(dst io.Writer, src io.Reader) (written int64, err error) {
|
2019-03-15 06:03:49 +00:00
|
|
|
buf := pool.GetBufPoolCopy()
|
|
|
|
defer pool.PutBufPoolCopy(buf)
|
2019-02-26 14:40:28 +00:00
|
|
|
for {
|
|
|
|
nr, er := src.Read(buf)
|
|
|
|
if nr > 0 {
|
|
|
|
nw, ew := dst.Write(buf[0:nr])
|
|
|
|
if nw > 0 {
|
|
|
|
written += int64(nw)
|
|
|
|
}
|
|
|
|
if ew != nil {
|
|
|
|
err = ew
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if nr != nw {
|
|
|
|
err = io.ErrShortWrite
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if er != nil {
|
|
|
|
if er != io.EOF {
|
|
|
|
err = er
|
|
|
|
}
|
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
2019-02-23 15:29:48 +00:00
|
|
|
return written, err
|
|
|
|
}
|
2019-03-01 09:23:14 +00:00
|
|
|
|
|
|
|
//send this ip forget to get a local udp port
|
|
|
|
func GetLocalUdpAddr() (net.Conn, error) {
|
|
|
|
tmpConn, err := net.Dial("udp", "114.114.114.114:53")
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
return tmpConn, tmpConn.Close()
|
|
|
|
}
|
2019-03-07 10:07:53 +00:00
|
|
|
|
|
|
|
func ParseStr(str string) (string, error) {
|
|
|
|
tmp := template.New("npc")
|
|
|
|
var err error
|
|
|
|
w := new(bytes.Buffer)
|
|
|
|
if tmp, err = tmp.Parse(str); err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
if err = tmp.Execute(w, GetEnvMap()); err != nil {
|
|
|
|
return "", err
|
|
|
|
}
|
|
|
|
return w.String(), nil
|
|
|
|
}
|
|
|
|
|
|
|
|
//get env
|
|
|
|
func GetEnvMap() map[string]string {
|
|
|
|
m := make(map[string]string)
|
|
|
|
environ := os.Environ()
|
|
|
|
for i := range environ {
|
|
|
|
tmp := strings.Split(environ[i], "=")
|
|
|
|
if len(tmp) == 2 {
|
|
|
|
m[tmp[0]] = tmp[1]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return m
|
|
|
|
}
|
2019-03-15 06:03:49 +00:00
|
|
|
|
|
|
|
func TrimArr(arr []string) []string {
|
|
|
|
newArr := make([]string, 0)
|
|
|
|
for _, v := range arr {
|
|
|
|
if v != "" {
|
|
|
|
newArr = append(newArr, v)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return newArr
|
|
|
|
}
|
|
|
|
|
|
|
|
func IsArrContains(arr []string, val string) bool {
|
|
|
|
if arr == nil {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
for _, v := range arr {
|
|
|
|
if v == val {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func RemoveArrVal(arr []string, val string) []string {
|
|
|
|
for k, v := range arr {
|
|
|
|
if v == val {
|
|
|
|
arr = append(arr[:k], arr[k+1:]...)
|
|
|
|
return arr
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return arr
|
|
|
|
}
|
2019-03-19 14:41:40 +00:00
|
|
|
|
|
|
|
func BytesToNum(b []byte) int {
|
|
|
|
var str string
|
|
|
|
for i := 0; i < len(b); i++ {
|
|
|
|
str += strconv.Itoa(int(b[i]))
|
|
|
|
}
|
|
|
|
x, _ := strconv.Atoi(str)
|
|
|
|
return int(x)
|
|
|
|
}
|
2019-03-29 07:21:30 +00:00
|
|
|
|
|
|
|
func GeSynctMapLen(m sync.Map) int {
|
|
|
|
var c int
|
|
|
|
m.Range(func(key, value interface{}) bool {
|
|
|
|
c++
|
|
|
|
return true
|
|
|
|
})
|
|
|
|
return c
|
|
|
|
}
|