Commit graph

72 commits

Author SHA1 Message Date
Kim Alvefur
2c61955e3a mod_smacks: Destroy timed out session in async context (fixes #1884)
Prevents ASYNC-01 due to storage interactions in a timer.

Also considered modifying mod_c2s to allow passing arbitrary closures
into its runner thread but this seems like a big step away from the
current code for just this module.

Also considered creating a dedicated runner in mod_smacks, but ensuring
continuity across module reloads might be tricky.

We could further improve this in the next major version.
2024-11-02 18:10:25 +01:00
Kim Alvefur
d840f27320 mod_smacks: Replace existing watchdog when starting hibernation
There shouldn't be one here but if there is, for some reason, it's
better to close it than have it around to wake up and possibly try to
destroy the session.
2023-04-02 10:40:48 +02:00
Kim Alvefur
3a3d9c6c2c mod_smacks: Fix stray watchdog closing sessions
Unsure exactly how this happens, but sometimes a watchdog appears to
close a session that isn't hibernating, or hasn't hibernating long
enough.
2023-04-02 10:37:44 +02:00
Kim Alvefur
67b6440d9b mod_smacks: Log something when hibernation starts
Will hopefully save future confusion about sessions being destroyed when
they are in fact not.
2023-01-19 20:59:28 +01:00
Kim Alvefur
d158455de6 mod_smacks: Disable resumption behavior on s2s
Since resumption is not supported on s2s currently, there is no point in
allocating resumption tokens.  The code that removes entries from
session_registry is only invoked for c2s sessions, thus enabling
resumable smacks on s2s adds an entry that never goes away.
2022-11-13 18:16:59 +01:00
Kim Alvefur
bfe2a924f8 mod_smacks: Fix #1761 by setting a flag earlier
This ensures that the flag is set even if the pre-drain callback is
called from send(), as would be the case if opportunistic writes are
enabled.
2022-06-12 01:50:33 +02:00
Kim Alvefur
d7e7558bae mod_smacks: Bounce unhandled stanzas from local origin (fix #1759)
Sending stanzas with a remote session as origin when the stanzas have a
local JID in the from attribute trips validation in core.stanza_router,
leading to warnings:
> Received a stanza claiming to be from remote.example, over a stream authed for localhost.example

Using module:send() uses the local host as origin, which is fine here.
2022-05-27 14:45:35 +02:00
Kim Alvefur
568aa79441 mod_smacks: Fix bounce of stanzas directed to full JID on unclean disconnect
Fixes #1758

Introduced in 1ea01660c79a

In e62025f949f9 to and from was inverted since it changed from acting on
a reply to acting on the original stanza (or a clone thereof)

Unsure of the purpose of this check, you don't usually send stanzas to
your own full JID. Perhaps guarding against routing loops?

The check was present in the original commit of mod_smacks,
prosody-modules rev 9a7671720dec
2022-05-27 12:05:47 +02:00
Kim Alvefur
8027b67f19 mod_smacks: Fix to use current method of counting acked stanzas
Fixes #1757

These places seem to have been left since e62025f949f9

The logic around expected_h in should_ack() misbehaved, always comparing
with 0 + unacked instead of acked + unacked.
2022-05-26 17:38:55 +02:00
Kim Alvefur
a3a343b20e mod_smacks: Tweak resumption age buckets towards multiples of 60
This seems like the thing to do for time, which is usually divided into
divisors divisible by 60, or multiplied by multiples of 60
2022-02-04 22:11:14 +01:00
Kim Alvefur
64c385c9f7 mod_smacks: Log error to silence luacheck 2021-12-31 00:59:10 +01:00
Kim Alvefur
f017e61543 mod_smacks: Limit "old" session resumption counters
Doing this when creating a whole new session seems reasonable because it
is already expensive and this is when it may be adding to the old
session store, while a successful resumption should be plus-minus zero.
2021-12-31 00:48:38 +01:00
Kim Alvefur
88da8ef1a0 mod_smacks: Record timestamp with persisted counters
For future cleanup routine when people inevitably complain about this
data being stored there forever
2021-12-31 00:18:13 +01:00
Jonas Schäfer
f53f452e47 mod_smacks: sprinkle some metrics on it 2021-12-27 16:16:53 +01:00
Kim Alvefur
ecab94165d mod_smacks: Compact code using new stanza API 2021-12-22 22:13:03 +01:00
Kim Alvefur
2f3b28380a mod_smacks: Use more compact resumption tokens
UUID seems like insane overkill for something user-scoped and not
security-sensitive. All that is needed is to avoid conflicts among what
should be relatively long-lived sessions.
2021-12-22 18:47:45 +01:00
Kim Alvefur
86617ab008 mod_smacks: Add future todo
The vision: All the queueing and counting and session replacement logic
in core, with mod_smacks only hooking this up to the XEP-0198 protocol.
2021-12-20 00:21:04 +01:00
Kim Alvefur
afb195c623 mod_smacks: Only include max resumption time when resumption is activated 2021-12-20 00:18:47 +01:00
Kim Alvefur
121ce4fda7 mod_smacks: Fix typos 2021-12-20 00:06:47 +01:00
Kim Alvefur
1a089b68ec mod_smacks: Fix error on shutdown if loaded on Component 2021-12-20 00:04:32 +01:00
Kim Alvefur
94af122279 mod_smacks: Fix typo (thanks codespell) 2021-12-19 15:00:22 +01:00
Kim Alvefur
884cfdcaaf mod_smacks: Avoid log noise when a non-smacks session is closed 2021-12-19 14:59:27 +01:00
Kim Alvefur
af3aa001dc mod_smacks: Check if session was really sleeping before logging message
It could have been resumed without going into hibernation first, i.e.
when the client notices the disconnect before the server, or if it
switches networks etc.
2021-12-18 15:45:06 +01:00
Kim Alvefur
549ee95de5 mod_smacks: Fix traceback when bouncing unacked stanzas
Errors sent from handle_unacked_stanzas() should usually not be sent to
the session itself, but if one is, it should not be queued.
2021-12-18 13:58:33 +01:00
Kim Alvefur
eb65a8b39a mod_smacks: Fix duplicate sleep behavior when replacing a session
Fixes that an extra watchdog was set, leaking the previous one, which
went on to do behave as if the session times out.
2021-12-18 13:48:57 +01:00
Kim Alvefur
3fe05657e3 mod_smacks: Remove references to connection on hibernation
Still having the connection on the session may cause unintentional
behavior, such as the session being treated as if connected, even tho
the connection has been closed.
2021-12-18 12:50:53 +01:00
Kim Alvefur
585a1aa0c6 mod_smacks: Add more logging 2021-12-18 12:50:09 +01:00
Kim Alvefur
0c57e44fd3 mod_smacks: Remove useless delay in requesting ack on resumption
Was this the last place using the delay? Nice!
2021-12-17 17:22:27 +01:00
Kim Alvefur
11e5efc23f mod_smacks: Fix to not wait for acks from before a resumption
Otherwise it can get stuck waiting indefinitely for an ack that made it
notice the connection was stale.
2021-12-17 17:20:26 +01:00
Kim Alvefur
4cde54475b mod_smacks: Split log messages for when an old session exists in storage
Non-existent did not seem entirely accurate for this case
2021-12-17 16:29:17 +01:00
Kim Alvefur
2e47306cb6 mod_smacks: Bounce unacked stanzas on shutdown 2021-12-17 16:21:26 +01:00
Kim Alvefur
685974b5d3 mod_smacks: Preserve counter values on shutdown 2021-12-17 16:00:08 +01:00
Kim Alvefur
b5c32b6572 mod_smacks: Simplify access to local user sessions
Less to type if per chance the next commit also wants to access
sessions.
2021-12-17 15:59:06 +01:00
Kim Alvefur
e10845657c mod_smacks: Cancel hibernation when session is closed
To ensure that if a session is replaced after it has gone into
hibernation, it does not come back and cause trouble for the new session
(see previous commit).
2021-12-16 23:04:50 +01:00
Kim Alvefur
6745972708 mod_smacks: Skip hibernation logic if session was closed or replaced
The resumption_token is removed when the session is closed via the
pre-session-close event, signaling that it cannot be resumed, and
therefore no hibernation timeout logic should be invoked.

Fixes that if a session somehow is replaced by a new one using the same
resource (which is the common behavior), the old session would still be
around until it times out at which point it sends `<presence
type="unavailable"/>` which would look as if it came from the new
session, ie appearing offline to everyone including MUCs.
2021-12-16 22:59:51 +01:00
Kim Alvefur
d87188b309 mod_smacks: Fix indentation
Meld keeps messing up indentation when I merge and rebase...
2021-12-16 22:42:08 +01:00
Kim Alvefur
d73f3bee87 mod_smacks: Stop stanzas from being queued on hibernation timeout
This overloads that flag a bit, but it has the intended effect of
stopping outgoing_stanza_filter() from queueing stanzas.

Fixes a traceback because of the queue having been removed somewhere
around here, since it is no longer needed.

Thanks Martin for reporting
2021-12-16 16:02:01 +01:00
Kim Alvefur
6e0bbc2af5 mod_smacks: Limit queue memory consumption using new util
This brings back the queue size limit that was once added, then removed
because destroying the session when reaching the limit was not great.
Instead, the queue wraps and overwrites the oldest unacked stanza on the
assumption that it will probably be acked anyway and thus does not need
to be delivered. If those discarded stanzas turn out to be needed on
resumption then the resumption fails.
2021-12-14 20:00:45 +01:00
Kim Alvefur
bdce99b7dd mod_smacks: Set a watchdog to watch sleeping sessions
Extending the timeout by poking the watchdog, and letting it go on
resumption, should be much better than the previous method.
2021-12-02 02:46:26 +01:00
Kim Alvefur
0162eba8c6 mod_smacks: Switch storage for tracking resumption tokens
All that was a complicated way to limit the number of resumable
sessions. Let's control resource usage some other way.  This leaves the
essence of mapping resumption tokens to live sessions.

This keeps resumption state across reloads.
2021-12-02 14:41:19 +01:00
Kim Alvefur
78a1e8352b mod_smacks: Clear resumption token from persistent storage on resumption 2021-12-01 20:13:08 +01:00
Kim Alvefur
d2b3e92578 mod_smacks: Persist old counter values to storage
This allows clients that try to resume a session after a server restart
to at least know which of their pending outgoing stanzas were received
and which need to be re-sent.

This removes the limit on how many of those counters are kept, which
should be fixed eventually.
2021-12-01 16:41:10 +01:00
Kim Alvefur
b1898099ee mod_smacks: Remove now unused variable [luacheck] 2021-12-15 12:09:30 +01:00
Kim Alvefur
c3ee82bcab mod_smacks: Remove unused event
Since nothing uses it. Some equivalent functionality may return in the
future.
2021-12-15 12:06:58 +01:00
Kim Alvefur
5f73d6f070 mod_smacks: Fix typo 2021-12-15 11:24:45 +01:00
Kim Alvefur
9c747a1dbc mod_smacks: Flag both sessions to prevent duplicating queue on resumption
I have no idea what is going on in this code, which session is which?

Something has one of the sessions as an upvalue which is where the
filter checks for it.
2021-12-14 12:59:38 +01:00
Kim Alvefur
ccd96b3fa3 mod_smacks: Increment a counter for each resumption
Encountered what looks like a bug where after *many* resumptions, part
of the queue was not acked.
2021-12-06 11:49:22 +01:00
Kim Alvefur
3129350d42 mod_smacks: Back out 48f8fa6cea7b - back in a86ae74da96c again
Maybe it works now with the session patching in the previous commit
2021-12-13 21:48:29 +01:00
Kim Alvefur
da18622846 mod_smacks: Patch various self-references on the resumed session
The number of places where the session is an upvalue to its own methods
is too high!
2021-12-13 21:46:49 +01:00
Kim Alvefur
50b57fb062 mod_smacks: Back out a86ae74da96c: Fixed one problem, caused another
As per a86ae74da96c the 'session' object here is the wrong session, so
the attempt to block stanzas from being added to the queue twice did not
work causing something of a leak.

Instead we have a leak of the previous session.
2021-12-13 21:17:54 +01:00