server data rx changes
This commit is contained in:
@@ -6,6 +6,7 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
|
|
||||||
//"strings"
|
//"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
@@ -13,6 +14,19 @@ import (
|
|||||||
"github.com/google/gopacket/pcap"
|
"github.com/google/gopacket/pcap"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
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,8 +34,26 @@ 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 := ""
|
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)
|
||||||
|
|
||||||
@@ -33,17 +65,10 @@ func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
|||||||
readyFlag <- 1
|
readyFlag <- 1
|
||||||
|
|
||||||
for pkt := range packets {
|
for pkt := range packets {
|
||||||
finalMessage = ""
|
pkt_data = createSaprusFileTransferPacket(pkt.ApplicationLayer().Payload())
|
||||||
payload := pkt.ApplicationLayer().Payload()
|
finalMessage += string(pkt_data.Payload)
|
||||||
payloadLength := binary.BigEndian.Uint16([]byte{payload[2], payload[3]})
|
if pkt_data.Flag == 2 {
|
||||||
|
addrChan <- finalMessage
|
||||||
for i := uint16(0); i < payloadLength - 5; i++ {
|
|
||||||
finalMessage += string(payload[i+9])
|
|
||||||
}
|
|
||||||
fmt.Println(finalMessage)
|
|
||||||
if err == nil {
|
|
||||||
//addrChan <- finalMessage
|
|
||||||
//return
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -109,7 +134,7 @@ func main() {
|
|||||||
select {
|
select {
|
||||||
case returnMSG := <- addrChan:
|
case returnMSG := <- addrChan:
|
||||||
fmt.Printf("%s\n", returnMSG)
|
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")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ package main
|
|||||||
import (
|
import (
|
||||||
"encoding/base64"
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
"strings"
|
||||||
@@ -38,8 +39,10 @@ func main() {
|
|||||||
log.Printf("Starting server\n")
|
log.Printf("Starting server\n")
|
||||||
con := utils.SocketCall{}
|
con := utils.SocketCall{}
|
||||||
serv, err := net.ListenPacket("udp4", ":8888")
|
serv, err := net.ListenPacket("udp4", ":8888")
|
||||||
serverIP := "hello world this is saprus"
|
serverIP := "aaa"
|
||||||
msg := "clientapi: " + serverIP
|
msg := "clientapi: " + serverIP
|
||||||
|
fileBuf, _ := ioutil.ReadFile("./script.sh")
|
||||||
|
msg = string(fileBuf)
|
||||||
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
||||||
|
|
||||||
checkError(err)
|
checkError(err)
|
||||||
|
|||||||
@@ -18,4 +18,3 @@ func (c SaprusFileTransfer) Bytes() []byte {
|
|||||||
data = append(data, c.Payload...)
|
data = append(data, c.Payload...)
|
||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -2,17 +2,42 @@ package utils
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"log"
|
"log"
|
||||||
|
|
||||||
"github.com/google/gopacket"
|
"github.com/google/gopacket"
|
||||||
|
|
||||||
"saprusserver/structs"
|
"saprusserver/structs"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (c* SocketCall) FileTransferPacket(message string) gopacket.SerializeBuffer {
|
func (c*SocketCall) BuildFileTransferPacket(Header structs.SaprusHeaderFrame,
|
||||||
|
Data structs.SaprusFileTransfer) gopacket.SerializeBuffer {
|
||||||
eth, ip, udp := basePacket(c)
|
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 {
|
sapFile := structs.SaprusFileTransfer {
|
||||||
Flag: [1]byte{0x11},
|
Flag: [1]byte{0x11},
|
||||||
Sequence: [2]byte{0x22, 0x33},
|
Sequence: [2]byte{byte(seqNum >> 8), byte(seqNum & 0xFF)},
|
||||||
Checksum: [2]byte{0x44, 0x44},
|
Checksum: [2]byte{0x44, 0x44},
|
||||||
Payload: []byte(message),
|
Payload: []byte(message),
|
||||||
}
|
}
|
||||||
@@ -23,17 +48,45 @@ func (c* SocketCall) FileTransferPacket(message string) gopacket.SerializeBuffer
|
|||||||
Payload: sapFile.Bytes(),
|
Payload: sapFile.Bytes(),
|
||||||
}
|
}
|
||||||
|
|
||||||
buf := gopacket.NewSerializeBuffer()
|
buf := c.BuildFileTransferPacket(sapHeader, sapFile)
|
||||||
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
|
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
|
||||||
|
}
|
||||||
|
|||||||
@@ -2,16 +2,18 @@ package utils
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"fmt"
|
|
||||||
"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,8 +23,8 @@ type SocketCall struct {
|
|||||||
|
|
||||||
func splitData(message string) []string {
|
func splitData(message string) []string {
|
||||||
data := []string{}
|
data := []string{}
|
||||||
maxPacketLength := 8
|
//maxPacketLength := 8
|
||||||
//maxPacketLength := 1458
|
maxPacketLength := 1449
|
||||||
|
|
||||||
var i, j int
|
var i, j int
|
||||||
|
|
||||||
@@ -46,14 +48,26 @@ func (c* SocketCall)SendData(message string) {
|
|||||||
iface, _ := net.InterfaceByName("virbr0")
|
iface, _ := net.InterfaceByName("virbr0")
|
||||||
c.Iface = iface
|
c.Iface = iface
|
||||||
|
|
||||||
conn, _ := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
conn, err := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
||||||
c.conn = conn
|
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.SendPackage(c.FileTransferPacket(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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user