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

Nextcloud flatpak can be opened multiple times #12

Open
Firstyear opened this issue Jan 15, 2018 · 21 comments
Open

Nextcloud flatpak can be opened multiple times #12

Firstyear opened this issue Jan 15, 2018 · 21 comments
Labels
bug Something isn't working

Comments

@Firstyear
Copy link

It's possible to open multiple instances of the nextcloud flatpak, and all of them attempt to run and sync content at the same time. This may or may not cause consistency issues, so it would be great if the nextcloud flatpak was limited to a single instance running.

Thanks,

@TingPing
Copy link
Member

Does flatpak run --filesystem=/tmp org.nextcloud.Nextcloud change anything?

@juliusknorr
Copy link
Collaborator

I thought this was fixed with flathub/org.nextcloud.Nextcloud#6 but unfortunately it seems to work only every second time when running Nextcloud. So maybe this is an upstream bug.

@Firstyear
Copy link
Author

Yes! Setting --filesystem=/tmp results in the second instance displaying:

Gtk-Message: Failed to load module "canberra-gtk-module"
Gtk-Message: Failed to load module "canberra-gtk-module"
Sys Info size:  0
int main(int, char**) Already running, exiting...

@juliusknorr
Copy link
Collaborator

@Firstyear does it also work if you try to open an instance for the third time?

@Firstyear
Copy link
Author

Okay, it opens again on the third time ...

@juliusknorr
Copy link
Collaborator

I'm still not sure if this is an upstream issue or not. When running the client without flatpak it works as expected every time.

@juliusknorr juliusknorr self-assigned this Mar 9, 2018
@prog-amateur
Copy link

Hello, did you find a solution ?
I am on Ubuntu Wayland. Any flatpak app I have installed can open, while Nextcloud can't.
Today, I have sync issues, and I can't simply open the UI.
This issue was open on January, do you care about flatpak support ?

@juliusknorr
Copy link
Collaborator

I still could not find out why this is happening, seems like an upstream issue as the lock file is there and can be accessed by the client but it only recognizes it sometimes. However I cannot reproduce this outside of flatpak. If anyone has some ideas how this could be debugged, help is very welcome.

@fabiscafe
Copy link

Could we set another lock file for the flatpak itself? In that way we can just ignore the nextcloud lock file.

@cwmke
Copy link

cwmke commented Nov 28, 2018

For Debugging

@jurf
Copy link
Member

jurf commented Jan 14, 2019

Setting --env=TMPDIR=/var/tmp should be enough to get this to work…

@RobertBuhren
Copy link

Launching nextcloud with:

/usr/bin/flatpak run --branch=stable --arch=x86_64 --env=TMPDIR=/var/tmp  --command=nextcloud org.nextcloud.Nextcloud

Still allows multiple instances to run. Imho this makes the flatpak nextcloud app unusable,

@juliusknorr juliusknorr removed their assignment Dec 2, 2019
@tilosp tilosp transferred this issue from flathub/org.nextcloud.Nextcloud Sep 2, 2020
@tilosp tilosp added the bug Something isn't working label Sep 4, 2020
@tilosp
Copy link
Collaborator

tilosp commented Sep 4, 2020

The problem is that that QtSingleApplication is used to allow only one instance to be open.
And QtSingleApplication relies heavily on pids which breaks completely since the new process has the same id as the already running one.

@tilosp
Copy link
Collaborator

tilosp commented Sep 4, 2020

I have opened an issue to discuss possible replacements for QtSingleApplication upstream nextcloud/desktop#2364

@Iolaum
Copy link

Iolaum commented Sep 12, 2020

Tried replicating the bug in a Gnome Boxes VM running Fedora SilverBlue 32 on Wayland. I failed to replicate it:

$ /usr/bin/flatpak run --branch=stable --arch=x86_64 --env=TMPDIR=/var/tmp  --command=nextcloud com.nextcloud.desktopclient.nextcloud 
QSocketNotifier: Can only be used with threads started with QThread
nextcloud.gui.application: Already running, exiting...
$ flatpak info com.nextcloud.desktopclient.nextcloud

Nextcloud desktop sync client - Nextcloud desktop synchronization client

          ID: com.nextcloud.desktopclient.nextcloud
         Ref: app/com.nextcloud.desktopclient.nextcloud/x86_64/stable
        Arch: x86_64
      Branch: stable
     Version: 3.0.1
     License: GPL-2.0+
      Origin: flathub
  Collection: org.flathub.Stable
Installation: system
   Installed: 163.9 MB
     Runtime: org.kde.Platform/x86_64/5.15
         Sdk: org.kde.Sdk/x86_64/5.15

      Commit: 16956de802284db5ec2c6090df550820fb08270ff2f9e3650329a81e911c1eeb
      Parent: c901e78be336fa30ad1d3936d819c82afb4d4c9813bd613512669c8701bd8ba6
     Subject: Do cleanup (72d3d910)
        Date: 2020-09-07 07:09:34 +0000

@tilosp
Copy link
Collaborator

tilosp commented Sep 30, 2020

@Iolaum have you tried more than once, because once it works for me too.
You basically have to run flatpak run com.nextcloud.desktopclient.nextcloud three times, once to start it.
Than again to test if it detects the already running one, which it does on my machine, and then again to trigger this bug.

@Iolaum
Copy link

Iolaum commented Sep 30, 2020

@tilosp You are correct, trying again succeeds where it shouldn't:

$ /usr/bin/flatpak run --branch=stable --arch=x86_64 --env=TMPDIR=/var/tmp  --command=nextcloud com.nextcloud.desktopclient.nextcloud
QSocketNotifier: Can only be used with threads started with QThread
nextcloud.gui.application: Already running, exiting...
$ /usr/bin/flatpak run --branch=stable --arch=x86_64 --env=TMPDIR=/var/tmp  --command=nextcloud com.nextcloud.desktopclient.nextcloud
QSocketNotifier: Can only be used with threads started with QThread
2020-09-30 23:58:04:106 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::findPassword(const QString&, const QString&, QKeychain::JobPrivate*)
2020-09-30 23:58:04:286 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::findPassword(const QString&, const QString&, QKeychain::JobPrivate*)
2020-09-30 23:58:04:287 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::findPassword(const QString&, const QString&, QKeychain::JobPrivate*)
2020-09-30 23:58:04:287 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::findPassword(const QString&, const QString&, QKeychain::JobPrivate*)
2020-09-30 23:58:04:287 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::findPassword(const QString&, const QString&, QKeychain::JobPrivate*)
2020-09-30 23:58:04:535 [ debug default ]	[ unknown ]:	static bool LibSecretKeyring::writePassword(const QString&, const QString&, const QString&, QKeychain::JobPrivate::Mode, const QByteArray&, QKeychain::JobPrivate*)
^C
$ 

@juliusvonkohout

This comment has been minimized.

@reos-rcrozier

This comment has been minimized.

@julianfairfax
Copy link
Contributor

This doesn't seem to be the case anymore. Tested with Nextcloud Desktop-Client 3.14.2 on Fedora Linux 41 (Workstation Edition).

@ekasprzak
Copy link

Still exists in my case - v3.14.3 (flatpak) on Fedora 40 WS.
I don't understand how it works, as it doesn't happen every time (when I click notification).
Based on previous comment I was checking that and also thought it's fixed now.
But it just happened again and again I need to go through a whole list of what I actually want to sync, which is not a great experience.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working
Projects
None yet
Development

No branches or pull requests