mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-08 17:24:08 +00:00
lib/model: Honor umask when creating folder directories on Unix (fixes #2519)
Doesn't change the behavior on Windows. GitHub-Pull-Request: https://github.com/syncthing/syncthing/pull/4076
This commit is contained in:
parent
c3820fbbf2
commit
bdb56d91b9
@ -231,8 +231,17 @@ func (m *Model) startFolderLocked(folder string) config.FolderType {
|
||||
// if these things don't work, we still want to start the folder and
|
||||
// it'll show up as errored later.
|
||||
|
||||
// Directory permission bits. Will be filtered down to something
|
||||
// sane by umask on Unixes.
|
||||
permBits := os.FileMode(0777)
|
||||
if runtime.GOOS == "windows" {
|
||||
// Windows has no umask so we must chose a safer set of bits to
|
||||
// begin with.
|
||||
permBits = 0700
|
||||
}
|
||||
|
||||
if _, err := os.Stat(cfg.Path()); os.IsNotExist(err) {
|
||||
if err := osutil.MkdirAll(cfg.Path(), 0700); err != nil {
|
||||
if err := osutil.MkdirAll(cfg.Path(), permBits); err != nil {
|
||||
l.Warnln("Creating folder:", err)
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user