Coverage for slidge / slixfix / __init__.py: 97%
34 statements
« prev ^ index » next coverage.py v7.13.5, created at 2026-04-06 05:07 +0000
« prev ^ index » next coverage.py v7.13.5, created at 2026-04-06 05:07 +0000
1# This module contains patches for slixmpp; some have pending requests upstream
2# and should be removed on the next slixmpp release.
3import uuid
5# ruff: noqa: F401
6import slixmpp.plugins
7import slixmpp.stanza.roster
8from slixmpp import Iq, Message
9from slixmpp.exceptions import IqError
10from slixmpp.plugins.xep_0050 import XEP_0050, Command
11from slixmpp.plugins.xep_0356.permissions import IqPermission
12from slixmpp.plugins.xep_0356.privilege import XEP_0356, PrivilegedIqError
13from slixmpp.plugins.xep_0469.stanza import NS as PINNED_NS
14from slixmpp.plugins.xep_0469.stanza import Pinned
15from slixmpp.xmlstream import StanzaBase
17from ..util.archive_msg import set_client_namespace
18from . import (
19 xep_0077,
20 xep_0100,
21 xep_0153,
22 xep_0292,
23)
26def set_pinned(self, val: bool) -> None: # noqa
27 extensions = self.parent()
28 if val:
29 extensions.enable("pinned")
30 else:
31 extensions._del_sub(f"{{{PINNED_NS}}}pinned")
34Pinned.set_pinned = set_pinned
37def session_bind(self, jid) -> None: # noqa
38 self.xmpp["xep_0030"].add_feature(Command.namespace)
39 # awful hack to for the disco items: we need to comment this line
40 # related issue: https://todo.sr.ht/~nicoco/slidge/131
41 # self.xmpp['xep_0030'].set_items(node=Command.namespace, items=tuple())
44XEP_0050.session_bind = session_bind # type:ignore
47def reply(self, body=None, clear: bool = True): # noqa
48 """
49 Overrides slixmpp's Message.reply(), since it strips to sender's resource
50 for mtype=groupchat, and we do not want that, because when we raise an XMPPError,
51 we actually want to preserve the resource.
52 (this is called in RootStanza.exception() to handle XMPPErrors)
53 """
54 new_message = StanzaBase.reply(self, clear)
55 new_message["thread"] = self["thread"]
56 new_message["parent_thread"] = self["parent_thread"]
58 del new_message["id"]
59 if self.stream is not None and self.stream.use_message_ids:
60 new_message["id"] = self.stream.new_id()
62 if body is not None:
63 new_message["body"] = body
64 return new_message
67Message.reply = reply # type: ignore
69slixmpp.plugins.PLUGINS.extend(
70 [
71 "xep_0292_provider",
72 ]
73)