2022-01-09 13:05:36 +10:30
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
2022-01-13 14:26:16 +10:30
|
|
|
"bytes"
|
|
|
|
"encoding/gob"
|
2022-01-09 13:05:36 +10:30
|
|
|
"fmt"
|
2022-01-13 14:26:16 +10:30
|
|
|
"io"
|
|
|
|
"log"
|
2022-01-09 13:05:36 +10:30
|
|
|
"net"
|
|
|
|
"os"
|
2022-01-13 14:26:16 +10:30
|
|
|
"time"
|
2022-01-09 13:05:36 +10:30
|
|
|
|
|
|
|
"github.com/tardisx/netgiv/secure"
|
|
|
|
)
|
|
|
|
|
|
|
|
type Server struct {
|
|
|
|
port int
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *Server) Run() {
|
2022-01-13 22:20:35 +10:30
|
|
|
address := fmt.Sprintf(":%d", s.port)
|
2022-01-09 13:05:36 +10:30
|
|
|
networkAddress, _ := net.ResolveTCPAddr("tcp", address)
|
|
|
|
|
|
|
|
listener, err := net.ListenTCP("tcp", networkAddress)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Print(err)
|
|
|
|
os.Exit(2)
|
|
|
|
}
|
|
|
|
|
|
|
|
for {
|
|
|
|
conn, err := listener.AcceptTCP()
|
|
|
|
|
|
|
|
if err != nil {
|
|
|
|
fmt.Print(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
go handleConnection(conn)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func handleConnection(conn *net.TCPConn) {
|
|
|
|
defer conn.Close()
|
2022-01-13 14:26:16 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
conn.SetDeadline(time.Now().Add(time.Second * 5))
|
2022-01-13 14:26:16 +10:30
|
|
|
|
2022-01-09 13:05:36 +10:30
|
|
|
sharedKey := secure.Handshake(conn)
|
2022-01-13 14:26:16 +10:30
|
|
|
secureConnection := secure.SecureConnection{Conn: conn, SharedKey: sharedKey, Buffer: &bytes.Buffer{}}
|
|
|
|
|
|
|
|
gob.Register(secure.PacketStart{})
|
|
|
|
gob.Register(secure.PacketSendDataStart{})
|
|
|
|
|
|
|
|
dec := gob.NewDecoder(&secureConnection)
|
2022-01-09 13:05:36 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
// Get the start packet
|
|
|
|
start := secure.PacketStart{}
|
2022-01-13 14:26:16 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
err := dec.Decode(&start)
|
|
|
|
if err == io.EOF {
|
|
|
|
log.Printf("connection has been closed after start packet")
|
|
|
|
return
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("some error with start packet: %w", err)
|
|
|
|
return
|
|
|
|
}
|
2022-01-09 13:05:36 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
log.Printf("Decoded packet:\n%#v", start)
|
|
|
|
conn.SetDeadline(time.Now().Add(time.Second * 5))
|
2022-01-13 14:26:16 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
if start.OperationType == secure.OperationTypeSend {
|
|
|
|
log.Printf("client wants to send us something, expecting a send start")
|
|
|
|
sendStart := secure.PacketSendDataStart{}
|
2022-01-13 14:26:16 +10:30
|
|
|
|
2022-01-13 22:20:35 +10:30
|
|
|
err = dec.Decode(&sendStart)
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("error at send data start: %w", err)
|
2022-01-13 14:26:16 +10:30
|
|
|
return
|
|
|
|
}
|
2022-01-13 22:20:35 +10:30
|
|
|
log.Printf("send start looks like: %v", sendStart)
|
|
|
|
file, err := os.CreateTemp("", "netgiv_")
|
2022-01-13 14:26:16 +10:30
|
|
|
if err != nil {
|
2022-01-13 22:20:35 +10:30
|
|
|
log.Printf("got error with temp file: %w", err)
|
|
|
|
return
|
2022-01-13 14:26:16 +10:30
|
|
|
}
|
2022-01-13 22:20:35 +10:30
|
|
|
log.Printf("writing data to file: %s", file.Name())
|
|
|
|
sendData := secure.PacketSendDataNext{}
|
|
|
|
for {
|
|
|
|
conn.SetDeadline(time.Now().Add(time.Second * 5))
|
|
|
|
err = dec.Decode(&sendData)
|
|
|
|
if err == io.EOF {
|
|
|
|
log.Printf("WE ARE DONE writing to: %s", file.Name())
|
|
|
|
break
|
|
|
|
}
|
|
|
|
if err != nil {
|
|
|
|
log.Printf("error decoding data next: %s", err)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
file.Write(sendData.Data)
|
|
|
|
}
|
|
|
|
return
|
|
|
|
} else {
|
|
|
|
log.Printf("bad operation")
|
|
|
|
return
|
2022-01-09 13:05:36 +10:30
|
|
|
}
|
2022-01-13 22:20:35 +10:30
|
|
|
|
2022-01-09 13:05:36 +10:30
|
|
|
}
|