Makefile, server entry point prototype, compareFiles function + other minor changes
This commit is contained in:
parent
2efb8c4130
commit
c1ccb61346
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,2 +1,3 @@
|
||||||
.vscode/
|
.vscode/
|
||||||
lab/
|
lab/
|
||||||
|
bin/*
|
5
Makefile
Normal file
5
Makefile
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
client:
|
||||||
|
go build -o bin/client cmd/client/main.go
|
||||||
|
|
||||||
|
server:
|
||||||
|
go build -o bin/server cmd/server/main.go
|
|
@ -1,44 +1,44 @@
|
||||||
package main
|
package client
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"cosync/internal/client"
|
"cosync/internal/client"
|
||||||
"cosync/internal/server"
|
"cosync/internal/server"
|
||||||
"cosync/tests"
|
|
||||||
|
// "cosync/tests"
|
||||||
"os"
|
"os"
|
||||||
)
|
)
|
||||||
|
|
||||||
//TODO: handle arguments correctly
|
// TODO: handle arguments correctly
|
||||||
func main() {
|
func main() {
|
||||||
argc := len(os.Args)
|
argc := len(os.Args)
|
||||||
if argc < 2 {
|
if argc < 2 {
|
||||||
panic("Not enough arguments (try --help)")
|
panic("Not enough arguments (try --help)")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
for i := 1; i < argc; i++ {
|
for i := 1; i < argc; i++ {
|
||||||
|
|
||||||
switch (os.Args[i]) {
|
switch os.Args[i] {
|
||||||
|
|
||||||
case "-s":
|
case "-s":
|
||||||
server.Run()
|
server.Run()
|
||||||
// break
|
// break
|
||||||
|
|
||||||
case "-c":
|
case "-c":
|
||||||
client.Run()
|
client.Run()
|
||||||
// break
|
// break
|
||||||
|
|
||||||
case "-p":
|
case "-p":
|
||||||
panic("Not implemented")
|
panic("Not implemented")
|
||||||
|
|
||||||
case "--help":
|
case "--help":
|
||||||
panic("Not implemented")
|
panic("Not implemented")
|
||||||
|
|
||||||
case "--test":
|
// case "--test":
|
||||||
tests.TestAll()
|
// tests.TestAll()
|
||||||
|
|
||||||
default:
|
default:
|
||||||
panic("Bad argument : \"" + os.Args[i] + "\"")
|
panic("Bad argument : \"" + os.Args[i] + "\"")
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
|
@ -1 +1,38 @@
|
||||||
package server
|
package server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"cosync/internal/server"
|
||||||
|
// "cosync/tests"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
|
// TODO: handle arguments correctly
|
||||||
|
func main() {
|
||||||
|
argc := len(os.Args)
|
||||||
|
if argc < 2 {
|
||||||
|
panic("Not enough arguments (try --help)")
|
||||||
|
}
|
||||||
|
|
||||||
|
for i := 1; i < argc; i++ {
|
||||||
|
|
||||||
|
switch os.Args[i] {
|
||||||
|
|
||||||
|
case "-s":
|
||||||
|
server.Run()
|
||||||
|
// break
|
||||||
|
|
||||||
|
case "-p":
|
||||||
|
panic("Not implemented")
|
||||||
|
|
||||||
|
case "--help":
|
||||||
|
panic("Not implemented")
|
||||||
|
|
||||||
|
// case "--test":
|
||||||
|
// tests.TestAll()
|
||||||
|
|
||||||
|
default:
|
||||||
|
panic("Bad argument : \"" + os.Args[i] + "\"")
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -7,14 +7,11 @@ import (
|
||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
// Config will follow this model
|
// Config will follow this model
|
||||||
// server : string
|
// server : string
|
||||||
// port : int
|
// port : int
|
||||||
|
|
||||||
|
var config_loaded bool = false
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Load config file
|
// Load config file
|
||||||
func LoadConfig() error {
|
func LoadConfig() error {
|
||||||
|
@ -43,6 +40,7 @@ func LoadConfig() error {
|
||||||
// return err
|
// return err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
config_loaded = true
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -57,7 +55,16 @@ func LoadSyncList() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
// returns all config variables
|
// returns all config variables
|
||||||
// ! WARNING: Do not use this function without executing LoadConfig prior
|
|
||||||
func GetConfig() map[string]any {
|
func GetConfig() map[string]any {
|
||||||
return viper.AllSettings()
|
|
||||||
|
if config_loaded {
|
||||||
|
return viper.AllSettings()
|
||||||
|
} else {
|
||||||
|
err := LoadConfig()
|
||||||
|
if err != nil {
|
||||||
|
panic("GetConfig: Failed to load config file -> " + err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return viper.AllSettings()
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,10 +5,10 @@ import (
|
||||||
)
|
)
|
||||||
|
|
||||||
type File struct {
|
type File struct {
|
||||||
ID string
|
ID string
|
||||||
ParentDirectory string
|
ParentDirectory Folder
|
||||||
Metadata FileMetadata
|
Metadata FileMetadata
|
||||||
State SynchronizationState
|
State SynchronizationState
|
||||||
}
|
}
|
||||||
|
|
||||||
type FileMetadata struct {
|
type FileMetadata struct {
|
||||||
|
@ -22,4 +22,13 @@ type SynchronizationState struct {
|
||||||
Status string // "pending", "in_progress", "completed", "error"
|
Status string // "pending", "in_progress", "completed", "error"
|
||||||
Progress float64
|
Progress float64
|
||||||
LastError error
|
LastError error
|
||||||
|
}
|
||||||
|
|
||||||
|
type Folder struct {
|
||||||
|
ID string
|
||||||
|
Files []File
|
||||||
|
Subfolders []Folder
|
||||||
|
|
||||||
|
Name string
|
||||||
|
Path string
|
||||||
}
|
}
|
|
@ -1,8 +1,36 @@
|
||||||
package core
|
package core
|
||||||
|
|
||||||
|
import (
|
||||||
|
"crypto/sha256"
|
||||||
|
"io"
|
||||||
|
"os"
|
||||||
|
)
|
||||||
|
|
||||||
//! Not implemented
|
// Panic if e contains an error
|
||||||
func CompareFiles(file1 File, file2 File) bool {
|
func Check(e error) {
|
||||||
return false
|
if e != nil {
|
||||||
|
panic("Check: A fatal error occured during execution -> " + e.Error())
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Returns true if files correspond
|
||||||
|
func CompareFiles(file1 File, file2 File) bool {
|
||||||
|
return file1.Metadata.Hash == file2.Metadata.Hash
|
||||||
|
}
|
||||||
|
|
||||||
|
// Gets the sha256 hash of a file's content
|
||||||
|
func GetHash(file File) ([]byte, error) {
|
||||||
|
// init
|
||||||
|
hasher := sha256.New()
|
||||||
|
file_path := "" //TODO: missing
|
||||||
|
// Open file
|
||||||
|
f, err := os.Open(file_path)
|
||||||
|
if err != nil { // Path error
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
// Compute hash
|
||||||
|
io.Copy(hasher, f)
|
||||||
|
sum := hasher.Sum(nil)
|
||||||
|
|
||||||
|
return sum, nil
|
||||||
|
}
|
||||||
|
|
|
@ -27,7 +27,7 @@ func Run() {
|
||||||
serverPort := strconv.Itoa(config["port"].(int))
|
serverPort := strconv.Itoa(config["port"].(int))
|
||||||
|
|
||||||
// Listening
|
// Listening
|
||||||
listener, err := net.Listen("tcp", ":" + serverPort)
|
listener, err := net.Listen("tcp", ":"+serverPort)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
panic(err)
|
panic(err)
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ func handleConnection(conn net.Conn) {
|
||||||
log.Println("Error reading from ", clientAddress, ": ", err)
|
log.Println("Error reading from ", clientAddress, ": ", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
// to rm
|
// to rm
|
||||||
println(message)
|
println(message)
|
||||||
// fmt.Println("Received from client:", message)
|
// fmt.Println("Received from client:", message)
|
||||||
|
@ -76,7 +76,7 @@ func handleConnection(conn net.Conn) {
|
||||||
// Send a response to the client
|
// Send a response to the client
|
||||||
_, err = conn.Write([]byte("Server received your message\n"))
|
_, err = conn.Write([]byte("Server received your message\n"))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Error replying to", clientAddress,": ", err)
|
log.Println("Error replying to", clientAddress, ": ", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
22
tests/cosync_test.go
Normal file
22
tests/cosync_test.go
Normal file
|
@ -0,0 +1,22 @@
|
||||||
|
package tests
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
"cosync/internal/client"
|
||||||
|
"cosync/internal/server"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestAll(t *testing.T) {
|
||||||
|
TestClientServerCommunication(t)
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestClientServerCommunication(t *testing.T) {
|
||||||
|
go client.Run()
|
||||||
|
go server.Run()
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConfigLoading(t *testing.T) {
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestConfigCreation(t *testing.T) {
|
||||||
|
}
|
|
@ -1,26 +0,0 @@
|
||||||
package tests
|
|
||||||
|
|
||||||
import (
|
|
||||||
// "testing"
|
|
||||||
"cosync/internal/client"
|
|
||||||
"cosync/internal/server"
|
|
||||||
)
|
|
||||||
|
|
||||||
func TestAll() bool {
|
|
||||||
TestClientServerCommunication()
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestClientServerCommunication() bool {
|
|
||||||
go client.Run()
|
|
||||||
go server.Run()
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestConfigLoading() bool {
|
|
||||||
return false
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestConfigCreation() bool {
|
|
||||||
return false
|
|
||||||
}
|
|
Loading…
Reference in a new issue