Make it possible to retrieve a particular file (not implemented on client yet)
This commit is contained in:
parent
d90eab464d
commit
7a1c344964
@ -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()
|
||||||
|
1
main.go
1
main.go
@ -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 {
|
||||||
|
67
server.go
67
server.go
@ -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
|
||||||
|
Loading…
x
Reference in New Issue
Block a user