Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[WIP] Use tus for uploads (and support range requests for downloads?) #286

Closed
wants to merge 8 commits into from

Conversation

butonic
Copy link
Contributor

@butonic butonic commented Oct 4, 2019

replace datasvc with tusdsvc ... or teach datasvc some tus tricks ... fixes #284

currently needs tus/tusd#309

pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/filestore/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/filestore/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/filestore/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/filestore/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/filestore/owncloud.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/tusdsvc.go Outdated Show resolved Hide resolved
pkg/storage/fs/eos/eos.go Outdated Show resolved Hide resolved
pkg/storage/fs/local/local.go Outdated Show resolved Hide resolved
pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
}

// infoPath returns the path to the .info file storing the file's info.
func (store OwnCloudStore) infoPath(ctx context.Context, id string) (string, error) {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

func OwnCloudStore.infoPath is unused (from unused)

pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
pkg/storage/fs/owncloud/owncloud.go Outdated Show resolved Hide resolved
tusd "github.com/tus/tusd/pkg/handler"
)

const UploadLengthDeferred = "1"
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

exported const UploadLengthDeferred should have comment or be unexported

cmd/revad/svcs/httpsvcs/tusdsvc/handler/datastore.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/handler/datastore.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/handler/composer.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/handler/composer.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/handler/composer.go Outdated Show resolved Hide resolved
haveInvalidDeferHeader := uploadDeferLengthHeader != "" && uploadDeferLengthHeader != UploadLengthDeferred
lengthIsDeferred := uploadDeferLengthHeader == UploadLengthDeferred

if lengthIsDeferred && !handler.composer.UsesLengthDeferrer {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ifElseChain: rewrite if-else to switch statement (from gocritic)

cmd/revad/svcs/httpsvcs/tusdsvc/handler/composer.go Outdated Show resolved Hide resolved
cmd/revad/svcs/httpsvcs/tusdsvc/handler/composer.go Outdated Show resolved Hide resolved
// Directly finish the upload if the upload is empty (i.e. has a size of 0).
// This statement is in an else-if block to avoid causing duplicate calls
// to finishUploadIfComplete if an upload is empty and contains a chunk.
handler.finishUploadIfComplete(ctx, upload, info, r)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of handler.finishUploadIfComplete is not checked (from errcheck)

return
}

defer lock.Unlock()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of lock.Unlock is not checked (from errcheck)

return
}

defer lock.Unlock()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of lock.Unlock is not checked (from errcheck)

}

handler.sendResp(w, r, http.StatusOK)
io.Copy(w, src)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of io.Copy is not checked (from errcheck)

w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.Header().Set("Content-Length", strconv.Itoa(len(reason)))
w.WriteHeader(statusErr.StatusCode())
w.Write(reason)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of w.Write is not checked (from errcheck)

@butonic
Copy link
Contributor Author

butonic commented Oct 4, 2019

aside from the noise above what really now is missing is an async process to propagate the etag, mtime and size changes. I want to trigger that only after the file upload is finished AND a possible workflow has happened (eg antivirus scan). eos should magically work without this. but for the owncloud storage driver this piece is still missing.

  • put the propagation code in the storage driver
  • have it subscribe to a redis channel, we already use redis for fileid to path lookup
  • publish the path when a file is changed from the tusd svc
  • publish the path when a folder changed ... can we throttle this? deduplicate events?
  • add a reva cmd that publishes a message. can then be used by inotify to trigger external changes ... hm ... or do we want to rely on inotify, see [WIP] storage/local notify #78
  • refactor this pr so it replaces the datasvc

}

var (
ErrUnsupportedVersion = NewHTTPError(errors.New("unsupported version"), http.StatusPreconditionFailed)
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

exported var ErrUnsupportedVersion should have comment or be unexported

LogEvent(h.logger, eventName, details...)
}

func LogEvent(logger *log.Logger, eventName string, details ...string) {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

exported function LogEvent should have comment or be unexported

haveInvalidDeferHeader := uploadDeferLengthHeader != "" && uploadDeferLengthHeader != UploadLengthDeferred
lengthIsDeferred := uploadDeferLengthHeader == UploadLengthDeferred

if lengthIsDeferred && !handler.composer.UsesLengthDeferrer {

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ifElseChain: rewrite if-else to switch statement (from gocritic)

// UploadProgress is used to send notifications about the progress of the
// currently running uploads. For each open PATCH request, every second
// a HookEvent instance will be send over this channel with the Offset field
// being set to the number of bytes which have been transfered to the server.

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

transfered is a misspelling of transferred (from misspell)

Suggested change
// being set to the number of bytes which have been transfered to the server.

// mimeInlineBrowserWhitelist is a map containing MIME types which should be
// allowed to be rendered by browser inline, instead of being forced to be
// downloadd. For example, HTML or SVG files are not allowed, since they may
// contain malicious JavaScript. In a similiar fashion PDF is not on this list

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

similiar is a misspelling of similar (from misspell)

Suggested change
// contain malicious JavaScript. In a similiar fashion PDF is not on this list

// Directly finish the upload if the upload is empty (i.e. has a size of 0).
// This statement is in an else-if block to avoid causing duplicate calls
// to finishUploadIfComplete if an upload is empty and contains a chunk.
handler.finishUploadIfComplete(ctx, upload, info, r)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of handler.finishUploadIfComplete is not checked (from errcheck)

return
}

defer lock.Unlock()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of lock.Unlock is not checked (from errcheck)

return
}

defer lock.Unlock()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of lock.Unlock is not checked (from errcheck)

}

handler.sendResp(w, r, http.StatusOK)
io.Copy(w, src)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of io.Copy is not checked (from errcheck)

w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.Header().Set("Content-Length", strconv.Itoa(len(reason)))
w.WriteHeader(statusErr.StatusCode())
w.Write(reason)

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of w.Write is not checked (from errcheck)

Signed-off-by: Jörn Friedrich Dreyer <[email protected]>
}

upload.info.Offset += n
upload.writeInfo()

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Error return value of upload.writeInfo is not checked (from errcheck)

@labkode labkode changed the title Use tus for uploads (and support range requests for downloads?) [WIP] Use tus for uploads (and support range requests for downloads?) Jan 10, 2020
@butonic butonic mentioned this pull request Apr 15, 2020
6 tasks
@butonic butonic closed this Apr 21, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

replace datasvc with a tus.io capable endpoint
2 participants