mod_push_offline - Send offline messages to a component ======================================================= * Requires: ejabberd 22.05 or higher * Author: Mujtaba Roohani * Copyright (C) 2022 Mujtaba Roohani This is an ejabberd module that sends all messages sent to an offline entity to the specified [component](https://xmpp.org/extensions/xep-0114.html). It is a small modification of `mod_push`, customized for development of advanced push notification services. This module can be used as a substitute to [mod_http_offline](https://github.com/raelmax/mod_http_offline/tree/master/) and mod_push if one wants to receive the complete stanza sent to offline entity instead of only the sender and body of the message. Configuration ------------- Configurable options: - `host`: This option defines the host to receive offline messages from the service. If the 'host' option is not specified, the host will be the hostname of the virtual host with the prefix "push.". Example Configuration --------------------- You can modify the default module configuration file like this: To enable the module: ```yaml modules: mod_push_offline: host: "push.localhost" ``` To enable the HTTP request handler in the listen section: ```yaml listen: - port: 5347 module: ejabberd_service access: all shaper_rule: fast ip: "::" hosts: "push.localhost": password: "Secret" ``` With that configuration, you can connect a [component](https://xmpp.org/extensions/xep-0114.html) to ejabberd with following credentials to receive offline messages: - domain: `push.localhost` - password: `Secret` Example Flow ----------------- When juliet sends a message to romeo who is unavailable: ``` Wherefore art thou, Romeo? ``` ejabberd.log shows those messages: ``` 2022-10-10 12:40:25.261336+05:00 [debug] <0.559.0>@ejabberd_hooks:safe_apply/4:315 Running hook offline_message_hook: mod_push_modified:offline_message/1 2022-10-10 12:40:25.261496+05:00 [debug] <0.559.0>@mod_push_modified:offline_message/1:79 Notifying romeo@localhost of offline message 2022-10-10 12:40:25.263651+05:00 [debug] <0.559.0>@ejabberd_router:do_route/1:384 Route: #message{ id = <<"9202008986926435556">>,type = normal,lang = <<>>, from = #jid{ user = <<"romeo">>,server = <<"localhost">>,resource = <<>>, luser = <<"romeo">>,lserver = <<"localhost">>, lresource = <<>>}, to = #jid{ user = <<>>,server = <<"push.localhost">>,resource = <<>>, luser = <<>>,lserver = <<"push.localhost">>,lresource = <<>>}, subject = [],body = [],thread = undefined, sub_els = [#ps_event{ items = #ps_items{ xmlns = <<>>,node = <<"urn:xmpp:push:nodes:messages">>, items = [#ps_item{ xmlns = <<>>,id = <<"9202008986926435556">>, sub_els = [#message{ id = <<"98b12ff6-f196-487d-99f3-08c9406474db">>,type = chat, lang = <<"en">>, from = #jid{ user = <<"juliet">>,server = <<"localhost">>, resource = <<"balcony">>,luser = <<"juliet">>, lserver = <<"localhost">>,lresource = <<"balcony">>}, to = #jid{ user = <<"romeo">>,server = <<"localhost">>, resource = <<>>,luser = <<"romeo">>, lserver = <<"localhost">>,lresource = <<>>}, subject = [], body = [#text{lang = <<>>,data = <<"Wherefore art thou, Romeo?">>}], thread = undefined, sub_els = [], meta = #{ip => {0,0,0,0,0,0,0,1}}}], node = <<>>,publisher = <<>>}], max_items = undefined,subid = <<>>,retract = undefined}, purge = undefined,subscription = undefined,delete = undefined, create = undefined,configuration = undefined}], meta = #{}} 2022-10-10 12:40:25.263991+05:00 [notice] <0.552.0> (tcp|<0.552.0>) Send XML on stream = <<"Wherefore art thou, Romeo?">> ``` If the component push.localhost is connected, it will receive this message: ``` Wherefore art thou, Romeo? ```