mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-10-27 00:23:41 +09: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