Commit graph

77 commits

Author SHA1 Message Date
Kim Alvefur
71ad48095d plugins: Use integer config API with interval specification where sensible
Many of these fall into a few categories:
- util.cache size, must be >= 1
- byte or item counts that logically can't be negative
- port numbers that should be in 1..0xffff
2023-07-17 01:38:54 +02:00
Kim Alvefur
1987a7411f plugins: Switch to :get_option_period() for time range options
Improves readability ("1 day" vs 86400) and centralizes validation.
2023-07-16 20:49:33 +02:00
Kim Alvefur
8c6116120b Merge 0.12->trunk 2023-05-01 22:24:13 +02:00
Kim Alvefur
8ef7bc2cf4 mod_csi_simple: Disable revert-to-inactive timer when going to active mode
This timer shouldn't kick in in the middle of active mode.
2023-05-01 15:10:32 +02:00
Kim Alvefur
9aecb5cd19 mod_csi_simple: Clear delayed active mode timer on disable
It should not be there afterwards. Noticed that it seems to fire some
time after resumption claiming that the queue size is nil, implying
that it may hold a reference to an expired session somehow.
2023-05-01 14:52:38 +02:00
Kim Alvefur
98922d54b1 plugins: Prefix module imports with prosody namespace 2023-03-24 13:15:28 +01:00
Kim Alvefur
07660a9088 mod_csi_simple: Collect stats on number of stanzas per flush
Because interesting, gives some idea about the efficiency.
2022-06-14 03:31:30 +02:00
Kim Alvefur
168197a05f plugins: Update for namespace bump in XEP-0353 v0.4.0 2022-01-11 17:51:26 +01:00
Kim Alvefur
8a949f83e2 mod_csi_simple: Skip initiating flush in all but inactive state
Both in the flushing and active states the right thing to do is skip
directly to returning the data. Also in any unknown state, like if the
filter is somehow left behind on module unload.
2021-11-20 23:54:43 +01:00
Kim Alvefur
349968eb67 mod_csi_simple: Early return on client activity while flushing buffer
Cuts down on log and measurement noise. We only want to do these things
here when initiating a flush.
2021-11-20 22:50:51 +01:00
Kim Alvefur
3fb3e86228 mod_csi_simple: Allow some straggler traffic after flushing buffer
Statistics from my server shows a high rate of very short buffer hold
times, most of which are the result of replies to pings or other iq
traffic, or mod_smacks acks and ack requests just after a flush was
completed.

This grace period should eliminate noise and quick flipping between
flushing and inactive mode.
2021-11-20 19:23:08 +01:00
Kim Alvefur
3c57156fb9 mod_csi_simple: Skip flushing of empty buffer
Just adds noise
2021-11-18 01:57:21 +01:00
Kim Alvefur
d922bbb1ef mod_csi_simple: Fire event when flushing due to client activity
So that the same things happen as when triggered by an outgoing stanza
2021-11-18 00:39:10 +01:00
Kim Alvefur
6289a2f29d mod_csi_simple: Detach cleanly from sessions if unloaded while flushing
Since it changes the state to "flushing" while doing just that.
Attempting to remove the filters from a session that does not have them
should be a safe noop.
2021-11-16 16:03:23 +01:00
Kim Alvefur
62c74a6ad3 mod_csi_simple: Only act in inactive mode to prevent infinite recursion
Definitely should not be firing an event that triggers like csi-flushing
from which it may make sense to send things, which leads right back here
2021-11-16 13:53:30 +01:00
Kim Alvefur
49e86e78c5 mod_csi_simple: Unlock writes after event, to allow things to be queued
E.g. mod_smacks could queue an <r>, which would be more likely to be
included in the same write and TCP segment as the previously buffered
data, reducing syscalls and network packets needing to be sent.
2021-11-16 13:37:18 +01:00
Kim Alvefur
cdffc6aac2 mod_csi_simple: Provide custom set of timing buckets
The default of 0.001..100.0 did not feel suitable here. This might be
better. Longer is better and hold times less than a few seconds is
generally undesirable.
2021-10-05 15:49:47 +02:00
Jonas Schäfer
93a2f1559d mod_csi_simple: convert to use new metric interface for flush reasons 2021-05-20 14:00:54 +02:00
Kim Alvefur
89ec64ff89 mod_csi_simple: s/algoritm/algorithm/ [codespell] 2021-03-05 15:05:21 +01:00
Kim Alvefur
40252c2cc7 mod_csi_simple: Add command to test importance algorithm on stream of stanzas
This won't include behavior provided by extra modules tho.
2021-02-23 19:52:57 +01:00
Kim Alvefur
51b055809a mod_csi_simple: Fire event when flushing queue
To let other plugins know and take some action, e.g. flushing other
buffers or whatnot.
2021-02-16 23:10:23 +01:00
Kim Alvefur
dcab373f45 mod_csi_simple: Set session state to 'flushing' while doing so
May be useful for 3rd party modules.
2021-02-16 23:09:51 +01:00
Kim Alvefur
cb1282bfd0 mod_csi_simple,mod_carbons,mod_mam: Update comment about XEP-0353
It went back to Deferred
2021-01-08 17:32:06 +01:00
Kim Alvefur
e856c00107 mod_csi_simple: Report whatever's not a stirng and not a stanza
This is either dead code or actually a type error, but catching that
should be the responsibility of the session.send function. This type
check is left since everything after it assumes a stanza object.

These last few commits aren't meant to change any behavior and it did
mark things not stanzas as important, but those would have been mostly
raw strings which are now specially handled.
2020-05-10 23:12:33 +02:00
Kim Alvefur
c34f2c9ebf mod_csi_simple: Report whitespace keepalives
Single space character is sent by mod_c2s when a session has been
silent for some time. This should account for the vast majority of raw
strings passing through here. If this is not the case then having stats
to say otherwise will be interesting.
2020-05-10 23:09:15 +02:00
Kim Alvefur
9b7ab06ef3 mod_csi_simple: Identify raw string data in logging and stats 2020-05-10 23:06:21 +02:00
Kim Alvefur
d4c1384269 mod_csi_simple: Collect stats on flush reasons 2020-05-09 17:47:03 +02:00
Kim Alvefur
edd5966062 mod_csi_simple: Record stats of how long buffers are held
Telnet command `stats:show("buffer_hold"):histogram()` looks nice!
2020-05-09 17:45:45 +02:00
Kim Alvefur
4053cca7dc mod_csi_simple: Change debug message of client-triggered flush for coherence
It now matches other the other source of flush reason logging.
2020-05-09 17:38:13 +02:00
Kim Alvefur
e1a3982654 mod_csi_simple: Reset queue counter to zero when enabling
For symmetry.
2020-05-09 17:07:43 +02:00
Kim Alvefur
859c3650e5 mod_csi_simple: Forget queue counter when disabling optimizations
Otherwise it might not start from zero when enabled again.
2020-05-09 17:05:46 +02:00
Kim Alvefur
cabd89913a mod_csi_simple: Fix flushing when client sent something
Forgot to unset the flag afterwards, so it would only work once.

The flag is not even needed, it works as intended without it.
2020-05-09 13:50:58 +02:00
Kim Alvefur
749ed917c1 mod_csi_simple: Fix treating presence errors as presence updates
Autocomplete fail probably.
2020-05-09 13:33:26 +02:00
Kim Alvefur
ade3caf1ad mod_csi_simple: Add comment highlighting that XEP-0353 is experimental
To make it easier to find implemented Experimental XEPs later. Also at
the time of this commit it has been Proposed as mentinoed in the
comment but hopefully that will be resolved soon.
2020-05-09 01:01:03 +02:00
Kim Alvefur
fc8a50cd73 mod_csi_simple: Fix unintentional order of rules from merge 2020-05-09 01:01:01 +02:00
Kim Alvefur
5b3710099c Merge 0.11->trunk 2020-05-09 00:48:22 +02:00
Kim Alvefur
b8779399f6 mod_csi_simple: Consider XEP-0353: Jingle Message Initiation important
Improves experience with VoIP calls initiated via JMI

Closes #1548
2020-05-08 23:47:48 +02:00
Kim Alvefur
b2baba1124 mod_csi_simple: Log reasons for not flushing 2020-05-07 23:02:47 +02:00
Kim Alvefur
a9ba50343c mod_csi_simple: Add short reasons to report
Should improve quality of debug logs
2020-05-07 22:56:30 +02:00
Kim Alvefur
44847d620c mod_csi_simple: Refactor to allow logging reason for buffer flush
Same style as mod_mam and mod_carbons allows easy comparison.

BC: Log format changes
2020-05-07 21:55:29 +02:00
Kim Alvefur
9339ebb8e3 mod_csi_simple: Don't consider presence errors as important
A large share of `<presence type=error>` appears to be noise from large
public channels and failed presence probes. The later at least should
count as presence updates, which are currently considered unimportant.

See also 8cecb85e4bc4 which is partly reverted here. The intent there
was probably mostly about message (delivery) errors, which should be
considered important.
2020-05-05 23:08:47 +02:00
Kim Alvefur
0085d410b2 mod_csi_simple: Explicitly mention iq stanzas
Should be more obvious that all iq stanzas are considered important.
Changes behavior for invalid things in the default namespace.
2020-04-26 11:40:48 +02:00
Kim Alvefur
37a42fa605 mod_csi_simple: Clarify what might not be stanzas here 2020-04-26 11:13:25 +02:00
Kim Alvefur
ea91b4cc7b mod_csi_simple: Consider nonzas important
This case was previously handled by fall-trough at the end of the
function.
2020-04-26 11:13:01 +02:00
Kim Alvefur
fc3bee71fd mod_csi_simple: Explicitly consider errors important
This was already the case for presence and iq stanzas but not messages.
2020-04-26 10:58:22 +02:00
Kim Alvefur
8f77033238 mod_csi_simple: Consider MUC invites important
Both mediated invites defined by XEP-0045: Multi-User Chat and direct
invites defined by XEP-0249: Direct MUC Invitations
2020-04-18 19:36:26 +02:00
Kim Alvefur
4b33a7aac8 mod_csi_simple: Allow configuring extra tags indicating importance 2020-04-18 16:18:41 +02:00
Kim Alvefur
2a7715e94b mod_csi_simple: Make sure to disable optimizations before mod_smacks (thanks pep.) 2019-11-17 17:59:56 +01:00
Kim Alvefur
2e1a43906f mod_csi_simple: Always remove session filters when disabling CSI
Only guard the actual pausing of outgoing data on the method existing.
This prevents the filters from lingering in case something happened to
the connection. Removing already removed filters should be a safe noop.
2019-10-05 16:55:58 +02:00
Kim Alvefur
1356b90c3a mod_csi_simple: Try not to flush buffer while already flushing it
Reduces log noice
2019-10-05 16:50:41 +02:00