mirror of
https://github.com/MuRuLOSE/limoka.git
synced 2026-06-16 14:34:17 +02:00
Added and updated repositories 2025-11-07 01:04:48
This commit is contained in:
1
mead0wsss/mead0wsMods/README.md
Normal file
1
mead0wsss/mead0wsMods/README.md
Normal file
@@ -0,0 +1 @@
|
||||
эрон дон дон
|
||||
@@ -1,5 +1,5 @@
|
||||
# -- version --
|
||||
__version__ = (1, 0, 0)
|
||||
__version__ = (1, 2, 0)
|
||||
# -- version --
|
||||
|
||||
|
||||
@@ -17,95 +17,209 @@ __version__ = (1, 0, 0)
|
||||
# scope: heroku_only
|
||||
|
||||
from .. import loader, utils
|
||||
from herokutl.tl.functions.payments import GetPaymentFormRequest, SendStarsFormRequest
|
||||
from herokutl.tl.functions.payments import GetPaymentFormRequest, SendStarsFormRequest, GetStarsStatusRequest
|
||||
from herokutl.tl.types import InputInvoiceStarGift, TextWithEntities
|
||||
from herokutl.errors.rpcerrorlist import BadRequestError
|
||||
import logging
|
||||
|
||||
@loader.tds
|
||||
class SenderGifts(loader.Module):
|
||||
"""Модуль для отправки подарков"""
|
||||
|
||||
"""Модуль для отправки подарков Telegram прямиком в чате"""
|
||||
strings = {
|
||||
"name": "SenderGifts",
|
||||
"usage": "<emoji document_id=4958526153955476488>❌</emoji> Используйте в формате: <code>.sendgift @username текст</code>",
|
||||
"usage": "<emoji document_id=4958526153955476488>❌</emoji> Используйте в формате: <code>.sendgift @username текст</code> или реплай + <code>.sendgift текст</code>",
|
||||
"checking_user": "<emoji document_id=5206634672204829887>🔍</emoji> Проверка пользователя...",
|
||||
"checking_balance": "<emoji document_id=5206634672204829887>🔍</emoji> Проверка баланса...",
|
||||
"user_not_found": "<emoji document_id=4958526153955476488>❌</emoji> Пользователь не найден",
|
||||
"gift_menu": "<emoji document_id=5931696400982088015>🎁</emoji> Выберите подарок.\n\n<emoji document_id=6032693626394382504>👤</emoji> Пользователь: {}\n<emoji document_id=5873153278023307367>📄</emoji> Текст: {}",
|
||||
"gift_menu": "<emoji document_id=5931696400982088015>🎁</emoji> Выберите категорию подарков.\n\n<emoji document_id=6032693626394382504>👤</emoji> Пользователь: {}\n<emoji document_id=5873153278023307367>📄</emoji> Текст: {}\n<emoji document_id=5951810621887484519>⭐</emoji> Баланс: {} звезд",
|
||||
"category_menu": "<emoji document_id=5931696400982088015>🎁</emoji> Подарки за {} ⭐\n\n<emoji document_id=6032693626394382504>👤</emoji> Пользователь: {}\n<emoji document_id=5873153278023307367>📄</emoji> Текст: {}",
|
||||
"sending_gift": "<emoji document_id=5201691993775818138>🛫</emoji> Отправка подарка...",
|
||||
"gift_sent": "<emoji document_id=5021905410089550576>✅</emoji> Подарок успешно отправлен!",
|
||||
"not_enough_stars": "<emoji document_id=4958526153955476488>❌</emoji> Недостаточно звезд для отправки подарка {}!",
|
||||
"min_stars_error": "<emoji document_id=4958526153955476488>❌</emoji> Недостаточно звезд для отправки минимального подарка!",
|
||||
"no_available_gifts": "<emoji document_id=4958526153955476488>❌</emoji> Нет доступных подарков для вашего баланса",
|
||||
"balance_error": "<emoji document_id=4958526153955476488>❌</emoji> Ошибка при проверке баланса",
|
||||
}
|
||||
|
||||
gifts = [
|
||||
[
|
||||
{"id": 5170145012310081615, "stars": 15, "emoji": "❤️", "name": "Сердце"},
|
||||
{"id": 5170233102089322756, "stars": 15, "emoji": "🧸", "name": "Мишка"},
|
||||
{"id": 5170250947678437525, "stars": 25, "emoji": "🎁", "name": "Подарок"},
|
||||
gift_categories = {
|
||||
15: [
|
||||
{"id": 5170145012310081615, "emoji": "❤️", "name": "Сердце"},
|
||||
{"id": 5170233102089322756, "emoji": "🧸", "name": "Мишка"},
|
||||
],
|
||||
[
|
||||
{"id": 5168103777563050263, "stars": 25, "emoji": "🌹", "name": "Роза"},
|
||||
{"id": 5170144170496491616, "stars": 50, "emoji": "🎂", "name": "Тортик"},
|
||||
{"id": 5170314324215857265, "stars": 50, "emoji": "💐", "name": "Цветы"},
|
||||
25: [
|
||||
{"id": 5170250947678437525, "emoji": "🎁", "name": "Подарок"},
|
||||
{"id": 5168103777563050263, "emoji": "🌹", "name": "Роза"},
|
||||
],
|
||||
[
|
||||
{"id": 5170564780938756245, "stars": 50, "emoji": "🚀", "name": "Ракета"},
|
||||
{"id": 5168043875654172773, "stars": 100, "emoji": "🏆", "name": "Кубок"},
|
||||
{"id": 5170690322832818290, "stars": 100, "emoji": "💍", "name": "Кольцо"},
|
||||
50: [
|
||||
{"id": 5170144170496491616, "emoji": "🎂", "name": "Тортик"},
|
||||
{"id": 5170314324215857265, "emoji": "💐", "name": "Цветы"},
|
||||
{"id": 5170564780938756245, "emoji": "🚀", "name": "Ракета"},
|
||||
],
|
||||
100: [
|
||||
{"id": 5168043875654172773, "emoji": "🏆", "name": "Кубок"},
|
||||
{"id": 5170690322832818290, "emoji": "💍", "name": "Кольцо"},
|
||||
{"id": 5170521118301225164, "emoji": "💎", "name": "Алмаз"},
|
||||
]
|
||||
]
|
||||
}
|
||||
|
||||
async def client_ready(self, client, db):
|
||||
self.client = client
|
||||
|
||||
async def get_star_balance(self):
|
||||
try:
|
||||
balance_info = (await self.client(GetStarsStatusRequest("me")))
|
||||
return balance_info.balance.amount
|
||||
except Exception as e:
|
||||
logging.error(f"Error getting balance: {e}")
|
||||
return 0
|
||||
|
||||
@loader.command()
|
||||
async def sendgift(self, message):
|
||||
"""Отправить подарок пользователю"""
|
||||
"""- <username> <text*> - отправить подарок пользователю (* - необязательный параметр.) Поддерживается реплай режим."""
|
||||
args = utils.get_args_raw(message)
|
||||
if not args:
|
||||
await utils.answer(message, self.strings["usage"])
|
||||
return
|
||||
|
||||
parts = args.split(maxsplit=1)
|
||||
if len(parts) < 1:
|
||||
await utils.answer(message, self.strings["usage"])
|
||||
return
|
||||
|
||||
username = parts[0]
|
||||
text = parts[1] if len(parts) > 1 else ""
|
||||
if username.startswith('@'):
|
||||
username = username[1:]
|
||||
msg = await utils.answer(message, self.strings["checking_user"])
|
||||
reply = await message.get_reply_message()
|
||||
if reply:
|
||||
user = reply.sender
|
||||
text = args if args else ""
|
||||
else:
|
||||
if not args:
|
||||
await utils.answer(message, self.strings["usage"])
|
||||
return
|
||||
parts = args.split(maxsplit=1)
|
||||
if len(parts) < 1:
|
||||
await utils.answer(message, self.strings["usage"])
|
||||
return
|
||||
username = parts[0]
|
||||
text = parts[1] if len(parts) > 1 else ""
|
||||
if username.startswith('@'):
|
||||
username = username[1:]
|
||||
msg = await utils.answer(message, self.strings["checking_user"])
|
||||
try:
|
||||
user = await self.client.get_entity(username)
|
||||
except Exception as e:
|
||||
logging.error(f"User not found: {e}")
|
||||
await utils.answer(msg, self.strings["user_not_found"])
|
||||
return
|
||||
|
||||
balance_msg = await utils.answer(message, self.strings["checking_balance"])
|
||||
try:
|
||||
user = await self.client.get_entity(username)
|
||||
balance = await self.get_star_balance()
|
||||
except Exception as e:
|
||||
logging.error(f"User not found: {e}")
|
||||
await utils.answer(msg, self.strings["user_not_found"])
|
||||
logging.error(f"Balance error: {e}")
|
||||
await utils.answer(balance_msg, self.strings["balance_error"])
|
||||
return
|
||||
|
||||
min_price = min(self.gift_categories.keys())
|
||||
if balance < min_price:
|
||||
await utils.answer(balance_msg, self.strings["min_stars_error"])
|
||||
return
|
||||
|
||||
available_categories = [price for price in self.gift_categories.keys() if balance >= price]
|
||||
if not available_categories:
|
||||
await utils.answer(balance_msg, self.strings["no_available_gifts"])
|
||||
return
|
||||
buttons = []
|
||||
for row in self.gifts:
|
||||
btn_row = []
|
||||
for gift in row:
|
||||
btn_row.append({
|
||||
"text": gift["emoji"],
|
||||
"callback": self._send_gift,
|
||||
"args": (user.id, gift["id"], text, gift["emoji"], msg.id),
|
||||
})
|
||||
buttons.append(btn_row)
|
||||
row = []
|
||||
for price in sorted(available_categories):
|
||||
row.append({
|
||||
"text": f"{price} ⭐",
|
||||
"callback": self._show_category,
|
||||
"args": (user.id, price, text, balance, message.id),
|
||||
})
|
||||
if len(row) == 2:
|
||||
buttons.append(row)
|
||||
row = []
|
||||
|
||||
if row:
|
||||
buttons.append(row)
|
||||
|
||||
await utils.answer(
|
||||
msg,
|
||||
balance_msg,
|
||||
self.strings["gift_menu"].format(
|
||||
f"@{user.username}" if user.username else user.first_name,
|
||||
text if text else "-",
|
||||
balance
|
||||
),
|
||||
reply_markup=buttons
|
||||
)
|
||||
|
||||
async def _show_category(self, call, user_id, price, text, balance, msg_id):
|
||||
gifts = self.gift_categories[price]
|
||||
buttons = []
|
||||
row = []
|
||||
for gift in gifts:
|
||||
row.append({
|
||||
"text": gift["emoji"],
|
||||
"callback": self._send_gift,
|
||||
"args": (user_id, gift["id"], text, gift["emoji"], msg_id, balance),
|
||||
})
|
||||
if len(row) == 3:
|
||||
buttons.append(row)
|
||||
row = []
|
||||
|
||||
if row:
|
||||
buttons.append(row)
|
||||
buttons.append([{
|
||||
"text": "⬅️ Назад",
|
||||
"callback": self._back_to_categories,
|
||||
"args": (user_id, text, balance, msg_id),
|
||||
}])
|
||||
|
||||
try:
|
||||
user = await self.client.get_entity(user_id)
|
||||
user_display = f"@{user.username}" if user.username else user.first_name
|
||||
except:
|
||||
user_display = f"ID: {user_id}"
|
||||
|
||||
await call.edit(
|
||||
self.strings["category_menu"].format(
|
||||
price,
|
||||
user_display,
|
||||
text if text else "-"
|
||||
),
|
||||
reply_markup=buttons
|
||||
)
|
||||
async def _send_gift(self, call, user_id, gift_id, text, gift_emoji, msg_id):
|
||||
|
||||
async def _back_to_categories(self, call, user_id, text, balance, msg_id):
|
||||
try:
|
||||
user = await self.client.get_entity(user_id)
|
||||
except:
|
||||
await call.answer("Ошибка получения пользователя", show_alert=True)
|
||||
return
|
||||
|
||||
available_categories = [price for price in self.gift_categories.keys() if balance >= price]
|
||||
|
||||
buttons = []
|
||||
row = []
|
||||
for price in sorted(available_categories):
|
||||
row.append({
|
||||
"text": f"{price} ⭐",
|
||||
"callback": self._show_category,
|
||||
"args": (user_id, price, text, balance, msg_id),
|
||||
})
|
||||
if len(row) == 2:
|
||||
buttons.append(row)
|
||||
row = []
|
||||
|
||||
if row:
|
||||
buttons.append(row)
|
||||
|
||||
await call.edit(
|
||||
self.strings["gift_menu"].format(
|
||||
f"@{user.username}" if user.username else user.first_name,
|
||||
text if text else "-",
|
||||
balance
|
||||
),
|
||||
reply_markup=buttons
|
||||
)
|
||||
|
||||
async def _send_gift(self, call, user_id, gift_id, text, gift_emoji, msg_id, balance):
|
||||
try:
|
||||
await call.edit(
|
||||
self.strings["sending_gift"],
|
||||
reply_markup=None
|
||||
)
|
||||
|
||||
user = await self.client.get_input_entity(user_id)
|
||||
inv = InputInvoiceStarGift(
|
||||
user,
|
||||
@@ -116,6 +230,7 @@ class SenderGifts(loader.Module):
|
||||
result = await self.client(SendStarsFormRequest(form.form_id, inv))
|
||||
|
||||
await call.edit(self.strings["gift_sent"])
|
||||
|
||||
except BadRequestError as e:
|
||||
if "BALANCE_TOO_LOW" in str(e):
|
||||
await call.edit(
|
||||
@@ -125,13 +240,12 @@ class SenderGifts(loader.Module):
|
||||
else:
|
||||
logging.error(f"Error sending gift: {e}")
|
||||
await call.edit(
|
||||
f"❌ Ошибка при отправке подарка: {str(e)}",
|
||||
f"<emoji document_id=4958526153955476488>❌</emoji> Ошибка при отправке подарка: {str(e)}",
|
||||
reply_markup=None
|
||||
)
|
||||
except Exception as e:
|
||||
logging.error(f"Error sending gift: {e}")
|
||||
await call.edit(
|
||||
f"❌ Ошибка при отправке подарка: {str(e)}",
|
||||
f"<emoji document_id=4958526153955476488>❌</emoji> Ошибка при отправке подарка: {str(e)}",
|
||||
reply_markup=None
|
||||
)
|
||||
# эрон Дон Дон
|
||||
|
||||
Reference in New Issue
Block a user