ing
This commit is contained in:
103
service/matcher/rmi/rmi.go
Normal file
103
service/matcher/rmi/rmi.go
Normal file
@@ -0,0 +1,103 @@
|
||||
package rmi
|
||||
|
||||
import (
|
||||
"bytes"
|
||||
"encoding/binary"
|
||||
|
||||
"git.loafle.net/overflow/overflow_discovery/service/matcher"
|
||||
)
|
||||
|
||||
const (
|
||||
MAGIC_NUMBER = 0x4a524d49
|
||||
STREAM_PROTOCOL = 0x4b
|
||||
VERSION = 0x0002
|
||||
ACK_PROTOCOL = 0x4e
|
||||
)
|
||||
|
||||
type RMI_SEND_MESSAGE struct {
|
||||
magic uint32
|
||||
version uint16
|
||||
protocol uint8
|
||||
}
|
||||
|
||||
type RMI_RECV_MESSAGE struct {
|
||||
streamMessage uint8
|
||||
packetLen uint16
|
||||
host []byte
|
||||
port [2]byte
|
||||
}
|
||||
|
||||
type RMIMatcher struct {
|
||||
matcher.Matchers
|
||||
}
|
||||
|
||||
func (r *RMIMatcher) ServiceName() string {
|
||||
return "RMI"
|
||||
}
|
||||
|
||||
func (r *RMIMatcher) IsPrePacket() bool {
|
||||
return false
|
||||
}
|
||||
|
||||
func (r *RMIMatcher) HasResponse(index int) bool {
|
||||
return true
|
||||
}
|
||||
|
||||
func (r *RMIMatcher) IsError(info matcher.MatchInfo, index int, packet *matcher.Packet) bool {
|
||||
return false
|
||||
}
|
||||
|
||||
func (r *RMIMatcher) Match(info matcher.MatchInfo, index int, packet *matcher.Packet) bool {
|
||||
result := false
|
||||
|
||||
if packet == nil || packet.Buffer == nil || packet.Len == 0 {
|
||||
return result
|
||||
}
|
||||
|
||||
//fmt.Println("packet :", packet)
|
||||
rmiRecv := RMI_RECV_MESSAGE{}
|
||||
|
||||
buf := bytes.NewReader(packet.Buffer)
|
||||
binary.Read(buf, binary.BigEndian, &rmiRecv.streamMessage)
|
||||
binary.Read(buf, binary.BigEndian, &rmiRecv.packetLen)
|
||||
|
||||
lenInt := int(rmiRecv.packetLen)
|
||||
|
||||
var tempHost = make([]byte, lenInt, lenInt)
|
||||
copy(rmiRecv.host, tempHost)
|
||||
|
||||
rmiRecv.host = tempHost
|
||||
|
||||
binary.Read(buf, binary.BigEndian, &rmiRecv.host)
|
||||
binary.Read(buf, binary.BigEndian, &rmiRecv.port)
|
||||
|
||||
hostIp := string(rmiRecv.host[:lenInt])
|
||||
//fmt.Println(hostIp)
|
||||
|
||||
//hostPort := binary.BigEndian.Uint16(rmiRecv.port[:2])
|
||||
|
||||
if rmiRecv.streamMessage == ACK_PROTOCOL && lenInt == len(hostIp) {
|
||||
result = true
|
||||
}
|
||||
|
||||
return result
|
||||
}
|
||||
|
||||
func NewMatcher() matcher.Matcher {
|
||||
|
||||
m := &RMIMatcher{}
|
||||
rsm := RMI_SEND_MESSAGE{
|
||||
magic: MAGIC_NUMBER,
|
||||
version: VERSION,
|
||||
protocol: STREAM_PROTOCOL,
|
||||
}
|
||||
|
||||
mCache := new(bytes.Buffer)
|
||||
binary.Write(mCache, binary.BigEndian, rsm)
|
||||
|
||||
sendByte1 := mCache.Bytes()
|
||||
|
||||
m.AddPacket(matcher.NewPacket(sendByte1, len(sendByte1)))
|
||||
|
||||
return m
|
||||
}
|
||||
52
service/matcher/rmi/rmi_test.go
Normal file
52
service/matcher/rmi/rmi_test.go
Normal file
@@ -0,0 +1,52 @@
|
||||
package rmi
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"git.loafle.net/overflow/overflow_discovery/match/packet"
|
||||
//"git.loafle.net/overflow/overflow_discovery/discovery/discovery/types"
|
||||
"net"
|
||||
"testing"
|
||||
)
|
||||
|
||||
func TestNew(t *testing.T) {
|
||||
r := NewRMIMatcher()
|
||||
fmt.Println("TestNew: ", r)
|
||||
}
|
||||
func TestRMIMatcher_Match(t *testing.T) {
|
||||
|
||||
fmt.Println("Match")
|
||||
|
||||
hm := NewRMIMatcher()
|
||||
|
||||
//port := types.NewPort("9840", types.NewHost("192.168.1.101"), types.TYPE_TCP)
|
||||
//
|
||||
//var ipport string
|
||||
//ipport = port.Host.Ip + ":" + string(port.Port)
|
||||
|
||||
//fmt.Println(ipport)
|
||||
|
||||
client, err := net.Dial("tcp", "192.168.1.101:9840")
|
||||
|
||||
if err != nil {
|
||||
t.Fatal(err)
|
||||
}
|
||||
|
||||
defer client.Close()
|
||||
|
||||
pack := hm.Packet(0)
|
||||
|
||||
fmt.Println(pack.Buffer)
|
||||
|
||||
//writer.WriteString(pack)
|
||||
client.Write(pack.Buffer)
|
||||
|
||||
bytes := make([]byte, 512)
|
||||
|
||||
l, _ := client.Read(bytes)
|
||||
|
||||
//fmt.Println(bytes)
|
||||
|
||||
t1 := hm.Match(0, packet.NewPacket(bytes, l), nil)
|
||||
|
||||
fmt.Println(t1)
|
||||
}
|
||||
Reference in New Issue
Block a user