[jdev] The future of Jabber/XMPP?

Evgeniy Khramtsov xramtsov at gmail.com
Fri Aug 27 04:00:07 CDT 2010


27.08.2010 02:47, Dave Cridland wrote:
> On Thu Aug 26 15:41:29 2010, Evgeniy Khramtsov wrote:
>> Lots of bugs in PEP server implementations are because the XEP itself
>> is written poorly. It doesn't scale: the idea of keeping resources
>> and features of every user from every server on the planet is
>> completely insane. Don't be surprised if you see memory leaks - they
>> are by design :)
>
> Well, I agree it's pretty easy to "leak" subscriptions (we[1] do,
> sometimes, if we never see an unavailable from a resource). That's our
> bug, and we'll be sorting that one out soon. Otherwise I don't think
> there's anything that inherently has a leak associated with it - even
> including the fact you gradually learn about every feature of every
> client, it's simply not that big a deal.

There is also a possibility where a malicious user can generate 
thousands of fake resources with different caps/features which you 
should also track. A server should also have a protection against this, 
especially if it is a small server.

> Honestly, I don't find PEP too much of a pain - it does have a memory
> cost, but it's really not astronomical, and the benefits are very nice
> for clients and users.

We choosed another approach in ejabberd, where we don't store anything 
except of caps_hash->features hash table. If you are wondered:

1) caps_hash->features table is only for *local* users. The overhead is 
really small for obvious reason.
2) since we already store local user's presence in C2S state (this is 
MUST in RFC), a server filters out *every* outgoing PEP message (based 
on caps from user's presence and features from caps_hash->features 
table) right before sending the message to the local user. No memory, no 
cpu overhead here.
3) for S2S users a server sends PEP message blindly to bare JID. In fact 
this doesn't even violate the XEP :)

So I suggest adding two "SHOULD" statements in the XEP:
1) a server SHOULD filter PEP messages before sending it to local user.
2) a server SHOULD broadcast bare PEP message to all available local 
user's resources.

-- 
Regards,
Evgeniy Khramtsov, ProcessOne.
xmpp:xram at jabber.ru.



More information about the JDev mailing list