d4rktg 0.4.9__py3-none-any.whl → 0.5.0__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.
d4rk/Utils/_round.py
CHANGED
@@ -3,37 +3,47 @@ from pyrogram.types import Message
|
|
3
3
|
|
4
4
|
# Track last bot index per chat
|
5
5
|
last_index_per_chat = {}
|
6
|
-
# Track
|
7
|
-
|
6
|
+
# Track bot order per chat
|
7
|
+
bot_order_per_chat = {}
|
8
|
+
# Track messages already responded to: chat_id -> set of message_ids
|
9
|
+
responded_messages = {}
|
8
10
|
|
9
11
|
def round_robin():
|
10
12
|
def decorator(func):
|
11
13
|
@wraps(func)
|
12
14
|
async def wrapper(client, message: Message, *args, **kwargs):
|
13
15
|
chat_id = message.chat.id
|
16
|
+
msg_id = message.id
|
14
17
|
|
15
18
|
# Private chats: all bots respond
|
16
19
|
if message.chat.type.name.lower() == "private":
|
17
20
|
return await func(client, message, *args, **kwargs)
|
18
21
|
|
19
|
-
#
|
20
|
-
if
|
21
|
-
|
22
|
-
|
23
|
-
# Initialize last_index for this chat
|
24
|
-
if chat_id not in last_index_per_chat:
|
22
|
+
# Initialize tracking for this chat
|
23
|
+
if chat_id not in bot_order_per_chat:
|
24
|
+
bot_order_per_chat[chat_id] = [client.me.id]
|
25
25
|
last_index_per_chat[chat_id] = 0
|
26
|
+
responded_messages[chat_id] = set()
|
27
|
+
|
28
|
+
# Skip if message already responded by any bot
|
29
|
+
if msg_id in responded_messages[chat_id]:
|
30
|
+
return
|
31
|
+
|
32
|
+
# Add new bots if not in the chat
|
33
|
+
if client.me.id not in bot_order_per_chat[chat_id]:
|
34
|
+
bot_order_per_chat[chat_id].append(client.me.id)
|
26
35
|
|
27
36
|
current_index = last_index_per_chat[chat_id]
|
28
|
-
selected_bot_id =
|
37
|
+
selected_bot_id = bot_order_per_chat[chat_id][current_index]
|
29
38
|
|
30
|
-
# Only
|
39
|
+
# Only selected bot responds
|
31
40
|
if client.me.id == selected_bot_id:
|
32
41
|
result = await func(client, message, *args, **kwargs)
|
33
|
-
|
34
|
-
|
35
|
-
|
42
|
+
# Mark message as responded
|
43
|
+
responded_messages[chat_id].add(msg_id)
|
44
|
+
# Rotate index
|
45
|
+
last_index_per_chat[chat_id] = (current_index + 1) % len(bot_order_per_chat[chat_id])
|
36
46
|
return result
|
37
47
|
|
38
48
|
return wrapper
|
39
|
-
return decorator
|
49
|
+
return decorator
|
@@ -16,9 +16,9 @@ d4rk/Utils/_fonts.py,sha256=CQsDqPgvp27t3f75Cxod0EmZogEssLwIpyesH-YY5KM,7518
|
|
16
16
|
d4rk/Utils/_ip.py,sha256=KJJW2QSngshIVWCO5YPXF1wj4IPQzVN5oFofpfzlU5w,559
|
17
17
|
d4rk/Utils/_movie_parser.py,sha256=QEPd3z04p4pk2vxZ-2fYlRxHmQbmwQd2mCIlBsBM5AY,7039
|
18
18
|
d4rk/Utils/_ractions.py,sha256=wOVPyoFnbDuMgoP6NF_gLO1DYcfhERC0trdAK1jWSE8,2170
|
19
|
-
d4rk/Utils/_round.py,sha256=
|
19
|
+
d4rk/Utils/_round.py,sha256=lKnkj8OC6rjYGnX5rY9-d6TliR43t2ICImuk2j5NLXk,1868
|
20
20
|
d4rk/Utils/_terminal.py,sha256=Anu4OcffY3v6LMOrCskP1cHrJIliomo1Hjownbhh2sQ,125
|
21
|
-
d4rktg-0.
|
22
|
-
d4rktg-0.
|
23
|
-
d4rktg-0.
|
24
|
-
d4rktg-0.
|
21
|
+
d4rktg-0.5.0.dist-info/METADATA,sha256=4cVq1vjwin8rD0zg-LhDjfD07_ZT_C4ixvuU743ULOI,652
|
22
|
+
d4rktg-0.5.0.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
|
23
|
+
d4rktg-0.5.0.dist-info/top_level.txt,sha256=qs1qTnKWImmGi7E0FoJS0OAEOHoVZA9vHRS3Pm6ncAo,5
|
24
|
+
d4rktg-0.5.0.dist-info/RECORD,,
|
File without changes
|
File without changes
|