Commit graph

137 commits

Author SHA1 Message Date
Kim Alvefur
0613c5b47f mod_mam: Rework hints handling
Improved readability and early returns definite yes/no answer.
2020-04-21 01:01:25 +02:00
Kim Alvefur
e5d6376c58 mod_mam: Invert check for type
This is based on code in mod_csi_simple and aiming towards being more
flexible and maintainable than a couple of tests for when not to store.
2020-04-21 00:56:56 +02:00
Kim Alvefur
962d36d401 mod_mam: Log 'why' a stanza is archived
Logging of 'why not' is already done. Why not both? Will make more sense
when the rules evolve a bit.
2020-04-21 00:53:23 +02:00
Kim Alvefur
5817e5f02d mod_mam: Factor out "should we store this" into a function
Meant to improve readability and ease further improvements to this
algorithm.
2020-04-21 00:53:21 +02:00
Kim Alvefur
d04da8fdd9 Merge 0.11->trunk 2020-03-11 22:44:41 +01:00
Kim Alvefur
e3911ce5da mod_mam,mod_muc_mam: Allow other work to be performed during archive cleanup (fixes #1504)
This lets Prosody handle socket related work between each step in the
cleanup in order to prevent the server from being completely blocked
during this.

An async storage backend would not need this but those are currently
rare.
2020-03-11 21:15:01 +01:00
Kim Alvefur
1eabf5bdb4 Merge 0.11->trunk 2019-12-24 00:39:45 +01:00
Kim Alvefur
c37b1cc072 mod_mam: Schedule cleanup again if unable to delete messages 2019-12-24 00:27:44 +01:00
Kim Alvefur
669ca29966 mod_mam: Log error when unable to delete old messages (fix #1479) [luacheck] 2019-12-24 00:27:41 +01:00
Kim Alvefur
1c3988b171 mod_mam: More careful validation of MAM query form
Adapted from mod_muc_mam
2019-12-23 23:30:45 +01:00
Kim Alvefur
a74a87fb30 mod_mam: Log error when unable to store stanza (fix #1478)
Unclear what else to do here.

Caught by luacheck
2019-12-23 23:18:39 +01:00
Matthew Wild
0007aa04f1 mod_mam: Add flag to session when it performs a MAM query 2019-10-03 16:38:15 +01:00
Kim Alvefur
f11e984c30 mod_mam: Cache last date that archive owner has messages to reduce writes (fixes #1368) 2019-05-27 19:00:32 +02:00
Matthew Wild
1f5a8b48df Merge 0.11->trunk 2019-10-03 16:38:46 +01:00
Kim Alvefur
5c3633477b mod_mam: Perform message expiry based on building an index by date (backport of 39ee70fbb009 from trunk)
For each day, store a set of users that have new messages. To expire
messages, we collect the union of sets of users from dates that fall
outside the cleanup range.

The previous algoritm did not work well with many users, especially with
the default settings.
2019-03-22 17:32:56 +01:00
Kim Alvefur
9beff3d274 mod_mam: Fix rebase mistake [luacheck]
The 'err' was there in trunk
2019-12-24 01:01:05 +01:00
Kim Alvefur
40b1e3e0ed plugins: Remove tostring call from logging
Taken care of by loggingmanager now

Mass-rewrite using lua pattern like `tostring%b()`
2019-07-30 02:29:36 +02:00
Kim Alvefur
f179d7fe1c mod_mam: Remove embedded fallback archive driver (fixes #972)
It was equivalent to mod_storage_memory, which is included as a separate module now.
2018-10-25 21:59:17 +02:00
Kim Alvefur
e2910e8847 mod_mam: Upgrade case of invalid archive store driver to hard error 2018-10-25 21:58:22 +02:00
Kim Alvefur
182e80684f mod_mam: Ignore case of null storage driver 2018-10-25 21:55:08 +02:00
Kim Alvefur
b7fc41affc mod_mam: Add coment on how 'complete' works 2018-06-10 00:14:34 +02:00
Kim Alvefur
48a65eed67 mod_mam: Handle edge-case of max=0 so that complete attr is set (fixes #1128) 2018-06-09 23:57:58 +02:00
Kim Alvefur
fa1406845d mod_mam: Remove unmatched closing paren 2018-03-09 21:51:06 +01:00
Kim Alvefur
1e6c295b68 mod_mam: Add an option for whether to include 'total' counts by default in queries 2018-03-07 15:05:20 +01:00
Kim Alvefur
07c0bc5d54 mod_mam: Log a debug message if archive expiry has been disabled 2018-03-07 14:59:00 +01:00
Kim Alvefur
db93331e68 Backed out changeset 97a094fdf101, interferes with 6ddddfe05a74 2018-03-07 14:46:55 +01:00
Kim Alvefur
4f92c540b6 mod_mam: Implement option to enable MAM implicitly when client support is detected (#867) 2018-02-21 21:02:16 +01:00
Emmanuel Gil Peyrot
1574b7a818 mod_mam: Also return the preferences on set
Fixes #995.
2017-09-19 23:38:08 +02:00
Kim Alvefur
32a1219188 mod_mam: Log a message when not archiving because it only had ignored tags 2017-09-18 18:35:01 +02:00
Kim Alvefur
015bc6ad59 mod_mam: Log a message in case archive deletion is not supported by the storage module in use 2017-09-12 14:59:52 +02:00
Kim Alvefur
863374e164 mod_mam: Use a FIFO queue for scheduling archive expiry 2017-09-12 14:42:56 +02:00
Kim Alvefur
3888136262 mod_mam: Factor out <stanza-id> stripping so it can be reused in two places 2017-09-03 17:13:30 +02:00
Kim Alvefur
a9333c4f4b mod_mam: Clone stanza before stripping stanza id after carbons 2017-09-03 12:42:25 +02:00
Kim Alvefur
88bd13d98b mod_mam: Clone stanzas before mutating (thanks waqas) (fixes #961) 2017-07-25 22:01:16 +02:00
Kim Alvefur
3e15f71ed1 mod_mam: Request a total count if no items are requested 2017-07-05 04:38:08 +02:00
Kim Alvefur
06b5c50c4e mod_mam: Attach stanza-id to original stanza (fixes #917) 2017-05-20 14:58:56 +02:00
Kim Alvefur
49655b2234 mod_mam: Format timestamps in log message 2017-05-07 20:23:29 +02:00
Kim Alvefur
afa9082458 mod_mam: Use correct variable 2017-04-27 12:41:53 +02:00
Kim Alvefur
3431032994 mod_mam: Don't ask the storage backend to count all items when expiry is disabled 2017-04-26 11:46:22 +02:00
Emmanuel Gil Peyrot
863f155efb mod_mam: Remove extraneous assert when opening the store 2017-04-02 19:38:52 +01:00
Kim Alvefur
4f82974fa8 mod_mam: Remove dead code (default will be filled in by mamprefs.lib) 2017-03-23 14:45:18 +01:00
Kim Alvefur
e9634beff0 mod_mam: Handle default_archive_policy option consistently 2017-03-16 21:01:45 +01:00
Kim Alvefur
ef1b01c822 mod_mam: Fix to treat first return value from archive:append as assigned ID 2017-02-20 01:26:48 +01:00
Kim Alvefur
04f890a467 mod_mam: Remove repeated blank line 2017-02-20 00:51:12 +01:00
Kim Alvefur
7e36855e9b mod_mam: Fix typo in comment 2017-02-20 00:38:32 +01:00
Kim Alvefur
f6b5f2631e mod_mam: Add missing wrapping <query> element when returning the query form 2017-02-20 00:37:46 +01:00
Kim Alvefur
23f6da0769 mod_mam: Update namespace to XEP-0313 v0.6 2017-02-20 00:32:59 +01:00
Kim Alvefur
f6dcf59968 mod_mam: Strip stanza-id tags after carbons 2017-02-19 23:39:53 +01:00
Kim Alvefur
9cde2e34c6 mod_mam: Fix wording of comment 2017-02-19 13:44:47 +01:00
Kim Alvefur
293402a338 mod_mam: Advertise Stanza ID support (XEP-0359) (thanks iNPUTmice) 2017-02-14 18:51:41 +01:00