mirror of
				https://gitee.com/gitea/gitea
				synced 2025-11-04 08:30:25 +08:00 
			
		
		
		
	Clean paths when looking in Storage (#19124)
* Clean paths when looking in Storage Ensure paths are clean for minio aswell as local storage. Use url.Path not RequestURI/EscapedPath in storageHandler. Signed-off-by: Andrew Thornton <art27@cantab.net> * Apply suggestions from code review Co-authored-by: Lauris BH <lauris@nix.lv>
This commit is contained in:
		@@ -10,36 +10,44 @@ import (
 | 
			
		||||
	"github.com/stretchr/testify/assert"
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
func TestLocalPathIsValid(t *testing.T) {
 | 
			
		||||
func TestBuildLocalPath(t *testing.T) {
 | 
			
		||||
	kases := []struct {
 | 
			
		||||
		path  string
 | 
			
		||||
		valid bool
 | 
			
		||||
		localDir string
 | 
			
		||||
		path     string
 | 
			
		||||
		expected string
 | 
			
		||||
	}{
 | 
			
		||||
		{
 | 
			
		||||
			"a",
 | 
			
		||||
			"0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			"a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			true,
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"../a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			false,
 | 
			
		||||
			"a",
 | 
			
		||||
			"../0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			"a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"a\\0\\a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			true,
 | 
			
		||||
			"a",
 | 
			
		||||
			"0\\a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			"a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"b/../a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			false,
 | 
			
		||||
			"b",
 | 
			
		||||
			"a/../0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			"b/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
		},
 | 
			
		||||
		{
 | 
			
		||||
			"..\\a/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			false,
 | 
			
		||||
			"b",
 | 
			
		||||
			"a\\..\\0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
			"b/0/a0eebc99-9c0b-4ef8-bb6d-6bb9bd380a14",
 | 
			
		||||
		},
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	for _, k := range kases {
 | 
			
		||||
		t.Run(k.path, func(t *testing.T) {
 | 
			
		||||
			assert.EqualValues(t, k.valid, isLocalPathValid(k.path))
 | 
			
		||||
			l := LocalStorage{dir: k.localDir}
 | 
			
		||||
 | 
			
		||||
			assert.EqualValues(t, k.expected, l.buildLocalPath(k.path))
 | 
			
		||||
		})
 | 
			
		||||
	}
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user