}
}
+ defer file.Close()
+
f, err := NewFileWrapper(fileStore, fullPath, 0)
if err != nil {
return err
}
- rLogger.Info("File upload started", "dstFile", fullPath)
+ rLogger.Debug("File upload started", "dstFile", fullPath)
rForkWriter := io.Discard
iForkWriter := io.Discard
}
if err := receiveFile(rwc, file, rForkWriter, iForkWriter, fileTransfer.bytesSentCounter); err != nil {
- rLogger.Error(err.Error())
- }
-
- if err := file.Close(); err != nil {
- return err
+ return fmt.Errorf("receive file: %v", err)
}
if err := fileStore.Rename(fullPath+".incomplete", fullPath); err != nil {
- return err
+ return fmt.Errorf("rename incomplete file: %v", err)
}
rLogger.Info("File upload complete", "dstFile", fullPath)
"bytes"
"encoding/binary"
"errors"
+ "fmt"
"io"
)
func receiveFile(r io.Reader, targetFile, resForkFile, infoFork, counterWriter io.Writer) error {
var ffo flattenedFileObject
if _, err := ffo.ReadFrom(r); err != nil {
- return err
+ return fmt.Errorf("read flatted file object: %v", err)
}
// Write the information fork
_, err := io.Copy(infoFork, &ffo.FlatFileInformationFork)
if err != nil {
- return err
+ return fmt.Errorf("write the information fork: %v", err)
}
if _, err = io.CopyN(targetFile, io.TeeReader(r, counterWriter), ffo.dataSize()); err != nil {
- return err
+ return fmt.Errorf("copy file data to partial file: %v", err)
}
if ffo.FlatFileHeader.ForkCount == [2]byte{0, 3} {
if err := binary.Read(r, binary.BigEndian, &ffo.FlatFileResForkHeader); err != nil {
- return err
+ return fmt.Errorf("read resource fork header: %v", err)
}
if _, err = io.CopyN(resForkFile, io.TeeReader(r, counterWriter), ffo.rsrcSize()); err != nil {
- return err
+ return fmt.Errorf("read resource fork: %v", err)
}
}
return nil