drive: fix upload to existing file (#2032)

This fixes uploads to existing files for Google Drive introduced by #2007.
Instead of updating the old file a new "Untitled" file would be created
in the root folder.
This commit is contained in:
Fabian Möller 2018-01-30 14:37:06 +01:00 committed by GitHub
parent 29d428040c
commit cf6d522d2f
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 4 additions and 5 deletions

View file

@ -824,7 +824,7 @@ func (f *Fs) PutUnchecked(in io.Reader, src fs.ObjectInfo, options ...fs.OpenOpt
} }
} else { } else {
// Upload the file in chunks // Upload the file in chunks
info, err = f.Upload(in, size, createInfo.MimeType, createInfo, remote) info, err = f.Upload(in, size, createInfo.MimeType, "", createInfo, remote)
if err != nil { if err != nil {
return o, err return o, err
} }
@ -1503,7 +1503,7 @@ func (o *Object) Update(in io.Reader, src fs.ObjectInfo, options ...fs.OpenOptio
} }
} else { } else {
// Upload the file in chunks // Upload the file in chunks
info, err = o.fs.Upload(in, size, updateInfo.MimeType, updateInfo, o.remote) info, err = o.fs.Upload(in, size, updateInfo.MimeType, o.id, updateInfo, o.remote)
if err != nil { if err != nil {
return err return err
} }

View file

@ -53,8 +53,7 @@ type resumableUpload struct {
} }
// Upload the io.Reader in of size bytes with contentType and info // Upload the io.Reader in of size bytes with contentType and info
func (f *Fs) Upload(in io.Reader, size int64, contentType string, info *drive.File, remote string) (*drive.File, error) { func (f *Fs) Upload(in io.Reader, size int64, contentType string, fileID string, info *drive.File, remote string) (*drive.File, error) {
fileID := info.Id
params := make(url.Values) params := make(url.Values)
params.Set("alt", "json") params.Set("alt", "json")
params.Set("uploadType", "resumable") params.Set("uploadType", "resumable")
@ -67,7 +66,7 @@ func (f *Fs) Upload(in io.Reader, size int64, contentType string, info *drive.Fi
if fileID != "" { if fileID != "" {
params.Set("setModifiedDate", "true") params.Set("setModifiedDate", "true")
urls += "/{fileId}" urls += "/{fileId}"
method = "PUT" method = "PATCH"
} }
urls += "?" + params.Encode() urls += "?" + params.Encode()
var res *http.Response var res *http.Response