netgiv/server.go

107 lines
2.1 KiB
Go
Raw Normal View History

package main
import (
"bytes"
"encoding/gob"
"fmt"
"io"
"log"
"net"
"os"
"time"
"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)
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 22:20:35 +10:30
conn.SetDeadline(time.Now().Add(time.Second * 5))
sharedKey := secure.Handshake(conn)
secureConnection := secure.SecureConnection{Conn: conn, SharedKey: sharedKey, Buffer: &bytes.Buffer{}}
gob.Register(secure.PacketStart{})
gob.Register(secure.PacketSendDataStart{})
dec := gob.NewDecoder(&secureConnection)
2022-01-13 22:20:35 +10:30
// Get the start packet
start := secure.PacketStart{}
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-13 22:20:35 +10:30
log.Printf("Decoded packet:\n%#v", start)
conn.SetDeadline(time.Now().Add(time.Second * 5))
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 22:20:35 +10:30
err = dec.Decode(&sendStart)
if err != nil {
log.Printf("error at send data start: %w", err)
return
}
2022-01-13 22:20:35 +10:30
log.Printf("send start looks like: %v", sendStart)
file, err := os.CreateTemp("", "netgiv_")
if err != nil {
2022-01-13 22:20:35 +10:30
log.Printf("got error with temp file: %w", err)
return
}
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-13 22:20:35 +10:30
}