jottacloud: Fix handling of reserved characters. fixes #2531

This commit is contained in:
Sebastian Bünger 2018-09-16 22:30:20 +02:00 committed by Nick Craig-Wood
parent d27630626a
commit b18595ae07
3 changed files with 10 additions and 12 deletions

View file

@ -199,7 +199,7 @@ func (f *Fs) readMetaDataForPath(path string) (info *api.JottaFile, err error) {
func (f *Fs) getAccountInfo() (info *api.AccountInfo, err error) { func (f *Fs) getAccountInfo() (info *api.AccountInfo, err error) {
opts := rest.Opts{ opts := rest.Opts{
Method: "GET", Method: "GET",
Path: rest.URLPathEscape(f.user), Path: urlPathEscape(f.user),
} }
var resp *http.Response var resp *http.Response
@ -220,7 +220,7 @@ func (f *Fs) setEndpointURL(mountpoint string) (err error) {
if err != nil { if err != nil {
return errors.Wrap(err, "failed to get endpoint url") return errors.Wrap(err, "failed to get endpoint url")
} }
f.endpointURL = rest.URLPathEscape(path.Join(info.Username, defaultDevice, mountpoint)) f.endpointURL = urlPathEscape(path.Join(info.Username, defaultDevice, mountpoint))
return nil return nil
} }
@ -241,6 +241,11 @@ func errorHandler(resp *http.Response) error {
return errResponse return errResponse
} }
// Jottacloud want's '+' to be URL encoded even though the RFC states it's not reserved
func urlPathEscape(in string) string {
return strings.Replace(rest.URLPathEscape(in), "+", "%2B", -1)
}
// filePathRaw returns an unescaped file path (f.root, file) // filePathRaw returns an unescaped file path (f.root, file)
func (f *Fs) filePathRaw(file string) string { func (f *Fs) filePathRaw(file string) string {
return path.Join(f.endpointURL, replaceReservedChars(path.Join(f.root, file))) return path.Join(f.endpointURL, replaceReservedChars(path.Join(f.root, file)))
@ -248,7 +253,7 @@ func (f *Fs) filePathRaw(file string) string {
// filePath returns a escaped file path (f.root, file) // filePath returns a escaped file path (f.root, file)
func (f *Fs) filePath(file string) string { func (f *Fs) filePath(file string) string {
return rest.URLPathEscape(f.filePathRaw(file)) return urlPathEscape(f.filePathRaw(file))
} }
// filePath returns a escaped file path (f.root, remote) // filePath returns a escaped file path (f.root, remote)

View file

@ -27,21 +27,14 @@ import (
var ( var (
charMap = map[rune]rune{ charMap = map[rune]rune{
'\\': '', // FULLWIDTH REVERSE SOLIDUS '\\': '', // FULLWIDTH REVERSE SOLIDUS
'+': '', // FULLWIDTH PLUS SIGN
'*': '', // FULLWIDTH ASTERISK '*': '', // FULLWIDTH ASTERISK
'<': '', // FULLWIDTH LESS-THAN SIGN '<': '', // FULLWIDTH LESS-THAN SIGN
'>': '', // FULLWIDTH GREATER-THAN SIGN '>': '', // FULLWIDTH GREATER-THAN SIGN
'?': '', // FULLWIDTH QUESTION MARK '?': '', // FULLWIDTH QUESTION MARK
'!': '', // FULLWIDTH EXCLAMATION MARK
'&': '', // FULLWIDTH AMPERSAND
':': '', // FULLWIDTH COLON ':': '', // FULLWIDTH COLON
';': '', // FULLWIDTH SEMICOLON ';': '', // FULLWIDTH SEMICOLON
'|': '', // FULLWIDTH VERTICAL LINE '|': '', // FULLWIDTH VERTICAL LINE
'#': '', // FULLWIDTH NUMBER SIGN
'%': '', // FULLWIDTH PERCENT SIGN
'"': '', // FULLWIDTH QUOTATION MARK - not on the list but seems to be reserved '"': '', // FULLWIDTH QUOTATION MARK - not on the list but seems to be reserved
'\'': '', // FULLWIDTH APOSTROPHE
'~': '', // FULLWIDTH TILDE
' ': '␠', // SYMBOL FOR SPACE ' ': '␠', // SYMBOL FOR SPACE
} }
invCharMap map[rune]rune invCharMap map[rune]rune

View file

@ -9,8 +9,8 @@ func TestReplace(t *testing.T) {
}{ }{
{"", ""}, {"", ""},
{"abc 123", "abc 123"}, {"abc 123", "abc 123"},
{`\+*<>?!&:;|#%"'~`, ``}, {`\*<>?:;|"`, ``},
{`\+*<>?!&:;|#%"'~\+*<>?!&:;|#%"'~`, ``}, {`\*<>?:;|"\*<>?:;|"`, ``},
{" leading space", "␠leading space"}, {" leading space", "␠leading space"},
{"trailing space ", "trailing space␠"}, {"trailing space ", "trailing space␠"},
{" leading space/ leading space/ leading space", "␠leading space/␠leading space/␠leading space"}, {" leading space/ leading space/ leading space", "␠leading space/␠leading space/␠leading space"},