Software /
code /
prosody-modules
Diff
mod_muc_markers/README.md @ 6003:fe081789f7b5
All community modules: Unify file extention of Markdown files to .md
author | Menel <menel@snikket.de> |
---|---|
date | Tue, 22 Oct 2024 10:26:01 +0200 |
parent | 4338:0227fb4d1b40 |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_muc_markers/README.md Tue Oct 22 10:26:01 2024 +0200 @@ -0,0 +1,45 @@ +# Introduction + +This module adds an internal Prosody API to retrieve the last displayed message by MUC occupants. + +## Requirements + +The clients must support XEP-0333, and the users to be tracked must be affiliated with the room. + +Currently due to lack of clarity about which id to use in acknowledgements in XEP-0333, this module +rewrites the id attribute of stanzas to match the stanza (archive) id assigned by the MUC server. + +Oh yeah, and mod_muc_mam is required (or another module that adds a stanza-id), otherwise this module +won't do anything. + +# Configuring + +## Enabling + +``` {.lua} +Component "rooms.example.net" "muc" +modules_enabled = { + "muc_markers"; + "muc_mam"; +} +``` + +## Settings + +| Name | Description | Default | +|----------------------------|--------------------------------------------------------------------------------------|-------------| +| muc_marker_summary_on_join | Whether a summary of all the latest markers should be sent to someone entering a MUC | true | +| muc_marker_type | The type of marker to track (displayed/received/acknowledged) | "displayed" | + + +# Developers + +## Example usage + +``` +local muc_markers = module:depends("muc_markers"); + +function something() + local last_displayed_id = muc_markers.get_user_read_marker("user@localhost", "room@conference.localhost"); +end +```