Compare commits

...

2 Commits

Author SHA1 Message Date
Pin
9812b17738 further updates 2023-03-20 23:32:15 -04:00
Pin
643be473a2 server updates 2023-03-20 23:29:07 -04:00
8 changed files with 163 additions and 23 deletions

View File

@@ -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 = ""
payload := pkt.ApplicationLayer().Payload()
payloadLength := binary.BigEndian.Uint16([]byte{payload[2], payload[3]})
for i := uint16(0); i < payloadLength - 5; i++ {
finalMessage += string(payload[i+9])
}
fmt.Println(finalMessage)
if err == nil { if err == nil {
if strings.Contains(string(msg), "clientapi") { //addrChan <- finalMessage
addrChan <- string(msg) //return
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")
} }

View File

@@ -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 |
+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
```

View File

@@ -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))

View 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
}

View File

@@ -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
} }

View 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, &eth, &ip, &udp, gopacket.Payload(sapHeader.Bytes()))
if err != nil {
log.Panic(err)
}
return buf
}

View 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
}

View File

@@ -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
} }
*/