Options for a good XMPP client?
-
Nice XMPP/Jabber support in UT would be cool, but so far there seems to be only the Loqui.im, Kaidan and Movim.
Loqui works reasonably well, but XMPP support really seems to be a stop-gap for them and it isn't really developed very actively. As a HTML5 app it also isn't very well integrated with notifications etc.
Kaidan seems promising, but the Kirigami UI is really alien in UT and right now it is still lacking too many features to be usable.
Movim is another HTML5 app and hasn't been updated for a while. It probably is a decent option, but depends on an external web-service (in addition to your XMPP server) and also doesn't do encrypted chats.
Other options:
- Make a HTML5 app with ConverseJS ( https://conversejs.org/ )
https://thealaskalinuxuser.wordpress.com/2018/04/24/ubuntu-touch-make-your-own-jabber-xmpp-app-in-10-minutes/
(Could probably be made better with some stuff from this electron port: https://github.com/nick-denry/Chimeverse )
This would be rather cool as it supports OMEMO e2e encryption and a lot of other modern features of XMPP. But I am not sure how well notification will work and what about web-push? Also the fullscreen theme isn't really mobile optimized and thus would need quite a bit of an update.
- Look into porting Smoose from SailfishOS:
https://github.com/geobra/harbour-shmoose
https://openrepos.net/content/schorsch/shmoose
Seems like a really promising start and a bit further in development than Kaidan, but I am unsure how easy it is to port over SailfishOS apps.
- Adopt Jabbercat:
https://github.com/jabbercat/jabbercat
https://jabbercat.org/
Currently a qt5/python desktop XMPP client not very actively developed, but this could be a good base for making a convergent XMPP app for UT touch.
Any other ideas or suggestions?
I might look into getting ConverseJS to run, but the other two options are way beyond my current capabilities for tinkering with code
- Make a HTML5 app with ConverseJS ( https://conversejs.org/ )
-
I personally put my faith in Kaidan, its actively developed, and hopefully it'll gain more developers since its on every platform known to man, but it does need more people on it, and it'd grow our relationship with plasma mobile, which seems to be going very well at the moment.
Of cause if an XMPP app is made for Ubuntu or takes on the UT guidelines, then more options are arguably better, but at the moment, the only xmpp app I see making a good future on Ubuntu Touch, would be Kaidan, I believe there team will actively work on making Ubuntu touch stuff work, such as notifications, and background services, but html5 apps, especially from apps that don't know, or care that we exist, is slightly less likely to get support for features required for many people.
-
https://github.com/geobra/harbour-shmoose/issues/55
Some interesting comments from the Smoose developer.
-
I played around with the UT Movim app a bit. Actually works reasonably well (but needs an update to Qtweb and SDK 16:04). The advantage of Movim is that it doesn't work like other XMPP clients internally (uses websockets instead) and thus should potentially work better on UT? The build in federated micro-blogging system is nice as well.
-
Hi, I will update the app in the next couple of days. Isn't much work
-
Just a small heads up. I got a prototype working based on ConverseJS. Not ready yet for a release, but you can follow development here:
https://github.com/poVoq/conversejs-ubportsIt's a HTML5 app using qtweb so don't expect great performance, but it seems quite usable on my Nexus5 so far.
The main issue right now is that it seems like the regular method of font loading in a browser does not work in a UT webview container. Anyone got a tip how to do that?
-
You can download a prototype version of my ConverseJS wrapper here now:
https://github.com/poVoq/conversejs-ubports/releases/tag/0.1I can't release this on the open-store due to the automatic app review restricting absolute paths in all apps. I tried about everything I could think of to avoid having the "/opt/click.ubuntu.com/" string in the ConverseJS settings. -
Found a working work-around which managed to by-pass the open-store restriction:
https://open-store.io/app/conversejs.povoq
Help to improve it appreciated, although other than some CSS fixes, most work has to be done upstream in the main ConverseJS.
Ideas to improve performance would be great.
Also: is there a way to pass through browser notifications to the main system notifications in qtwebview?
-
@poVoq for information about the notifications, refers to : http://docs.ubports.com/en/latest/appdev/guides/pushnotifications.html
But AFAIK, there is no such think through QTWebView, maybe you can catch the notifications somehow and use the push notifications system
-
@AppLee no I mean the HTML browser notifications that modern browsers use to directly pass through web-site notifications to the system notification queue. I am aware that these will not work if an app goes to sleep, but that can be suppressed with UT-tweek tool.
Push notifications are a totally different beast that I am looking into here: https://github.com/poVoq/conversejs-ubports/issues/1
(if there was an implementation for this, it would work with any XMPP client on UT, not only mine) -
@poVoq I understand what you want to achieve.
But I don't think confined apps can access the notification layer without using the push notifications system.[Edit] Have a look there : https://open-store.io/app/pushclient.christianpauly
It's easy to understand but I don't have time to dive in -
@AppLee Push notifications work slightly different with XMPP, as it already has build in support for that. In theory you just need to pass back your device identifier and JID of the push service to the XMPP server (ConverseJS has build in support for that) and the XMPP server (if it has mod_push enabled) contacts the push notification service of the app developer (via S2S connection). The problem is that such an XMPP compatible server software that talks to the Ubports push notification server does not exist yet. There are existing projects though that seem quite close to what is needed.
Edit: if the Ubports push notification server would understand XML messages it could likely also be contacted directly by the XMPP server. I think the original Android push notification system works like that, it is just that Google decided it would only allow registered servers to contact their push notification server, so a proxy server by the XMPP app developer is still needed. I think for Ubports push notification server is is not the case.
-
The developer of P2 is willing to add Ubports push notification support for XMPP clients, but it would need to be implemented by someone with Java knowledge. According to him it should be really easy though.
On an unrelated note, this might also be a portable qt native xmpp client: https://github.com/ksiazkowicz/lightbulb
-
Just as an update to this: I talked to the developer of Jabbercat/aioxmpp and it seems it would be fairly easy to write a new mobile friendly qt quick controls 2 UI on top of his abstracted jclib (pure Python):
https://github.com/jabbercat/jclibI am toying with the idea of having a go at it, but if a more experienced Python developer would take it up that would probably be more successful.
-
Another but also Javascript based option that seems promising (but still needs a bit of work) is this:
https://github.com/nioc/xmpp-webIt is even PWA capable, so on Android for example it works quite nicely as a progressive web app already. I hope PWA will be added to UT at some point, as it is really a neat standard for webapps.
-
Hi everyone, I'm New on ubports, on android I use Conversation , but on Ubports I want to use xmpp client for Muc chatroom support like gajim on Debian . I try with converseJS but don't work because I canβt connect .
-
@mito77 said in Options for a good XMPP client?:
Hi everyone, I'm New on ubports, on android I use Conversation , but on Ubports I want to use xmpp client for Muc chatroom support like gajim on Debian . I try with converseJS but don't work because I canβt connect .
Hi @mito77 can you explain better what you mean with "can't connect"? What XMPP server are you using? If it is self-hosted, make sure it is up to date and configured to expose BOSH or websockets as alternative connection methodes. Due to the webapp nature of ConverseJS you can not connect with the regular 5222 port as Conversations/Gajim etc. does.
-
@poVoq thank you . it work very good with bosh or wss link . I found on the wiki of the xmpp service. but ConverseJS dont save my login, and don't save my wss or my bosh. When I
restart the app it's blank . https://wiki.jabberfr.org/JabberFR
it's because the client don't have XEP-0156 natively -
@mito77 the wss and bosh address is saved in the app, just not displayed again in the form field.
However you need to put in again your JID and password each time. I have some ideas how to add an option to stay logged in, but doing so (with the option to also log out again) is a bit complicated.
Xep-0156 is supported in the new upstream version of ConverseJS. I need to get around updating my app to it.
-
Hi Povoq I'm reconnected again and again on a muc, and the error message is : "This groupchat has reached its maximum number of participants". Or we are three people in the muc chatroom.