I made a little tool to unzip archives in a sane way (github.com)
from myxi@toast.ooo to programming@programming.dev on 01 Dec 2024 13:56
https://toast.ooo/post/5572108

I like trying out new things quite frequently and often times these tools are packed in an archive file. But I’m in constant fear whenever I am to unpack those archives because sometimes there are hundreds of files and the person who packed them wouldn’t even do the bare minimum of nesting them inside a directory.

Dolphin (file explorer) had a useful thing where it would detect whether the contents are already nested and if they are not only then it would nest them inside a directory. I tried searching for something similar for the CLI but couldn’t find anything so here it is. Another benefit is that it supports .zip, .tar.xz, .tar.gz simultaneously so I don’t need to deal with manpages of unzip, tar thousand times just because I keep forgetting how to use them. Now it’s just vert x file.zip.

I can add support for a few more formats but I don’t feel the need at least for now (PRs welcome).

#programming

threaded - newest

TriflingToad@sh.itjust.works on 01 Dec 2024 14:55 next collapse

So it detects if there’s a single folder inside the zip containing all the files or all the files directly inside the zip? That’s useful!

Reminds me of Minecraft texture packs back in the day where nobody really understand how to make a texture pack and all used Ms paint and this was a common issue as clicking “add to .zip” on the folder would make a containing folder and not work. This would mean each user would have to extract it and have folders in their resource pack folder instead of zips.
This… worked, but when the client(basically a large QOL mod) ~50% of people used added the ability to put texture packs in folders to organize them it treated the unzipped packs like a folder so they stopped working.

Albbi@lemmy.ca on 01 Dec 2024 15:31 next collapse

but when the client(basically a large QOL mod)

I think you a word. Did you mean when the client updated?

Deebster@infosec.pub on 01 Dec 2024 17:18 collapse

There’s enough words there - I read it as “when this widely-used client added feature x”…

Albbi@lemmy.ca on 02 Dec 2024 06:58 collapse

Ah you’re right. I was expecting the word update or something after client.

Deebster@infosec.pub on 02 Dec 2024 10:32 collapse

It’s definitely a bit of a confusing garden-path sentence.

myxi@toast.ooo on 01 Dec 2024 15:45 collapse

So it detects if there’s a single folder inside the zip containing all the files or all the files directly inside the zip?

Yes. It also has l (lowercase L) subcommand which lists the contents of the archives to the terminal (stdout).

kevincox@lemmy.ml on 01 Dec 2024 15:25 next collapse

Warning

Never extract archives from untrusted sources without prior inspection. It is possible that files are created outside of path, e.g. members that have absolute filenames starting with “/” or filenames with two dots “…”.

docs.python.org/3/library/tarfile.html#tarfile.Ta…

I would be careful if using this as a general purpose tool.

A better alternative would likely be to use the regular command-line tools which have been hardened to this type of thing (and are likely much faster) and then just inspect the result. Always create a wrapper directory, then if the result is only one directory inside of that move it out, otherwise just keep the wrapper. I would recommend that the other updates their tool to do this rather than the current approach.

myxi@toast.ooo on 01 Dec 2024 15:41 collapse

UPDATE: Implemented VERT_USE_EXTERNAL_TOOLS environment variable. See #Configuration.

I had passed the filter parameter as “data”, which should help prevent most issues with it but yes I agree that it would’ve been better to use external tools to do the heavy-lifting. I avoided them to make the program cross-platform and easier to setup (you currently can just run a simple pip command to install it). I may introduce them as optional backends later with a warning on the default ones but for now I’m postponing it.

FizzyOrange@programming.dev on 01 Dec 2024 21:42 next collapse

Very nice! This is definitely an annoying problem.

I’m not trusting this to Python though.

mindbleach@sh.itjust.works on 02 Dec 2024 02:54 next collapse

Unzip tools should always do it in a new folder.

I can deal with home/ZipName/ZipName. I have no patience whatsoever for a program dumping randomly-dated files onto an existing directory.

Do the simplest thing that could possibly work.

prof@infosec.pub on 02 Dec 2024 10:43 collapse

Good luck with the project.

I want to request a not-feature: One time I extracted an archive with an odd command that ended up dumping all its contents without directories straight into the base folder of the archive without a way to undo that. Please don’t make that possible with your tool. 😂

I had to manually clean up the directory.

myxi@toast.ooo on 02 Dec 2024 11:12 collapse

Vert guarantees a single file/directory when you extract something with it. If there are more than 1 file in the archive it will nest them in a directory. I have no plans to add any flags or anything to make it extract without nesting either.