d4rktg 0.4.5__tar.gz → 0.4.7__tar.gz
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.
- {d4rktg-0.4.5 → d4rktg-0.4.7}/PKG-INFO +1 -1
- d4rktg-0.4.7/VERSION.txt +1 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/__init__.py +1 -1
- d4rktg-0.4.7/d4rk/Utils/_round.py +32 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rktg.egg-info/PKG-INFO +1 -1
- d4rktg-0.4.5/VERSION.txt +0 -1
- d4rktg-0.4.5/d4rk/Utils/_round.py +0 -34
- {d4rktg-0.4.5 → d4rktg-0.4.7}/MANIFEST.in +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/README.rst +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Database/__init__.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Database/db.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Handlers/__init__.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Handlers/_bot.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Handlers/_scheduler.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Logs/__init__.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Logs/_logger.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Models/__init__.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Models/_commands.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Models/_movie_title.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_decorators.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_delete.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_fonts.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_ip.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_movie_parser.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_ractions.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/Utils/_terminal.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rk/__init__.py +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rktg.egg-info/SOURCES.txt +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rktg.egg-info/dependency_links.txt +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rktg.egg-info/requires.txt +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/d4rktg.egg-info/top_level.txt +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/requirements.txt +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/setup.cfg +0 -0
- {d4rktg-0.4.5 → d4rktg-0.4.7}/setup.py +0 -0
d4rktg-0.4.7/VERSION.txt
ADDED
@@ -0,0 +1 @@
|
|
1
|
+
0.4.7
|
@@ -0,0 +1,32 @@
|
|
1
|
+
from itertools import cycle
|
2
|
+
from functools import wraps
|
3
|
+
from pyrogram.types import Message
|
4
|
+
|
5
|
+
last_selected_per_chat = {}
|
6
|
+
|
7
|
+
def round_robin():
|
8
|
+
def decorator(func):
|
9
|
+
@wraps(func)
|
10
|
+
async def wrapper(client, message: Message, *args, **kwargs):
|
11
|
+
chat_id = message.chat.id
|
12
|
+
|
13
|
+
# Private chats: all bots respond
|
14
|
+
if message.chat.type.name.lower() == "private":
|
15
|
+
return await func(client, message, *args, **kwargs)
|
16
|
+
|
17
|
+
# If first message in chat, set current bot as last_selected
|
18
|
+
if chat_id not in last_selected_per_chat:
|
19
|
+
last_selected_per_chat[chat_id] = client.me.id
|
20
|
+
|
21
|
+
# Only the last_selected bot responds
|
22
|
+
if client.me.id == last_selected_per_chat[chat_id]:
|
23
|
+
result = await func(client, message, *args, **kwargs)
|
24
|
+
|
25
|
+
# rotate: pick the next bot (you'll need a list of bot IDs per chat)
|
26
|
+
bots_in_chat = list({client.me.id}) # replace with actual bot list
|
27
|
+
idx = bots_in_chat.index(client.me.id)
|
28
|
+
last_selected_per_chat[chat_id] = bots_in_chat[(idx + 1) % len(bots_in_chat)]
|
29
|
+
return result
|
30
|
+
|
31
|
+
return wrapper
|
32
|
+
return decorator
|
d4rktg-0.4.5/VERSION.txt
DELETED
@@ -1 +0,0 @@
|
|
1
|
-
0.4.5
|
@@ -1,34 +0,0 @@
|
|
1
|
-
from itertools import cycle
|
2
|
-
from functools import wraps
|
3
|
-
from pyrogram.types import Message
|
4
|
-
|
5
|
-
last_selected = None
|
6
|
-
bot_order = []
|
7
|
-
|
8
|
-
def round_robin():
|
9
|
-
def decorator(func):
|
10
|
-
@wraps(func)
|
11
|
-
async def wrapper(client, message: Message, *args, **kwargs):
|
12
|
-
global last_selected, bot_order
|
13
|
-
|
14
|
-
# Private chats: all bots respond
|
15
|
-
if message.chat.type.name.lower() == "private":
|
16
|
-
return await func(client, message, *args, **kwargs)
|
17
|
-
|
18
|
-
# If this chat is new, start order dynamically
|
19
|
-
chat_id = message.chat.id
|
20
|
-
if chat_id not in bot_order:
|
21
|
-
bot_order.append(client.me.id)
|
22
|
-
last_selected = client.me.id
|
23
|
-
|
24
|
-
# Only the "current" bot responds
|
25
|
-
if client.me.id == last_selected:
|
26
|
-
result = await func(client, message, *args, **kwargs)
|
27
|
-
|
28
|
-
# Rotate for next message
|
29
|
-
alive_bots = [b for b in bot_order if b is not None] # optionally skip dead bots
|
30
|
-
idx = alive_bots.index(last_selected)
|
31
|
-
last_selected = alive_bots[(idx + 1) % len(alive_bots)]
|
32
|
-
return result
|
33
|
-
return wrapper
|
34
|
-
return decorator
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|