mirror of
https://github.com/octoleo/syncthing.git
synced 2024-11-09 23:00:58 +00:00
Try not to leave directories behind with incorrect permissions
This commit is contained in:
parent
e1f1ae041f
commit
fe43e3b89d
@ -1,5 +1,8 @@
|
|||||||
#!/bin/sh
|
#!/bin/bash
|
||||||
|
set -euo pipefail
|
||||||
|
IFS=$'\n\t'
|
||||||
|
|
||||||
./test-http.sh || exit
|
go test -tags integration -v
|
||||||
./test-merge.sh || exit
|
./test-http.sh
|
||||||
./test-delupd.sh || exit
|
./test-merge.sh
|
||||||
|
./test-delupd.sh
|
||||||
|
@ -461,7 +461,7 @@ func (p *puller) handleBlock(b bqBlock) bool {
|
|||||||
of.temp = filepath.Join(p.repoCfg.Directory, defTempNamer.TempName(f.Name))
|
of.temp = filepath.Join(p.repoCfg.Directory, defTempNamer.TempName(f.Name))
|
||||||
|
|
||||||
dirName := filepath.Dir(of.filepath)
|
dirName := filepath.Dir(of.filepath)
|
||||||
_, err := os.Stat(dirName)
|
info, err := os.Stat(dirName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
err = os.MkdirAll(dirName, 0777)
|
err = os.MkdirAll(dirName, 0777)
|
||||||
} else {
|
} else {
|
||||||
@ -469,6 +469,8 @@ func (p *puller) handleBlock(b bqBlock) bool {
|
|||||||
if dirName != p.repoCfg.Directory {
|
if dirName != p.repoCfg.Directory {
|
||||||
err = os.Chmod(dirName, 0777)
|
err = os.Chmod(dirName, 0777)
|
||||||
}
|
}
|
||||||
|
// Change it back after creating the file, to minimize the time window with incorrect permissions
|
||||||
|
defer os.Chmod(dirName, info.Mode())
|
||||||
}
|
}
|
||||||
if err != nil {
|
if err != nil {
|
||||||
l.Infof("mkdir: error: %q / %q: %v", p.repoCfg.ID, f.Name, err)
|
l.Infof("mkdir: error: %q / %q: %v", p.repoCfg.ID, f.Name, err)
|
||||||
@ -632,7 +634,13 @@ func (p *puller) handleEmptyBlock(b bqBlock) {
|
|||||||
dirName := filepath.Dir(of.filepath)
|
dirName := filepath.Dir(of.filepath)
|
||||||
os.Chmod(of.filepath, 0666)
|
os.Chmod(of.filepath, 0666)
|
||||||
if dirName != p.repoCfg.Directory {
|
if dirName != p.repoCfg.Directory {
|
||||||
|
info, err := os.Stat(dirName)
|
||||||
|
if err != nil {
|
||||||
|
l.Debugln("weird! can't happen?", err)
|
||||||
|
}
|
||||||
os.Chmod(dirName, 0777)
|
os.Chmod(dirName, 0777)
|
||||||
|
// Change it back after deleting the file, to minimize the time window with incorrect permissions
|
||||||
|
defer os.Chmod(dirName, info.Mode())
|
||||||
}
|
}
|
||||||
if p.versioner != nil {
|
if p.versioner != nil {
|
||||||
if debug {
|
if debug {
|
||||||
|
@ -7,17 +7,28 @@ package osutil
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"os"
|
"os"
|
||||||
|
"path/filepath"
|
||||||
"runtime"
|
"runtime"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Rename(from, to string) error {
|
func Rename(from, to string) error {
|
||||||
|
// Make sure the destination directory is writeable
|
||||||
|
toDir := filepath.Dir(to)
|
||||||
|
if info, err := os.Stat(toDir); err == nil {
|
||||||
|
os.Chmod(toDir, 0777)
|
||||||
|
defer os.Chmod(toDir, info.Mode())
|
||||||
|
}
|
||||||
|
|
||||||
|
// On Windows, make sure the destination file is writeable (or we can't delete it)
|
||||||
if runtime.GOOS == "windows" {
|
if runtime.GOOS == "windows" {
|
||||||
os.Chmod(to, 0666) // Make sure the file is user writeable
|
os.Chmod(to, 0666)
|
||||||
err := os.Remove(to)
|
err := os.Remove(to)
|
||||||
if err != nil && !os.IsNotExist(err) {
|
if err != nil && !os.IsNotExist(err) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
defer os.Remove(from) // Don't leave a dangling temp file in case of rename error
|
|
||||||
|
// Don't leave a dangling temp file in case of rename error
|
||||||
|
defer os.Remove(from)
|
||||||
return os.Rename(from, to)
|
return os.Rename(from, to)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user