forked from TrueCloudLab/rclone
jottacloud: Fix handling of reserved characters. fixes #2531
This commit is contained in:
parent
d27630626a
commit
b18595ae07
3 changed files with 10 additions and 12 deletions
|
@ -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)
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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"},
|
||||||
|
|
Loading…
Reference in a new issue