X-Git-Url: https://git.r.bdr.sh/rbdr/mobius/blobdiff_plain/c6a3fa2cdbf7eb78964a5df7622482cdd8782d74..95159e5585762c06c654945070ba54262b7dcec9:/hotline/transfer.go?ds=sidebyside diff --git a/hotline/transfer.go b/hotline/transfer.go index 4c80581..1257f8a 100644 --- a/hotline/transfer.go +++ b/hotline/transfer.go @@ -5,8 +5,6 @@ import ( "encoding/binary" "errors" "io" - "os" - "path/filepath" ) type transfer struct { @@ -37,12 +35,12 @@ func receiveFile(r io.Reader, targetFile, resForkFile, infoFork, counterWriter i } // Write the information fork - _, err := infoFork.Write(ffo.FlatFileInformationFork.MarshalBinary()) + _, err := io.Copy(infoFork, &ffo.FlatFileInformationFork) if err != nil { return err } - if _, err = io.Copy(targetFile, io.TeeReader(r, counterWriter)); err != nil { + if _, err = io.CopyN(targetFile, io.TeeReader(r, counterWriter), ffo.dataSize()); err != nil { return err } @@ -51,19 +49,9 @@ func receiveFile(r io.Reader, targetFile, resForkFile, infoFork, counterWriter i return err } - if _, err = io.Copy(resForkFile, io.TeeReader(r, counterWriter)); err != nil { + if _, err = io.CopyN(resForkFile, io.TeeReader(r, counterWriter), ffo.rsrcSize()); err != nil { return err } } return nil } - -func (s *Server) bannerDownload(w io.Writer) error { - bannerBytes, err := os.ReadFile(filepath.Join(s.ConfigDir, s.Config.BannerFile)) - if err != nil { - return err - } - _, err = w.Write(bannerBytes) - - return err -}