Compare commits
2 Commits
dev
...
9812b17738
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9812b17738 | ||
|
|
643be473a2 |
@@ -1,12 +1,12 @@
|
|||||||
package main
|
package main
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"encoding/base64"
|
//"encoding/base64"
|
||||||
"encoding/binary"
|
"encoding/binary"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"strings"
|
//"strings"
|
||||||
"time"
|
"time"
|
||||||
|
|
||||||
"github.com/google/gopacket"
|
"github.com/google/gopacket"
|
||||||
@@ -21,10 +21,11 @@ func errCheck(err error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
func listenDiscoverResponse(addrChan chan string, readyFlag chan int) {
|
||||||
|
finalMessage := ""
|
||||||
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,12 +33,17 @@ 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()))
|
finalMessage = ""
|
||||||
if err == nil {
|
payload := pkt.ApplicationLayer().Payload()
|
||||||
if strings.Contains(string(msg), "clientapi") {
|
payloadLength := binary.BigEndian.Uint16([]byte{payload[2], payload[3]})
|
||||||
addrChan <- string(msg)
|
|
||||||
return
|
for i := uint16(0); i < payloadLength - 5; i++ {
|
||||||
|
finalMessage += string(payload[i+9])
|
||||||
}
|
}
|
||||||
|
fmt.Println(finalMessage)
|
||||||
|
if err == nil {
|
||||||
|
//addrChan <- finalMessage
|
||||||
|
//return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -102,7 +108,7 @@ func main() {
|
|||||||
// 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(5 * time.Second):
|
||||||
fmt.Printf("error\n")
|
fmt.Printf("error\n")
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -31,8 +31,21 @@ Saprus Protocol Header:
|
|||||||
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 Type | Length | |
|
| Saprus Type | Length | |
|
||||||
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +-+-+-+-+-+-+-+-+
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ +
|
||||||
| Saprus Type Payload (0-1455) |
|
| 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 |
|
||||||
|
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
|
||||||
|
```
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ 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 := "client data being send from the sender"
|
serverIP := "hello world this is saprus"
|
||||||
msg := "clientapi: " + serverIP
|
msg := "clientapi: " + serverIP
|
||||||
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
b64Msg := base64.StdEncoding.EncodeToString([]byte(msg))
|
||||||
|
|
||||||
|
|||||||
21
server/structs/file_transfer.go
Normal file
21
server/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
|
||||||
|
}
|
||||||
|
|
||||||
@@ -4,13 +4,15 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type SaprusHeaderFrame struct {
|
type SaprusHeaderFrame struct {
|
||||||
PacketType uint16
|
PacketType [2]byte
|
||||||
Length uint16
|
Length [2]byte
|
||||||
Payload []byte
|
Payload []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c SaprusHeaderFrame) Bytes() []byte {
|
func (c SaprusHeaderFrame) Bytes() []byte {
|
||||||
data := []byte{byte(c.PacketType), byte(c.Length)}
|
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...)
|
data = append(data, c.Payload...)
|
||||||
return data
|
return data
|
||||||
}
|
}
|
||||||
|
|||||||
39
server/utils/file_transfer.go
Normal file
39
server/utils/file_transfer.go
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
package utils
|
||||||
|
|
||||||
|
import (
|
||||||
|
"log"
|
||||||
|
"github.com/google/gopacket"
|
||||||
|
|
||||||
|
"saprusserver/structs"
|
||||||
|
)
|
||||||
|
|
||||||
|
func (c* SocketCall) FileTransferPacket(message string) gopacket.SerializeBuffer {
|
||||||
|
eth, ip, udp := basePacket(c)
|
||||||
|
|
||||||
|
sapFile := structs.SaprusFileTransfer {
|
||||||
|
Flag: [1]byte{0x11},
|
||||||
|
Sequence: [2]byte{0x22, 0x33},
|
||||||
|
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 := 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
|
||||||
|
}
|
||||||
|
|
||||||
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,8 +1,8 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import (
|
import (
|
||||||
//"bytes"
|
"encoding/binary"
|
||||||
//"encoding/binary"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net"
|
"net"
|
||||||
"unicode/utf8"
|
"unicode/utf8"
|
||||||
@@ -21,10 +21,12 @@ type SocketCall struct {
|
|||||||
|
|
||||||
func splitData(message string) []string {
|
func splitData(message string) []string {
|
||||||
data := []string{}
|
data := []string{}
|
||||||
|
maxPacketLength := 8
|
||||||
|
//maxPacketLength := 1458
|
||||||
|
|
||||||
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 +37,38 @@ 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, _ := packet.Listen(iface, packet.Raw, int(layers.EthernetTypeIPv4), nil)
|
||||||
|
c.conn = conn
|
||||||
|
|
||||||
splitMessage := splitData(message)
|
splitMessage := splitData(message)
|
||||||
|
|
||||||
for i := 0; i < len(splitMessage); i++ {
|
for i := 0; i < len(splitMessage); i++ {
|
||||||
c.init(splitMessage[i])
|
c.SendPackage(c.FileTransferPacket(splitMessage[i]))
|
||||||
}
|
}
|
||||||
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,9 +96,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{
|
||||||
PacketType: 10,
|
PacketType: [2]byte{0, 10},
|
||||||
Length: uint16(len(data)),
|
Length: saprusPayloadLengthTwo,
|
||||||
Payload: []byte(data),
|
Payload: []byte(data),
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -96,4 +128,4 @@ func (c* SocketCall)init(data string) {
|
|||||||
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
|
|||||||
Reference in New Issue
Block a user