Commit graph

9752 commits

Author SHA1 Message Date
Kim Alvefur
0ada5ddd56 mod_websocket: Clear mask bit when reflecting ping frames (fixes #1484) 2020-01-02 10:49:37 +01:00
Kim Alvefur
1ee37abc70 prosodyctl: Print a blank line to improve spacing and readability 2019-12-31 02:50:25 +01:00
Kim Alvefur
964d68a2e6 prosodyctl check: Warn about conflict between mod_pep and mod_pep_simple
Related #1483
2019-12-31 02:48:49 +01:00
Kim Alvefur
3c8015ee10 core.rostermanager: Cache rosters of offline users for faster access (fixes #1233)
(grafted from 42a3e3a2824822cef7640ac56d182c59bdd4224e)
2018-12-16 02:56:11 +01:00
Kim Alvefur
a9e50317d5 mod_mam: Fix rebase mistake [luacheck]
The 'err' was there in trunk
2019-12-24 01:01:05 +01:00
Kim Alvefur
72963873cd mod_muc_mam: Fix rebase mistake [luacheck]
The 'err' was there in trunk
2019-12-24 01:00:35 +01:00
Kim Alvefur
6ceb83042a mod_muc_mam: Schedule cleanup again on failure 2019-12-24 00:26:40 +01:00
Kim Alvefur
9505466b43 mod_muc_mam: Log error when unable to delete old messages (fix #1481) [luacheck] 2019-12-24 00:26:37 +01:00
Kim Alvefur
99f1926c30 mod_muc_mam: Log error when unable to store stanza (fix #1480) [luacheck] 2019-12-23 23:32:49 +01:00
Kim Alvefur
a13a26a435 mod_mam: Schedule cleanup again if unable to delete messages 2019-12-24 00:27:44 +01:00
Kim Alvefur
fa9d8957e3 mod_mam: Log error when unable to delete old messages (fix #1479) [luacheck] 2019-12-24 00:27:41 +01:00
Kim Alvefur
7928145f7d mod_mam: Log error when unable to store stanza (fix #1478)
Unclear what else to do here.

Caught by luacheck
2019-12-23 23:18:39 +01:00
Kim Alvefur
32bb14048a mod_auth_internal_hashed: Pass on errors from password hash function (fixes #1477) 2019-12-23 22:42:39 +01:00
Kim Alvefur
d25a2f42a9 mod_pep: Handle presence subscriptions in filter (fixes #1372)
Take two on 045209b41b3a
2019-06-10 13:57:09 +02:00
Kim Alvefur
b9a80e5643 util.pubsub: Pass subscribers trough a filter callback 2019-06-06 18:13:46 +02:00
Kim Alvefur
d615cd3484 util.pubsub: Factor out calling of broadcaster
This will simplify doing things along with broadcasting.
2019-06-06 17:37:15 +02:00
Kim Alvefur
17f90edfaa net.resolvers.basic: Normalise IP literals, ensures net.server is happy 2019-11-24 04:41:07 +01:00
Kim Alvefur
fcef79d2e9 net.resolvers.basic: Fix resolution of IPv6 literals (in brackets) (fixes #1459) 2019-11-24 04:26:44 +01:00
Kim Alvefur
b8c255a83c net.resolvers.basic: Move IP literal check to constructor
This is to prepare for fixing #1459. An IPv6 literal in [ ] brackets
does not pass IDNA and resolving it fails there.
2019-11-24 04:23:51 +01:00
Kim Alvefur
a2aa11f3ae core.modulemanager: Disable mod_vcard if mod_vcard_legacy is enabled to prevent conflict (#1469) 2019-11-23 23:11:03 +01:00
Kim Alvefur
d76bbecd01 prosodyctl check: Warn about conflict between mod_vcard and mod_vcard_legacy (#1469) 2019-11-23 23:10:39 +01:00
Kim Alvefur
59e906ef3f MUC: Keep role across nickname change (fixes #1466) 2019-11-23 01:05:28 +01:00
Kim Alvefur
d0cb023ea8 util.pposix: Avoid overflow of malloc info at 2GB (fixes #1445 until 4GB) 2019-11-16 16:45:33 +01:00
Kim Alvefur
49995f4ec4 net.resolvers: Fix traceback from hostname failing IDNA
Related to #1426
2019-11-08 00:54:56 +01:00
Kim Alvefur
9e67d0c702 util.startup: Ensure prosody.paths are absolute (see #1430)
Normally these paths are injected into the installed 'prosody'
executable as absolute paths, but it is possible to override at least
the config path via environment variable or command line argument. This
makes sure a path relative to pwd stays relative to that instead of the
data directory.
2019-11-04 00:29:49 +01:00
Kim Alvefur
c5b914260a util.startup: Update config path (fixes #1430) 2019-11-03 22:19:09 +01:00
Kim Alvefur
7ad5df7a4a net.resolvers: Abort on hostnames not passing IDNA validation
Prevents error on trying to use nil.

Needs better error reporting in the future.
2019-11-02 19:36:19 +01:00
Kim Alvefur
e064687531 net.resolvers: Apply IDNA conversion to ascii for DNS lookups (fixes #1426) 2019-11-02 19:24:26 +01:00
Kim Alvefur
01c5fd53fb util.interpolation: Support unescaped variables with more modifiers (fixes #1452)
Tests will be added in trunk.
2019-10-20 20:52:14 +02:00
Kim Alvefur
3e484e457e MUC: Don't advertise registration feature on host JID (fixes #1451)
There is currently no mention in XEP-0045 of how or where to advertise
support for registration.

Advertising on the host JID may be confusable with service-wide
registration, as implemented in ejabberd.

A common and sensible pattern in XMPP is that a feature is advertised on
the JID where the service is available.
2019-10-20 01:20:11 +02:00
Matthew Wild
0ddc46653c mod_mam: Add flag to session when it performs a MAM query 2019-10-03 16:38:15 +01:00
Kim Alvefur
da04fec77a MUC: Strip tags with MUC-related namespaces from private messages (fixes #1427)
Prevents duplication since it adds another <{muc#user}x> here
2019-09-29 20:48:00 +02:00
Kim Alvefur
54f1f9f4fc mod_vcard_legacy: Don't owerwrite empty photo elements (fixes #1432) 2019-09-21 16:29:16 +02:00
Kim Alvefur
9d55062487 mod_vcard_legacy: Advertise lack of avatar correctly (fixes #1431) (thanks lovetox) 2019-09-21 15:20:50 +02:00
Matthew Wild
30c2b8036c prosodyctl: Fix traceback on incorrect proxy65_address type 2019-09-11 15:03:54 +01:00
Matthew Wild
a358e3e4b9 Added tag 0.11.3 for changeset dd7e924c74ef 2019-09-05 16:01:16 +01:00
Kim Alvefur
66f5741a5f MUC: Fix delay@from to be room JID (fixes #1416) 2019-08-31 16:08:45 +02:00
Kim Alvefur
708f1a00bf MUC: Advertise XEP-0410 support
Unsure if the feature was in the XEP at the time of 7c1cdf5f9f83
2019-07-30 08:01:22 +02:00
Kim Alvefur
74c233d119 mod_websocket: Clone stanza before mutating (fixes #1398)
Checking for `stanza.attr.xmlns == nil` to determine if the stanza
object is an actual stanza (`<message>`, `<presence>` or `<iq>` in the
`jabber:client` or `jabbber:server` namespace) or some other stream
element.

Since this mutation is not reverted, it may leak to other places and
cause them to mistreat stanzas as stream elements. Especially in cases
like MUC where a single stanza is broadcast to many recipients.
2019-07-20 04:19:58 +02:00
Kim Alvefur
23eb311e20 util.serialization: Cache default serialization instance (fixes #1389)
Most serialization uses still use the default serialize() and thus
duplicate much of the setup, which negates some of the performance
improvements of the rewrite.
2019-07-08 02:46:27 +02:00
Kim Alvefur
04384c44a0 net.server_epoll: Backport timer optimization 6c2370f17027 from trunk (see #1388)
The previous timer handling did not scale well and led to high CPU usage
with many connections (each with at least an read timeout).
2019-07-08 01:17:34 +02:00
Kim Alvefur
ad7fac4b3b scansion/blocking: Remove the right irrelevant thing 2019-06-20 22:25:46 +02:00
Kim Alvefur
0f582a5656 mod_blocklist: Remove unrelated tags from test case 2019-06-20 22:10:19 +02:00
Kim Alvefur
897031cde2 mod_blocklist: Trigger resend of presence when unblocking a contact (fixes #1380) 2019-06-20 21:20:00 +02:00
Kim Alvefur
51fb4278df mod_blocklist: Update test case with correct behavior (see #1380)
Expect failure
2019-06-20 21:18:46 +02:00
Kim Alvefur
85748bb15e mod_blocklist: Add test case capturing current behavior 2019-06-20 21:08:12 +02:00
Kim Alvefur
3b5c4ceac3 mod_pep: Revert 045209b41b3a, caused a regression
Adding in all presence based subscriptions in the broadcaster caused
resend_last_item() to unintentionally send out more notifications than
it should have.
2019-06-10 12:58:00 +02:00
Kim Alvefur
1cb7ec78b2 util.sql: Ignore if tables and indices already exist on creation (fixes #1064)
Tested with SQLite3 3.16.2 and 3.27.2 and Postgres 11.

MySQL does not support IF NOT EXISTS for indices so not handled here.
2019-05-30 23:50:28 +02:00
Kim Alvefur
c0263dfb30 mod_pep: Handle presence based subscription outside of util.pubsub (fixes #1372)
Subscriptions were updated for each incoming presence stanza from
contacts. Each subscription change triggered a configuration save, which
would filter out the presence based subscriptions and usually end up
replacing the existing data with identical data. With many subscribed
nodes this adds up to a fair bit of IO bound work that is avoided by
keeping them separate.
2019-05-30 15:16:56 +02:00
Kim Alvefur
c44c195f98 mod_muc_mam: Cache last date that archive owner has messages to reduce writes (fixes #1368) 2019-05-27 19:00:34 +02:00