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

Provide an official flatpak on flathub #5776

Open
Hofer-Julian opened this issue Dec 7, 2024 · 21 comments
Open

Provide an official flatpak on flathub #5776

Hofer-Julian opened this issue Dec 7, 2024 · 21 comments
Labels
distribution Something related to the packaged binaries, app-images and installers enhancement An improvement to an existing feature

Comments

@Hofer-Julian
Copy link

First, thanks a lot for your work. GitButler is fascinating, and I'd love to use it on a regular basis.

Since .deb packages are specific to Debian-based distributions and AppImage doesn't work on Wayland, I'd love to see if you'd take over the flatpak on flathub and fix the remaining paper cuts.

The (seemingly) flatpak specific ones that I noticed are:

  • git binary cannot be found (probably best to package it within the flatpak)
  • it cannot access git repositories after restart (I would just give it access to the whole home folder)
  • it attempts to acccess some D-Bus service (need to figure out which one and poke a whole for it)

I also hope that #5609 helps here

@Byron Byron added enhancement An improvement to an existing feature distribution Something related to the packaged binaries, app-images and installers labels Dec 8, 2024
@Byron
Copy link
Collaborator

Byron commented Dec 8, 2024

Thanks a lot for the suggestion, and the helpful tips as well!

  • git binary cannot be found (probably best to package it within the flatpak)

Most Git clients I tried ended up doing this, even though a FlatPak release seems to be a special case of this as to GitButler, git would just natively appear in the PATH if it's bundled? This is more of a rhetorical question, as I know nothing about FlatPak really.

  • it attempts to acccess some D-Bus service (need to figure out which one and poke a whole for it)

This is probably keyring crate trying to read previously stored secrets from the system keychain. #5753 updates it to the latest version, which may also affect how this works on Linux.

CC @ndom91 who knows all about our FlatPak setup.

@ndom91
Copy link
Contributor

ndom91 commented Dec 8, 2024

Interesting timing haha. I've been working on a replacement flathub repo here for the past few days.

Building the app from scratch and bundling git seems to fix most issues. I also have pretty lenient flatoak sandbox rules atm, so maybe that's avoiding the dbus issue you're referring to.

Everything seems to work building the debug build locally. However I can't get the release build to build locally yet, I think that's a more general rust / tauri issue with my build system though. The tauri build process just segfaults toward the end.

The build/bundle GHA is also not quite working yet, but that one seems more easily fixable. It can't find the appstream-compose binary, even though its installed. Some bubblewrap issue probbaly

I've tried reaching out to the existing flathub gitbutler maintainer on our discord, they're a member, but haven't heard back.

@ndom91
Copy link
Contributor

ndom91 commented Dec 8, 2024

Also side note, the appimage doesn't work on wayland for you? I use it on Hyprland and another Ubuntu 24.04 gnome box regularly, what issues are you running into?

Alternarively, you can force gitbutler to run as an xwayland window by prepending the following env var to launching the appimage, i.e.

GDK_BACKEND="x11" ./GitButler.AppImage 

@Hofer-Julian
Copy link
Author

@Byron

Most Git clients I tried ended up doing this, even though a FlatPak release seems to be a special case of this as to GitButler, git would just natively appear in the PATH if it's bundled? This is more of a rhetorical question, as I know nothing about FlatPak really.

Maybe you are more familiar with Docker? Flatpak behaves very similarly. Inside the container there's a filestructure resembling a classical unix file structure. If you put an executable into /usr/bin it will be in your PATH

@Hofer-Julian
Copy link
Author

@ndom91

Interesting timing haha. I've been working on a replacement flathub repo here for the past few days.

That's awesome. Let me know when you can need a second pair of eyes for something

I've tried reaching out to the existing flathub gitbutler maintainer on our discord, they're a member, but haven't heard back.

Are you part of the GitButler team? If the current maintainer is unresponsive, don't hesitate to reach out to flathub maintainers. They will help to transfer ownership of the repository.

Also side note, the appimage doesn't work on wayland for you? I use it on Hyprland and another Ubuntu 24.04 gnome box regularly, what issues are you running into?

The AppImage started on my Fedora machine. I don't know if it used Wayland or XWayland behind the scenes. I was actually under the impression that AppImage is completely incompatible with Wayland because of this gist by the AppImage creator. When trying it out, I've hit the mentioned clipboard problem, which is why I couldn't log into GitButler and therefore also not GitHub. And of course it doesn't install a desktop file and doesn't have an icon.

@ndom91
Copy link
Contributor

ndom91 commented Dec 8, 2024

Oh interesting, I'd never seen that gist. No so generally our appimage should "just work"😅. Of course not installing a desktop file, etc. is definitely annoying, but we've worked around the open external links and clipboard problems afaik

I am on the gitbutler team, and yeah if it comes time to release it and I still haven't heard back then I'll reach out to the flathub team.

Once I can get the release build building either locally or in CI I'd be happy about some more testing and feedback! I can ping you back in this issue with a download link if that's cool 🙏

@Hofer-Julian
Copy link
Author

Once I can get the release build building either locally or in CI I'd be happy about some more testing and feedback! I can ping you back in this issue with a download link if that's cool 🙏

Yes, please do that 🤝

@ndom91
Copy link
Contributor

ndom91 commented Dec 8, 2024

@Hofer-Julian alright so I've got it building the release build in CI finally. Unfortunately this still doesn't seem to communicate with the keyring correctly. I can login and everything works fine, however, as soon as I hard reload the application, or close / reopen it, the auth token is gone.

Looking into the keyring, it doesn't look like anything is ever written into there.

Anyway, besides for that I haven't found any big issues yet: https://github.com/ndom91/gitbutler-flathub/actions/runs/12223161843

@Hofer-Julian
Copy link
Author

Awesome!

Actually, I cannot reproduce your problems.
It stores both GitButler and GitHub credentials just fine for me.
If I restart the application, I am still logged in.

image

@Hofer-Julian
Copy link
Author

Copying link when logging into GitButler still doesn't work. Seems like I wrongly blamed AppImage for that. If I press on the whole field in order to trigger opening the browser instead, logging in works just fine.

@Byron
Copy link
Collaborator

Byron commented Dec 8, 2024

Looking into the keyring, it doesn't look like anything is ever written into there.

Maybe you could try again with #5753 applied? It updates the keyring crate and maybe that changes something to the better.

@ndom91
Copy link
Contributor

ndom91 commented Dec 8, 2024

@Hofer-Julian oh great news then haha. I'm testing this on a pretty vanilla Ubuntu 24.04 VM though so I can't be the only one having this issue 🤔

However, on my local nixos system I can't reproduce the keyring issue either. I can, however, reproduce the clipboard issue

image

@Byron I'll give your keyring crate PR a test tomorrow

@Hofer-Julian
Copy link
Author

The copying is especially weird, since copying works just fine during the github authentication process.

@ndom91
Copy link
Contributor

ndom91 commented Dec 9, 2024

@Byron #5753 didn't seem to help in this case unfortunately :(

That Ubuntu box still doesn't seem to write the info the password keyring. Also maybe notable, but its not working on both Ubuntu 24.04 VMs I have - one on my desktop at home and one on my laptop at work. They're both super vanilla gnome installations of 24.04.

@Hofer-Julian
Copy link
Author

That Ubuntu box still doesn't seem to write the info the password keyring. Also maybe notable, but its not working on both Ubuntu 24.04 VMs I have - one on my desktop at home and one on my laptop at work. They're both super vanilla gnome installations of 24.04.

Mmmh, but the AppImage or deb package adds the keyring entry correctly?

@ndom91
Copy link
Contributor

ndom91 commented Dec 9, 2024

That Ubuntu box still doesn't seem to write the info the password keyring. Also maybe notable, but its not working on both Ubuntu 24.04 VMs I have - one on my desktop at home and one on my laptop at work. They're both super vanilla gnome installations of 24.04.

Mmmh, but the AppImage or deb package adds the keyring entry correctly?

Correct and the same flatpak works well in my normal desktop nixos environment haha

Maybe something that Ubuntu is missing out of the box 🤔

@Byron
Copy link
Collaborator

Byron commented Dec 9, 2024

@Byron #5753 didn't seem to help in this case unfortunately :(

Too bad, thanks for giving it a shot. But maybe there is still hope - there are plenty of linux-features that one can enable to use different credential stores. If any of that makes sense to you, maybe that is something you could additionally try - it should be as easy as picking different cargo-features in the Cargo manifest that declares the keyring dependency.

@ndom91
Copy link
Contributor

ndom91 commented Dec 9, 2024

Yeah tbh I don't think its an issue on the side of our code / the keyring crate though at this point. Everywhere we've tried so far has worked (granted a small sample size 😅) except the two vanilla Ubuntu 24.04 VMs I have.

So I'm thinking more that Ubuntu just doesn't come with somethign critical pre-installed. Pulling on that thread some more:

  • It does have gnome-keyring installed as well as the gnome seahorse GUI for viewing your keyring.
  • The AppImage / deb installations can interact with the keyring successfully on those same systems
  • Maybe its some desktop portal / dbus communication issue? 🤔

Any other thoughts?

@Hofer-Julian
Copy link
Author

One other thing one could try is this crate: https://crates.io/crates/oo7

On Linux it is actually preferred, since it stores the secret in a way that only GitButler can see it but not other apps.

@Byron
Copy link
Collaborator

Byron commented Dec 9, 2024

Thanks for the suggestion, this is one of the coolest names for a crate for sure!

It seems Linux only and using it here would mean some effort as keyring is probably the best place to make it available in. And then we'd still not know if it makes a difference.

Trying different cargo features for keyring would be the first thing to try… but trying the cli of 007 might be even easier.

And speaking off, keyring also has a CLI - this should make trying different features trivial to find something that works consistently.

@ndom91
Copy link
Contributor

ndom91 commented Jan 15, 2025

Hey folks, a quick update - we're getting ready to release a first-party flatpak. I've been working on the build at https://github.com/ndom91/gitbutler-flathub. There you can find the latest build artifact (a .flatpak file you can install with flatpak install ..) under the github actions (i.e. https://github.com/ndom91/gitbutler-flathub/actions/runs/12789271694).

I've been in touch with the author of the community com.gitbutler.gitbutler flathub package that's already out there and I will just commit our changes into that repository once we're ready and then going forward we'll maintain that together.

So long story short, if you're already using the flathub package - it should work better and require no changes from you other than updating it.

We'd love any and all feedback you may have on it already, if you're up for trying out an experimental release, you can download it from the GHA linked above 🙏

EDIT: Updating the keyring feature from linux-native to the dbus one (sync-secret-service) fixed that secret store issue btw 🥳

Unfortunately that secret store feature didnt work in a "vanilla" GitButler build on linux for me. Same is true for the "mixed" feature (linux-native-sync-persistent). So I've kept the upstream one untouched at linux-native and added a little patch to the flatpak build to swap the feature to sync-secret-service there.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
distribution Something related to the packaged binaries, app-images and installers enhancement An improvement to an existing feature
Projects
None yet
Development

No branches or pull requests

3 participants