aboutsummaryrefslogtreecommitdiffstats
path: root/modules/storage/local.go
diff options
context:
space:
mode:
authorzeripath <art27@cantab.net>2022-12-19 00:50:36 +0000
committerGitHub <noreply@github.com>2022-12-19 08:50:36 +0800
commita89b399faa275c28d0ffe9759d492636f67d6da0 (patch)
treefef5a9e6e30fc3a37d106d84075627a0fb796d8d /modules/storage/local.go
parent998fe26051514ee74bb9c2f0e7de56014933133b (diff)
downloadgitea-a89b399faa275c28d0ffe9759d492636f67d6da0.tar.gz
gitea-a89b399faa275c28d0ffe9759d492636f67d6da0.zip
Local storage should not store files as executable (#22162)
The PR #21198 introduced a probable security vulnerability which resulted in making all storage files be marked as executable. This PR ensures that these are forcibly marked as non-executable. Fix #22161 Signed-off-by: Andrew Thornton <art27@cantab.net>
Diffstat (limited to 'modules/storage/local.go')
-rw-r--r--modules/storage/local.go3
1 files changed, 2 insertions, 1 deletions
diff --git a/modules/storage/local.go b/modules/storage/local.go
index a439a24592..ca51d26c9a 100644
--- a/modules/storage/local.go
+++ b/modules/storage/local.go
@@ -102,7 +102,8 @@ func (l *LocalStorage) Save(path string, r io.Reader, size int64) (int64, error)
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 {
+ // but we don't want to make these files executable - so ensure that we mask out the executable bits
+ if err := util.ApplyUmask(p, os.ModePerm&0o666); err != nil {
return 0, err
}