• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..03-May-2022-

README.markdownH A D05-Jun-20213.3 KiB7251

mod_muc_cloud_notify.luaH A D05-Jun-202119 KiB514408

README.markdown

1---
2labels:
3- 'Stage-Alpha'
4summary: 'XEP-XXX: Cloud push notifications for MUC'
5---
6
7# Introduction
8
9This is an experimental fork of [mod_cloud_notify](https://modules.prosody.im/mod_cloud_notify.html)
10which allows a [XEP-0357 Push Notifications App Servers](https://xmpp.org/extensions/xep-0357.html#general-architecture)
11to be registered against a MUC domain (normally they're only registered against
12your own chat server's domain).
13
14The goal here is to also enable push notifications also for MUCs.
15
16In contrast to mod_cloud_notify, this module does NOT integrate with
17mod_smacks, because a MUC can't access a remote user's XEP-0198 queue.
18
19Configuration
20=============
21
22  Option                               Default           Description
23  ------------------------------------ ----------------- -------------------------------------------------------------------------------------------------------------------
24  `push_notification_with_body`        `false`           Whether or not to send the message body to remote pubsub node.
25  `push_notification_with_sender`      `false`           Whether or not to send the message sender to remote pubsub node.
26  `push_max_errors`                    `16`              How much persistent push errors are tolerated before notifications for the identifier in question are disabled
27  `push_notification_important_body`   `New Message!`    The body text to use when the stanza is important (see above), no message body is sent if this is empty
28  `push_max_devices`                   `5`               The number of allowed devices per user (the oldest devices are automatically removed if this threshold is reached)
29
30There are privacy implications for enabling these options because
31plaintext content and metadata will be shared with centralized servers
32(the pubsub node) run by arbitrary app developers.
33
34## To test this module:
35
36The [Converse](http://conversejs.org/) client has support for registering push
37"app servers" against a MUC.
38
39You specify app servers with the [push_app_servers](https://conversejs.org/docs/html/configuration.html#push-app-servers)
40config setting.
41
42And then you need to set [enable_muc_push](https://conversejs.org/docs/html/configuration.html#enable-muc-push)
43to `true` so that these app servers are also registered against MUC domains.
44
45Additionally you need to set [auto_register_muc_nickname](https://conversejs.org/docs/html/configuration.html#auto-register-muc-nickname)
46to true.
47
48Then, when you enter a MUC, Converse will try to automatically register your nickname
49on that MUC.
50
51Note: Converse currently doesn't let you register separate app servers for
52a MUC domain. The same app servers are registered for the MUC domain and your
53own domain.
54
55## To be done:
56
57We currently don't handle "ghost connections", users who are currently offline
58but the XMPP server is not yet aware of this and shows considers them online in
59the MUC.
60
61Prosody already checks for error bounces from undelivered groupchat messages
62and then kicks the particular user from the room.
63
64So these ghost connection users eventually get kicked from the room.
65
66We now need a module that fires an event when a groupchat messages can't be
67delivered to an occupant. The module can look up the undelivered message in MAM
68and include it in the event.
69
70In mod_muc_cloud_notify we can then listen for this event and send out a push
71notification.
72