Compare commits
5 Commits
13790469a7
...
dev
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
995a2bd30a | ||
|
|
855c1a075f | ||
|
|
812096514d | ||
|
|
4ccd7de4b5 | ||
|
|
a3fab879a0 |
@@ -1,18 +1,33 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/base64"
|
//"encoding/base64"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"errors"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
//"net"
|
||||||
"strings"
|
|
||||||
|
//"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/google/gopacket"
|
"github.com/google/gopacket"
|
||||||
"github.com/google/gopacket/pcap"
|
"github.com/google/gopacket/pcap"
|
||||||
|
|
||||||
|
"client/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type SaprusHeaderPacket struct {
|
||||||
|
Type uint16
|
||||||
|
Length uint16
|
||||||
|
}
|
||||||
|
|
||||||
|
type SaprusFileTransfer struct {
|
||||||
|
Header SaprusHeaderPacket
|
||||||
|
Flag uint8
|
||||||
|
Sequence uint16
|
||||||
|
Checksum uint16
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
func errCheck(err error) {
|
func errCheck(err error) {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
@@ -20,11 +35,30 @@ func errCheck(err error) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func createSaprusFileTransferPacket(payload []byte) SaprusFileTransfer {
|
||||||
|
var packet SaprusFileTransfer
|
||||||
|
|
||||||
|
packet.Header.Type = binary.BigEndian.Uint16([]byte{payload[0], payload[1]})
|
||||||
|
packet.Header.Length = binary.BigEndian.Uint16([]byte{payload[2], payload[3]})
|
||||||
|
|
||||||
|
packet.Flag = uint8(payload[4])
|
||||||
|
packet.Sequence = binary.BigEndian.Uint16([]byte{payload[5], payload[6]})
|
||||||
|
packet.Checksum = binary.BigEndian.Uint16([]byte{payload[7], payload[8]})
|
||||||
|
|
||||||
|
for i := uint16(0); i < packet.Header.Length - 5; i++ {
|
||||||
|
packet.Payload = append(packet.Payload, payload[i+9])
|
||||||
|
}
|
||||||
|
|
||||||
|
return packet
|
||||||
|
}
|
||||||
|
|
||||||
func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
||||||
|
finalMessage := ""
|
||||||
|
var pkt_data SaprusFileTransfer
|
||||||
handle, err := pcap.OpenLive("any", int32(1600), true, pcap.BlockForever)
|
handle, err := pcap.OpenLive("any", int32(1600), true, pcap.BlockForever)
|
||||||
errCheck(err)
|
errCheck(err)
|
||||||
|
|
||||||
err = handle.SetBPFFilter("udp and port 8850")
|
err = handle.SetBPFFilter("udp and port 6767")
|
||||||
errCheck(err)
|
errCheck(err)
|
||||||
|
|
||||||
packets := gopacket.NewPacketSource(handle, handle.LinkType()).Packets()
|
packets := gopacket.NewPacketSource(handle, handle.LinkType()).Packets()
|
||||||
@@ -32,52 +66,18 @@ func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
|||||||
readyFlag <- 1
|
readyFlag <- 1
|
||||||
|
|
||||||
for pkt := range packets {
|
for pkt := range packets {
|
||||||
msg, err := base64.StdEncoding.DecodeString(string(pkt.ApplicationLayer().Payload()))
|
pkt_data = createSaprusFileTransferPacket(pkt.ApplicationLayer().Payload())
|
||||||
if err == nil {
|
finalMessage += string(pkt_data.Payload)
|
||||||
if strings.Contains(string(msg), "clientapi") {
|
if pkt_data.Flag == 2 {
|
||||||
addrChan <- string(msg)
|
addrChan <- finalMessage
|
||||||
return
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
func toMaxHost(n *net.IPNet) (net.IP, error) {
|
|
||||||
if n.IP.To4() == nil {
|
|
||||||
return net.IP{}, errors.New("IP address is not IPv4")
|
|
||||||
}
|
|
||||||
|
|
||||||
ip := make(net.IP, len(n.IP.To4()))
|
|
||||||
binary.BigEndian.PutUint32(ip,
|
|
||||||
binary.BigEndian.Uint32(n.IP.To4())|^binary.BigEndian.Uint32(net.IP(n.Mask).To4()))
|
|
||||||
|
|
||||||
return ip, nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func bcastAddresses() []string {
|
|
||||||
var addrs []string = nil
|
|
||||||
interfaceInfo, _ := net.Interfaces()
|
|
||||||
for i := 0; i < len(interfaceInfo); i++ {
|
|
||||||
addr, err := interfaceInfo[i].Addrs()
|
|
||||||
errCheck(err)
|
|
||||||
for j := 0; j < len(addr); j++ {
|
|
||||||
_, ipNet, _ := net.ParseCIDR(addr[j].String())
|
|
||||||
bcast, err := toMaxHost(ipNet)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
} else {
|
|
||||||
addrs = append(addrs, bcast.String())
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return addrs
|
|
||||||
}
|
|
||||||
|
|
||||||
func main() {
|
func main() {
|
||||||
sendAddrs := bcastAddresses()
|
sendAddrs := []string{"255.255.255.255"}
|
||||||
|
|
||||||
addrChan := make(chan string)
|
addrChan := make(chan string)
|
||||||
readyFlag := make(chan int)
|
readyFlag := make(chan int)
|
||||||
@@ -88,22 +88,16 @@ func main() {
|
|||||||
<- readyFlag
|
<- readyFlag
|
||||||
|
|
||||||
for i := 0; i < len(sendAddrs); i++ {
|
for i := 0; i < len(sendAddrs); i++ {
|
||||||
remoteAddr := sendAddrs[i] + ":8888"
|
c := utils.SocketCall{}
|
||||||
remote, err := net.ResolveUDPAddr("udp4", remoteAddr)
|
|
||||||
errCheck(err)
|
|
||||||
conn, err := net.DialUDP("udp4", nil, remote)
|
|
||||||
errCheck(err)
|
|
||||||
defer conn.Close()
|
|
||||||
|
|
||||||
_, err = conn.Write([]byte(conn.LocalAddr().String() + "here"))
|
c.SendData("hello")
|
||||||
errCheck(err)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Listen timeout
|
// Listen timeout
|
||||||
select {
|
select {
|
||||||
case returnMSG := <- addrChan:
|
case returnMSG := <- addrChan:
|
||||||
fmt.Printf("%s\n", strings.Fields(returnMSG)[1])
|
fmt.Printf("%s\n", returnMSG)
|
||||||
case <- time.After(5 * time.Second):
|
case <- time.After(60 * time.Second):
|
||||||
fmt.Printf("error\n")
|
fmt.Printf("error\n")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -2,6 +2,15 @@ module client
|
|||||||
|
|
||||||
go 1.18
|
go 1.18
|
||||||
|
|
||||||
require github.com/google/gopacket v1.1.19
|
require (
|
||||||
|
github.com/google/gopacket v1.1.19
|
||||||
|
github.com/mdlayher/packet v1.1.1
|
||||||
|
)
|
||||||
|
|
||||||
require golang.org/x/sys v0.0.0-20190412213103-97732733099d // indirect
|
require (
|
||||||
|
github.com/josharian/native v1.0.0 // indirect
|
||||||
|
github.com/mdlayher/socket v0.4.0 // indirect
|
||||||
|
golang.org/x/net v0.2.0 // indirect
|
||||||
|
golang.org/x/sync v0.1.0 // indirect
|
||||||
|
golang.org/x/sys v0.2.0 // indirect
|
||||||
|
)
|
||||||
|
|||||||
@@ -1,5 +1,11 @@
|
|||||||
github.com/google/gopacket v1.1.19 h1:ves8RnFZPGiFnTS0uPQStjwru6uO6h+nlr9j6fL7kF8=
|
github.com/google/gopacket v1.1.19 h1:ves8RnFZPGiFnTS0uPQStjwru6uO6h+nlr9j6fL7kF8=
|
||||||
github.com/google/gopacket v1.1.19/go.mod h1:iJ8V8n6KS+z2U1A8pUwu8bW5SyEMkXJB8Yo/Vo+TKTo=
|
github.com/google/gopacket v1.1.19/go.mod h1:iJ8V8n6KS+z2U1A8pUwu8bW5SyEMkXJB8Yo/Vo+TKTo=
|
||||||
|
github.com/josharian/native v1.0.0 h1:Ts/E8zCSEsG17dUqv7joXJFybuMLjQfWE04tsBODTxk=
|
||||||
|
github.com/josharian/native v1.0.0/go.mod h1:7X/raswPFr05uY3HiLlYeyQntB6OO7E/d2Cu7qoaN2w=
|
||||||
|
github.com/mdlayher/packet v1.1.1 h1:7Fv4OEMYqPl7//uBm04VgPpnSNi8fbBZznppgh6WMr8=
|
||||||
|
github.com/mdlayher/packet v1.1.1/go.mod h1:DRvYY5mH4M4lUqAnMg04E60U4fjUKMZ/4g2cHElZkKo=
|
||||||
|
github.com/mdlayher/socket v0.4.0 h1:280wsy40IC9M9q1uPGcLBwXpcTQDtoGwVt+BNoITxIw=
|
||||||
|
github.com/mdlayher/socket v0.4.0/go.mod h1:xxFqz5GRCUN3UEOm9CZqEJsAbe1C8OwSK46NlmWuVoc=
|
||||||
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
golang.org/x/crypto v0.0.0-20190308221718-c2843e01d9a2/go.mod h1:djNgcEr1/C05ACkg1iLfiJU5Ep61QUkGW8qpdssI0+w=
|
||||||
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
golang.org/x/crypto v0.0.0-20191011191535-87dc89f01550/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
|
||||||
golang.org/x/lint v0.0.0-20200302205851-738671d3881b/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY=
|
golang.org/x/lint v0.0.0-20200302205851-738671d3881b/go.mod h1:3xt1FjdF8hUf6vQPIChWIBhFzV8gjjsPE/fR3IyQdNY=
|
||||||
@@ -7,10 +13,16 @@ golang.org/x/mod v0.1.1-0.20191105210325-c90efee705ee/go.mod h1:QqPTAvyqsEbceGzB
|
|||||||
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
golang.org/x/net v0.0.0-20190404232315-eb5bcb51f2a3/go.mod h1:t9HGtf8HONx5eT2rtn7q6eTqICYqUVnKs3thJo3Qplg=
|
||||||
golang.org/x/net v0.0.0-20190620200207-3b0461eec859 h1:R/3boaszxrf1GEUWTVDzSKVwLmSJpwZ1yqXm8j0v2QI=
|
golang.org/x/net v0.0.0-20190620200207-3b0461eec859 h1:R/3boaszxrf1GEUWTVDzSKVwLmSJpwZ1yqXm8j0v2QI=
|
||||||
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
golang.org/x/net v0.0.0-20190620200207-3b0461eec859/go.mod h1:z5CRVTTTmAJ677TzLLGU+0bjPO0LkuOLi4/5GtJWs/s=
|
||||||
|
golang.org/x/net v0.2.0 h1:sZfSu1wtKLGlWI4ZZayP0ck9Y73K1ynO6gqzTdBVdPU=
|
||||||
|
golang.org/x/net v0.2.0/go.mod h1:KqCZLdyyvdV855qA2rE3GC2aiw5xGR5TEjj8smXukLY=
|
||||||
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
golang.org/x/sync v0.0.0-20190423024810-112230192c58/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
|
golang.org/x/sync v0.1.0 h1:wsuoTGHzEhffawBOhz5CYhcrV4IdKZbEyZjBMuTp12o=
|
||||||
|
golang.org/x/sync v0.1.0/go.mod h1:RxMgew5VJxzue5/jJTE5uejpjVlOe/izrB70Jof72aM=
|
||||||
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
golang.org/x/sys v0.0.0-20190215142949-d0b11bdaac8a/go.mod h1:STP8DvDyc/dI5b8T5hshtkjS+E42TnysNCUPdjciGhY=
|
||||||
golang.org/x/sys v0.0.0-20190412213103-97732733099d h1:+R4KGOnez64A81RvjARKc4UT5/tI9ujCIVX+P5KiHuI=
|
golang.org/x/sys v0.0.0-20190412213103-97732733099d h1:+R4KGOnez64A81RvjARKc4UT5/tI9ujCIVX+P5KiHuI=
|
||||||
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
golang.org/x/sys v0.0.0-20190412213103-97732733099d/go.mod h1:h1NjWce9XRLGQEsW7wpKNCjG9DtNlClVuFLEZdDNbEs=
|
||||||
|
golang.org/x/sys v0.2.0 h1:ljd4t30dBnAvMZaQCevtY0xLLD0A+bRZXbgLMLU1F/A=
|
||||||
|
golang.org/x/sys v0.2.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg=
|
||||||
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
golang.org/x/text v0.3.0/go.mod h1:NqM8EUOU14njkJ3fqMW+pc6Ldnwhi/IjpwHt7yyuwOQ=
|
||||||
golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28=
|
golang.org/x/tools v0.0.0-20200130002326-2f3ba24bd6e7/go.mod h1:TB2adYChydJhpapKDTa4BR/hXlZSLoq2Wpct/0txZ28=
|
||||||
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
golang.org/x/xerrors v0.0.0-20191011141410-1b5146add898/go.mod h1:I/5z698sn9Ka8TeJc9MKroUUfqBBauWjQqLJ2OPfmY0=
|
||||||
|
|||||||
21
client/golang/structs/file_transfer.go
Normal file
21
client/golang/structs/file_transfer.go
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package structs
|
||||||
|
|
||||||
|
import (
|
||||||
|
)
|
||||||
|
|
||||||
|
type SaprusFileTransfer struct {
|
||||||
|
Flag [1]byte
|
||||||
|
Sequence [2]byte
|
||||||
|
Checksum [2]byte
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c SaprusFileTransfer) Bytes() []byte {
|
||||||
|
data := []byte{}
|
||||||
|
data = append(data, c.Flag[0])
|
||||||
|
data = append(data, c.Sequence[0], c.Sequence[1])
|
||||||
|
data = append(data, c.Checksum[0], c.Checksum[1])
|
||||||
|
data = append(data, c.Payload...)
|
||||||
|
return data
|
||||||
|
}
|
||||||
|
|
||||||
21
client/golang/structs/message.go
Normal file
21
client/golang/structs/message.go
Normal file
@@ -0,0 +1,21 @@
|
|||||||
|
package structs
|
||||||
|
|
||||||
|
import (
|
||||||
|
)
|
||||||
|
|
||||||
|
type SaprusClientMessage struct {
|
||||||
|
Flag [1]byte
|
||||||
|
Sequence [2]byte
|
||||||
|
Checksum [2]byte
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c SaprusClientMessage) Bytes() []byte {
|
||||||
|
data := []byte{}
|
||||||
|
data = append(data, c.Flag[0])
|
||||||
|
data = append(data, c.Sequence[0], c.Sequence[1])
|
||||||
|
data = append(data, c.Checksum[0], c.Checksum[1])
|
||||||
|
data = append(data, c.Payload...)
|
||||||
|
return data
|
||||||
|
}
|
||||||
|
|
||||||
18
client/golang/structs/saprus.go
Normal file
18
client/golang/structs/saprus.go
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
package structs
|
||||||
|
|
||||||
|
import (
|
||||||
|
)
|
||||||
|
|
||||||
|
type SaprusHeaderFrame struct {
|
||||||
|
PacketType [2]byte
|
||||||
|
Length [2]byte
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c SaprusHeaderFrame) Bytes() []byte {
|
||||||
|
data := []byte{}
|
||||||
|
data = append(data, c.PacketType[0], c.PacketType[1])
|
||||||
|
data = append(data, c.Length[0], c.Length[1])
|
||||||
|
data = append(data, c.Payload...)
|
||||||
|
return data
|
||||||
|
}
|
||||||
92
client/golang/utils/file_transfer.go
Normal file
92
client/golang/utils/file_transfer.go
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/google/gopacket"
|
||||||
|
|
||||||
|
"client/structs"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (c*SocketCall) BuildFileTransferPacket(Header structs.SaprusHeaderFrame,
|
||||||
|
Data structs.SaprusFileTransfer) gopacket.SerializeBuffer {
|
||||||
|
eth, ip, udp := basePacket(c)
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: Header.PacketType,
|
||||||
|
Length: c.saprusPayloadLength(Data.Bytes()),
|
||||||
|
Payload: Data.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := gopacket.NewSerializeBuffer()
|
||||||
|
opts := gopacket.SerializeOptions {
|
||||||
|
ComputeChecksums: true,
|
||||||
|
FixLengths: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
udp.SetNetworkLayerForChecksum(&ip)
|
||||||
|
err := gopacket.SerializeLayers(buf, opts, ð, &ip, &udp, gopacket.Payload(sapHeader.Bytes()))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) FileTransferPacket(message string, seqNum uint16) gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x11},
|
||||||
|
Sequence: [2]byte{byte(seqNum >> 8), byte(seqNum & 0xFF)},
|
||||||
|
Checksum: [2]byte{0x44, 0x44},
|
||||||
|
Payload: []byte(message),
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x88, 0x88},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) InitFileTransferPacket() gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x01},
|
||||||
|
Sequence: [2]byte{0x00, 0x00},
|
||||||
|
Checksum: [2]byte{0x00, 0x00},
|
||||||
|
Payload: []byte{},
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x00, 0x00},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) EndFileTransferPacket() gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x02},
|
||||||
|
Sequence: [2]byte{0x00, 0x00},
|
||||||
|
Checksum: [2]byte{0x00, 0x00},
|
||||||
|
Payload: []byte{},
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x00, 0x00},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
27
client/golang/utils/packet_helper.go
Normal file
27
client/golang/utils/packet_helper.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/google/gopacket/layers"
|
||||||
|
)
|
||||||
|
|
||||||
|
func basePacket(c* SocketCall) (layers.Ethernet, layers.IPv4, layers.UDP) {
|
||||||
|
eth := layers.Ethernet {
|
||||||
|
EthernetType: layers.EthernetTypeIPv4,
|
||||||
|
SrcMAC: c.Iface.HardwareAddr,
|
||||||
|
DstMAC: layers.EthernetBroadcast,
|
||||||
|
}
|
||||||
|
ip := layers.IPv4 {
|
||||||
|
Version: 4,
|
||||||
|
TTL: 64,
|
||||||
|
SrcIP: []byte{0, 0, 0, 0},
|
||||||
|
DstIP: []byte{255, 255, 255, 255},
|
||||||
|
Protocol: layers.IPProtocolUDP,
|
||||||
|
}
|
||||||
|
udp := layers.UDP {
|
||||||
|
SrcPort: 8850,
|
||||||
|
DstPort: 8888,
|
||||||
|
}
|
||||||
|
|
||||||
|
return eth, ip, udp
|
||||||
|
}
|
||||||
|
|
||||||
88
client/golang/utils/raw.go
Normal file
88
client/golang/utils/raw.go
Normal file
@@ -0,0 +1,88 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/binary"
|
||||||
|
"log"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"net"
|
||||||
|
"unicode/utf8"
|
||||||
|
|
||||||
|
"github.com/google/gopacket"
|
||||||
|
"github.com/google/gopacket/layers"
|
||||||
|
"github.com/mdlayher/packet"
|
||||||
|
)
|
||||||
|
|
||||||
|
type SocketCall struct {
|
||||||
|
conn *packet.Conn
|
||||||
|
Iface *net.Interface
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
func splitData(message string) []string {
|
||||||
|
data := []string{}
|
||||||
|
maxPacketLength := 1449
|
||||||
|
|
||||||
|
var i, j int
|
||||||
|
|
||||||
|
for i, j = 0, maxPacketLength; j < len(message); i, j = j, j+maxPacketLength {
|
||||||
|
for !utf8.RuneStart(message[j]) {
|
||||||
|
j--
|
||||||
|
}
|
||||||
|
data = append(data, message[i:j])
|
||||||
|
}
|
||||||
|
data = append(data, message[i:])
|
||||||
|
|
||||||
|
return data
|
||||||
|
}
|
||||||
|
|
||||||
|
func GetAdapter() string {
|
||||||
|
inetInterface := ""
|
||||||
|
inetInterfaces, _ := net.Interfaces()
|
||||||
|
if inetInterfaces[0].Name == "lo" {
|
||||||
|
inetInterface = inetInterfaces[1].Name
|
||||||
|
} else {
|
||||||
|
inetInterface = inetInterfaces[0].Name
|
||||||
|
}
|
||||||
|
return inetInterface
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) SendPackage(buf gopacket.SerializeBuffer) error {
|
||||||
|
_, err := c.conn.WriteTo(buf.Bytes(), &packet.Addr{HardwareAddr: layers.EthernetBroadcast})
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall)SendData(message string) {
|
||||||
|
iface, _ := net.InterfaceByName(GetAdapter())
|
||||||
|
c.Iface = iface
|
||||||
|
|
||||||
|
conn, err := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
||||||
|
c.conn = conn
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
splitMessage := splitData(message)
|
||||||
|
|
||||||
|
for i := 0; i < len(splitMessage); i++ {
|
||||||
|
c.SendPackage(c.FileTransferPacket(splitMessage[i], uint16(i)))
|
||||||
|
time.Sleep(20 * time.Microsecond)
|
||||||
|
|
||||||
|
time.Sleep(200 * time.Microsecond)
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) saprusPayloadLength(pkt []byte) [2]byte{
|
||||||
|
payloadLength := make([]byte, 2)
|
||||||
|
var length [2]byte
|
||||||
|
binary.BigEndian.PutUint16(payloadLength, uint16(len(pkt)))
|
||||||
|
|
||||||
|
length[0] = payloadLength[0]
|
||||||
|
length[1] = payloadLength[1]
|
||||||
|
|
||||||
|
return length
|
||||||
|
}
|
||||||
|
|
||||||
@@ -30,9 +30,36 @@ Saprus Protocol Header:
|
|||||||
0 1 2 3 4
|
0 1 2 3 4
|
||||||
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7
|
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7
|
||||||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
| Saprus Header | Saprus Type | Length | |
|
| Saprus Type | Length | |
|
||||||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +
|
||||||
| Saprus Type Payload (0-1453) |
|
| Saprus Type Payload (0-1454) |
|
||||||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
```
|
```
|
||||||
|
|
||||||
|
## File Transfer
|
||||||
|
|
||||||
|
Saprus Type: 0x88 0x88
|
||||||
|
|
||||||
|
```
|
||||||
|
0 1 2 3 4
|
||||||
|
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
|
| Flag | Sequence | Checksum | |
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +
|
||||||
|
| Payload |
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
|
```
|
||||||
|
|
||||||
|
## hold
|
||||||
|
|
||||||
|
Saprus Type: 0x00 0x3C
|
||||||
|
|
||||||
|
```
|
||||||
|
0 1 2 3 4
|
||||||
|
0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7 8 9 0 1 2 3 4 5 6 7
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
|
| Dest | |
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +
|
||||||
|
| Payload |
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
|
```
|
||||||
|
|||||||
@@ -1,17 +1,15 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/base64"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
|
||||||
|
|
||||||
"saprusserver/utils"
|
"saprusserver/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
func welcomeMessage() {
|
func welcomeMessage() {
|
||||||
msg :=`Welcome to --
|
msg :=`
|
||||||
██████ ▄▄▄ ██▓███ ██▀███ █ ██ ██████
|
██████ ▄▄▄ ██▓███ ██▀███ █ ██ ██████
|
||||||
▒██ ▒ ▒████▄ ▓██░ ██▒▓██ ▒ ██▒ ██ ▓██▒▒██ ▒
|
▒██ ▒ ▒████▄ ▓██░ ██▒▓██ ▒ ██▒ ██ ▓██▒▒██ ▒
|
||||||
░ ▓██▄ ▒██ ▀█▄ ▓██░ ██▓▒▓██ ░▄█ ▒▓██ ▒██░░ ▓██▄
|
░ ▓██▄ ▒██ ▀█▄ ▓██░ ██▓▒▓██ ░▄█ ▒▓██ ▒██░░ ▓██▄
|
||||||
@@ -26,49 +24,28 @@ func welcomeMessage() {
|
|||||||
fmt.Println(msg)
|
fmt.Println(msg)
|
||||||
}
|
}
|
||||||
|
|
||||||
func main() {
|
func checkError(err error) {
|
||||||
welcomeMessage()
|
|
||||||
log.Printf("Starting server\n")
|
|
||||||
con := utils.SocketCall{}
|
|
||||||
serv, err := net.ListenPacket("udp4", ":8888")
|
|
||||||
//serverIP := "192.168.122.1:8000/script.sh"
|
|
||||||
serverIP := "hello world client data is fake }P"
|
|
||||||
msg := "clientapi: " + serverIP
|
|
||||||
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
log.Println("Found Error")
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
welcomeMessage()
|
||||||
|
log.Println("Starting server")
|
||||||
|
|
||||||
|
serv, err := net.ListenPacket("udp4", ":8888")
|
||||||
|
checkError(err)
|
||||||
|
|
||||||
defer serv.Close()
|
defer serv.Close()
|
||||||
|
|
||||||
buff := make([]byte, 2048)
|
buff := make([]byte, 2048)
|
||||||
|
|
||||||
for {
|
for {
|
||||||
|
|
||||||
_, addr, err := serv.ReadFrom(buff)
|
_, addr, err := serv.ReadFrom(buff)
|
||||||
|
checkError(err)
|
||||||
|
|
||||||
if err != nil {
|
go utils.ProcessRequests(buff, addr)
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
remoteAddr := strings.Split(addr.String(), ":")
|
|
||||||
|
|
||||||
//remote, err := net.ResolveUDPAddr("udp4", remoteAddr[0] + ":8850")
|
|
||||||
log.Printf("Received data %s\n", remoteAddr)
|
|
||||||
|
|
||||||
if err != nil {
|
|
||||||
panic(err)
|
|
||||||
}
|
|
||||||
|
|
||||||
con.SendData(b64Msg)
|
|
||||||
|
|
||||||
//conn, _ := net.DialUDP("udp4", nil, remote)
|
|
||||||
//defer conn.Close()
|
|
||||||
|
|
||||||
//conn.Write([]byte(b64Msg))
|
|
||||||
//conn.Close()
|
|
||||||
|
|
||||||
log.Printf("Sending data to %s\n", addr)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
20
server/structs/file_transfer.go
Normal file
20
server/structs/file_transfer.go
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
package structs
|
||||||
|
|
||||||
|
import (
|
||||||
|
)
|
||||||
|
|
||||||
|
type SaprusFileTransfer struct {
|
||||||
|
Flag [1]byte
|
||||||
|
Sequence [2]byte
|
||||||
|
Checksum [2]byte
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c SaprusFileTransfer) Bytes() []byte {
|
||||||
|
data := []byte{}
|
||||||
|
data = append(data, c.Flag[0])
|
||||||
|
data = append(data, c.Sequence[0], c.Sequence[1])
|
||||||
|
data = append(data, c.Checksum[0], c.Checksum[1])
|
||||||
|
data = append(data, c.Payload...)
|
||||||
|
return data
|
||||||
|
}
|
||||||
26
server/structs/saprus.go
Normal file
26
server/structs/saprus.go
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
package structs
|
||||||
|
|
||||||
|
import (
|
||||||
|
)
|
||||||
|
|
||||||
|
type UDPPackage struct {
|
||||||
|
SourcePort [2]byte
|
||||||
|
Destport [2]byte
|
||||||
|
Length [2]byte
|
||||||
|
Checksum [2]byte
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
type SaprusHeaderFrame struct {
|
||||||
|
PacketType [2]byte
|
||||||
|
Length [2]byte
|
||||||
|
Payload []byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c SaprusHeaderFrame) Bytes() []byte {
|
||||||
|
data := []byte{}
|
||||||
|
data = append(data, c.PacketType[0], c.PacketType[1])
|
||||||
|
data = append(data, c.Length[0], c.Length[1])
|
||||||
|
data = append(data, c.Payload...)
|
||||||
|
return data
|
||||||
|
}
|
||||||
92
server/utils/file_transfer.go
Normal file
92
server/utils/file_transfer.go
Normal file
@@ -0,0 +1,92 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
|
||||||
|
"github.com/google/gopacket"
|
||||||
|
|
||||||
|
"saprusserver/structs"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (c*SocketCall) BuildFileTransferPacket(Header structs.SaprusHeaderFrame,
|
||||||
|
Data structs.SaprusFileTransfer) gopacket.SerializeBuffer {
|
||||||
|
eth, ip, udp := basePacket(c)
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: Header.PacketType,
|
||||||
|
Length: c.saprusPayloadLength(Data.Bytes()),
|
||||||
|
Payload: Data.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := gopacket.NewSerializeBuffer()
|
||||||
|
opts := gopacket.SerializeOptions {
|
||||||
|
ComputeChecksums: true,
|
||||||
|
FixLengths: true,
|
||||||
|
}
|
||||||
|
|
||||||
|
udp.SetNetworkLayerForChecksum(&ip)
|
||||||
|
err := gopacket.SerializeLayers(buf, opts, ð, &ip, &udp, gopacket.Payload(sapHeader.Bytes()))
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) FileTransferPacket(message string, seqNum uint16) gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x11},
|
||||||
|
Sequence: [2]byte{byte(seqNum >> 8), byte(seqNum & 0xFF)},
|
||||||
|
Checksum: [2]byte{0x44, 0x44},
|
||||||
|
Payload: []byte(message),
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x88, 0x88},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) InitFileTransferPacket() gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x01},
|
||||||
|
Sequence: [2]byte{0x00, 0x00},
|
||||||
|
Checksum: [2]byte{0x00, 0x00},
|
||||||
|
Payload: []byte{},
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x00, 0x00},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) EndFileTransferPacket() gopacket.SerializeBuffer {
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x02},
|
||||||
|
Sequence: [2]byte{0x00, 0x00},
|
||||||
|
Checksum: [2]byte{0x00, 0x00},
|
||||||
|
Payload: []byte{},
|
||||||
|
}
|
||||||
|
|
||||||
|
sapHeader := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{0x00, 0x00},
|
||||||
|
Length: c.saprusPayloadLength(sapFile.Bytes()),
|
||||||
|
Payload: sapFile.Bytes(),
|
||||||
|
}
|
||||||
|
|
||||||
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
|
|
||||||
|
return buf
|
||||||
|
}
|
||||||
27
server/utils/packet_helper.go
Normal file
27
server/utils/packet_helper.go
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/google/gopacket/layers"
|
||||||
|
)
|
||||||
|
|
||||||
|
func basePacket(c* SocketCall) (layers.Ethernet, layers.IPv4, layers.UDP) {
|
||||||
|
eth := layers.Ethernet {
|
||||||
|
EthernetType: layers.EthernetTypeIPv4,
|
||||||
|
SrcMAC: c.Iface.HardwareAddr,
|
||||||
|
DstMAC: layers.EthernetBroadcast,
|
||||||
|
}
|
||||||
|
ip := layers.IPv4 {
|
||||||
|
Version: 4,
|
||||||
|
TTL: 64,
|
||||||
|
SrcIP: []byte{0, 0, 0, 0},
|
||||||
|
DstIP: []byte{255, 255, 255, 255},
|
||||||
|
Protocol: layers.IPProtocolUDP,
|
||||||
|
}
|
||||||
|
udp := layers.UDP {
|
||||||
|
SrcPort: 6868,
|
||||||
|
DstPort: 6767,
|
||||||
|
}
|
||||||
|
|
||||||
|
return eth, ip, udp
|
||||||
|
}
|
||||||
|
|
||||||
@@ -1,17 +1,19 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
//"bytes"
|
"encoding/binary"
|
||||||
//"encoding/binary"
|
|
||||||
"log"
|
"log"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
//"fmt"
|
||||||
|
//"log"
|
||||||
"net"
|
"net"
|
||||||
"unicode/utf8"
|
"unicode/utf8"
|
||||||
|
|
||||||
"github.com/google/gopacket"
|
"github.com/google/gopacket"
|
||||||
"github.com/google/gopacket/layers"
|
"github.com/google/gopacket/layers"
|
||||||
"github.com/mdlayher/packet"
|
"github.com/mdlayher/packet"
|
||||||
|
//"saprusserver/structs"
|
||||||
"saprusserver/structs"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type SocketCall struct {
|
type SocketCall struct {
|
||||||
@@ -21,10 +23,12 @@ type SocketCall struct {
|
|||||||
|
|
||||||
func splitData(message string) []string {
|
func splitData(message string) []string {
|
||||||
data := []string{}
|
data := []string{}
|
||||||
|
//maxPacketLength := 8
|
||||||
|
maxPacketLength := 1449
|
||||||
|
|
||||||
var i, j int
|
var i, j int
|
||||||
|
|
||||||
for i, j = 0, 1458; j < len(message); i, j = j, j+1458 {
|
for i, j = 0, maxPacketLength; j < len(message); i, j = j, j+maxPacketLength {
|
||||||
for !utf8.RuneStart(message[j]) {
|
for !utf8.RuneStart(message[j]) {
|
||||||
j--
|
j--
|
||||||
}
|
}
|
||||||
@@ -35,15 +39,50 @@ func splitData(message string) []string {
|
|||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) SendPackage(buf gopacket.SerializeBuffer) error {
|
||||||
|
_, err := c.conn.WriteTo(buf.Bytes(), &packet.Addr{HardwareAddr: layers.EthernetBroadcast})
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
func (c* SocketCall)SendData(message string) {
|
func (c* SocketCall)SendData(message string) {
|
||||||
|
iface, _ := net.InterfaceByName("virbr0")
|
||||||
|
c.Iface = iface
|
||||||
|
|
||||||
|
conn, err := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
||||||
|
c.conn = conn
|
||||||
|
|
||||||
|
if err != nil {
|
||||||
|
log.Panic(err)
|
||||||
|
}
|
||||||
|
|
||||||
splitMessage := splitData(message)
|
splitMessage := splitData(message)
|
||||||
|
|
||||||
|
c.SendPackage(c.InitFileTransferPacket())
|
||||||
|
|
||||||
for i := 0; i < len(splitMessage); i++ {
|
for i := 0; i < len(splitMessage); i++ {
|
||||||
c.init(splitMessage[i])
|
c.SendPackage(c.FileTransferPacket(splitMessage[i], uint16(i)))
|
||||||
|
time.Sleep(20 * time.Microsecond)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
time.Sleep(200 * time.Microsecond)
|
||||||
|
|
||||||
|
c.SendPackage(c.EndFileTransferPacket())
|
||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (c* SocketCall) saprusPayloadLength(pkt []byte) [2]byte{
|
||||||
|
payloadLength := make([]byte, 2)
|
||||||
|
var length [2]byte
|
||||||
|
binary.BigEndian.PutUint16(payloadLength, uint16(len(pkt)))
|
||||||
|
|
||||||
|
length[0] = payloadLength[0]
|
||||||
|
length[1] = payloadLength[1]
|
||||||
|
|
||||||
|
return length
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
func (c* SocketCall)init(data string) {
|
func (c* SocketCall)init(data string) {
|
||||||
iface, _ := net.InterfaceByName("virbr0")
|
iface, _ := net.InterfaceByName("virbr0")
|
||||||
conn, err := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
conn, err := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
||||||
@@ -71,8 +110,16 @@ func (c* SocketCall)init(data string) {
|
|||||||
SrcPort: 6868,
|
SrcPort: 6868,
|
||||||
DstPort: 6767,
|
DstPort: 6767,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
saprusPayloadLength := make([]byte, 2)
|
||||||
|
binary.BigEndian.PutUint16(saprusPayloadLength, uint16(len(data)))
|
||||||
|
var saprusPayloadLengthTwo [2]byte
|
||||||
|
saprusPayloadLengthTwo[0] = saprusPayloadLength[0]
|
||||||
|
saprusPayloadLengthTwo[1] = saprusPayloadLength[1]
|
||||||
|
|
||||||
saprus := structs.SaprusHeaderFrame{
|
saprus := structs.SaprusHeaderFrame{
|
||||||
MagicNumber: 132,
|
PacketType: [2]byte{0, 10},
|
||||||
|
Length: saprusPayloadLengthTwo,
|
||||||
Payload: []byte(data),
|
Payload: []byte(data),
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -95,4 +142,4 @@ func (c* SocketCall)init(data string) {
|
|||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|||||||
@@ -1,6 +1,44 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/base64"
|
||||||
|
"log"
|
||||||
|
"net"
|
||||||
|
"strings"
|
||||||
|
|
||||||
|
"saprusserver/structs"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
func (c *SocketCall) GatherSaprusHeader(buf []byte) structs.SaprusHeaderFrame {
|
||||||
|
data := structs.SaprusHeaderFrame {
|
||||||
|
PacketType: [2]byte{buf[0], buf[1]},
|
||||||
|
Length: [2]byte{buf[2], buf[3]},
|
||||||
|
}
|
||||||
|
return data
|
||||||
|
}
|
||||||
|
|
||||||
|
func ProcessRequests(buf []byte, addr net.Addr) {
|
||||||
|
c := SocketCall{}
|
||||||
|
|
||||||
|
msg := "hello world"
|
||||||
|
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
||||||
|
|
||||||
|
saprusHeader := c.GatherSaprusHeader(buf)
|
||||||
|
|
||||||
|
remoteAddr := strings.Split(addr.String(), ":")
|
||||||
|
|
||||||
|
switch {
|
||||||
|
case strings.Contains(string(buf), "here"):
|
||||||
|
log.Printf("Sending Data to %s\n", remoteAddr)
|
||||||
|
c.SendData(b64Msg)
|
||||||
|
case saprusHeader.PacketType == [2]byte{0x88, 0x88}:
|
||||||
|
log.Printf("New find:: %s\n", remoteAddr)
|
||||||
|
c.SendData(base64.StdEncoding.EncodeToString([]byte("hello\n")))
|
||||||
|
case saprusHeader.PacketType == [2]byte{0x00, 0x3C}:
|
||||||
|
log.Printf("Broadcast message::%s\n", remoteAddr)
|
||||||
|
default:
|
||||||
|
log.Printf("Packet type not found::%x\n", string(saprusHeader.PacketType[:]))
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user