Commit graph

12246 commits

Author SHA1 Message Date
Matthew Wild
d595ebf9e1 mod_storage_xep0227: Fix luacheck warning 2022-01-17 14:18:27 +00:00
Matthew Wild
2e538ffc6b mod_storage_xep0227: Fix traceback during iteration of driver stores
:include(other_set), :add(item)
2022-01-17 14:12:45 +00:00
Matthew Wild
ee1f7077e3 mod_storage_xep0227: Fix file export (missing parameter) from refactor in 270047afa6af 2022-01-17 14:11:45 +00:00
Kim Alvefur
a798505a97 mod_http: Increase severity of loading unreachable http modules
This is either caused by an earlier failure to bind http/s ports, in
which case that should be corrected, or explicitly disbling the http/s
ports, in which case ... why enable http modules?

Suggested by jonas’
2022-01-15 17:37:07 +01:00
Matthew Wild
695fb9b8fb Added tag 0.11.12 for changeset 783056b4e448 2022-01-13 12:18:49 +00:00
Jonas Schäfer
23a43df6fb util.xml: Do not allow doctypes, comments or processing instructions
Yes. This is as bad as it sounds. CVE pending.

In Prosody itself, this only affects mod_websocket, which uses util.xml
to parse the <open/> frame, thus allowing unauthenticated remote DoS
using Billion Laughs. However, third-party modules using util.xml may
also be affected by this.

This commit installs handlers which disallow the use of doctype
declarations and processing instructions without any escape hatch. It,
by default, also introduces such a handler for comments, however, there
is a way to enable comments nontheless.

This is because util.xml is used to parse human-facing data, where
comments are generally a desirable feature, and also because comments
are generally harmless.
2022-01-10 18:23:54 +01:00
Kim Alvefur
e812ce9b4a Tag 0.11.11 2021-12-20 16:24:52 +01:00
Kim Alvefur
77630b72ff mod_http: Skip querying portmanager when http_external_url when is set
When http_external_url is set then the portmanager usage only really
serves as a check of whether any http service is enabled at all.

Should allow generating an URL from prosodyctl when http_external_url is
set.
2021-11-27 12:26:15 +01:00
Kim Alvefur
cced954ac3 util.jid: Explicitly check for nil rather than falsy
A boolean false should blow up.
2022-01-15 16:25:25 +01:00
Jonas Schäfer
91055b49bb mod_storage_xep0227: treat roster metadata pseudo-entry correctly
The roster version is stored in a pseudo-item which has the key `false`.
The if condition in the touched code attempts to guard against this, but
it does not take into account that the jid prepping returns nil instead
of false.

By moving the jid prepping into the if, we can check for the metadata
entry safely.
2022-01-15 15:40:29 +01:00
Jonas Schäfer
bb100ed33e mod_storage_xep0227: be defensive against empty vCard
An empty vCard store may look like the empty table, which does not have
the `attr` key, which would then blow up in util.stanza.deserialize.
2022-01-15 15:39:13 +01:00
Kim Alvefur
b187489802 mod_http: Limit unencrypted http port (5280) to loopback by default
Since accessing this port directly over the wider Internet is unlikely
to intentional anymore.  Most uses will likely be by reverse proxies, by
mistake or because of trouble configuring HTTPS.

Blocking mistaken uses is just a good thing, letting users send
potentially private things unencrypted tends to be Strongly Discouraged
these days.

Many reverse proxy setups operate over loopback, so listening there
instead of all interfaces is a net improvement.

Improved automatic certificate location and SNI support has mostly
eliminated the need for manual certificate configuration so HTTPS should
Just Work once certificates have been provided.

For local testing during development, connecting over loopback is likely
fine as well. When really needed, `http_interfaces` can still be set.

Suggested by Link Mauve
2022-01-15 15:13:41 +01:00
Kim Alvefur
e0e180aa9d mod_cron: Allow for a small amount of timer drift
If the timer activates a bit early then a task might be just a few
seconds short of being allowed to run. This would run such a task rather
than wait another hour.

The value 0.5% chosen so that a weekly task does not run an entire hour
earlier than last time.
2022-01-15 09:09:24 +01:00
Matthew Wild
9767804146 mod_storage_xep0227: Fix luacheck warnings 2022-01-14 17:00:13 +00:00
Matthew Wild
843e4ad49d mod_storage_xep0227: Add API to iterate all stores of a user 2022-01-14 16:57:19 +00:00
Matthew Wild
2d0db1b0a3 mod_storage_xep0227: Skip self-contacts on roster import 2022-01-14 16:55:18 +00:00
Jonas Schäfer
e0b15fcba3 util.xml: Do not allow doctypes, comments or processing instructions
Yes. This is as bad as it sounds. CVE pending.

In Prosody itself, this only affects mod_websocket, which uses util.xml
to parse the <open/> frame, thus allowing unauthenticated remote DoS
using Billion Laughs. However, third-party modules using util.xml may
also be affected by this.

This commit installs handlers which disallow the use of doctype
declarations and processing instructions without any escape hatch. It,
by default, also introduces such a handler for comments, however, there
is a way to enable comments nontheless.

This is because util.xml is used to parse human-facing data, where
comments are generally a desirable feature, and also because comments
are generally harmless.
2022-01-10 18:23:54 +01:00
Kim Alvefur
ec9ec1b9a0 mod_http_file_share: Always measure total disk usage for statistics!
Metrics available or not depending on configuration is weird, even tho
it might be expensive to calculate and it's only really needed when
there is a global quota.

Default quota is set to infinity, which is essentially what it was.

Reports NaN if there is an error, which should count as over the
infinite default quota.
2022-01-11 04:15:29 +01:00
Kim Alvefur
2a0311098c mod_bookmarks: Fix traceback on attempt to convert invalid bookmark
Found by accidentally publishing {urn:xmpp:bookmarks:0}conference
instead of :1 due to testing this earlier for the blocking.

By the principle of garbage in, garbage out, just generate a bookmark
from the item id / JID and carry on with a warning.
2022-01-11 00:06:48 +01:00
Kim Alvefur
ba50691289 mod_bookmarks: Block publishing to older XEP-0402 v0.3.0 node
Having both the :0 and :1 nodes would be especially awkward, since there
is no upgrade path for this case. In theory, these should be rare since
no clients should have been doing XEP-0402 unless mod_bookmarks(2) was
enabled. This was guesstimated to be rare with most clients doing
XEP-0048 with Private XML.
2022-01-10 22:15:55 +01:00
Kim Alvefur
bdd8dddff5 mod_storage_xep0227: Fix writing non-user data
Attempt to concatenate nil 'user'

Not much data actually makes sense but the migrator tries to write or
clear these.
2022-01-10 16:53:58 +01:00
Matthew Wild
e65e3cad0f mod_storage_xep0227: Ignore luacheck warning 2022-01-10 15:50:55 +00:00
Matthew Wild
68636e702c mod_storage_xep0227: Support for exporting nodes with no stored configuration 2022-01-10 15:48:45 +00:00
Matthew Wild
65dff38bbb mod_storage_xep0227: Allow overriding the input/output layer for XEP-0227 data
This can (and will) be used to support in-memory import/export functions.
2022-01-10 15:47:59 +00:00
Kim Alvefur
125249a322 mod_bookmarks: Skip migration of legacy data when empty
Should save some cycles and not log the debug message on every login.
2022-01-10 00:13:17 +01:00
Kim Alvefur
939e49685c mod_bookmarks: Make sure legacy bookmarks node exists to hold access model 2022-01-10 00:11:36 +01:00
Kim Alvefur
8a53094a7d mod_bookmarks: Broadcast notifications per XEP-0048 and XEP-0411
For compatibility with clients relying on the notifications
2022-01-09 18:42:22 +01:00
Kim Alvefur
d8c9ea741b util.prosodyctl.cert: Fix boolean logic bug
Boolean logic, never correct on the first try.

We want to skip copying the same cert if it _has_ been imported already,
not if it has not.
2022-01-09 21:47:04 +01:00
Kim Alvefur
3854d0c090 migrator: Support pubsub and pep as a special-case
This sorta overloads the type suffix but PEP is used for enough stuff
to justify this hack
2022-01-09 18:52:58 +01:00
Kim Alvefur
f04a5512a7 migrator: Enhance logging 2022-01-09 16:35:43 +01:00
Kim Alvefur
b21bc2b374 migrator: Add option to keep going despite errors 2022-01-09 16:08:15 +01:00
Kim Alvefur
07c3f35ab8 migrator: Also migrate host/non-user archive data
Needed for things like mod_http_file_share
2022-01-09 15:52:50 +01:00
Kim Alvefur
e9b2be9e44 migrator: Refactor out individual item migrator for code deduplication 2022-01-09 15:50:21 +01:00
Kim Alvefur
25a9fd3fdd migrator: Include --options in usage info 2022-01-09 16:15:21 +01:00
Kim Alvefur
bf60d226b8 migrator: Reuse earlier usage text 2022-01-09 15:57:59 +01:00
Kim Alvefur
6852806c10 migrator: Customise cli argument parsing (--help, --verbose)
Previously -v etc would do nothing and --config without argument would
not have worked correctly.
2022-01-09 15:19:55 +01:00
Kim Alvefur
552af220f4 util.startup: Allow supplying an argument parsing settings
The 'prosody' global is not global this early so there was no way to
override the process type field or argument parsing settings from
outside, e.g. from the migrator.
2022-01-09 15:16:09 +01:00
Kim Alvefur
2cb9d62b2b util.prosodyctl.check: Parameterize replacement instructions
This ought to make it easier to translate in the future.
And easier to reword, now!
2022-01-08 18:02:32 +01:00
Kim Alvefur
540364a054 util.prosodyctl.check: Move word to ease future translations
Recent experience with translations in the context of Snikket
highlighted that sentences spread across concatenated strings like this
makes the experience less than pleasant for translators.

We don't have translation yet, but it is a future goal and why not?

The duplication can be solved with a parameterized function for the
common cases.
2022-01-08 17:01:10 +01:00
Kim Alvefur
a0dbd1fc24 util.prosodyctl.check: Use same wording about 'daemonize' and 'no_daemonize'
Why would they use different wording?
2022-01-08 22:55:49 +01:00
Kim Alvefur
475ab4aed2 mod_bookmarks: Add option for disabling upgrade of legacy bookmarks
Might be nice to reduce amount of things happening on connect once
all users has upgraded
2022-01-08 00:32:33 +01:00
Kim Alvefur
1fa49be063 mod_bookmarks: Unhook PEP service objects on removal from cache
See 1dc00ca6ee9d
2022-01-08 00:30:26 +01:00
Kim Alvefur
d3bd9f9be5 util.pposix: Use mallinfo2() on glibc 2.33, fix #1649 2022-01-06 18:56:06 +01:00
Kim Alvefur
8a97d634a4 util.pubsub: Fix item store resize to "max"
Previously this would end up passing the "max" directly to the
underlying storage.
2022-01-06 01:18:35 +01:00
Emmanuel Gil Peyrot
b5b67241e0 mod_bookmarks: Override the node configuration if it was wrong 2022-01-06 00:59:40 +01:00
Kim Alvefur
f1dd97cb9c mod_invites: Comment on module loading for HTTP invite URLs 2022-01-05 22:37:42 +01:00
Kim Alvefur
ca08584d74 mod_pep: Wipe pubsub service on user deletion
Data is already wiped from storage, but this ensures everything is
properly unsubscribed, possibly with notifications etc.

Clears recipient cache as well, since it is no longer relevant.
2021-11-04 01:00:06 +01:00
Kim Alvefur
db0e630ad7 mod_pep: Prevent creation of services for non-existent users
Using a dedicated service should give identical behavior, except for a
possible timing difference in the user existence lookup.
2021-11-04 00:55:59 +01:00
Kim Alvefur
4a89e829d4 mod_pep: Limit possible growth of node subscription info 2021-11-04 00:36:41 +01:00
Kim Alvefur
cc03265206 mod_pep: Limit possible growth of number of pubsub services 2021-11-04 00:35:44 +01:00