💾 Archived View for jacksonchen666.com › posts › 2024-11-05 › 01-30-49 › index.gmi captured on 2024-12-17 at 10:01:40. Gemini links have been rewritten to link to archived content

View Raw

More Information

-=-=-=-=-=-=-

Thunderbird, osu!(lazer), and Minecraft, on macOS and Linux, on an encrypted external drive

2024-11-05 01:30:49Z (last updated 2024-12-11 00:28:01Z)

The issue and context

So here's the problem.

I use Thunderbird.

I play osu!(lazer).

I play Minecraft.

Those things create data, and when I moved that data to `gayming`, I didn't think about power outages. Then a power outage happened, and I couldn't use any of those even on my battery powered laptop cause I didn't have the data.

Keeping data consistent between multiple computers for those applications is a major hassle I'd rather not do manually every time I switch to using another computer (i.e. a manual file transfer). Of course, I also have to make it work on macOS and Linux (and not using macOS is not really a reasonable option right now).

Considered solutions

So I thought about it. Here's 2 ideas I have thought of:

Syncthing

I have considered Syncthing, but considering that:

So uh, no, it's not /that/ reliable for "when I need it the most".

Putting stuff on an SSD

So, here's my next idea: I put data on my SSD. Simple, right?

Well I have some desires:

How to put stuff on an SSD, encrypted, which is supported on both macOS and Linux

Good question. So I asked the Fediverse for some encryption software suggestions.

The Fediverse had various people reply to me with various software suggestions. I had to throw out half of the suggestions because they were for encrypting files for single files, and didn't provide anything like a filesystem. (I could blame this on people not reading my post, or I could blame myself for not writing the post fully, and using editing to rely on deduplicating suggestions, which might not federate well.) Well anyways, thanks for everyone who suggested!

So, here are the suggestions which fit the criteria for use:

There are things I've just looked and went "ehhh no" immediately:

VeraCrypt

VeraCrypt homepage

VeraCrypt runs on Windows, macOS, and Linux. It creates "containers", stuff where you can put files in and it's encrypted. Of course, caveats include having to pre-format the container fully (quick format was disabled) and the container being not resizeable (I think).

My problem here though, is filesystem. I could only choose ExFAT realistically, since I wanted it to be usable on macOS and Linux. And given that sometimes, you know, power loss, I was kind of icky about that given ExFAT had no journaling.

Another thing is that VeraCrypt would be required to unlock the container on all computers that want to read from it, so both macOS and Linux. That's not an issue.

Final thing to consider: Licensing. VeraCrypt is a fork of TrueCrypt (licensed under its own source-available license at best), so best to assume there's still code under the TrueCrypt license, which means VeraCrypt would still count as source-available at best. This leads to less Linux distributions packaging VeraCrypt at all, including Debian and Fedora, so you'll have to go to VeraCrypt's download page. I personally just `emerge`'d it in Gentoo, accepted the license with full ignorance, and got VeraCrypt on my Linux.

VeraCrypt's download page

All that out of the way, pretty much all apps worked. I still had to type out passwords, but I could use favorites to just open the password prompt. (Although favorites aren't perfect for things like non-persistent disk identifiers)

Linsk

Linsk

Linsk is "what if we just ran linux in a VM to read the FS, then made that available over a network filesystem protocol"

It honestly feels like a dirty solution that could be hacked together in a shell script quickly, but it's actually an entire go program.

It seems like it was intended for more than just encrypted partitions, allowing the use of unencrypted partitions with filesystems that Linux can support. However, my use case is encrypted partitions only.

Booting an operating system is, unsurprisingly, slower than opening an application like VeraCrypt. The password prompt is blocked by the fact that you need to boot an entire operating system (Alpine Linux), and you had no retries opportunities before the program just decides "yeah I'm just gonna terminate".

The biggest pain point is mounting and unmounting. The program is a terminal only program, and that makes it very fucking annoying to deal with (yes, a neovim user just said this). It also requires you to manually connect to the storage thing and disconnect from it, and if you accidentally unplug your drive, well I hope you can get your system to disconnect from the network filesystem.

The performance also was kinda surprisingly bad, and also power usage (although I didn't really have a baseline for that at all during use, so)

It also didn't work with Thunderbird (showed some empty stuff in a window upon startup) and Minecraft (something with locks, worlds don't show up at all), only osu!(lazer), so it's not useful in the end.

The only advantage this had was that I needed nothing more on Linux. It all worked on Linux already.

(Wow I really do sound like saying "this was complete crap" with lots of dunking 🫠)

CryFS

I never tested this, because CryFS could corrupt the filesystem. The name is a little /too/ fitting.

CryFS's README about "Stability / Production readiness"

gocryptfs

I never got around to testing this because VeraCrypt already worked and I didn't feel like learning to use another program.

Software choice conclusion

VeraCrypt, cause it's the only thing that seems to work reasonably well and with all the apps. Caveat is licensing (so less distros are willing to package it), and with cross-platform, not much filesystem choices (although that's probably to be expected with doing stuff cross-platform).

Putting the apps on the SSD

OK yeah encryption software chosen, but now how do you move applications to external storage?

Well, it depends on the application itself.

osu!(lazer)

You can just use in-game options to tell it to move to another place.

If you do open the game without the drive first, just click "Use default location until restart" on the missing external storage prompt, close the game, mount the drive, and open the game again.

Another option is to move your data to where you have moved it to, selecting the directory inside your osu!(lazer) folder, at which point osu!(lazer) will ask you if you want to use the chosen target instead of migrating.

Side note: osu!(lazer) doesn't prompt whether you want to move existing data from the running installation. What I just described could cause you to lose your settings (and maybe even all your data) if you misclick into the wrong folder.

Thunderbird

Run Thunderbird's profile manager, figure out where your existing profile is, move it manually, delete the old profile (if it asks you if you wanna delete files, don't (it shouldn't be asking for files that don't exist anyways)), then finally, add a new profile, and choose the location manually. Then Thunderbird should run off of the external drive.

I have setup another profile off the SSD so I can check emails without having to have a drive constantly attached. It doesn't contain my usual email setup because it shouldn't become the primary thing.

Using Thunderbird on both Linux and macOS creates an interesting side-effect, possibly with how VeraCrypt/macOS handles files starting with `._` which I assume are some macOS specific crap. They exist as actual files on Linux, so Thunderbird... literally takes some folders starting with `._` as actual folders.

Also another interesting thing: I run Thunderbird on macOS ARM64, and Linux x86_64. This seems to break extensions somehow in that every time I switch computers, it's like if it's not installed or something. Well, it's still listed, and turning it off and on and restarting Thunderbird makes it work again. This is an annoyance since I use Dark Reader, so I tend to get white backgrounds on screen which is not what I want.

Minecraft

Well, PrismLauncher: Moving the data to a new place is manual, but you can set paths for where data is. So it does technically support it, just not moving your existing data.

Conclusion

With VeraCrypt and applications that support moving data elsewhere and using it there, I can have applications use my data on multiple computers, across operating systems, with mostly no issues (aside from Thunderbird extensions).

That's good enough for me.

public inbox (comments and discussions)

public inbox archives

(mailing list etiquette for public inbox)