aboutsummaryrefslogtreecommitdiffstats
path: root/plugins
Commit message (Collapse)AuthorAgeFilesLines
* mod_admin_shell: Visual tweaks to the output of debug:cert_index()13.0.1Matthew Wild2 days1-2/+9
|
* mod_admin_shell: Add debug:cert_index() commandMatthew Wild3 days1-0/+50
|
* mod_tls: Collect full certificate chain validation informationKim Alvefur4 days1-1/+2
| | | | | | 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.
* mod_s2s: Handle single message from chain validationKim Alvefur4 days1-9/+15
| | | | | | 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.
* mod_s2s: Deal with OpenSSL changing spelling in stringsKim Alvefur5 days1-1/+1
| | | | https://github.com/openssl/openssl/commit/ade08735f9d0ac85d611c5abee8a1df651bbca13
* mod_tls: Enable Prosody's certificate checking for incoming s2s connections ↵Matthew Wild5 days1-1/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | (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.
* mod_roster: Fix shell commands when a component is involved (fixes #1908)Kim Alvefur5 days1-1/+1
| | | | | Prevent attempt to load rosters on Components since they do not have users or rosters.
* mod_admin_shell, prosodyctl shell: Report command failure when no password ↵Matthew Wild6 days1-1/+7
| | | | entered (fixes #1907)
* doap: Add XEP-0333Kim Alvefur13 days2-2/+0
|
* doap: Add XEP-0334Kim Alvefur13 days2-2/+0
|
* mod_http_file_share: Explicitly reject all unsupported rangesKim Alvefur14 days1-0/+3
| | | | Fail fast. Otherwise it sends the whole file.
* mod_http_file_share: Fix off by one in Range responseKim Alvefur14 days1-2/+3
| | | | See #1914
* mod_storage_sql: Drop legacy index without confirmation to ease upgradesKim Alvefur14 days1-10/+6
| | | | | Deleting one index should be safe enough to do without requiring a explicitly upgrading during downtime. People had trouble with this.
* mod_storage_sql: Fix indentationKim Alvefur2025-03-191-28/+28
| | | | Off-by-one in autoindent after `if not success then` since 3ec48555b773
* mod_http_file_share: Improve error reporting by using util.error moreKim Alvefur2025-03-161-9/+30
| | | | | This should pass back the error message as well as the status code to the client.
* prosodyctl shell: More reliable detection of REPL/interactive mode (fixes #1895)Matthew Wild2025-03-131-4/+2
|
* mod_admin_shell: Remove outdated help text (fixes #1898)Matthew Wild2025-03-131-7/+2
| | | | | | | | 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!
* mod_websocket: Merge session close handling changes from mod_c2s (bug fixes)Matthew Wild2025-03-111-11/+17
| | | | | | | | | | | | | | | | | 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.
* mod_c2s: Code formatting changeMatthew Wild2025-03-111-2/+6
| | | | | | 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.
* mod_storage_internal: Use UUIDv7 for message idsMatthew Wild2025-03-101-2/+2
| | | | | | This matches what we use for SQL already, so provides some consistency. Client developers prefer sortable ids.
* mod_external_services: Also use TURN REST credential algo for 'turns' ↵Matthew Wild2025-03-011-0/+1
| | | | (thanks moreroid)
* mod_component: Don't return error reply for errors, fixes #1897Kim Alvefur2025-02-221-1/+3
|
* mod_bosh,mod_websocket: Don't load mod_http_altconnect in global contextKim Alvefur2025-02-222-2/+6
| | | | | | It blocked loading on VirtualHosts since it was already loaded globally Thanks eTaurus
* mod_invites: Hide --group flag unless mod_invites_groups is enabledMatthew Wild2025-02-171-1/+6
| | | | | | The WIP groups support is not complete yet, and won't work without extra modules (which are not yet a part of Prosody). For now we hide --group support unless mod_invites_groups (community module) is specified in modules_enabled.
* mod_invites: Fix traceback when no flags passedMatthew Wild2025-02-171-6/+6
|
* mod_invites: Deprecate 'mod_invites generate' in favour of new shell commandsMatthew Wild2025-02-171-108/+61
|
* mod_admin_shell: Improve help listing in non-REPL modeMatthew Wild2025-02-171-2/+36
|
* mod_admin_shell: Fix simple command execution (e.g. help)Matthew Wild2025-02-171-3/+15
|
* mod_admin_shell: Set flag on session when in REPL modeMatthew Wild2025-02-171-0/+4
|
* mod_admin_shell: Improved error handling for shell-invoked commandsMatthew Wild2025-02-171-5/+25
|
* mod_admin_shell, util.prosodyctl.shell: Process command-line args on ↵Matthew Wild2025-02-171-18/+95
| | | | | | | | | | | | server-side, with argparse support This allow a shell-command to provide a 'flags' field, which will automatically cause the parameters to be fed through argparse. The rationale is to make it easier for more complex commands to be invoked from the command line (`prosodyctl shell foo bar ...`). Until now they were limited to accepting a list of strings, and any complex argument processing was non-standard and awkward to implement.
* mod_invites: Fix storing --group (thanks lissine)Kim Alvefur2025-02-171-1/+1
| | | | | | | This made it ignore `--group` completely, but if you incorrectly used `--group foo` it would store `groups=true`. Introduced in 9ba11ef91ce4
* mod_bosh, mod_websocket: Add soft dependency on mod_http_altconnectMatthew Wild2025-02-162-0/+4
|
* mod_http_altconnect: Imported from prosody-modules 6d5a19bdd718 w/changesMatthew Wild2025-02-161-0/+52
| | | | | | | Changes from community version: - Add options to allow explicit control over whether BOSH/WS is advertised - Always serve XML at /host-meta (no guessing based on Accept), least surprising
* mod_http_file_share: Persist total storage usage when it increases (fixes #1891)Matthew Wild2025-02-151-0/+1
|
* core.certmanager: Move LuaSec verification tweaks to mod_s2sKim Alvefur2025-02-151-0/+8
| | | | | These two settings are only really needed for XMPP server-to-server connections.
* mod_cloud_notify, mod_cron, mod_invites: Add 'prosody.' prefix to requiresMatthew Wild2025-02-153-10/+10
|
* MUC: Use new XEP namespace for hats by defaultMatthew Wild2025-02-141-1/+1
| | | | Revert with muc_hats_compat = true in the config if necessary.
* mod_admin_shell: Remove duplicated lineMatthew Wild2025-02-131-2/+0
|
* mod_admin_shell: Rename user:setrole to user:set_rolesMatthew Wild2025-02-131-4/+4
| | | | | This is more readable and accessible, and it will only be harder to change after release.
* mod_admin_shell: Hide secondary role commands, focus on primary rolesMatthew Wild2025-02-131-7/+17
| | | | | | | | | Secondary roles are an advanced feature without any strong use cases currently. Having multiple ways to manage roles is confusing. Now the 'user:role' command will just show the primary role if that is all there is, but will list secondary roles too if there are any (which in 99.9% of cases there won't be).
* mod_admin_shell: Support for hiding certain commands from default help listingMatthew Wild2025-02-131-5/+8
| | | | Useful for e.g. deprecated commands.
* mod_account_activity: Fix error when no duration specified in shell commandMatthew Wild2025-02-131-1/+1
|
* mod_admin_shell: Fix result handling of user addrole/delrole commandsMatthew Wild2025-02-131-2/+10
|
* mod_authz_internal: Fix error messagesMatthew Wild2025-02-131-2/+2
|
* mod_authz_internal: Fix return values of secondary role management methodsMatthew Wild2025-02-131-3/+8
| | | | usermanager expects (role, err) and (ok, err)
* mod_presence: Fix traceback if origin gets disconnected during processingMatthew Wild2025-02-131-2/+10
| | | | Fixes #1887
* mod_invites: Add shell commands to list, show and delete pending invitationsMatthew Wild2025-02-131-0/+140
|
* mod_invites: Shell command to create reset linksMatthew Wild2025-02-131-0/+18
|
* mod_account_activity: Add shell command to list inactive accountsMatthew Wild2025-02-121-0/+43
| | | | Including accounts which may never have logged in.