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

feat(nextcloud): Implement chunked upload #2308

Draft
wants to merge 2 commits into
base: main
Choose a base branch
from

Conversation

provokateurin
Copy link
Member

@provokateurin provokateurin commented Jul 22, 2024

#1123

This PR isn't finished because I want to discuss the direction first.
For now I made the WebDavClient re-usable for WebDAV extensions by allowing to configure the endpoint. This will also be necessary for #718.
I'm not sure if this is the right way or if the methods should be re-implemented. Maybe the best way is to have an abstract DavClient and then let the WebDavClient extend it and supply the endpoint and additional helper methods if necessary.
There is also the problem with the username because currently we use the remote.php/webdav endpoint which doesn't require it, but any other endpoint like remote.php/dav/files/{username} or remote.php/dav/uploads/{username} need it. Unfortunately the root client only knows the login name which is not necessarily the username so it needs to be passed manually with the endpoint.

For the chunked upload part I want to add some helper methods for uploading a stream or file that is automatically divided in chunks so it is easily usable.

@Leptopoda
Copy link
Member

This might not answer your questions about how to handle the clients, but the http package already provides a MultipartRequest using the multipart/form-data content type. From a quick search in the server repo, this is also what the server expects.
https://github.com/nextcloud/server/blob/f9d4becf60da69f272f6c5700bbdf5cb99761bc4/apps/files/js/jquery.fileupload.js#L142-L145
https://pub.dev/documentation/http/latest/http/MultipartRequest-class.html

@provokateurin
Copy link
Member Author

That's the old unchunked upload which doesn't help at all here. I followed https://docs.nextcloud.com/server/latest/developer_manual/client_apis/WebDAV/chunking.html to implement it which is completely custom.

@Leptopoda
Copy link
Member

What methods will the caldav and carddav client need?
The proposed patch only makes use of the put method.

@provokateurin
Copy link
Member Author

They would also use all the other methods because they just operate on the same "filesystem" structures. Using streams and files is probably not useful there as the data is usually small and not stored in files, so those would be WebDAV specific.

@provokateurin
Copy link
Member Author

I can make a quick diagram later to explain what I have in mind for the structure.

@Leptopoda
Copy link
Member

Sure, that would help a lot.
I'm going to read a bit into carddav and caldav but in general I'd prefer to have a client that we extend rather than wrap.

@provokateurin
Copy link
Member Author

Yeah same here

Signed-off-by: provokateurin <kate@provokateurin.de>
Signed-off-by: provokateurin <kate@provokateurin.de>
@provokateurin provokateurin force-pushed the feat/nextcloud/chunked-upload branch from 5002b96 to 8e503af Compare July 27, 2024 08:06
@provokateurin
Copy link
Member Author

I feel like working on this without looking more into #718 makes no sense because I don't know what will be necessary for it. If I knew that it would be easy to chose the right way to abstract this.
I'll give it a shot then, let's see where it goes.

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.

2 participants