netgiv/server.go

86 lines
1.4 KiB
Go

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() {
address := fmt.Sprintf("127.0.0.1:%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()
conn.SetDeadline(time.Now().Add(time.Second))
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)
// At this point we are in
for {
p1 := secure.PacketStart{}
log.Print("trying to decode something from wire")
err := dec.Decode(&p1)
if err == io.EOF {
log.Printf("connection has been closed")
return
}
if err != nil {
panic(err)
}
log.Printf("Decoded packet:\n%#v", p1)
p2 := secure.PacketSendDataStart{}
err = dec.Decode(&p2)
if err == io.EOF {
log.Printf("connection has been closed")
return
}
if err != nil {
panic(err)
}
log.Printf("Decoded packet:\n%#v", p2)
}
}