Commit graph

9900 commits

Author SHA1 Message Date
Kim Alvefur
00735e4759 MUC: Fix logic for access to affiliation lists
Fixes https://prosody.im/security/advisory_20210722/

Backs out 4d7b925652d9
2021-07-22 17:18:39 +02:00
Kim Alvefur
59d820880f util.ip: Fix netmask for link-local address range
This may have mistakenly caused link-local addresses to be considered
global.  May have caused mod_s2s and prosodyctl check dns to behave
incorrectly on networks using link-local IPv4 addresses. By my
guesstimate, these are extremely rare.  Probably minimal impact beyond
a bit longer to establish s2s and some possible confusion from
prosodyctl check dns results.

Ref RFC 3927
2021-07-03 03:27:57 +02:00
Kim Alvefur
13c5a2359d prosodyctl: Add 'limits' to known globals to warn about misplacing it
It will do nothing in a VirtualHost section for example.
2021-05-27 12:35:55 +02:00
Kim Alvefur
0c6f17043f mod_pep: Remove obsolete node restoration code (now done by util.pubsub)
Originally added in 202b9951b037 but util.pubsub gained a better method
in 6c2c2fc4b8dd since then, which mod_pep uses since 9194431b6447 which
should have deleted this.

All these :create calls would have failed with a 'conflict' error, since
the nodes had already been created. This was never noticed because of
missing error handling.

Also note that this code did not restore node configuration.
2021-05-16 16:14:23 +02:00
Kim Alvefur
0e1bf3c061 util.pubsub: Fix traceback if node data not initialized
This should not be possible, but a traceback indicating node_data being
nil here was reported by Ron in the chat.
2021-05-16 16:02:00 +02:00
Matthew Wild
a95576d485 Added tag 0.11.9 for changeset d0e9ffccdef9 2021-05-12 16:42:51 +01:00
Kim Alvefur
c2ce30433a mod_dialback: Remove d-w-d feature
Backs out 1d0862814bfc and 2fdd71b08126

Largely unused, undocumented and did not have enough tests to provide
confidence in its correct operation.
2021-05-12 17:22:02 +02:00
Kim Alvefur
1cd5049c77 mod_dialback: Use correct host for certificate check (fixes #1381) 2019-06-23 16:16:26 +02:00
Matthew Wild
0a3d796623 mod_dialback: Use constant-time comparison with hmac 2021-05-12 14:00:53 +01:00
Matthew Wild
0d3dc2e522 mod_proxy65: Restrict access to local c2s connections by default
Previously no 'proxy65_acl' option would allow unrestricted access by local or
remote JIDs.
2021-05-12 13:59:49 +01:00
Matthew Wild
6f6c807bdf mod_limits: Use default limits if none configured 2021-05-11 14:22:59 +01:00
Matthew Wild
6d15e34180 prosody.cfg.lua.dist: Enable rate limits by default 2021-05-11 14:17:12 +01:00
Matthew Wild
3fd3d2cd99 prosodyctl about: Report libexpat version if known 2021-05-11 14:15:22 +01:00
Matthew Wild
f0c2ed1201 certmanager: Disable renegotiation by default
This requires LuaSec 0.7+ and OpenSSL 1.1.1+
2021-05-11 14:14:15 +01:00
Matthew Wild
08f721a072 mod_limits: Don't emit error when no burst period is configured 2021-05-11 14:10:26 +01:00
Kim Alvefur
b369dea3d8 core.certmanager: Test for SSL options in absence of LuaSec config 2021-04-26 15:32:05 +02:00
Kim Alvefur
a174420e52 core.certmanager: Attempt to directly access LuaSec config table
Due to a bug this field was not properly exported before
See https://github.com/brunoos/luasec/issues/149
2021-04-26 15:30:13 +02:00
Matthew Wild
92cec56e97 util.xmppstream: Allow dynamically configuring the stanza size limit for a stream
This may be useful for any plugins that want to experiment with different policies
for stanza size limits (e.g. unauthenticated vs authenticated streams).
2021-05-10 17:03:27 +01:00
Matthew Wild
7cb3ec61d5 util.xmppstream: Mark bytes for stream closure as handled 2021-05-10 17:02:37 +01:00
Matthew Wild
1e42cdef09 MUC: Add support for advertising muc#roomconfig_allowinvites in room disco#info
The de-facto interpretation of this (undocumented) option is to indicate to
the client whether it is allowed to invite other users to the MUC.

This is differs from the existing option in our config form, which only
controls the behaviour of sending of invites in a members-only MUC (we always
allow invites in open rooms).

Conversations is one client known to use this disco#info item to determine
whether it may send invites.
2021-05-10 17:01:38 +01:00
Matthew Wild
6a54d2d2c4 mod_auth_internal_{plain,hashed}: Use constant-time string comparison for secrets 2021-05-10 16:50:24 +01:00
Matthew Wild
d126ee88bc util.xmppstream: Reduce default xmppstream limit to 1MB 2021-05-10 16:44:55 +01:00
Matthew Wild
06161ab766 util.set: Add is_set() to test if an object is a set 2021-05-10 16:41:56 +01:00
Matthew Wild
f5460a5037 util.hashes: Add constant-time string comparison (binding to CRYPTO_memcmp) 2021-05-10 16:24:54 +01: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
Matthew Wild
4c7989e7e4 util.startup: Set more aggressive defaults for GC
Testing has demonstrated that the default GC parameters are not
sufficient to prevent runaway memory growth when running under Lua 5.2
and Lua 5.3.

Setting the GC speed to 500 was tested on Lua versions 5.1->5.4 and did
not display unbounded memory growth.
2021-05-07 16:41:39 +01:00
Matthew Wild
e9b383cdb2 prosodyctl: check config: Add 'gc' to list of global options 2021-04-30 21:20:14 +01:00
Kim Alvefur
f1550b900d mod_saslauth: Use a defined SASL error 2021-03-18 16:16:54 +01:00
Kim Alvefur
139cafdbaf mod_saslauth: Improve code style
This many returns deserve their own line.

`session["sasl_handler"]` style isn't used anywhere else.
2021-03-18 16:17:45 +01: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
a7cc31c6bb mod_saslauth: Don't throw errors in async code when connections are gone
Fixes #1515
2021-03-18 14:30:47 +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
aa9e2741d5 mod_http: Restore ip field for requests without proxies
8603011e51fe optimized out more than just the loop, leaving the .ip
field blank when the request wasn't from a proxy.
2021-02-27 20:45:45 +01:00
Kim Alvefur
e52a77ff84 mod_http: Fix trusted proxies check (thanks buildbot)
is_trusted_proxy() is only in trunk, I dun goofed when I rebased
8603011e51fe from trunk.
2021-02-18 14:34:38 +01:00
Kim Alvefur
80116bf0e3 mod_http: Skip IP resolution in non-proxied case
Skips doing the whole get_ip_from_request() dance if the request isn't
from a proxy at all, even if the client sent the header for some reason.
2021-02-18 12:00:00 +01:00
Kim Alvefur
269069faa6 Tag 0.11.8 2021-02-15 18:16:07 +01:00
Kim Alvefur
f01247ec56 mod_pep: Advertise base pubsub feature (fixes #1632)
Noticed while discussing feature discovery in Gajim
Thanks lovetox
2021-02-15 16:29:13 +01:00
Kim Alvefur
1f45b63544 util.interpolation: Fix combination of filters and fallback values #1623 2021-01-25 20:58:11 +01:00
Kim Alvefur
f36531b53a net.adns: Prevent empty packets from being sent on "connect" (fix #1619)
Thanks Ge0rG for testing
2021-01-12 13:25:08 +01:00
Kim Alvefur
5cf3eea245 net.server_epoll: Fix off-by-one in 2c559953ad41
Thanks tmolitor
2021-01-10 14:54:03 +01:00
Kim Alvefur
365e5b0cb4 util.timer: Ensure timers can't run more than once per tick (fixes #1620)
See longer explanation in 2c559953ad41
2021-01-08 23:23:56 +01:00
Kim Alvefur
861e5125c7 net.server_epoll: Ensure timers can't run more than once per tick
This makes sure that a timer that returns 0 (or less) does not prevent
runtimers() from completing, as well as making sure a timer added with
zero timeout from within a timer does not run until the next tick.

Thanks tmolitor
2021-01-08 21:57:19 +01:00
Kim Alvefur
7f7ec9e1ed util.stanza: Move misplaced argument to correct place
valid_utf8() takes only one argument, so the false was probably meant
to be valid_xml_cdata(text, attribute=false)
2020-12-24 17:57:28 +01:00
Kim Alvefur
db3c36c69d mod_s2s: Fix copypaste mistake in b3ae48362f78
Directly sending something over s2s needs to use sends2s() but the code
copied from mod_c2s had .send()
2020-12-16 08:50:20 +01:00
Matthew Wild
4bceaa2443 MUC: Fix logic bug causing unnecessary presence to be sent, fixes #1615 (thanks damencho) 2020-12-15 13:36:08 +00:00
Kim Alvefur
f4c821cc4a mod_s2s: Prevent whitespace keepalives the stream has been opened
This will result in the stream timing out instead, which is probably
correct if the stream has not been opened yet.

This was already done for c2s in e69df8093387

Thanks Ge0rG
2020-12-10 11:53:10 +01:00
Kim Alvefur
15b64ea4ff mod_saslauth: Only advertise channel binding if a finished message is available
In some cases this method returns nothing, unclear why.
2020-11-23 21:52:46 +01:00
Kim Alvefur
b62216fab3 mod_saslauth: Disable 'tls-unique' channel binding with TLS 1.3 (closes #1542)
The 'tls-unique' channel binding is undefined in TLS 1.3 according to a
single sentence in parenthesis in Apendix C of RFC 8446

This may trigger downgrade protection in clients that were expecting
channel binding to be available.
2020-11-23 21:42:52 +01:00