slidge 0.1.2__py3-none-any.whl → 0.1.3__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- slidge/core/gateway/session_dispatcher.py +9 -0
- slidge/group/participant.py +4 -4
- {slidge-0.1.2.dist-info → slidge-0.1.3.dist-info}/METADATA +1 -1
- {slidge-0.1.2.dist-info → slidge-0.1.3.dist-info}/RECORD +7 -7
- {slidge-0.1.2.dist-info → slidge-0.1.3.dist-info}/LICENSE +0 -0
- {slidge-0.1.2.dist-info → slidge-0.1.3.dist-info}/WHEEL +0 -0
- {slidge-0.1.2.dist-info → slidge-0.1.3.dist-info}/entry_points.txt +0 -0
@@ -448,6 +448,15 @@ class SessionDispatcher:
|
|
448
448
|
entity.react(legacy_id, emojis, xmpp_id=xmpp_id, carbon=True)
|
449
449
|
|
450
450
|
async def on_presence(self, p: Presence):
|
451
|
+
if p.get_plugin("muc_join", check=True):
|
452
|
+
# handled in on_groupchat_join
|
453
|
+
# without this early return, since we switch from and to in this
|
454
|
+
# presence stanza, on_groupchat_join ends up trying to instantiate
|
455
|
+
# a MUC with the user's JID, which in turn leads to slidge sending
|
456
|
+
# a (error) presence from=the user's JID, which terminates the
|
457
|
+
# XML stream.
|
458
|
+
return
|
459
|
+
|
451
460
|
session = await self.__get_session(p)
|
452
461
|
|
453
462
|
pto = p.get_to()
|
slidge/group/participant.py
CHANGED
@@ -143,6 +143,7 @@ class LegacyParticipant(
|
|
143
143
|
|
144
144
|
if self.is_system:
|
145
145
|
self.jid = j
|
146
|
+
self._nickname_no_illegal = ""
|
146
147
|
return
|
147
148
|
|
148
149
|
nickname = unescaped_nickname
|
@@ -213,7 +214,6 @@ class LegacyParticipant(
|
|
213
214
|
|
214
215
|
kwargs["status_codes"] = set()
|
215
216
|
p = self._make_presence(ptype="available", last_seen=last_seen, **kwargs)
|
216
|
-
self.__add_nick_element(p)
|
217
217
|
self._send(p)
|
218
218
|
|
219
219
|
if old:
|
@@ -301,6 +301,7 @@ class LegacyParticipant(
|
|
301
301
|
**send_kwargs,
|
302
302
|
) -> MessageOrPresenceTypeVar:
|
303
303
|
stanza["occupant-id"]["id"] = self.__occupant_id
|
304
|
+
self.__add_nick_element(stanza)
|
304
305
|
if isinstance(stanza, Presence):
|
305
306
|
if stanza["type"] == "unavailable" and not self.__presence_sent:
|
306
307
|
return stanza # type:ignore
|
@@ -344,11 +345,11 @@ class LegacyParticipant(
|
|
344
345
|
)
|
345
346
|
return item
|
346
347
|
|
347
|
-
def __add_nick_element(self,
|
348
|
+
def __add_nick_element(self, stanza: Union[Presence, Message]):
|
348
349
|
if (nick := self._nickname_no_illegal) != self.jid.resource:
|
349
350
|
n = self.xmpp.plugin["xep_0172"].stanza.UserNick()
|
350
351
|
n["nick"] = nick
|
351
|
-
|
352
|
+
stanza.append(n)
|
352
353
|
|
353
354
|
def _get_last_presence(self) -> Optional[CachedPresence]:
|
354
355
|
own = super()._get_last_presence()
|
@@ -400,7 +401,6 @@ class LegacyParticipant(
|
|
400
401
|
)
|
401
402
|
if presence_id:
|
402
403
|
p["id"] = presence_id
|
403
|
-
self.__add_nick_element(p)
|
404
404
|
self._send(p, full_jid)
|
405
405
|
|
406
406
|
def leave(self):
|
@@ -25,7 +25,7 @@ slidge/core/gateway/ping.py,sha256=YUmreEyEw89l0M65D_AylL5oW4xj4lvJvhwucyiKofw,1
|
|
25
25
|
slidge/core/gateway/presence.py,sha256=Ow2tWRx-tBL9mGeYRrHLboxD2CdJ32w9yor1kHZEL4U,2732
|
26
26
|
slidge/core/gateway/registration.py,sha256=KmxDFV3N01gCs_58Re9QIxJukYP7S3_i6IbukZxzEIs,1619
|
27
27
|
slidge/core/gateway/search.py,sha256=ZZPnZlTYFedsQAY-80ZX2el_oej6X7HfIwydYdTxl-o,3518
|
28
|
-
slidge/core/gateway/session_dispatcher.py,sha256=
|
28
|
+
slidge/core/gateway/session_dispatcher.py,sha256=UoBygDrgKIwIb-0TcrPzxxg_AuFhkexGGgvWZWroLts,29641
|
29
29
|
slidge/core/gateway/vcard_temp.py,sha256=uCSefV1D0Xx7Ex40t4uS0KHF7cbnq-xixAQQBxTtme8,4639
|
30
30
|
slidge/core/mixins/__init__.py,sha256=iAVi4gzekXIR2xDS8ic1gSguvBbfVSScWArM4t87L-U,368
|
31
31
|
slidge/core/mixins/attachment.py,sha256=yu7AzrRUCvKM_4AXYO1a83I4o_Sc8h3zteNRYOP2LgU,17808
|
@@ -42,7 +42,7 @@ slidge/core/session.py,sha256=xKyFxmi_tbp0WJNB7uJX_AENA2u1Pc0EzGr54ajmzfA,26134
|
|
42
42
|
slidge/group/__init__.py,sha256=yFt7cHqeaKIMN6f9ZyhhspOcJJvBtLedGv-iICG7lto,258
|
43
43
|
slidge/group/archive.py,sha256=5lnhUZ27RoVsYgcs-KiYiOLHZtB7VfRozLiTf0ZGNjM,3426
|
44
44
|
slidge/group/bookmarks.py,sha256=2uX7EiMlJJhYOnTXS1oJOchF5u_hFQAlp8VT2mcPqi0,5944
|
45
|
-
slidge/group/participant.py,sha256=
|
45
|
+
slidge/group/participant.py,sha256=hZNxh8QXaYb4AjVqUYQmHPwWnec1RdyQVDP1sZE85Jk,14947
|
46
46
|
slidge/group/room.py,sha256=I6cysvz8rfL6mZZ2AloYufJeG4FlDkEmESLH5oG8b-0,38972
|
47
47
|
slidge/migration.py,sha256=PPSjYMFsc9WGWWiSHWqUskpV_L9OJcrlecRf-Z0Vw_E,334
|
48
48
|
slidge/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -89,8 +89,8 @@ slidge/util/sql.py,sha256=xjSldsDwgpZc20cmk6UfS4nhdc7Hbuml7kjH6IZgT0I,16517
|
|
89
89
|
slidge/util/test.py,sha256=8cTrL-traDv2jfvfTDNgqewsBJH19ePQ1bf7qzp1RHQ,10688
|
90
90
|
slidge/util/types.py,sha256=djIOI4kBBKl_2w8gm7QLtE3NDOCA832rD_GU7A3N6U4,4689
|
91
91
|
slidge/util/util.py,sha256=t8t1nPybcitpmuSlYsOwZ8gDjfiEwTjaa4D7vtzrvQ8,8587
|
92
|
-
slidge-0.1.
|
93
|
-
slidge-0.1.
|
94
|
-
slidge-0.1.
|
95
|
-
slidge-0.1.
|
96
|
-
slidge-0.1.
|
92
|
+
slidge-0.1.3.dist-info/LICENSE,sha256=DZak_2itbUtvHzD3E7GNUYSRK6jdOJ-GqncQ2weavLA,34523
|
93
|
+
slidge-0.1.3.dist-info/METADATA,sha256=yCKNkKIY6QS_HY0XKsRFaIQ68hpDGeh1lRPFKgLOgrk,4736
|
94
|
+
slidge-0.1.3.dist-info/WHEEL,sha256=7Z8_27uaHI_UZAc4Uox4PpBhQ9Y5_modZXWMxtUi4NU,88
|
95
|
+
slidge-0.1.3.dist-info/entry_points.txt,sha256=SNl72KSocF5plsu_67xyH6wVWfGTXQbzkQgXbLtzDrQ,47
|
96
|
+
slidge-0.1.3.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|