container_network/crawler/health/SocketHeahthCrawler.go

154 lines
3.2 KiB
Go
Raw Normal View History

2018-04-19 15:46:38 +00:00
package health
import (
"crypto/tls"
"encoding/base64"
"fmt"
"net"
"time"
cnsm "git.loafle.net/commons/service_matcher-go"
2018-04-28 15:01:45 +00:00
cuej "git.loafle.net/commons/util-go/encoding/json"
2018-06-13 11:22:23 +00:00
ocmm "git.loafle.net/overflow/commons-go/model/meta"
2018-04-26 08:50:26 +00:00
ocmsc "git.loafle.net/overflow/commons-go/model/sensorconfig"
2018-04-19 15:46:38 +00:00
"git.loafle.net/overflow/crawler-go"
)
type SocketHeahthCrawler struct {
crawler.Crawler
m cnsm.Matcher
}
func (s *SocketHeahthCrawler) SetMatcher(m cnsm.Matcher) {
s.m = m
}
2018-04-26 08:50:26 +00:00
func (s *SocketHeahthCrawler) getConnection(config *ocmsc.SensorConfig) (net.Conn, error) {
2018-04-19 15:46:38 +00:00
connection := config.Target.Connection
2018-06-13 11:22:23 +00:00
metaIPType := connection.MetaIPType
2018-04-19 15:46:38 +00:00
ip := connection.IP
port := connection.Port
2018-06-13 11:22:23 +00:00
metaPortType := connection.MetaPortType
metaCryptoType := connection.MetaCryptoType
2018-04-19 15:46:38 +00:00
addr := fmt.Sprintf("%s:%s", ip, port)
2018-06-13 11:22:23 +00:00
network := ""
switch ocmm.ToMetaIPTypeEnum(metaIPType) {
case ocmm.MetaIPTypeEnumV6:
switch ocmm.ToMetaPortTypeEnum(metaPortType) {
case ocmm.MetaPortTypeEnumUDP:
network = "udp6"
default:
network = "tcp6"
}
default:
switch ocmm.ToMetaPortTypeEnum(metaPortType) {
case ocmm.MetaPortTypeEnumUDP:
network = "udp"
default:
network = "tcp"
}
}
conn, err := net.Dial(network, addr)
2018-04-19 15:46:38 +00:00
if err != nil {
return nil, err
}
2018-06-13 11:22:23 +00:00
if ocmm.ToMetaCryptoTypeEnum(metaCryptoType) == ocmm.MetaCryptoTypeEnumTLS {
2018-04-19 15:46:38 +00:00
cfg := &tls.Config{
InsecureSkipVerify: true,
ServerName: ip,
ClientAuth: tls.RequestClientCert,
}
tlsConn := tls.Client(conn, cfg)
if err := tlsConn.Handshake(); err != nil {
return nil, err
}
conn = tlsConn
}
return conn, nil
}
2018-04-26 08:50:26 +00:00
func (s *SocketHeahthCrawler) CheckHeahth(config *ocmsc.SensorConfig) (result map[string]string, err error) {
2018-04-19 15:46:38 +00:00
result = make(map[string]string, 0)
result["StartTime"] = time.Now().String()
conn, cErr := s.getConnection(config)
if cErr != nil {
result["Error"] = cErr.Error()
err = cErr
return
}
defer conn.Close()
connection := config.Target.Connection
port, _ := cuej.NumberToInt(connection.Port)
info := cnsm.NewMatchInfo(connection.IP, port)
if s.m.IsPrePacket() {
result["PacketType"] = "Pre"
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
p := cnsm.NewPacket(buf, n)
if !s.m.Match(info, 0, p) {
result["Packet"] = convertBase64(buf)
result["Error"] = "Not Matched"
return
}
for i := 0; i < s.m.PacketCount(); i++ {
pack := s.m.Packet(i)
conn.Write(pack.Buffer)
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
if !s.m.HasResponse(i + 1) { // empty last response
break
}
p := cnsm.NewPacket(buf, n)
if s.m.Match(info, i+1, p) == false {
result["Packet"] = convertBase64(buf)
result["Error"] = "Not Matched"
return
}
}
} else {
result["PacketType"] = "Post"
for i := 0; i < s.m.PacketCount(); i++ {
pack := s.m.Packet(i)
conn.Write(pack.Buffer)
buf := make([]byte, 1024)
n, _ := conn.Read(buf)
if !s.m.HasResponse(i) { // empty last response
break
}
p := cnsm.NewPacket(buf, n)
if s.m.Match(info, i, p) == false {
result["Packet"] = convertBase64(buf)
result["Error"] = "Not Matched"
return
}
}
}
result["EndTime"] = time.Now().String()
return
}
func convertBase64(buf []byte) string {
return base64.StdEncoding.EncodeToString(buf)
}