slidge 0.2.3.post1__py3-none-any.whl → 0.2.4__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- slidge/__version__.py +1 -1
- slidge/core/dispatcher/message/message.py +4 -1
- slidge/core/gateway.py +2 -0
- slidge/core/mixins/recipient.py +2 -2
- slidge/group/room.py +21 -1
- slidge/slixfix/__init__.py +72 -5
- slidge/slixfix/xep_0492/__init__.py +8 -0
- slidge/slixfix/xep_0492/notify.py +16 -0
- slidge/slixfix/xep_0492/stanza.py +102 -0
- {slidge-0.2.3.post1.dist-info → slidge-0.2.4.dist-info}/METADATA +2 -2
- {slidge-0.2.3.post1.dist-info → slidge-0.2.4.dist-info}/RECORD +14 -11
- {slidge-0.2.3.post1.dist-info → slidge-0.2.4.dist-info}/WHEEL +0 -0
- {slidge-0.2.3.post1.dist-info → slidge-0.2.4.dist-info}/entry_points.txt +0 -0
- {slidge-0.2.3.post1.dist-info → slidge-0.2.4.dist-info}/top_level.txt +0 -0
slidge/__version__.py
CHANGED
@@ -296,7 +296,10 @@ class MessageContentMixin(DispatcherMixin):
|
|
296
296
|
# no need to carbon for groups, we just don't echo the stanza
|
297
297
|
entity.react(legacy_id, carbon=True) # type: ignore
|
298
298
|
await session.on_react(entity, legacy_id, [], thread=thread)
|
299
|
-
raise XMPPError(
|
299
|
+
raise XMPPError(
|
300
|
+
"policy-violation", # type:ignore
|
301
|
+
text=error_msg,
|
302
|
+
)
|
300
303
|
|
301
304
|
await session.on_react(entity, legacy_id, emojis, thread=thread)
|
302
305
|
if isinstance(entity, LegacyMUC):
|
slidge/core/gateway.py
CHANGED
@@ -913,7 +913,9 @@ SLIXMPP_PLUGINS = [
|
|
913
913
|
"xep_0444", # Message reactions
|
914
914
|
"xep_0447", # Stateless File Sharing
|
915
915
|
"xep_0461", # Message replies
|
916
|
+
"xep_0469", # Bookmark Pinning
|
916
917
|
"xep_0490", # Message Displayed Synchronization
|
918
|
+
"xep_0492", # Chat Notification Settings
|
917
919
|
]
|
918
920
|
|
919
921
|
LOG_STRIP_ELEMENTS = ["data", "binval"]
|
slidge/core/mixins/recipient.py
CHANGED
@@ -21,9 +21,9 @@ class ReactionRecipientMixin:
|
|
21
21
|
form["type"] = "result"
|
22
22
|
form.add_field("FORM_TYPE", "hidden", value="urn:xmpp:reactions:0:restrictions")
|
23
23
|
if self.REACTIONS_SINGLE_EMOJI:
|
24
|
-
form.add_field("max_reactions_per_user", value="1")
|
24
|
+
form.add_field("max_reactions_per_user", value="1", type="number")
|
25
25
|
if available:
|
26
|
-
form.add_field("allowlist", value=list(available))
|
26
|
+
form.add_field("allowlist", value=list(available), type="text-multi")
|
27
27
|
return form
|
28
28
|
|
29
29
|
async def available_emojis(
|
slidge/group/room.py
CHANGED
@@ -26,6 +26,7 @@ from ..core.mixins.disco import ChatterDiscoMixin
|
|
26
26
|
from ..core.mixins.lock import NamedLockMixin
|
27
27
|
from ..core.mixins.recipient import ReactionRecipientMixin, ThreadRecipientMixin
|
28
28
|
from ..db.models import Room
|
29
|
+
from ..slixfix.xep_0492.stanza import WhenLiteral
|
29
30
|
from ..util import ABCSubclassableOnceAtMost
|
30
31
|
from ..util.types import (
|
31
32
|
HoleBound,
|
@@ -994,7 +995,14 @@ class LegacyMUC(
|
|
994
995
|
p["muc"]["status_codes"] = {110, 333}
|
995
996
|
p.send()
|
996
997
|
|
997
|
-
async def add_to_bookmarks(
|
998
|
+
async def add_to_bookmarks(
|
999
|
+
self,
|
1000
|
+
auto_join=True,
|
1001
|
+
invite=False,
|
1002
|
+
preserve=True,
|
1003
|
+
pin: bool | None = None,
|
1004
|
+
notify: WhenLiteral | None = None,
|
1005
|
+
):
|
998
1006
|
"""
|
999
1007
|
Add the MUC to the user's XMPP bookmarks (:xep:`0402')
|
1000
1008
|
|
@@ -1012,6 +1020,11 @@ class LegacyMUC(
|
|
1012
1020
|
settings.
|
1013
1021
|
:param preserve: preserve auto-join and bookmarks extensions
|
1014
1022
|
set by the user outside slidge
|
1023
|
+
:param pin: Pin the group chat bookmark :xep:`0469`. Requires privileged entity.
|
1024
|
+
If set to ``None`` (default), the bookmark pinning status will be untouched.
|
1025
|
+
:param notify: Chat notification setting: :xep:`0492`. Requires privileged entity.
|
1026
|
+
If set to ``None`` (default), the setting will be untouched. Only the "global"
|
1027
|
+
notification setting is supported (ie, per client type is not possible).
|
1015
1028
|
"""
|
1016
1029
|
item = Item()
|
1017
1030
|
item["id"] = self.jid
|
@@ -1046,6 +1059,13 @@ class LegacyMUC(
|
|
1046
1059
|
item["conference"]["autojoin"] = auto_join
|
1047
1060
|
|
1048
1061
|
item["conference"]["nick"] = self.user_nick
|
1062
|
+
|
1063
|
+
if pin is not None:
|
1064
|
+
item["conference"]["extensions"]["pinned"] = pin
|
1065
|
+
|
1066
|
+
if notify is not None:
|
1067
|
+
item["conference"]["extensions"]["notify"].configure(notify)
|
1068
|
+
|
1049
1069
|
iq = Iq(stype="set", sfrom=self.user_jid, sto=self.user_jid)
|
1050
1070
|
iq["pubsub"]["publish"]["node"] = self.xmpp["xep_0402"].stanza.NS
|
1051
1071
|
iq["pubsub"]["publish"].append(item)
|
slidge/slixfix/__init__.py
CHANGED
@@ -5,17 +5,30 @@
|
|
5
5
|
|
6
6
|
import slixmpp.plugins
|
7
7
|
from slixmpp import Iq, Message
|
8
|
-
from slixmpp.exceptions import XMPPError
|
8
|
+
from slixmpp.exceptions import _DEFAULT_ERROR_TYPES, XMPPError
|
9
|
+
from slixmpp.plugins.xep_0004.stanza.field import FormField
|
9
10
|
from slixmpp.plugins.xep_0050 import XEP_0050, Command
|
10
11
|
from slixmpp.plugins.xep_0231 import XEP_0231
|
11
12
|
from slixmpp.plugins.xep_0425.stanza import Moderate
|
13
|
+
from slixmpp.plugins.xep_0469.stanza import NS as PINNED_NS
|
14
|
+
from slixmpp.plugins.xep_0469.stanza import Pinned
|
12
15
|
from slixmpp.xmlstream import StanzaBase
|
13
16
|
|
14
|
-
from . import
|
17
|
+
from . import (
|
18
|
+
link_preview,
|
19
|
+
xep_0077,
|
20
|
+
xep_0100,
|
21
|
+
xep_0153,
|
22
|
+
xep_0292,
|
23
|
+
xep_0356_old,
|
24
|
+
xep_0492,
|
25
|
+
)
|
15
26
|
|
16
27
|
# TODO: remove this when the fix is included in slixmpp
|
17
28
|
Moderate.interfaces.add("id")
|
18
29
|
|
30
|
+
_DEFAULT_ERROR_TYPES["policy-violation"] = "modify" # type:ignore
|
31
|
+
|
19
32
|
|
20
33
|
async def _handle_bob_iq(self, iq: Iq):
|
21
34
|
cid = iq["bob"]["cid"]
|
@@ -42,6 +55,17 @@ async def _handle_bob_iq(self, iq: Iq):
|
|
42
55
|
iq.send()
|
43
56
|
|
44
57
|
|
58
|
+
def set_pinned(self, val: bool):
|
59
|
+
extensions = self.parent()
|
60
|
+
if val:
|
61
|
+
extensions.enable("pinned")
|
62
|
+
else:
|
63
|
+
extensions._del_sub(f"{{{PINNED_NS}}}pinned")
|
64
|
+
|
65
|
+
|
66
|
+
Pinned.set_pinned = set_pinned
|
67
|
+
|
68
|
+
|
45
69
|
XEP_0231._handle_bob_iq = _handle_bob_iq
|
46
70
|
|
47
71
|
|
@@ -75,13 +99,56 @@ def reply(self, body=None, clear=True):
|
|
75
99
|
return new_message
|
76
100
|
|
77
101
|
|
102
|
+
Message.reply = reply # type: ignore
|
103
|
+
|
104
|
+
|
105
|
+
FormField.set_value_base = FormField.set_value # type:ignore
|
106
|
+
|
107
|
+
|
108
|
+
def set_value(self: FormField, value):
|
109
|
+
if not self._type:
|
110
|
+
if isinstance(value, bool):
|
111
|
+
self._type = "boolean"
|
112
|
+
elif isinstance(value, str):
|
113
|
+
self._type = "text-single"
|
114
|
+
elif isinstance(value, (list, tuple)):
|
115
|
+
self._type = "text-multi"
|
116
|
+
|
117
|
+
FormField.set_value_base(self, value)
|
118
|
+
|
119
|
+
|
120
|
+
def get_value(self, convert=True, convert_list=False):
|
121
|
+
valsXML = self.xml.findall("{%s}value" % self.namespace)
|
122
|
+
if len(valsXML) == 0:
|
123
|
+
return None
|
124
|
+
elif self._type == "boolean":
|
125
|
+
if convert:
|
126
|
+
return valsXML[0].text in self.true_values
|
127
|
+
return valsXML[0].text
|
128
|
+
elif self._type in self.multi_value_types or len(valsXML) > 1:
|
129
|
+
values = []
|
130
|
+
for valXML in valsXML:
|
131
|
+
if valXML.text is None:
|
132
|
+
valXML.text = ""
|
133
|
+
values.append(valXML.text)
|
134
|
+
if self._type == "text-multi" and convert_list:
|
135
|
+
values = "\n".join(values)
|
136
|
+
return values
|
137
|
+
else:
|
138
|
+
if valsXML[0].text is None:
|
139
|
+
return ""
|
140
|
+
return valsXML[0].text
|
141
|
+
|
142
|
+
|
143
|
+
FormField.set_value = set_value # type:ignore
|
144
|
+
FormField.get_value = get_value # type:ignore
|
145
|
+
|
146
|
+
|
78
147
|
slixmpp.plugins.PLUGINS.extend(
|
79
148
|
[
|
80
149
|
"link_preview",
|
81
150
|
"xep_0292_provider",
|
82
151
|
"xep_0356_old",
|
152
|
+
"xep_0492",
|
83
153
|
]
|
84
154
|
)
|
85
|
-
|
86
|
-
|
87
|
-
Message.reply = reply # type: ignore
|
@@ -0,0 +1,16 @@
|
|
1
|
+
from slixmpp.plugins import BasePlugin
|
2
|
+
from . import stanza
|
3
|
+
|
4
|
+
|
5
|
+
class XEP_0492(BasePlugin):
|
6
|
+
"""
|
7
|
+
XEP-0492: Chat notification settings
|
8
|
+
"""
|
9
|
+
|
10
|
+
name = "xep_0492"
|
11
|
+
description = "XEP-0492: Chat notification settings"
|
12
|
+
dependencies = {"xep_0402"}
|
13
|
+
stanza = stanza
|
14
|
+
|
15
|
+
def plugin_init(self):
|
16
|
+
stanza.register_plugin()
|
@@ -0,0 +1,102 @@
|
|
1
|
+
from typing import Literal, Optional, cast
|
2
|
+
|
3
|
+
from slixmpp import register_stanza_plugin
|
4
|
+
from slixmpp.plugins.xep_0402.stanza import Extensions
|
5
|
+
from slixmpp.xmlstream import ElementBase
|
6
|
+
|
7
|
+
from ...util.types import ClientType
|
8
|
+
|
9
|
+
NS = "urn:xmpp:notification-settings:0"
|
10
|
+
|
11
|
+
WhenLiteral = Literal["never", "always", "on-mention"]
|
12
|
+
|
13
|
+
|
14
|
+
class Notify(ElementBase):
|
15
|
+
"""
|
16
|
+
Chat notification settings element
|
17
|
+
|
18
|
+
|
19
|
+
To enable it on a Conference element, use configure() like this:
|
20
|
+
|
21
|
+
.. code-block::python
|
22
|
+
|
23
|
+
# C being a Conference element
|
24
|
+
C['extensions']["notify"].configure("always", client_type="pc")
|
25
|
+
|
26
|
+
Which will add the <notify> element to the <extensions> element.
|
27
|
+
"""
|
28
|
+
|
29
|
+
namespace = NS
|
30
|
+
name = "notify"
|
31
|
+
plugin_attrib = "notify"
|
32
|
+
interfaces = {"notify"}
|
33
|
+
|
34
|
+
def configure(self, when: WhenLiteral, client_type: Optional[ClientType] = None) -> None:
|
35
|
+
"""
|
36
|
+
Configure the chat notification settings for this bookmark.
|
37
|
+
|
38
|
+
This method ensures that there are no conflicting settings, e.g.,
|
39
|
+
both a <never /> and a <always /> element.
|
40
|
+
"""
|
41
|
+
cls = _CLASS_MAP[when]
|
42
|
+
element = cls()
|
43
|
+
if client_type is not None:
|
44
|
+
element["client-type"] = client_type
|
45
|
+
|
46
|
+
match = client_type if client_type is not None else ""
|
47
|
+
for child in self:
|
48
|
+
if isinstance(child, _Base) and child["client-type"] == match:
|
49
|
+
self.xml.remove(child.xml)
|
50
|
+
|
51
|
+
self.append(element)
|
52
|
+
|
53
|
+
def get_config(
|
54
|
+
self, client_type: Optional[ClientType] = None
|
55
|
+
) -> Optional[WhenLiteral]:
|
56
|
+
"""
|
57
|
+
Get the chat notification settings for this bookmark.
|
58
|
+
|
59
|
+
:param client_type: Optionally, get the notification for a specific client type.
|
60
|
+
If unset, returns the global notification setting.
|
61
|
+
|
62
|
+
:return: The chat notification setting as a string, or None if unset.
|
63
|
+
"""
|
64
|
+
match = client_type if client_type is not None else ""
|
65
|
+
for child in self:
|
66
|
+
if isinstance(child, _Base) and child["client-type"] == match:
|
67
|
+
return cast(WhenLiteral, child.name)
|
68
|
+
return None
|
69
|
+
|
70
|
+
|
71
|
+
class _Base(ElementBase):
|
72
|
+
namespace = NS
|
73
|
+
interfaces = {"client-type"}
|
74
|
+
|
75
|
+
|
76
|
+
class Never(_Base):
|
77
|
+
name = "never"
|
78
|
+
|
79
|
+
|
80
|
+
class Always(_Base):
|
81
|
+
name = "always"
|
82
|
+
|
83
|
+
|
84
|
+
class OnMention(_Base):
|
85
|
+
name = "on-mention"
|
86
|
+
|
87
|
+
|
88
|
+
class Advanced(ElementBase):
|
89
|
+
namespace = NS
|
90
|
+
name = plugin_attrib = "advanced"
|
91
|
+
|
92
|
+
|
93
|
+
_CLASS_MAP = {
|
94
|
+
"never": Never,
|
95
|
+
"always": Always,
|
96
|
+
"on-mention": OnMention,
|
97
|
+
}
|
98
|
+
|
99
|
+
|
100
|
+
def register_plugin():
|
101
|
+
register_stanza_plugin(Extensions, Notify)
|
102
|
+
register_stanza_plugin(Notify, Advanced)
|
@@ -1,6 +1,6 @@
|
|
1
1
|
Metadata-Version: 2.2
|
2
2
|
Name: slidge
|
3
|
-
Version: 0.2.
|
3
|
+
Version: 0.2.4
|
4
4
|
Summary: XMPP bridging framework
|
5
5
|
Author-email: Nicolas Cedilnik <nicoco@nicoco.fr>
|
6
6
|
License: GNU AFFERO GENERAL PUBLIC LICENSE
|
@@ -693,7 +693,7 @@ Requires-Dist: thumbhash>=0.1.2
|
|
693
693
|
|
694
694
|
|
695
695
|
[](https://ci.codeberg.org/repos/14027)
|
696
|
-
[](https://slidge.im/coverage)
|
696
|
+
[](https://slidge.im/coverage/main)
|
697
697
|
|
698
698
|
[](https://pypi.org/project/slidge/)
|
699
699
|
[](https://packages.debian.org/unstable/python3-slidge)
|
@@ -1,6 +1,6 @@
|
|
1
1
|
slidge/__init__.py,sha256=S0tUjqpZlzsr8G4Y_1Xt-KCYB07qaknTB0OwHU8k29U,1587
|
2
2
|
slidge/__main__.py,sha256=ydjUklOoavS4YlGfjRX_8BQN2DaSbaXPMi47RkOgcFI,37
|
3
|
-
slidge/__version__.py,sha256=
|
3
|
+
slidge/__version__.py,sha256=ieOsYgM0aVfIKxAjpsbCrB7YTVXvXet9-wS_3Z87ito,165
|
4
4
|
slidge/main.py,sha256=vMJzhvUxbeuIXuHxXXs6lm_ShBjXiS9B5Li5Ge4vWPo,6238
|
5
5
|
slidge/migration.py,sha256=4BJmPIRB56_WIhRTqBFIIBXuvnhhBjjOMl4CE7jY6oc,1541
|
6
6
|
slidge/py.typed,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
@@ -17,7 +17,7 @@ slidge/contact/contact.py,sha256=BQ5Fw7InnI76S5bQi_kZL1HhtptZhegmtsKksml7tjY,231
|
|
17
17
|
slidge/contact/roster.py,sha256=x3speGdHbZ-VTLoQLQW4s53rBeBvW87W8ZibCCZSLDA,10300
|
18
18
|
slidge/core/__init__.py,sha256=RG7Jj5JCJERjhqJ31lOLYV-7bH_oblClQD1KF9LsTXo,68
|
19
19
|
slidge/core/config.py,sha256=WP3-ScXqdAhJBX7IRB5pBi_tAV_vE6G5W3Z-LGGULQw,7691
|
20
|
-
slidge/core/gateway.py,sha256=
|
20
|
+
slidge/core/gateway.py,sha256=Rid4Zc_IIV-3lMiiBirqiezkxC_Ed1HMlb9HLyxlnJc,36594
|
21
21
|
slidge/core/pubsub.py,sha256=oTiS5KFQJAmsgkhOsvfvthT-LkuZGQSCrrUG0JskNkI,11907
|
22
22
|
slidge/core/session.py,sha256=nQexpCd1jlHOhQPnFI4ri-5odp3N2pU5HO4l7WFetZY,28148
|
23
23
|
slidge/core/dispatcher/__init__.py,sha256=1EXcjXietUKlxEqdrCWCV3xZ3q_DSsjHoqWrPMbtYao,84
|
@@ -32,7 +32,7 @@ slidge/core/dispatcher/vcard.py,sha256=Rmx-wCz6Lps0mXCO48HppNQlS3GOgMuzuw9hZYBdl
|
|
32
32
|
slidge/core/dispatcher/message/__init__.py,sha256=vpDGOc_U9XvkUU_ws9n9-5M2NPJ87XGTVpuIxM7Z99k,223
|
33
33
|
slidge/core/dispatcher/message/chat_state.py,sha256=sCdEpzbgmvBmTovNOCv9uY6v0eJZcWVvDYAGlAV3FJ4,1735
|
34
34
|
slidge/core/dispatcher/message/marker.py,sha256=f1ezaMoHupBFZY7aUMsWLAQG7G1J9b3ihxICCkpGtis,2411
|
35
|
-
slidge/core/dispatcher/message/message.py,sha256=
|
35
|
+
slidge/core/dispatcher/message/message.py,sha256=07h7OBbIh3OtSbi7DNwv5ANRTzWbwS9ICMHjS_6KpEM,15360
|
36
36
|
slidge/core/dispatcher/muc/__init__.py,sha256=V8URHLJ_y7mk-7Id6FzRuczb1Uq_Z69fhxvzHuVLH1w,269
|
37
37
|
slidge/core/dispatcher/muc/admin.py,sha256=mkosquhaI2iC_mFq7C08kjwjr4iVqAWp7kbOTmgUQtU,3321
|
38
38
|
slidge/core/dispatcher/muc/mam.py,sha256=1ROVP4ZPEVEH-HR5qRV4YwHz-V15uu5gyhv1ZwwKhk8,2821
|
@@ -50,7 +50,7 @@ slidge/core/mixins/message.py,sha256=5Tt1r_8rjsV445b_28Lx73S-rW5tsP1uGPQhIKN64VM
|
|
50
50
|
slidge/core/mixins/message_maker.py,sha256=TcCutHi0sIwL6beJNkN7XyR0aDIbA0xZyxd2Gc9ulG4,6022
|
51
51
|
slidge/core/mixins/message_text.py,sha256=pCY4tezEuwB2ZuUyUi72i4v9AJkxp_SWF1jrFsn94Ns,8096
|
52
52
|
slidge/core/mixins/presence.py,sha256=yywo6KAw8C7GaZSMrSMuioNfhW08MrnobHt8XbHd0q8,7891
|
53
|
-
slidge/core/mixins/recipient.py,sha256=
|
53
|
+
slidge/core/mixins/recipient.py,sha256=b0uFnpym-hOFgYxGjXT1xQcZ4YRbDSBftPcNWLzSwEI,1336
|
54
54
|
slidge/db/__init__.py,sha256=EBDH1JSEhgqYcli2Bw11CRC749wJk8AOucgBzmhDSvU,105
|
55
55
|
slidge/db/avatar.py,sha256=FfRt2Vu11ZKD9F3x1_drawvUd-TDE3mp7SE3BZ9hOOg,6467
|
56
56
|
slidge/db/meta.py,sha256=v1Jf-npZ28QwdGpsLQWLBHEbEP3-jnPrygRg05tJ_Iw,1831
|
@@ -81,8 +81,8 @@ slidge/group/__init__.py,sha256=yFt7cHqeaKIMN6f9ZyhhspOcJJvBtLedGv-iICG7lto,258
|
|
81
81
|
slidge/group/archive.py,sha256=IPqklzo0UN3lPHckfsKW9c4nl3m_9XGY4u0eehrhe8k,5281
|
82
82
|
slidge/group/bookmarks.py,sha256=AvFL34bEX6n3OP1Np309T5hrLK9GnjkjdyLJ3uiLZyc,6616
|
83
83
|
slidge/group/participant.py,sha256=epxXqJ545ALkEYxziiobH149nlBeSZlxsNCYeI8LFhM,17357
|
84
|
-
slidge/group/room.py,sha256=
|
85
|
-
slidge/slixfix/__init__.py,sha256=
|
84
|
+
slidge/group/room.py,sha256=aJ-VIYACuEuoyKDsBFxsUZFoVpd265i0mzTOOHCNTPg,46849
|
85
|
+
slidge/slixfix/__init__.py,sha256=aEXtmxMgxQWsUoDV5NSxZKwb-Hml5XeR2FMJlnaDUng,4324
|
86
86
|
slidge/slixfix/delivery_receipt.py,sha256=3bWdZH3-X3CZJXmnI_TpjkTUUK-EY4Ktm78lW0-40fc,1366
|
87
87
|
slidge/slixfix/roster.py,sha256=KvDjh9q7pqaZf69H93okfib13cc95uVZUJ6rzpqmDaU,1704
|
88
88
|
slidge/slixfix/link_preview/__init__.py,sha256=TDPTSEH5FQxgGpQpQIde-D72AHg-6YVWG-tOj4KpKmU,290
|
@@ -101,6 +101,9 @@ slidge/slixfix/xep_0292/vcard4.py,sha256=jL-TOW3eG2QXLduSLNq03L8HoUNmvy8kTZI5ojv
|
|
101
101
|
slidge/slixfix/xep_0356_old/__init__.py,sha256=3jGWJX2m5gWgDCxcVqCsCCVPRTcfmU96yenwvAJtOKE,180
|
102
102
|
slidge/slixfix/xep_0356_old/privilege.py,sha256=kcJzFbzhOHtQMtzOJpvvwm1pghSpealWnqhC0zc8dGo,5338
|
103
103
|
slidge/slixfix/xep_0356_old/stanza.py,sha256=i7aqcaTg6PBhVwbHToLtlrwxBj7uO-M7VrYSyElyEKI,1229
|
104
|
+
slidge/slixfix/xep_0492/__init__.py,sha256=kjWVeX3SG_2ohHx0fuMh1gmM2G57Bl6SRo7Mfv6sglA,161
|
105
|
+
slidge/slixfix/xep_0492/notify.py,sha256=8EPSdU3rTzWkHNm8oFr0tK2PmMJ6hBAIr88GoOmHTuQ,340
|
106
|
+
slidge/slixfix/xep_0492/stanza.py,sha256=gL0ixpV07Q9eqTXIOjdLVPtim45izuwaLk0iCoZ8e7c,2649
|
104
107
|
slidge/util/__init__.py,sha256=BELovoTMPcPPGz3D48esBr8A4BRRHXTvavfgnArBgEc,301
|
105
108
|
slidge/util/archive_msg.py,sha256=xXAR0BI5r3d6KKWjae9594izCOv6iI03z2WLuTecNw8,1724
|
106
109
|
slidge/util/conf.py,sha256=1j2OnOsCBar1tOObErhXR5RC3Vl3faliOZ1U8J3My58,6613
|
@@ -108,8 +111,8 @@ slidge/util/db.py,sha256=4LxZj8oBYgiSnyBUnF_ALjr0TblkfNQq_p28sCfkHMY,242
|
|
108
111
|
slidge/util/test.py,sha256=l1VHBsw5Uzk2t7wtkfb9kWvtehcYhw1t_d567JAJFKA,14135
|
109
112
|
slidge/util/types.py,sha256=R_xfS5mRL0XUJIoDpnaAkZlTOoLPerduXBFftaVwIAI,5489
|
110
113
|
slidge/util/util.py,sha256=An4BRIHktZGXnu4kCwaKYaSye_PlyuxEm_4SC9YvPhc,9594
|
111
|
-
slidge-0.2.
|
112
|
-
slidge-0.2.
|
113
|
-
slidge-0.2.
|
114
|
-
slidge-0.2.
|
115
|
-
slidge-0.2.
|
114
|
+
slidge-0.2.4.dist-info/METADATA,sha256=pMPAZlzk25loszDWjC73w2dvufxfN4f9NxTxxQ7KcNA,44799
|
115
|
+
slidge-0.2.4.dist-info/WHEEL,sha256=In9FTNxeP60KnTkGw7wk6mJPYd_dQSjEZmXdBdMCI-8,91
|
116
|
+
slidge-0.2.4.dist-info/entry_points.txt,sha256=py3_x834fFJ2TEzPd18Wt2DnysdAfuVqJ5zzBrXbAZs,44
|
117
|
+
slidge-0.2.4.dist-info/top_level.txt,sha256=2LRjDYHaGZ5ieCMF8xy58JIiabRMzX-MGMbCZwfE17c,7
|
118
|
+
slidge-0.2.4.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|