summaryrefslogtreecommitdiffstats
path: root/modules/storage/local.go
diff options
context:
space:
mode:
authorNulo (he/him) <86896666+catdevnull@users.noreply.github.com>2022-09-24 13:04:14 +0000
committerGitHub <noreply@github.com>2022-09-24 21:04:14 +0800
commitcca189ef97d5f9fd3f52c75ec6e1ae916916cd08 (patch)
tree593bd91a628b337699048bfc31363e7c6225321e /modules/storage/local.go
parent83680c97a7fd23d2a2953302771ed2b234c0689e (diff)
downloadgitea-cca189ef97d5f9fd3f52c75ec6e1ae916916cd08.tar.gz
gitea-cca189ef97d5f9fd3f52c75ec6e1ae916916cd08.zip
Save files in local storage as umask (#21198)
Go creates temporary files as 600, but sometimes we want the group to be able to read them (for example, for another user to back up the storage) This PR applies the umask to the renamed tmp files in local storage. Co-authored-by: wxiaoguang <wxiaoguang@gmail.com>
Diffstat (limited to 'modules/storage/local.go')
-rw-r--r--modules/storage/local.go4
1 files changed, 4 insertions, 0 deletions
diff --git a/modules/storage/local.go b/modules/storage/local.go
index 701b0b1a9f..5d5b06b648 100644
--- a/modules/storage/local.go
+++ b/modules/storage/local.go
@@ -102,6 +102,10 @@ func (l *LocalStorage) Save(path string, r io.Reader, size int64) (int64, error)
if err := util.Rename(tmp.Name(), p); err != nil {
return 0, err
}
+ // Golang's tmp file (os.CreateTemp) always have 0o600 mode, so we need to change the file to follow the umask (as what Create/MkDir does)
+ if err := util.ApplyUmask(p, os.ModePerm); err != nil {
+ return 0, err
+ }
tmpRemoved = true