mirror of https://github.com/gogs/gogs.git
repo_editor: prohibits uploading files to `.git.` directory (#6970)
Co-authored-by: Joe Chen <jc@unknwon.io>pull/6986/head
parent
649e9e7f8c
commit
519aeefbd9
|
@ -460,7 +460,11 @@ type UploadRepoFileOptions struct {
|
||||||
|
|
||||||
// isRepositoryGitPath returns true if given path is or resides inside ".git" path of the repository.
|
// isRepositoryGitPath returns true if given path is or resides inside ".git" path of the repository.
|
||||||
func isRepositoryGitPath(path string) bool {
|
func isRepositoryGitPath(path string) bool {
|
||||||
return strings.HasSuffix(path, ".git") || strings.Contains(path, ".git"+string(os.PathSeparator))
|
return strings.HasSuffix(path, ".git") ||
|
||||||
|
strings.Contains(path, ".git"+string(os.PathSeparator)) ||
|
||||||
|
// Windows treats ".git." the same as ".git"
|
||||||
|
strings.HasSuffix(path, ".git.") ||
|
||||||
|
strings.Contains(path, ".git."+string(os.PathSeparator))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (repo *Repository) UploadRepoFiles(doer *User, opts UploadRepoFileOptions) error {
|
func (repo *Repository) UploadRepoFiles(doer *User, opts UploadRepoFileOptions) error {
|
||||||
|
|
|
@ -13,21 +13,27 @@ import (
|
||||||
|
|
||||||
func Test_isRepositoryGitPath(t *testing.T) {
|
func Test_isRepositoryGitPath(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
path string
|
path string
|
||||||
expVal bool
|
wantVal bool
|
||||||
}{
|
}{
|
||||||
{path: filepath.Join(".", ".git"), expVal: true},
|
{path: filepath.Join(".", ".git"), wantVal: true},
|
||||||
{path: filepath.Join(".", ".git", ""), expVal: true},
|
{path: filepath.Join(".", ".git", ""), wantVal: true},
|
||||||
{path: filepath.Join(".", ".git", "hooks", "pre-commit"), expVal: true},
|
{path: filepath.Join(".", ".git", "hooks", "pre-commit"), wantVal: true},
|
||||||
{path: filepath.Join(".git", "hooks"), expVal: true},
|
{path: filepath.Join(".git", "hooks"), wantVal: true},
|
||||||
{path: filepath.Join("dir", ".git"), expVal: true},
|
{path: filepath.Join("dir", ".git"), wantVal: true},
|
||||||
|
|
||||||
{path: filepath.Join(".gitignore"), expVal: false},
|
{path: filepath.Join(".", ".git."), wantVal: true},
|
||||||
{path: filepath.Join("dir", ".gitkeep"), expVal: false},
|
{path: filepath.Join(".", ".git.", ""), wantVal: true},
|
||||||
|
{path: filepath.Join(".", ".git.", "hooks", "pre-commit"), wantVal: true},
|
||||||
|
{path: filepath.Join(".git.", "hooks"), wantVal: true},
|
||||||
|
{path: filepath.Join("dir", ".git."), wantVal: true},
|
||||||
|
|
||||||
|
{path: filepath.Join(".gitignore"), wantVal: false},
|
||||||
|
{path: filepath.Join("dir", ".gitkeep"), wantVal: false},
|
||||||
}
|
}
|
||||||
for _, test := range tests {
|
for _, test := range tests {
|
||||||
t.Run("", func(t *testing.T) {
|
t.Run("", func(t *testing.T) {
|
||||||
assert.Equal(t, test.expVal, isRepositoryGitPath(test.path))
|
assert.Equal(t, test.wantVal, isRepositoryGitPath(test.path))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue