[PD1] restructure

This commit is contained in:
Afonso Franco 2024-04-16 12:23:00 +01:00
parent c0e19b5774
commit 8553e1674e
Signed by: afonso
SSH key fingerprint: SHA256:aiLbdlPwXKJS5wMnghdtod0SPy8imZjlVvCyUX9DJNk
17 changed files with 141 additions and 33 deletions

View file

@ -1 +0,0 @@
package client

View file

@ -0,0 +1,9 @@
package main
import (
"PD1/internal/client"
)
func main(){
client.Run()
}

View file

@ -0,0 +1,9 @@
package main
import (
"PD1/internal/server"
)
func main(){
server.Run()
}

View file

@ -1,3 +1,8 @@
module PD1
go 1.22.2
require (
golang.org/x/crypto v0.11.0 // indirect
software.sslmate.com/src/go-pkcs12 v0.4.0 // indirect
)

4
Projs/PD1/go.sum Normal file
View file

@ -0,0 +1,4 @@
golang.org/x/crypto v0.11.0 h1:6Ewdq3tDic1mg5xRO4milcWCfMVQhI4NkqWWvqejpuA=
golang.org/x/crypto v0.11.0/go.mod h1:xgJhtzW8F9jGdVFWZESrid1U1bjeNy4zgy5cRr/CIio=
software.sslmate.com/src/go-pkcs12 v0.4.0 h1:H2g08FrTvSFKUj+D309j1DPfk5APnIdAQAB8aEykJ5k=
software.sslmate.com/src/go-pkcs12 v0.4.0/go.mod h1:Qiz0EyvDRJjjxGyUQa2cCNZn/wMyzrRJ/qcDXOQazLI=

View file

@ -0,0 +1,7 @@
package client
import "fmt"
func Run() {
fmt.Println("Client is running...")
}

View file

@ -0,0 +1,68 @@
package protocol
import (
"encoding/json"
"fmt"
"time"
)
type PacketType int
const (
ReqPK PacketType = iota
ReqAllMsg
ReqMsg
SendPK
UsrMsg
)
type PacketBody interface {}
type Packet struct {
Flag PacketType
Body PacketBody
}
// Client --> Server: Ask for a user's public key
type RequestPubKey struct {
FromUID string
KeyUID string
}
// Client --> Server: Ask for all the client's messages in the queue
type RequestAllMsg struct {
FromUID string
}
// Client --> Server: Ask for a specific message in the queue
type RequestMsg struct {
Num uint16
}
// Server --> Client: Send the client the requested public key
type SendPubKey struct {
Key []byte
}
// Bidirectional: Send messages between server and clients
type SendMessage struct {
ToUID string
Subject []byte
Body []byte
}
type Message struct {
FromUID string
ToUID string
Subject []byte
Body []byte
Timestamp time.Time
}
func (p Packet) Marshal() ([]byte, error) {
return json.Marshal(p)
}
func (p *Packet) Unmarshal(data []byte) error {
return json.Unmarshal(data, p)
}

View file

@ -0,0 +1,30 @@
package server
import (
_ "PD1/internal/utils/cryptoUtils"
_ "PD1/internal/utils/networking"
"fmt"
"net"
)
func clientHandler(conn net.Conn) {
}
func Run(port int) {
ip, err := net.ResolveTCPAddr("tcp", ":8080")
if err != nil {
panic("Server could not bind to address")
}
listener, err := net.ListenTCP("tcp", ip)
if err != nil {
panic("Server could not listen on address")
}
for {
conn, err := listener.Accept()
if err!=nil{
panic("Server could not accept connection")
}
go clientHandler(conn)
}
}

View file

@ -1,4 +1,4 @@
package crypto
package cryptoUtils
import "fmt"

View file

@ -0,0 +1,5 @@
package networking
func sendPacket(){
}

View file

@ -0,0 +1 @@
Libs

View file

@ -1,17 +0,0 @@
package server
import (
_ "PD1/utils/networking"
_ "PD1/utils/crypto"
)
const (
a = iota
b
c
d
e
)
func main() {
}

View file

@ -11,8 +11,8 @@ cmd="go build"
[targets.server]
deps=["check"]
cmd="go run ./src/server/server.go"
cmd="go run ./cmd/server/server.go"
[targets.client]
deps=["check"]
cmd="go run ./src/server/client.go"
cmd="go run ./cmd/client/client.go"

View file

@ -1,7 +0,0 @@
package networking
import "fmt"
func Print(){
fmt.Println("networking package")
}

View file

@ -1,5 +0,0 @@
package protocol
type message struct{
}