Kim Alvefur
36512eca29
mod_c2s,mod_s2s: Fix error on shutdown (Thanks Martin)
...
Since there are two calls to done() that can happen, if the timing is
right (or wrong) both can happen, which previously triggered an error.
2022-02-22 14:17:27 +01:00
Kim Alvefur
1d20ec63e6
mod_c2s,mod_s2s: Wrap callback to improve tracebacks
...
Should make traces point here instead of timer dispatch, making
debugging easier
2022-02-22 12:35:31 +01:00
Kim Alvefur
b70a61be4c
mod_c2s: Ignore unused event payload [luacheck]
2022-02-18 23:13:01 +01:00
Kim Alvefur
a8f4892fe3
mod_c2s,mod_s2s: Wait for sessions to close before proceeding with shutdown steps
...
Ensures unavailable presence and other outgoing stanzas are sent.
Waiting for c2s sessions to close first before proceeding to disable and
close s2s ensures that unavailable presence can go out, even if it
requires dialback to complete first.
2022-02-17 03:49:47 +01:00
Kim Alvefur
13dc49d1a7
mod_c2s: Close ports in a separate, earlier event from closing sessions
...
Lets other things step in and do things while c2s ports are closed, e.g.
mod_smacks, or other modules with port handlers that forward to c2s.
2022-02-18 14:25:22 +01:00
Kim Alvefur
f56aaf1ba1
mod_c2s,mod_s2s: Disable and close port listeners before closing sessions
...
This ensures no new clients can start connecting during shutdown
2022-02-11 21:36:53 +01:00
Kim Alvefur
6c98ee025e
mod_c2s: Fire pre-closing event regardless of connected state
...
With mod_smacks, a session can outlive the connection, so whether the
event is fired should not hinge on whether the session is connected or
not.
Helps mod_smacks remove some state.
2021-12-18 13:43:57 +01:00
Kim Alvefur
d02e79c6a9
mod_c2s: Add event just before closing as session
...
To allow modules to do things just before the session is closed. The
'(pre-)resource-unbind' events are fired after the stream is closed,
leaving no way to send something.
2021-12-01 15:06:48 +01:00
Matthew Wild
1a64d5d876
mod_c2s: Disconnect user sessions on a role change event
...
The overlapping logic for deletion and password changed has been merged into
a single function.
2021-11-12 13:26:05 +00:00
Kim Alvefur
ef6cb64b9e
mod_c2s,etc: Identify stanza object with appropriate function
...
Better than duck typing, in case anyone ever passes a non-stanza table
with a 'name' field.
2021-10-24 15:17:01 +02:00
Kim Alvefur
f24aba7b19
mod_c2s: Rename Direct TLS listener 'c2s_direct_tls' for clarity
...
And to follow existing naming practices better than 'legacy_ssl' did.
2021-09-09 22:14:43 +02:00
Kim Alvefur
8bde7461c1
mod_c2s,mod_s2s: Indicate stanza size violation with condition from XEP-0205 (thanks mjk)
2021-09-06 23:21:25 +02:00
Kim Alvefur
48216c1dc8
mod_c2s,mod_s2s: Fire event just before writes
...
Could allow e.g. a XEP-0198 implementation to efficiently send ack
requests at optimal times without using timers or nextTick.
2021-08-16 12:45:14 +02:00
Kim Alvefur
814a3a3482
mod_c2s: Guard against LuaSec not returning TLS info (thanks Martin)
...
The :info() method has been observed to return nothing ... sometimes.
Unclear what causes it. Perhaps the TLS connection was shut down or
hasn't fully settled?
The LuaSec code has code paths that return nothing or nil, error, so it
is best to guard against it.
2021-06-21 13:36:05 +02:00
Kim Alvefur
0acd505f2e
mod_c2s: Log the same messages for Direct TLS as with starttls
...
^C^V
2021-06-20 18:15:59 +02:00
Kim Alvefur
807c78400f
mod_c2s: Update a comment to reflect Direct TLS
2021-06-20 18:14:18 +02:00
Kim Alvefur
db64810141
mod_c2s: Add a Direct TLS listener
...
This only differs from 'legacy_ssl' in name, at least on the server
side. For clients this is the one that uses SRV records.
2021-06-20 16:51:08 +02:00
Kim Alvefur
aa041ffa10
mod_c2s,mod_s2s: Collect stats on TLS versions and ciphers
2021-06-16 00:00:17 +02:00
Matthew Wild
5bc8b2a379
Merge 0.11->trunk
2021-05-13 11:17:13 +01:00
Jonas Schäfer
2bfa403e36
mod_c2s: Port to new OpenMetrics API
2021-04-18 12:34:17 +02:00
Kim Alvefur
21fa25b27b
mod_c2s: Fix traceback if session was destroyed while opening stream (thanks Ge0rG)
...
Could happen with the 'opportunistic_writes' setting, since then the
stream opening is written directly to the socket, which can in turn
trigger session destruction if the socket somehow got closed just after
the other sent their stream header.
Error happens later when it tries to `hosts[session.host == nil].events`
2021-04-14 16:02:47 +02:00
Kim Alvefur
7c5659808a
Merge 0.11->trunk
2021-04-10 16:45:44 +02:00
Kim Alvefur
72cb2e0362
mod_c2s: Log about missing conn on async state changes
2021-03-18 16:24:46 +01:00
Kim Alvefur
846862e1e7
mod_c2s: Improve code style
...
We don't use the quoted table indexing style that often, it's not needed
here and it's enough to check for falsyness rather than `nil`.
2021-03-18 16:23:47 +01:00
Kim Alvefur
b5f808c769
mod_c2s: Fix traceback in session close when conn is nil
...
Unclear how this happens.
2021-03-17 12:47:16 +01:00
tmolitor
2b0c472f87
mod_c2s: Don't throw errors in async code when connections are gone
...
Fixes #1507
2021-03-18 14:30:32 +01:00
Kim Alvefur
f7cfe660cd
mod_c2s: Log a debug message before closing due to c2s_timeout
...
It was confusing that the connection would just close without much
explanation.
Wanted this while investigating https://github.com/conversejs/converse.js/issues/2438
2021-03-23 21:46:11 +01:00
Kim Alvefur
2845337d4b
mod_c2s: Reflect stream 'from' attribute back if set ( fix #1625 )
...
Clients should *not* be setting this before TLS anyways.
2021-02-03 21:41:45 +01:00
Kim Alvefur
c90918837e
mod_c2s,mod_s2s: Make stanza size limits configurable
2020-05-31 22:39:34 +02:00
Matthew Wild
4c4e764e23
mod_c2s, mod_s2s, mod_component, mod_bosh, mod_websockets: Set default stanza size limits
...
c2s/bosh/ws streams will default to 256KB, s2s and components to 512KB.
These values are aligned with ejabberd's default settings, which should reduce
issues related to inconsistent size limits between servers on the XMPP network.
The previous default (10MB) is excessive for any production server, and allows
significant memory usage by even unauthenticated sessions.
2021-05-07 17:03:49 +01:00
Kim Alvefur
5abc2e6a5c
mod_c2s,mod_s2s: Make stanza size limits configurable
2020-05-31 22:39:34 +02:00
Kim Alvefur
d22e85debc
mod_c2s,mod_s2s: Use a distinct stream error for hitting stanza size limit
...
Since this is not a real parse error, it should not be reported as such.
2020-05-31 22:25:48 +02:00
Kim Alvefur
0747cbea53
mod_c2s: Run stream open and close events in async thread, fixes #1103
...
Enables async processing during stream opening and closing.
2020-05-08 23:58:24 +02:00
Kim Alvefur
a63e5be1b7
mod_c2s: Swap comments
2020-04-19 13:04:12 +02:00
Kim Alvefur
0fdb85997a
mod_net_multiplex: Add support for using ALPN
...
Potentially a bit more efficient since it can jump to the selected
protocol on connect instead of waiting for some data to look at.
Adds a 'protocol' field to net providers for this purpose.
2019-11-29 23:27:51 +01:00
Kim Alvefur
e131bbd3a4
mod_c2s: Validate that a 'to' attribute exists at all
...
Prevents traceback from nameprep(nil)
2019-11-02 15:39:40 +01:00
Kim Alvefur
b16782257d
Remove COMPAT with temporary luasec fork
...
The changes in the temporary fork were merged into mainline luasec ca
2013 and included in the 0.5 release in 2014.
2019-08-25 23:12:55 +02:00
Kim Alvefur
4512a6266d
mod_c2s: Associate connection with session last ( fixes #1313 )
...
This way, any fatal error in the callback will not leave a
half-established session.
2019-05-18 17:45:20 +02: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
0f11cd3a54
mod_c2s: Fix fallback for missing session logger
2018-10-12 02:16:24 +02:00
Matthew Wild
55969635f1
Merge 0.10->trunk
2018-05-30 22:43:45 +01:00
Matthew Wild
b294f1695c
Merge 0.9->0.10
2018-05-30 21:55:09 +01:00
Kim Alvefur
32b507c866
mod_c2s: Do not allow the stream 'to' to change across stream restarts ( fixes #1147 )
2018-05-25 21:09:34 +02:00
Kim Alvefur
c931751893
Merge 0.10->trunk
2018-05-22 22:25:59 +02:00
Kim Alvefur
0f78fff909
mod_c2s: Avoid concatenating potential nil value ( fixes #753 )
2018-05-22 22:22:57 +02:00
Kim Alvefur
12cdea49b3
mod_c2s: Iterate over child tags instead of child nodes in stream error (fixes traceback from #987 )
2017-09-13 18:18:57 +02:00
Emmanuel Gil Peyrot
bf5d8303ce
mod_c2s: Add a counter for IPv6.
2017-09-09 14:45:23 +01:00
Kim Alvefur
7896770380
Merge 0.10->trunk
2017-11-10 17:47:50 +01:00
Kim Alvefur
b395681f11
mod_c2s: Set a default value for c2s_timeout ( fixes #1036 )
2017-11-10 07:11:03 +01:00
Kim Alvefur
4c6c255113
Merge 0.10->trunk
2017-09-14 02:48:34 +02:00