Commit graph

13812 commits

Author SHA1 Message Date
Matthew Wild
e19a4891fc Merge 13.0->trunk 2025-04-02 17:28:33 +01:00
Matthew Wild
3acd17a59e prosodyctl check certs: Use correct hostname in warning message about HTTPS 2025-04-02 17:27:39 +01:00
Kim Alvefur
99a70ea86e Merge 13.0->trunk 2025-04-02 17:15:29 +02:00
Matthew Wild
521b13beb5 Merge 13.0->trunk 2025-04-02 16:14:24 +01:00
Matthew Wild
c384aeca79 portmanager: Use alternate host (if any) for SNI (many thanks Zaak!)
This was an oversight in the fix for #1915 in commit 4ea7bd7325be (though it
seems commit 7e9ebdc75ce4 was the first to introduce this bug).
2025-04-02 16:13:55 +01:00
Kim Alvefur
c701571b95 net.server_epoll: Use correct connection timeout when initiating Direct TLS
Otherwise it takes a lot longer to time out Direct TLS connections than
TCP / STARTTLS connections.
2025-04-02 15:54:31 +02:00
Kim Alvefur
9877db0ede Merge 13.0->trunk 2025-04-01 21:25:31 +02:00
Kim Alvefur
1d47e2fab1 mod_tls: Collect full certificate chain validation information
Enabling at least one of the ssl.verifyext modes enables a callback that
collects all the errors, which are used by mod_s2s to report better
problem descriptions.
2025-04-01 20:49:58 +02:00
Kim Alvefur
5dbd3b15e4 mod_s2s: Handle single message from chain validation
Setting ssl.verifyext enables a callback that collects all errors from
every layer of the certificate chain. Otherwise a single string is
returned, which we did not handle before.
2025-04-01 20:42:53 +02:00
Kim Alvefur
126262edb3 Merge 13.0->trunk 2025-04-01 18:31:26 +02:00
Kim Alvefur
7976f21e3e mod_s2s: Deal with OpenSSL changing spelling in strings
ade08735f9
2025-04-01 18:15:34 +02:00
Matthew Wild
c914afdc49 mod_tls: Enable Prosody's certificate checking for incoming s2s connections (fixes #1916) (thanks Damian, Zash)
Various options in Prosody allow control over the behaviour of the certificate
verification process For example, some deployments choose to allow falling
back to traditional "dialback" authentication (XEP-0220), while others verify
via DANE, hard-coded fingerprints, or other custom plugins.

Implementing this flexibility requires us to override OpenSSL's default
certificate verification, to allow Prosody to verify the certificate itself,
apply custom policies and make decisions based on the outcome.

To enable our custom logic, we have to suppress OpenSSL's default behaviour of
aborting the connection with a TLS alert message. With LuaSec, this can be
achieved by using the verifyext "lsec_continue" flag.

We also need to use the lsec_ignore_purpose flag, because XMPP s2s uses server
certificates as "client" certificates (for mutual TLS verification in outgoing
s2s connections).

Commit 99d2100d2918 moved these settings out of the defaults and into mod_s2s,
because we only really need these changes for s2s, and they should be opt-in,
rather than automatically applied to all TLS services we offer.

That commit was incomplete, because it only added the flags for incoming
direct TLS connections. StartTLS connections are handled by mod_tls, which was
not applying the lsec_* flags. It previously worked because they were already
in the defaults.

This resulted in incoming s2s connections with "invalid" certificates being
aborted early by OpenSSL, even if settings such as `s2s_secure_auth = false`
or DANE were present in the config.

Outgoing s2s connections inherit verify "none" from the defaults, which means
OpenSSL will receive the cert but will not terminate the connection when it is
deemed invalid. This means we don't need lsec_continue there, and we also
don't need lsec_ignore_purpose (because the remote peer is a "server").

Wondering why we can't just use verify "none" for incoming s2s? It's because
in that mode, OpenSSL won't request a certificate from the peer for incoming
connections. Setting verify "peer" is how you ask OpenSSL to request a
certificate from the client, but also what triggers its built-in verification.
2025-04-01 17:26:56 +01:00
Matthew Wild
e39d14c8e8 prosodyctl: Fix spacing in warning message 2025-04-01 14:38:37 +01:00
Kim Alvefur
d4af16441d Merge 13.0->trunk 2025-03-31 21:23:35 +02:00
Kim Alvefur
f0c6467af8 mod_roster: Fix shell commands when a component is involved (fixes #1908)
Prevent attempt to load rosters on Components since they do not have
users or rosters.
2025-03-31 21:19:14 +02:00
Matthew Wild
9f728624b2 Merge 13.0->trunk 2025-03-31 17:32:11 +01:00
Matthew Wild
f0042849ba mod_admin_shell, prosodyctl shell: Report command failure when no password entered (fixes #1907) 2025-03-31 17:30:50 +01:00
Matthew Wild
ce9fa7d874 Merge 13.0->trunk 2025-03-31 16:43:06 +01:00
Matthew Wild
4f94d2425d util.adminstream: Fix traceback on double-close (fixes #1913)
In some circumstances, particularly with 'opportunistic_writes' and
'fatal_errors' enabled in the epoll backend, the connection may be closed
halfway through the session close process (because it contains debug logging,
which in the case of the watch:log() command, will trigger a write to the
socket).

The chosen fix is to cache session.conn in a local variable (we already did
this later on, but this pulls it up to the top of the function, which is
generally more correct anyway).
2025-03-31 16:25:09 +01:00
Matthew Wild
5e1352f983 Merge 13.0->trunk 2025-03-31 12:21:22 +01:00
Kim Alvefur
96aadab60b core.portmanager: Restore use of per-host 'ssl' for SNI hosts. Fixes #1915.
This was an unintentional regression, as per-host 'ssl' options became valid
in 0.12 when SNI support was added for direct TLS ports. While we encourage
most people to use the simpler automatic certificate selection (and it seems
most do, given the overlooking of this bug), there are likely always going to
be use cases for manually-configured certificates.

The issue was introduced in commit 7e9ebdc75ce4 which inadvertently removed
the per-host option checking for SNI.
2025-03-29 22:25:19 +01:00
Kim Alvefur
3d5416fa91 Merge 13.0->trunk 2025-03-23 20:19:09 +01:00
Kim Alvefur
be51e54c68 doap: Add XEP-0333 2025-03-23 19:59:45 +01:00
Kim Alvefur
780b392d25 doap: Add XEP-0334 2025-03-23 19:57:06 +01:00
Kim Alvefur
4068c28023 doap: Add XEP-0156 and mod_http_altconnect 2025-03-23 19:47:34 +01:00
Kim Alvefur
d3899c1e16 Merge 13.0->trunk 2025-03-23 17:24:49 +01:00
Kim Alvefur
faed304d55 mod_http_file_share: Explicitly reject all unsupported ranges
Fail fast. Otherwise it sends the whole file.
2025-03-23 12:36:47 +01:00
Kim Alvefur
afd99708d6 mod_http_file_share: Fix off by one in Range response
See #1914
2025-03-23 12:21:19 +01:00
Kim Alvefur
b9d4cc24df mod_storage_sql: Drop legacy index without confirmation to ease upgrades
Deleting one index should be safe enough to do without requiring a
explicitly upgrading during downtime. People had trouble with this.
2025-03-23 12:15:16 +01:00
Kim Alvefur
244220453d Merge 13.0->trunk 2025-03-22 11:56:23 +01:00
Kim Alvefur
6959547703 core.usermanager: Fix COMPAT layer for legacy is_admin() function
Thanks ctrlaltca

Fixes #1912
2025-03-22 11:53:15 +01:00
Kim Alvefur
0ed2d38edf core.storagemanager: Fix tests by removing an assert that upset luarocks
Not sure why but this assert() caused a stack overflow in luarocks
2025-03-19 16:15:52 +01:00
Kim Alvefur
eacf72504c mod_storage_sql: Fix indentation
Off-by-one in autoindent after `if not success then` since 3ec48555b773
2025-03-19 16:13:32 +01:00
Matthew Wild
8a4d96bb71 Merge 13.0->trunk 2025-03-17 16:49:22 +00:00
Matthew Wild
3d74ce8584 prosodyctl check: Be more robust against invalid disco_items, and show warning 2025-03-17 16:48:39 +00:00
Kim Alvefur
8bcd4f6807 Merge 13.0->trunk 2025-03-17 15:23:50 +01:00
Kim Alvefur
780fd208bc mod_http_file_share: Improve error reporting by using util.error more
This should pass back the error message as well as the status code to
the client.
2025-03-16 15:20:45 +01:00
Matthew Wild
614ca69407 Merge 13.0->trunk 2025-03-13 13:11:57 +00:00
Matthew Wild
6bf45cacf9 Added tag 13.0.0 for changeset a8ad0741632d 2025-03-13 13:11:22 +00:00
Matthew Wild
421afd79f4 CHANGES: 13.0.0 release date 2025-03-13 13:11:05 +00:00
Matthew Wild
287349f2eb CHANGES: Fix 13.0.0 version number 2025-03-13 13:10:22 +00:00
Matthew Wild
77fb638f4d Merge 13.0->trunk 2025-03-13 11:41:32 +00:00
Matthew Wild
57d168dd5e prosodyctl shell: More reliable detection of REPL/interactive mode (fixes #1895) 2025-03-13 11:37:11 +00:00
Matthew Wild
384e3dbea2 mod_admin_shell: Remove outdated help text (fixes #1898)
The ! commands have been broken for some time, and we're not going to
implement them right now. If we want fancier editing, we can now do that on
the client side (with readline and stuff).

Also removes mention of telnet!
2025-03-13 11:35:39 +00:00
Matthew Wild
04bd8258ef prosodyctl check features: Report size limit for HTTP upload
This also adds a generic "meta" mechanism where checks can return annotations.
2025-03-13 11:33:08 +00:00
Matthew Wild
9f50add34e prosodyctl check features: Add descriptions to features
Also shuffles mod_pep check to multi-device sync, as I think that's a better
fit.
2025-03-13 11:32:22 +00:00
Matthew Wild
74970e2815 Merge 13.0->trunk 2025-03-11 18:45:23 +00:00
Matthew Wild
8005ac825f mod_websocket: Merge session close handling changes from mod_c2s (bug fixes)
This should bring some fixes and general robustness that mod_websocket had
missed out on. The duplicated code here is not at all ideal. To prevent this
happening again, we should figure out how to have the common logic in a single
place, while still being able to do the websocket-specific parts that we need.

The main known bug that this fixes is that it's possible for a session to get
into a non-destroyable state. For example, if we try to session:close() a
hibernating session, then session.conn is nil and the function will simply
return without doing anything. In the mod_c2s code we already handle this, and
just destroy the session. But if a hibernating websocket session is never
resumed or becomes non-resumable, it will become immortal!

By merging the fix from mod_c2s, the session should now be correctly
destroyed.
2025-03-11 18:44:40 +00:00
Matthew Wild
5b4624137d mod_c2s: Code formatting change
Although we do sometimes use single-line if blocks, I'm expanding this one to
make it easier to compare with the duplicated (but modified) code in
mod_websocket that we plan to de-duplicate one day.
2025-03-11 18:37:16 +00:00
Matthew Wild
5b1d83614b CHANGES: Add list of new modules 2025-03-11 18:27:54 +00:00