Commit graph

12246 commits

Author SHA1 Message Date
Kim Alvefur
bc15d6424f man/prosodyctl: Complete list of 'check' variants
Especially 'connectivity' was missing
2022-02-02 18:28:28 +01:00
Kim Alvefur
3627a37091 man/prosodyctl: Clarify description of --root 2022-02-02 18:25:42 +01:00
Kim Alvefur
f30bbd6dcf util.startup: Teach prosodyctl to be completely --silent 2021-11-28 23:07:51 +01:00
Kim Alvefur
14f31180b5 util.startup: Teach prosodyctl to be --quiet as complement to --verbose
Original motivation was tiresome warnings about Lua 5.4 not being
supported yet.

Can still be handy to tweak log level, e.g. to prevent logging to
interfere with command output.
2021-11-28 23:07:35 +01:00
Kim Alvefur
7f2e4b6313 man/prosodyctl: Normalize formatting syntax
Filtered trough pandoc
2022-02-02 18:30:54 +01:00
Kim Alvefur
da53d0fc75 util.dns: Minor updates of SVCB parser
Now based on draft-ietf-dnsop-svcb-https-08
2022-02-02 17:58:48 +01:00
Kim Alvefur
b657d2ab26 util.dns: Implement SVCB record parser
Based on draft-ietf-dnsop-svcb-https-00
2020-10-04 21:29:44 +02:00
Kim Alvefur
29238183e9 util.dns: Fix returning read position after zero-length name
Doesn't affect normal usage by Prosody since neither A nor AAAA records
use this and SRV records has the host name last so the position is not
needed.
2020-10-04 21:27:20 +02:00
Kim Alvefur
c0be07a6b6 util.dnsregistry: Regenerate from IANA registry
Note the duplicate 9 and 16 entries, neither of which are especially
relevant for our resolver usage.
2022-02-02 17:31:39 +01:00
Kim Alvefur
8b68fc3c6c tools.dnsregistry: For converting IANA DNS registry data to Lua table 2020-10-04 19:26:53 +02:00
Kim Alvefur
d98c136bb9 util.dns: Move DNS parameters details into util.dnsregistry
Goal is to regenerate this file from the IANA registry using a tool.
Having it in a separate file will reduce vcs noise in util.dns
2020-10-04 19:23:16 +02:00
Kim Alvefur
e5b994e70c doap: Make note of mod_mam storing XEP-0184 receipts 2021-03-18 00:03:16 +01:00
Kim Alvefur
168197a05f plugins: Update for namespace bump in XEP-0353 v0.4.0 2022-01-11 17:51:26 +01:00
Kim Alvefur
4973762abb util.prosodyctl.check: Fix reset of libunbound before DNS checks
Probably worked anyway but settings might not always have been applied
depending on what order things happens in.

Error was hidden by the pcall, which was sorta intentional...
2022-02-01 14:46:42 +01:00
Kim Alvefur
b5a932e77f doap: Let's say XEP-0368 support is complete now
We break the SHOULD about the merged _xmpp and _xmpps SRV handling, but
we follow all the MUSTs
2022-01-31 17:07:12 +01:00
Kim Alvefur
26e4b84130 util.prosodyctl.check: Fix A/AAAA check for proxy65 and http
When there are no records to return the return value from dns.lookup()
might be nil or might be a table containing zero records, depending on
which DNS library is used
2022-01-30 16:04:22 +01:00
Kim Alvefur
8ebfaefcbb util.prosodyctl.check: Include multiplexed ports in DNS checks #1704 2022-01-30 13:16:30 +01:00
Kim Alvefur
8fbf286e64 mod_admin_shell: Add descriptions of each column to 'help columns'
Since some of the titles are quite dense
2022-01-30 12:49:43 +01:00
Kim Alvefur
b5a87898ee mod_admin_shell: Use exact match instead of Lua patterns in c2s,s2s:show
It is unexpected that 'example.com' matches 'exampleicom.org' and this
use of Lua patterns is undocumented and unlikely to be widely known or
used.
2022-01-30 11:10:51 +01:00
Kim Alvefur
ca19260145 mod_http_file_share: Use alternate syntax for filename in Content-Disposition
The Lua string.format %q doesn't behave correctly for all characters
that should be escaped in a quoted-string. And who knows what effects
higher Unicode might have here.

Applying percent-encoding of filenames seems like the safest way to deal
with filenames, as well as being easier than implementing the actual
quoted-string transform, which seems complicated and I'm not even sure
it covers every possible character.

Filenames can safely be assumed to be UTF-8 since they are passed in an
attribute in the query without any escaping.
2022-01-29 16:11:38 +01:00
Kim Alvefur
46ad556ca0 mod_admin_shell: Fix traceback on rendering graph of stats without extra labels
Stops an error when extra_labels is nil since it attempts to index it

Unsure about correctness
2022-01-29 15:01:38 +01:00
Kim Alvefur
d9f7b26328 mod_admin_shell: Add help section about stats 2022-01-29 14:58:37 +01:00
Kim Alvefur
09d7e131d0 mod_admin_shell: Add help section about customizing table columns 2022-01-28 20:39:13 +01:00
Kim Alvefur
c4e87ac9fb README: Reflow text to ~78 columns
It's what `gwl` in my vim did. Must be optimal then.
2022-01-28 14:19:05 +01:00
Kim Alvefur
f5d2ee89b1 INSTALL: Update from site version 2022-01-28 11:57:58 +01:00
Kim Alvefur
dccab4e10f util.format: Expand explanation of purpose in comments 2022-01-27 21:40:13 +01:00
Kim Alvefur
c551d3d8dd util.format: Skip control code escaping when doing full serialization
Fixes that a multi-line string ended up "like\
\9this" instead of "like\nthis" as can be demonstrated by somehow
initiating a connection to a HTTP server.
2022-01-27 21:14:22 +01:00
Kim Alvefur
d607d2898f util.prosodyctl.cert: Look for certs matching 'http_host'
This should ensure any certificate needed for HTTP services will also be
included in the certificate import.
2022-01-27 16:23:26 +01:00
Kim Alvefur
cde551332e util.prosodyctl.check: Fix use of LuaSocket URL parser 2022-01-27 12:52:01 +01:00
Kim Alvefur
0448e82513 util.prosodyctl.check: Add HTTP related DNS checks
Since XEP-0363 is essentially mandatory now this will hopefully help
diagnose some common issues.
2022-01-27 12:36:50 +01:00
Kim Alvefur
04910e15b6 util.prosodyctl.cert: Look for certificates in a consistent order
Shortest first, then alphabetically, so that it prefers the base domain
over subdomains.

Fixes that it might otherwise pick a random sub-domain for filename on
each run, cluttering the certs directory and potentially tricking
Prosody into using an older certificate that might be about to expire.
2022-01-26 13:24:23 +01:00
Kim Alvefur
b0e565598a mod_pubsub: Allow configuring summary templates
Enables generation of summaries for more than Atom without additional
modules.
2022-01-24 23:06:45 +01:00
Kim Alvefur
c8ea4743f2 mod_pubsub: Use the util.xtemplate to render Atom summary 2022-01-24 23:04:38 +01:00
Kim Alvefur
7e65b1deef util.xtemplate: Yet another string template library
This one takes a stanza as input

Roughly based on util.interpolation
2022-01-24 23:54:32 +01:00
Kim Alvefur
55da054c9b mod_pubsub: Use the 'pubsub#type' setting to pick summary generator
Allows using different ones even if multiple semantically different
formats share the same root element xmlns, e.g. generic Atom and
XEP-0277 entries.
2022-01-24 23:05:26 +01:00
Kim Alvefur
c0be43a098 mod_tls: Set ALPN on outgoing connections
Relevant and sometimes needed for Direct TLS which mod_s2s uses this
context for. Primarily when e.g. mod_net_multiplex or equivalent ALPN
based dispatch is used.

All these contexts should likely move away from mod_tls and into either
mod_s2s or portmanager. The later already duplicates some of this work.
2022-01-25 13:20:26 +01:00
Kim Alvefur
7a706aecec mod_admin_shell: Add command to show current user roles 2022-01-23 20:06:50 +01:00
Kim Alvefur
1809c0460f mod_admin_shell: Add help section about roles
As in the argument to user:create() and user:roles()

Tricky to come up with something sensible to write when Prosody core
only knows of the 'prosody:admin' role so far.
2022-01-23 19:55:32 +01:00
Kim Alvefur
90215f635b mod_s2s: Retrieve TLS context for outgoing Direct TLS connections from mod_tls
So that the same TLS context is used for both Direct TLS and starttls,
since they are supposed to be functionally identical apart from the few
extra round trips.

A new event is added because the 's2s-created' event fires much later,
after a connection has already been established, where we need the TLS
context before that.
2022-01-21 18:42:38 +01:00
Kim Alvefur
268dfa38c0 mod_s2s: Enable outgoing Direct TLS connections
Makes it faster by cutting out the roundtrips involved in <starttls/>,
at the cost of making an additional SRV lookup.

Since we already ignore a missing <starttls/> offer and try anyway there
is not much difference in security. The fact that XMPP is used and the
hostnames involved might still be visible until the future Encrypted
ClientHello extension allows hiding those too.
2022-01-21 17:59:19 +01:00
Kim Alvefur
9f1af0be2e net.connect: Allow passing TLS context from resolver
Only allowing it to be passed directly makes it hard to combine plain
(i.e. starttls) and Direct TLS connections in the same connection
resolution procedure. But now we can, using chained resolvers!
2022-01-21 17:57:47 +01:00
Kim Alvefur
f31762a075 net.resolvers.chain: A resolver for combining other resolvers
Say if you wanted to try both _xmpp and _xmpps services
2022-01-21 17:56:20 +01:00
Kim Alvefur
991e6531ab Merge 0.11->trunk 2022-01-20 13:02:24 +01:00
Kim Alvefur
785d327308 util.xml: Deduplicate handlers for restricted XML
Makes the code more like util.xmppstream, allowing easier comparisons if
we ever need to apply fixes in the future.
2022-01-20 10:51:46 +01:00
Kim Alvefur
d17619344d util.xml: Break reference to help the GC (fix #1711)
LuaExpat uses a registry reference to track handlers, which makes
it so that an upvalue like this creates a reference loop that keeps the
parser and its handlers from being garbage collected. The same issue has
affected util.xmppstream in the past.

Code for checking:

	local xml_parse = require"util.xml".parse;
	for i = 1, 10000 do xml_parse("<root/>") end
	collectgarbage(); collectgarbage();
	print(collectgarbage("count"), "KiB");

A future release of LuaExpat may fix the underlying issue there.
2022-01-20 09:57:20 +01:00
Kim Alvefur
41e0ddd791 util.prosodyctl.cert: Check success of copy operations, warn on fail
Debugging a case where certs are not imported correctly but prosodyctl
still reports success. Hoping this will shed some light on it.
2022-01-19 10:28:09 +01:00
Kim Alvefur
2a1f14fc26 util.prosodyctl.cert: Pass variables via formatting instead of concatenation
Prevents potential weirdness in case there's any %s or such in a host,
file or directory name, since show_warning() is printf().
2022-01-19 10:26:43 +01:00
Kim Alvefur
456d91e7d7 tools/xep227toprosody: Remove obsolete tool in favor of storage driver
This tool hasn't been updated for recent XEP-0227 changes, hasn't seen
many changes at all since its introduction and I don't remember anyone
mentioning ever using it.

Using mod_storage_xmlarchive and the migrator or the 3rd party
mod_migrate tool should work better these days and should be the way
forward.
2022-01-18 15:43:17 +01:00
Kim Alvefur
73c3ab7888 core.certmanager: Use 'tls_profile' instead of 'tls_preset' to match documentation
Confusion!

Thanks Martin
2022-01-18 11:52:35 +01:00
Kim Alvefur
8edd063114 core.certmanager: Apply TLS preset before global settings (thanks Menel)
Allows overriding settings via the global 'ssl' settings as before.
This order was probably accidental. That said, 'ssl' is a giant footgun
we will want to discourage use of.
2022-01-18 08:04:16 +01:00