"bufio"
"hash"
"io"
- "io/ioutil"
"os"
"path/filepath"
+ "strconv"
+ "time"
"golang.org/x/crypto/blake2b"
)
+func TempFile(dir, prefix string) (*os.File, error) {
+ // Assume that probability of suffix collision is negligible
+ suffix := strconv.FormatInt(time.Now().UnixNano()+int64(os.Getpid()), 16)
+ name := filepath.Join(dir, "nncp"+prefix+suffix)
+ return os.OpenFile(name, os.O_RDWR|os.O_CREATE|os.O_EXCL, os.FileMode(0666))
+}
+
func (ctx *Ctx) NewTmpFile() (*os.File, error) {
jobsPath := filepath.Join(ctx.Spool, "tmp")
var err error
- if err = os.MkdirAll(jobsPath, os.FileMode(0700)); err != nil {
+ if err = os.MkdirAll(jobsPath, os.FileMode(0777)); err != nil {
return nil, err
}
- fd, err := ioutil.TempFile(jobsPath, "")
+ fd, err := TempFile(jobsPath, "")
if err == nil {
ctx.LogD("tmp", SDS{"src": fd.Name()}, "created")
}
os.Remove(tmp.Fd.Name())
}
+func DirSync(dirPath string) error {
+ fd, err := os.Open(dirPath)
+ if err != nil {
+ return err
+ }
+ err = fd.Sync()
+ if err != nil {
+ fd.Close()
+ return err
+ }
+ return fd.Close()
+}
+
func (tmp *TmpFileWHash) Commit(dir string) error {
var err error
- if err = os.MkdirAll(dir, os.FileMode(0700)); err != nil {
+ if err = os.MkdirAll(dir, os.FileMode(0777)); err != nil {
return err
}
if err = tmp.W.Flush(); err != nil {
tmp.Fd.Close()
checksum := ToBase32(tmp.Hsh.Sum(nil))
tmp.ctx.LogD("tmp", SDS{"src": tmp.Fd.Name(), "dst": checksum}, "commit")
- return os.Rename(tmp.Fd.Name(), filepath.Join(dir, checksum))
+ if err = os.Rename(tmp.Fd.Name(), filepath.Join(dir, checksum)); err != nil {
+ return err
+ }
+ return DirSync(dir)
}