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

Add OpenSUSE package #2242

Open
sith-on-mars opened this issue Nov 5, 2020 · 30 comments
Open

Add OpenSUSE package #2242

sith-on-mars opened this issue Nov 5, 2020 · 30 comments

Comments

@sith-on-mars
Copy link

It would be nice that if there is a official OpenSUSE version. OpenSUSE is a a well-known, very established Linux distro and has been around since 2005. Its Enterprise edition, SUSE, existed since 2000. OpenSUSE uses RPM package so it's pretty similar to Fedora. However, during the installation on my OpenSUSE Tumbleweed using the Fedora package, I encountered two issues:

  1. The installer says dependency dbus-libs cannot be found. This warning can be ignored since OpenSUSE already installs this dependency actually by default, but just with a different naming convention.
  2. Startup on boot doesn't work and requires manual fixing. One needs to edit mullvad-daemon.service with this command input: sudo nano /opt/Mullvad\ VPN/resources/mullvad-daemon.service, then change Wants=network.target to Wants=network-online.target. You can see the detailed discussion here.

Having an officially supported OpenSUSE package should be a quick job, since the OpenSUSE package is pretty similar to Fedora package with a few changes.

@faern
Copy link
Member

faern commented Nov 5, 2020

Creating a single OpenSUSE compatible RPM is probably a quick job. But it's also going to be outdated quickly. What's harder is to automate the creation of this for every build. The extra build time needed. More artifacts to keep track of and distribute. More complex website download page etc.

Yes, we want to reach out via more distribution channels and in more formats. But each way is a commitment that will cost time and resources forever, not a one time investment.

Thanks for the feedback and the detailed steps needed to produce an OpenSUSE compatible installer! Hopefully we'll get there eventually.

@xadaemon
Copy link

xadaemon commented Nov 20, 2020

I managed to get it working with relative ease by symlinking from /opt/Mullvad VPN to /opt/mullvadVPN, since systemd was complaining about not finding the file.
Bellow is how my file ended up:

# Systemd service unit file for the Mullvad VPN daemon

[Unit]
Description=Mullvad VPN daemon
Wants=network-online.target
After=network-online.target
After=NetworkManager.service
After=systemd-resolved.service
StartLimitBurst=5
StartLimitIntervalSec=20

[Service]
Restart=always
RestartSec=1
ExecStart=/opt/MullvadVPN/resources/mullvad-daemon -v --disable-stdout-timestamps

[Install]
WantedBy=multi-user.target

edit: clarify why the symlink.

UPDATE:

The issue was something else I found out later but forgotten to update here. Read my latest comment for context.

@dinotheextinct
Copy link

I would also strongly support this, I am paying for this service and want to use wireguard. In order to use this properly on Opensuse a proper package would be necessary.

@ghost
Copy link

ghost commented Feb 22, 2021

Just jumping in here to suggest a couple of things which may be of help.

The first is the possibility of an AppImage, which is already an open issue (#1123), but it's a bit old and I don't know if it was ever considered.

It might be incredibly useful as it'll work across every distribution and you wouldn't actually need to build separate packages for each release. The downside is file size, since depencies, runtimes, etc. are part of the AppImage itself. The benefit, though, would be one identical file for every Linux user to download, regardless of distro.

I'm unaware of how it works with network interfaces, though, so it might not be option.

The second option is OpenSuse's OBS. It'll also help with automating and maintaining .deb and .rpm files since it's not actually limited to OpenSuse itself and works with packages used on various distributions.

See the developer section on the main site here: https://openbuildservice.org/

Admittedly, I'm not a developer, but I've occasionally found other projects on GitHub which use it for automating packages and updates.

Additionally, because it's technically a repository, I believe you could also allow people to add it as a third party repo which would allow them to update the app using their system's package manager without having to go to the website or the releases page here to download a new updated binary, though that's of course another matter altogether.

Just a couple of small suggestions and I admit I'm unaware of the inner workings of the systems I brought up, but maybe it could be of help.

@TruckerZer0
Copy link

TruckerZer0 commented Feb 23, 2021

+1 On having an openSUSE OBS Mullvad repo, something like "home:mullvad:mullvadvpn-app", even better if cross-distro;

Or what about simply removing "dbus-libs" from the rpm package installation requisites?

@myrust
Copy link

myrust commented Mar 11, 2021

Creating a single OpenSUSE compatible RPM is probably a quick job. But it's also going to be outdated quickly. What's harder is to automate the creation of this for every build. The extra build time needed. More artifacts to keep track of and distribute. More complex website download page etc.

Yes, we want to reach out via more distribution channels and in more formats. But each way is a commitment that will cost time and resources forever, not a one time investment.

Thanks for the feedback and the detailed steps needed to produce an OpenSUSE compatible installer! Hopefully we'll get there eventually.

Use OBS to automate the build and provide packages from the same source for Fedora, Debian, Ubuntu, SUSE Linux Enterprise and other distributions!
https://build.opensuse.org/

@groenator
Copy link

The problem with the package is a naming issue.

Here is what zypper is saying:

sudo zypper --no-gpg-checks in MullvadVPN-2021.4_x86_64.rpm 
Loading repository data...
Reading installed packages...
Resolving package dependencies...

Problem: nothing provides 'dbus-libs' needed by the to be installed mullvad-vpn-2021.4.0-1.x86_64
 Solution 1: do not install mullvad-vpn-2021.4.0-1.x86_64
 Solution 2: break mullvad-vpn-2021.4.0-1.x86_64 by ignoring some of its dependencies

Choose from above solutions by number or cancel [1/2/c/d/?] (c): c

lib-dbus is installed_

LANG=C zypper se -si libdbus
Loading repository data...
Reading installed packages...

S  | Name               | Type    | Version                  | Arch   | Repository
---+--------------------+---------+--------------------------+--------+----------------------
i+ | libdbus-1-3        | package | 1.12.20-5.4              | x86_64 | Main Repository (OSS)
i+ | libdbus-1-3-32bit  | package | 1.12.20-5.4              | x86_64 | Main Repository (OSS)
i  | libdbusmenu-glib4  | package | 16.04.0-7.10             | x86_64 | Main Repository (OSS)
i  | libdbusmenu-gtk3-4 | package | 16.04.0-7.9              | x86_64 | Main Repository (OSS)
i+ | libdbusmenu-qt5-2  | package | 0.9.3+16.04.20160218-1.5 | x86_64 | Main Repository (OSS)

checking the rpm is showing is a naming scheme error.

rpm -q --requires mullvad-vpn 
/bin/sh
/bin/sh
/bin/sh
/bin/sh
/bin/sh
dbus-libs
libXScrnSaver
libnotify
libnsl
rpmlib(CompressedFileNames) <= 3.0.4-1
rpmlib(PayloadFilesHavePrefix) <= 4.0-1
rpmlib(PayloadIsXz) <= 5.2-1

So maybe the devs can fix this issue easier, maybe create a new RPM for openSuse?

@faern
Copy link
Member

faern commented Aug 9, 2021

We are not going to have separate artifacts for OpenSUSE for now. There are more issues than this on OpenSUSE with our app already. Making the installer work better will just encourage more people to try to use it and they will hit the other issues. We don't support Suse and currently don't have the bandwidth to do so sadly. But this issue remains open for some future date when we might have the bandwidth to support this distro.

@groenator
Copy link

groenator commented Aug 9, 2021 via email

@t-wilis
Copy link

t-wilis commented Feb 15, 2022

Late on this I know, but why is there a space in the folder name for Mullvad in /opt/'Mullvad VPN'?
Why not just MullvadVPN, Mullvad_VPN, or Mullvad-VPN?

Historically have had issues on various OS's when spaces are introduced in paths.

Just to be clear, I am not requesting you to support OpenSUSE or SUSE. I know manpower is limited and you do what you can.

@faern
Copy link
Member

faern commented Feb 15, 2022

Systems that can't handle spaces have bugs in them. Yes, the pragmatic approach is to avoid spaces to avoid the issues. The correct solution is for those systems to fix their bugs. We started having a space in the name because electron-builder that we use to package our app uses the app name as the directory name by default and it was not configurable. So we just went with it. And to change it now would be a bit complicated and not really worth it given that it works fine on the vast majority of all systems/distros.

@EwolBash
Copy link

We are not going to have separate artifacts for OpenSUSE for now. There are more issues than this on OpenSUSE with our app already. Making the installer work better will just encourage more people to try to use it and they will hit the other issues. We don't support Suse and currently don't have the bandwidth to do so sadly. But this issue remains open for some future date when we might have the bandwidth to support this distro.

What kind of issues? Is it something we as users could approach Suse about?

@who-biz
Copy link

who-biz commented Sep 8, 2022

For anyone in need of an AppImage compiling source, I have made one available here: https://github.com/who-biz/mullvadvpn-app-appimage

Please see README for additional info.

@ewal
Copy link

ewal commented Nov 8, 2022

I recently did a fresh install of openSUSE Tumbleweed and got very surprised that the gui app just worked without me doing anything so maybe this problem is fixed. 🥳
Previously I started the daemon manually but those days are hopefully over 🙂

@cornfeedhobo
Copy link

@faern can you point me to the spec file that currently builds the fedora rpm?

@raksooo
Copy link
Member

raksooo commented May 4, 2023

@cornfeedhobo To build the rpm we use Electron builder, which generates the spec file from the information specified here: https://github.com/mullvad/mullvadvpn-app/blob/main/gui/tasks/distribution.js.

@cornfeedhobo
Copy link

@raksooo Here is my triage:

I think the simplest solution is to copy the pattern of the deb config to not include any dependency definitions.

  • As reported by others, the app currently works out of the box for most suse users, but they are going to bump into issues with package names not matching those of Fedora.

  • I believe the documentation on how to build is sufficient for any distros that want to take up building a native package through their build systems and ensure dependencies align.

  • Similarly, any user that's stubborn enough to go searching for your RPM is probably going to be able to navigate installing any missing dependencies. The only cases I anticipate will be related to the system tray icon support. The other dependencies are widely required and will likely already be installed.

  • Long term, for the purposes of offloading the maintenance overhead of building these packages and giving your company greater exposure, thought should be given to writing instructions for offline compilation for distros that may want to include this as a package in a "main" repo. Most build environments (e.g. open build service) are not allowed to access remote resources during compilation.

If you agree with my assessment, making a PR is trivial.

@cornfeedhobo
Copy link

@raksooo PR submitted. Please review.

@cornfeedhobo
Copy link

I could use some other voices on my pr. I firmly believe it's being gated arbitrarily. I've dealt with this in the past with some fedora zealots. Not really sure where we can go, because this is a hard blocker unless they decide to use a different build tool chain.

@secretmango
Copy link

Creating a single OpenSUSE compatible RPM is probably a quick job. But it's also going to be outdated quickly. What's harder is to automate the creation of this for every build. The extra build time needed. More artifacts to keep track of and distribute. More complex website download page etc.

Yes, we want to reach out via more distribution channels and in more formats. But each way is a commitment that will cost time and resources forever, not a one time investment.

Thanks for the feedback and the detailed steps needed to produce an OpenSUSE compatible installer! Hopefully we'll get there eventually.

so... Flatpak?

@secretmango
Copy link

I could use some other voices on my pr. I firmly believe it's being gated arbitrarily. I've dealt with this in the past with some fedora zealots. Not really sure where we can go, because this is a hard blocker unless they decide to use a different build tool chain.

you did some more changes and didn't answer why they are there. This alone blocks merging.

@dinotheextinct
Copy link

Any news on this?

@Andriamanitra
Copy link

Andriamanitra commented Jan 7, 2024

I would appreciate an official package but as a workaround I was able to get the app working on OpenSUSE Tumbleweed by following these instructions from reddit:

TL;DR:

  1. Download the RPM for Fedora
  2. sudo zypper install rpmrebuild
  3. Modify the RPM with sudo rpmrebuild -enp MullvadVPN-2023.6_x86_64.rpm (opens $EDITOR)
  4. Change
    • "Requires: dbus-libs" to "Requires: libdbus-1-3"
    • "Requires: libnotify" to "Requires: libnotify4"
  5. The modified rpm is saved to /usr/src/packages/RPMS/x86_64/. Install it using sudo zypper install /usr/src/packages/RPMS/x86_64/mullvad-vpn-2023.6-1.x86_64.rpm (you will get a warning about unsigned package but it can be ignored)

@cornfeedhobo
Copy link

@firefoxlover I have limited time and I ran out of interest to fight for something that feels painfully obvious. You are welcome to pick up where I left off :)

@I-I-IT
Copy link

I-I-IT commented Feb 27, 2024

@Andriamanitra your technique worked. I had previously downloaded a very old version (from OpenSUSE repo). Following your techniques, I modified the RPM file and then tried to open it, however the installer had an error. But using sudo zypper install mullvad-vpn-2024.1~beta2-1.x86_64.rpm succeeded an updated the app, albeit with the unsigned warning.

@mullvad this would take 2 seconds for you to modify.

@tomas-kuchta
Copy link

tomas-kuchta commented Mar 25, 2024

This is how I solved it in openSuSE 15.5:
Download .deb package (not rpm)
sudo zypper install dpkg
sudo dpkg -i MullvadVPN-2024.1_amd64.deb

Just a comment: Given that Ubuntu/Debian artifacts are the same as openSuSE's, both distros use the systemd and networkManager - I am not sure what to think about the extra effort in creating openSuSE specific rpm.

@secretmango
Copy link

crazy that this works, but this will likely not work on the immutable variants. Creating an opensuse rpm should be a very small change

@bernado82
Copy link

@Andriamanitra
I hadn't thought of modifying the Mullvad VPN specfile to rename the libnotify package name to libnotify4 because it worked without doing that. But now, I think I'll do it for my next rebuilds.

Few community packages for Mullvad VPN are available in openSUSE repositories:
https://software.opensuse.org/package/mullvadvpn

If after a Tumbleweed/Leap system update, Mullvad VPN display a scrambled window or none worldmap, try to:

  • Clear GPU cache with: rm -r ~/.config/Mullvad\ VPN/GPUCache/
  • Add option "--disable-gpu" in launcher command (example: /opt/Mullvad\ VPN/mullvad-vpn --disable-gpu)
  • Re-install same RPM package or use a new version.

@I-I-IT
Copy link

I-I-IT commented Apr 3, 2024 via email

@vyvir
Copy link

vyvir commented Jul 29, 2024

+1 for OpenSUSE support!

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

Successfully merging a pull request may close this issue.