Make it possible to retrieve a particular file (not implemented on client yet)

This commit is contained in:
Justin Hawkins 2022-01-15 16:47:06 +10:30
parent d90eab464d
commit 7a1c344964
3 changed files with 64 additions and 13 deletions

View File

@ -83,7 +83,7 @@ func (c *Client) Connect() error {
} }
req := secure.PacketReceiveDataStartRequest{ req := secure.PacketReceiveDataStartRequest{
Id: 234, Id: 0, // 0 means last? Change to do a fetch?
} }
err = enc.Encode(req) err = enc.Encode(req)
if err != nil { if err != nil {
@ -96,7 +96,6 @@ func (c *Client) Connect() error {
panic(err) panic(err)
} }
log.Printf("server said %v", res)
if res.Status == secure.ReceiveDataStartResponseOK { if res.Status == secure.ReceiveDataStartResponseOK {
for { for {
res := secure.PacketReceiveDataNext{} res := secure.PacketReceiveDataNext{}
@ -104,16 +103,16 @@ func (c *Client) Connect() error {
if err != nil { if err != nil {
panic(err) panic(err)
} }
// log.Printf("got %d bytes, last is %t", res.Size, res.Last)
// print(res.Data)
os.Stdout.Write(res.Data[:res.Size]) os.Stdout.Write(res.Data[:res.Size])
if res.Last { if res.Last {
break break
} }
} }
log.Printf("finished") log.Printf("finished")
} else if res.Status == secure.ReceiveDataStartResponseNotFound {
log.Printf("ngf not found")
} else { } else {
panic("don't handle this yet") panic("unknown status")
} }
conn.Close() conn.Close()

View File

@ -21,7 +21,6 @@ func main() {
s := Server{port: *port} s := Server{port: *port}
s.Run() s.Run()
} else { } else {
log.Printf("Client running on %d\n", *port)
c := Client{port: *port, address: *addr, list: *isList, receive: *isReceive} c := Client{port: *port, address: *addr, list: *isList, receive: *isReceive}
err := c.Connect() err := c.Connect()
if err != nil { if err != nil {

View File

@ -8,6 +8,7 @@ import (
"log" "log"
"net" "net"
"os" "os"
"os/signal"
"sync/atomic" "sync/atomic"
"time" "time"
@ -27,6 +28,7 @@ type NGF struct {
Filename string // could be empty string if we were not supplied with one Filename string // could be empty string if we were not supplied with one
Kind string // Kind string //
Size uint64 // file size Size uint64 // file size
Timestamp time.Time
} }
var ngfs []NGF var ngfs []NGF
@ -44,6 +46,23 @@ func (s *Server) Run() {
ngfs = make([]NGF, 0) ngfs = make([]NGF, 0)
go func() {
sigchan := make(chan os.Signal)
signal.Notify(sigchan, os.Interrupt)
<-sigchan
for _, ngf := range ngfs {
log.Printf("removing file: %s", ngf.StorePath)
err := os.Remove(ngf.StorePath)
if err != nil {
log.Printf("could not remove %s: %v", ngf.StorePath, err)
}
}
os.Exit(0)
}()
// start main program tasks
for { for {
conn, err := listener.AcceptTCP() conn, err := listener.AcceptTCP()
@ -106,6 +125,7 @@ func handleConnection(conn *net.TCPConn) {
Kind: "", Kind: "",
Size: 0, Size: 0,
Id: atomic.AddUint32(&globalId, 1), Id: atomic.AddUint32(&globalId, 1),
Timestamp: time.Now(),
} }
if err != nil { if err != nil {
@ -158,25 +178,58 @@ func handleConnection(conn *net.TCPConn) {
} }
log.Printf("The asked for %v", req) log.Printf("The asked for %v", req)
// do we have this ngf by id?
var requestedNGF *NGF
if len(ngfs) > 0 {
if req.Id == 0 {
// they want the most recent one
requestedNGF = &ngfs[len(ngfs)-1]
} else {
for _, ngf := range ngfs {
if ngf.Id == req.Id {
requestedNGF = &ngf
}
}
}
}
if requestedNGF == nil {
// not found
log.Printf("user requested %d, not found", req.Id)
res := secure.PacketReceiveDataStartResponse{
Status: secure.ReceiveDataStartResponseNotFound,
}
err = enc.Encode(res)
if err != nil {
log.Printf("could not send NotFound: %v", err)
}
return
}
res := secure.PacketReceiveDataStartResponse{ res := secure.PacketReceiveDataStartResponse{
Status: secure.ReceiveDataStartResponseOK, Status: secure.ReceiveDataStartResponseOK,
Filename: "abcdef", Filename: requestedNGF.Filename,
Kind: "", Kind: requestedNGF.Kind,
TotalSize: 12340, TotalSize: uint32(requestedNGF.Size),
} }
err = enc.Encode(res) err = enc.Encode(res)
if err != nil { if err != nil {
log.Printf("error sending PacketReceiveDataStartResponse: %v", err) log.Printf("error sending PacketReceiveDataStartResponse: %v", err)
return return
} }
log.Printf("%#v", ngfs)
// now just start sending the file in batches // now just start sending the file in batches
buf := make([]byte, 2048) buf := make([]byte, 2048)
filename := ngfs[0].StorePath filename := requestedNGF.StorePath
log.Printf("opening %s", filename) log.Printf("opening %s", filename)
f, err := os.Open(filename) f, err := os.Open(filename)
if err != nil {
log.Printf("could not find file %s: %v", filename, err)
return
}
for { for {
n, err := f.Read(buf) n, err := f.Read(buf)
eof := false eof := false