From 9228b671ce1fd5018ac1185f81551979c270a5d0 Mon Sep 17 00:00:00 2001 From: Roman Perekhod Date: Wed, 20 Mar 2024 13:47:13 +0100 Subject: [PATCH] fix uploading via a public link --- changelog/unreleased/fix-publiclink-upload.md | 6 ++++++ internal/http/services/owncloud/ocdav/tus.go | 12 +++++++++--- 2 files changed, 15 insertions(+), 3 deletions(-) create mode 100644 changelog/unreleased/fix-publiclink-upload.md diff --git a/changelog/unreleased/fix-publiclink-upload.md b/changelog/unreleased/fix-publiclink-upload.md new file mode 100644 index 0000000000..6d56c162fc --- /dev/null +++ b/changelog/unreleased/fix-publiclink-upload.md @@ -0,0 +1,6 @@ +Bugfix: Fix uploading via a public link + +Fix http error when uploading via a public link + +https://github.com/cs3org/reva/pull/4589 +https://github.com/owncloud/ocis/issues/8699 diff --git a/internal/http/services/owncloud/ocdav/tus.go b/internal/http/services/owncloud/ocdav/tus.go index bd5831d4eb..c22651978a 100644 --- a/internal/http/services/owncloud/ocdav/tus.go +++ b/internal/http/services/owncloud/ocdav/tus.go @@ -319,9 +319,15 @@ func (s *svc) handleTusPost(ctx context.Context, w http.ResponseWriter, r *http. w.Header().Set(net.HeaderOCMtime, httpRes.Header.Get(net.HeaderOCMtime)) } - if resid, err := storagespace.ParseID(httpRes.Header.Get(net.HeaderOCFileID)); err == nil { - sReq.Ref = &provider.Reference{ - ResourceId: &resid, + if strings.HasPrefix(uReq.GetRef().GetPath(), "/public") && uReq.GetRef().GetResourceId() == nil { + // Use the path based request for the public link + sReq.Ref.Path = uReq.Ref.GetPath() + sReq.Ref.ResourceId = nil + } else { + if resid, err := storagespace.ParseID(httpRes.Header.Get(net.HeaderOCFileID)); err == nil { + sReq.Ref = &provider.Reference{ + ResourceId: &resid, + } } } finishUpload = httpRes.Header.Get(net.HeaderUploadOffset) == r.Header.Get(net.HeaderUploadLength)