Commit graph

5241 commits

Author SHA1 Message Date
Kim Alvefur
85ff75c53f mod_s2s_auth_certs: Validate certificates against secure SRV targets
Secure delegation or "Mini-DANE"

As with the existing DANE support, only usable in one direction, client
certificate authentication will fail if this is relied on.
2022-12-22 00:13:37 +01:00
Kim Alvefur
62f32cd01d Revert unintentionally committed parts of 12bd40b8e105 2022-12-21 21:34:07 +01:00
Kim Alvefur
e3d771baf9 mod_s2s: Retrieve stanza size limit from peer for bidi connections
Having mod_s2s know about the bidi namespace is perhaps a bit awkward
but putting this in mod_s2s_bidi would be more awkward as it has nothing
to do with limits.  Some indirection event could be added in the future.
2022-11-09 19:10:16 +01:00
Kim Alvefur
96fb9a4a32 mod_s2s: Advertise stream features on bidi connections 2022-10-20 14:22:36 +02:00
Kim Alvefur
728ee0b92a mod_s2s_bidi: Add provisions for advertising features to bidi peers
As introduced in XEP-xxxx: Stream Limits Advertisement
2022-10-20 14:12:56 +02:00
Kim Alvefur
a46ae8cb89 mod_c2s,mod_s2s: Adapt to XEP-xxxx: Stream Limits Advertisement
Thanks MattJ
2022-10-20 14:04:56 +02:00
Kim Alvefur
d4f4f76c3c mod_s2s: Avoid sending too large stanzas
Just dropping them isn't great but hopefully something more sensible can
be done in the future.

Will need work to ensure that this signal is handled correctly in
sending modules etc.
2021-03-16 18:30:54 +01:00
Kim Alvefur
6d0298961d mod_s2s: Record stanza size limit advertised by other servers
For future use, i.e. canceling sending of stanzas that exceed the limit
2021-03-16 18:30:34 +01:00
Kim Alvefur
f6c3c1dd95 mod_s2s: Advertise stanza size limit to other servers
So they can, like, not send big stanzas.
2021-03-16 18:25:05 +01:00
Kim Alvefur
b8c31f2d5c mod_c2s: Advertise stanza size limit to clients
Should help clients avoid sending stanzas that will get their stream
killed.  Custom namespace while ironing out the protocol.

My spoon is too big!
2021-03-16 18:17:05 +01:00
Kim Alvefur
8bb22ccfed mod_smacks: Factor out resumption token table key generation
So that happens in a single place, where it can be changed easier.
2022-11-13 19:44:53 +01:00
Kim Alvefur
080d7974bf Merge 0.12->trunk 2022-12-12 07:10:54 +01:00
Kim Alvefur
c916ce76ee mod_smacks: Only track resumable sessions
Required due to track_session() having moved here
2022-11-18 16:18:47 +01:00
Kim Alvefur
d158455de6 mod_smacks: Disable resumption behavior on s2s
Since resumption is not supported on s2s currently, there is no point in
allocating resumption tokens.  The code that removes entries from
session_registry is only invoked for c2s sessions, thus enabling
resumable smacks on s2s adds an entry that never goes away.
2022-11-13 18:16:59 +01:00
Matthew Wild
e817ec013c Merge 0.12->trunk 2022-10-31 14:32:26 +00:00
Matthew Wild
246d797f81 mod_http: Allow disabling CORS in the http_cors_override option and by default
Fixes #1779.

Due to an oversight in the logic, if the user set 'enabled' to false in an
override, it would disable the item's requested CORS settings, but still apply
Prosody's default CORS policy.

This change ensures that 'enabled = false' will now disable CORS entirely for
the requested item.

Due to the new structure of the code, it was necessary to have a flag to say
whether CORS is to be applied at all. Rather than hard-coding 'true' here, I
chose to add a new option: 'http_default_cors_enabled'. This is a boolean that
allows the operator to disable Prosody's default CORS policy entirely (the one
that is used when a module or config does not override it). This makes it
easier to disable CORS and then selectively enable it only on services you
want it on.
2022-10-31 14:32:02 +00:00
Kim Alvefur
bd0e903b07 Merge 0.12->trunk 2022-10-24 15:25:12 +02:00
Kim Alvefur
20532df525 mod_admin_shell: Ensure available connection for column 'secure'
Similar to #1777
2022-10-23 16:22:12 +02:00
Kim Alvefur
c51152432a mod_admin_shell: Ensure connection exists to get port from (fixes #1777) 2022-10-23 16:19:39 +02:00
Kim Alvefur
2269035c0d mod_blocklist: Add option 'migrate_legacy_blocking' to disable migration from mod_privacy
Tiny performance improvement for new users by skipping this check. Most
servers should have gone trough the migration for all active users long
ago.

As a suitable first step of phasing out this code, we make it possible
to disable it first. Later it can be disabled by default, before finally
the code is deleted.
2022-10-17 15:20:06 +02:00
Matthew Wild
fdf61a38cf mod_c2s: Include stream attributes in stream-features event
We need this to access 'from' in SASL2/FAST.
2022-10-14 11:21:16 +01:00
Matthew Wild
32c38bc249 mod_tokenauth: Allow attaching an arbitrary data table to a token 2022-10-13 22:46:19 +01:00
Matthew Wild
01e03f4837 mod_smacks: Change boolean attribute from '1' to 'true' for compatibility
Conversations 2.10.10 and earlier expect this to be literally 'true' and don't
recognise '1'. This leads to it not attempting resumption with Prosody at all
since this change was introduced in 36ba170c4fd0.

Thanks to Zash for noticing, debugging and diagnosing this issue.

This issue is fixed in Conversations commit 052c58f3 (unreleased at the time
of writing).
2022-10-07 11:35:56 +01:00
Matthew Wild
12fc0febf1 mod_tokenauth: Remove expired tokens from storage 2022-10-06 16:00:39 +01:00
Matthew Wild
36afd999b1 mod_tokenauth: Invalidate tokens issued before most recent password change
This is a security improvement, to ensure that sessions authenticated using a
token (note: not currently possible in stock Prosody) are invalidated just
like password-authenticated sessions are.
2022-10-06 15:59:07 +01:00
Kim Alvefur
988e651630 mod_authz_internal: Fix warning due to global use
Thanks Menel and Martin
2022-10-04 12:04:43 +02:00
Jonas Schäfer
865b6da69d Backed out changeset 1bc2220cd6ec
The use of the error helpers creates an `<error/>` child element
containing the error condition. This is however not allowed as per
XEP-0198, which specifies that the error condition is to be a direct
child of the `<failed/>` stream management element.

This has triggered a fun reconnect loop in aioxmpp where it was
reported by a user [1].

   [1]: https://github.com/horazont/aioxmpp/issues/382
2022-10-03 12:55:11 +02:00
Matthew Wild
5ed7f1638c mod_authz_internal: Allow specifying default role for public (remote) users 2022-09-29 12:46:02 +01:00
Matthew Wild
53ccf68cdf Backed out changeset 73a45ba6e3f1 in favour of 427dd01f0864
New behaviour (muc_room_allow_persistent = true, the default):

- Parent host users are not restricted by default (prosody:user)
- Users without roles (by default that is non-admins, non-parent-host users,
  and users on other servers) can no longer configure persistence by default.

muc_room_allow_persistent = false will restrict persistence to prosody:admin.

Parent-host users should not be restricted by default, and this can be
configured via the new roles/permissions options.
2022-09-29 12:43:09 +01:00
Matthew Wild
856a482013 mod_muc: Better map restrict_room_creation to role permissions (behaviour change)
With this change and 427dd01f0864, room creation is now effectively restricted
to parent-host users by default. This is a better default than previous
Prosody versions (where room creation was not restricted).

The "local" option for restrict_room_creation is no longer used (any value
other than true/false won't change the default behaviour).

restrict_room_creation = true will grant prosody:admin the ability to create
rooms.

restrict_room_creation = false disables all permission checks.

Anything between these two can be achieved using custom roles and permissions.
2022-09-29 12:30:52 +01:00
Matthew Wild
9b8c2cd1c9 mod_authz_internal: Allow configuring role of local-server/parent-host users
'host_user_role' is the default role of users who have JIDs on the "parent"
host (i.e. jabber.org users on conference.jabber.org). Defaults to
'prosody:user'.

'server_user_roles' is the default role of users who have JIDs on any active
host on the current Prosody instance. Default to nil (no role).

This finally allows better permissions splitting between host and server
users, which has previously been done (e.g. in MUC) with options like
'restrict_room_creation' and 'muc_room_allow_persistent'. Using roles makes
these permissions a lot more flexible, and easier for developers to integrate.
2022-09-29 12:10:14 +01:00
Matthew Wild
4dc941fa53 muc: Re-allow non-admins to configure persistence (thanks Meaz)
Non-admins don't have a role on MUC services by default. Not even
prosody:user. This meant they had no :create-persistent-room permission, even
if muc_room_allow_persistent was true (the default).

Now we only check the role permissions if persistent room creation is
restricted, otherwise we skip any permission checks, just like previous
versions.
2022-09-28 17:47:00 +01:00
Kim Alvefur
8b82dc338c mod_admin_shell: Fix display of session without role (thanks Link Mauve)
This can happen to sessions before they are assigned a role
2022-09-23 11:58:15 +02:00
Matthew Wild
afa583dfcd mod_saslauth: Put <sasl-channel-binding> in stream:features per XEP-0440 0.4.0 2022-09-21 15:00:06 +01:00
Kim Alvefur
1dd9e547ce mod_storage_sql: Strip timestamp precision in queries to fix error (thanks muppeth)
Fixes
Error in SQL transaction: Error executing statement parameters: ERROR:  invalid input syntax for integer

This was handled for INSERT in 9524bb7f3944 but not SELECT.
2022-09-07 12:27:12 +02:00
Matthew Wild
fd637bf6be mod_http_file_share: Use correct variable name (thanks riau.sni) 2022-09-04 10:01:57 +01:00
Matthew Wild
af0f1947cf mod_saslauth: Fix incorrect variable name introduced in 27a4a7e64831 2022-09-03 21:25:51 +01:00
Matthew Wild
5f2c086da7 mod_smacks: Set session flag during successful enable 2022-09-03 21:20:29 +01:00
Matthew Wild
a061b11f32 mod_smacks: Add type field to results so actions can be later distinguished 2022-09-03 21:20:07 +01:00
Matthew Wild
5eef82fdcf mod_saslauth: Only announce bind feature if no resource yet bound
It's now possible to bind during SASL2 negotiation.
2022-09-03 21:19:00 +01:00
Kim Alvefur
e38e915ef5 mod_s2s: Fix firing buffer drain events
Fixes the same kind of issue as in 65563530375b but once and for all,
while improving similarity between incoming and outgoing connections.
2022-08-26 18:53:00 +02:00
Kim Alvefur
ee21d9480a mod_admin_shell: Switch names for user role management commands
user:roles() does not convey that this is the mutating command, it
should have been called setroles from the start but wasn't due to lack
of foresight. This has to accidentally removing roles when wanting to
show them.
2022-08-15 18:56:22 +02:00
Kim Alvefur
2dbbce2382 mod_storage_sql: Fix summary API with Postgres (fixes #1766)
The ORDER BY and LIMIT clauses are not needed and don't even make much
sense. This part was most likely a leftover from the :find method.

Tested with sqlite and postgres 14
2022-07-22 19:09:50 +02:00
Kim Alvefur
78e7707791 mod_http_files: Log warning about legacy modules using mod_http_files
It is time. Most community modules should have been adjusted to work
with the new (net.http.files) way.

At some point this usage should be prevented.

Related to #1765
2022-07-17 17:05:28 +02:00
Kim Alvefur
96301b2229 mod_bookmarks: Reduce error about not having bookmarks to debug (thanks tom)
This is happens if the account is new and doesn't have any bookmarks
yet, which is not a problem.

Rarely seen since most clients currently use the older version of
XEP-0084 stored in XEP-0049 rather than in PEP, but at least one
(Converse.js )does.

One scenario in which this would show up often is with Converse.js as a
guest chat using anonymous authentication, where all "accounts" would
always be new and not have any bookmarks. This scenario probably does
not need to have mod_bookmarks at all, but if enabled globally it would
likely become loaded onto the VirtualHost unless explicitly disabled.
2022-07-26 23:44:33 +02:00
Kim Alvefur
9f51add3a8 mod_storage_sql: Fix bypass of load procedure under prosodyctl
There's no 'prosody.prosodyctl' property other than this one, introduced
in 6216743c188c in 2015.

Guessing that the intent was to skip this when running as a prosodyctl
command. The module.command code does its own version of this
initialization, so this seems likely.

Thanks raja for noticing
2022-07-26 00:39:16 +02:00
Matthew Wild
7a36d5edcf mod_http_file_share: Switch to new util.jwt API
Some changes/improvements in this commit:

  - Default token lifetime is now 3600s (from 300s)
  - Tokens are only validated once per upload
  - "iat"/"exp" are handled automatically by util.jwt
2022-07-11 13:49:47 +01:00
Matthew Wild
78a197c25d mod_smacks: Set session.smacks after sending <enabled/> to fix traceback
...with opportunistic writes enabled.
2022-08-29 15:58:51 +01:00
Matthew Wild
1254a0de55 mod_smacks: Use new :add_error() in last remaining error result construction 2022-08-29 15:48:07 +01:00
Matthew Wild
79ac7f6b74 mod_smacks: Split enable handling to stages, to allow easier SASL2 integration 2022-08-29 15:45:52 +01:00