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

Source#readZip() #1462

Open
vanniktech opened this issue Mar 28, 2024 · 5 comments
Open

Source#readZip() #1462

vanniktech opened this issue Mar 28, 2024 · 5 comments

Comments

@vanniktech
Copy link
Contributor

Counterpart of what I wrote here #1442 (comment)

When the user is choosing for instance on Android from the file picker a file, I can get an InputStream quite easily. Which I can also call source() on but from there I don't get an easy way of reading it as a zip file. I could as a workaround write it to a file and then call openZip() but I think it's beneficial to have a readZip() directly on a Source so that any source is readable as a Zip.

@swankjesse
Copy link
Collaborator

Unfortunately the thing we need to read a zip FileSystem isn’t a Source (streaming) but rather a FileHandle (random access).

@vanniktech
Copy link
Contributor Author

That makes sense. Does InputStream have random access? If not, how is ZipInputStream able to use an InputStream?

@JakeWharton
Copy link
Collaborator

JakeWharton commented Mar 28, 2024

ZipInputStream reads valid entries from the beginning of the stream through to the end. Only once at the end do you reach the central index and can realize that some of the entities you saw were not in the directory and thus were old/fake/malicious.

@JakeWharton
Copy link
Collaborator

Still worth doing, in my opinion, as it has its uses too. Just gotta put a big caveat.

@marcardar
Copy link

marcardar commented Dec 26, 2024

Is this a drawback of having layered Sources as opposed to typed InputStreams? A FileInputStream allows us to access FileDescriptor etc: https://developer.android.com/reference/java/io/FileInputStream#getFD()

The reason I mention this is because looking at AssetFileSystem, all calls to the underlying AssetManager.open() use default accessMode AssetManager.ACCESS_STREAMING and so we lose the ability of random access. The source API calls don't have a concept of random access mode, so the only options would be for AssetManager.asFileSystem() to take a Boolean to indicate whether all open() calls should be random access of not, and that would feel a little hacky.

Or alternatively, FileSystem.source() could have an extra argument preferRandomAccess with default value false.

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

No branches or pull requests

4 participants