ctlsock: interpret paths that point above CWD as ""

Paths that start with ".." were previously accepted as-is.
This commit is contained in:
Jakob Unterwurzacher 2017-01-29 15:24:47 +01:00
parent 6166dad05c
commit 532ef15417
2 changed files with 19 additions and 5 deletions

View File

@ -2,19 +2,29 @@ package ctlsock
import (
"path/filepath"
"strings"
)
// SanitizePath adapts filepath.Clean for FUSE paths.
// 1) It always returns a relative path
// 1) A leading slash is dropped
// 2) It returns "" instead of "."
// 3) If the cleaned path points above CWD (start with ".."), an empty string
// is returned
// See the TestSanitizePath testcases for examples.
func SanitizePath(path string) string {
clean := filepath.Clean(path)
if clean == "." || clean == "/" {
if len(path) == 0 {
return ""
}
if clean[0] == '/' {
clean = clean[1:]
// Drop leading slash
if path[0] == '/' {
path = path[1:]
}
clean := filepath.Clean(path)
if clean == "." {
return ""
}
if clean == ".." || strings.HasPrefix(clean, "../") {
return ""
}
return clean
}

View File

@ -15,6 +15,10 @@ func TestSanitizePath(t *testing.T) {
{"/foo/", "foo"},
{"/foo/./foo", "foo/foo"},
{"./", ""},
{"..", ""},
{"foo/../..", ""},
{"foo/../../aaaaaa", ""},
{"/foo/../../aaaaaa", ""},
}
for _, tc := range testCases {
res := SanitizePath(tc[0])