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

Downloading drive_document fails #117

Open
michellealva opened this issue Aug 15, 2023 · 2 comments
Open

Downloading drive_document fails #117

michellealva opened this issue Aug 15, 2023 · 2 comments
Assignees
Labels
bug Something isn't working

Comments

@michellealva
Copy link

michellealva commented Aug 15, 2023

Tried downloading a file and got the below error.

Traceback (most recent call last):
  File "apps/frappe/frappe/app.py", line 83, in application
    response = frappe.api.handle()
  File "apps/frappe/frappe/api.py", line 53, in handle
    return _RESTAPIHandler(call, doctype, name).get_response()
  File "apps/frappe/frappe/api.py", line 69, in get_response
    return self.handle_method()
  File "apps/frappe/frappe/api.py", line 79, in handle_method
    return frappe.handler.handle()
  File "apps/frappe/frappe/handler.py", line 48, in handle
    data = execute_cmd(cmd)
  File "apps/frappe/frappe/handler.py", line 86, in execute_cmd
    return frappe.call(method, **frappe.form_dict)
  File "apps/frappe/frappe/__init__.py", line 1646, in call
    return fn(*args, **newargs)
  File "apps/frappe/frappe/utils/typing_validations.py", line 30, in wrapper
    return func(*args, **kwargs)
  File "apps/drive/drive/api/files.py", line 302, in get_file_content
    file = open(drive_entity.path, "rb")
TypeError: expected str, bytes or os.PathLike object, not NoneType
@michellealva michellealva added the bug Something isn't working label Aug 15, 2023
@uhrjun
Copy link
Contributor

uhrjun commented Aug 16, 2023

The drive_document doctype doesn't currently support being downloaded. It's saved as a base64 string from a binary CRDT

onUpdate() {
componentContext.$emit("update:modelValue", Y.encodeStateAsUpdate(doc));
componentContext.findCommentsAndStoreValues();
componentContext.setCurrentComment();
},

this.$resources.updateDocument.submit({
entity_name: this.entityName,
doc_name: this.document,
title: this.titleVal,
content: fromUint8Array(this.content),
comments: this.comments,
file_size: fromUint8Array(this.content).length,

All of this is done to support real time editing. Since the CRDT encodes and contains the entire document history and blame to prevent collisions.

Desired behaviour here would be downloading a PDF of the document perfectly reflecting the style and typography.

This is easy when done client side, provided the document is rendered. As opposed to requesting the download from the server. Which will require considerable amounts of work to do this correctly, decoding the CRDT to HTML and responding with a generated PDF.

Another potential solution would be just storing the HTML content (we can generate this during runtime) on disk along with the CRDT in the DB, and then generating a PDF from the saved HTML. This effectively doubles or close to doubles the file size. Which potentially isn't that big of an issue for unicode characters alone (which is all drive_document contains) since even after potentially doubling the file size we're still realistically talking about KBs worth of data. But this still isn't a perfect solution. Since this would involve tracking the file_size of both the HTML content and the CRDT. Could potentially cause issues/orphaned items I guess.

Implemented just disallowing & skipping them in batch downloads 2ce2c6d for now. To prevent all of this from breaking so abruptly.

@uhrjun uhrjun changed the title Cannot download file Downloading drive_document fails Aug 16, 2023
@netchampfaris
Copy link
Contributor

A Document should be downloadable as a PDF. That's a basic expectation from a user.

Now, to implement it you can do JSON to HTML to PDF or store both JSON and HTML. Storing the data in two formats and having the PDF feature is better than not having the feature and saving some KBs.

@uhrjun uhrjun pinned this issue Aug 29, 2023
@uhrjun uhrjun self-assigned this Aug 29, 2023
@uhrjun uhrjun unpinned this issue Sep 29, 2023
@uhrjun uhrjun pinned this issue Oct 23, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests

3 participants