async with AsyncSession(engine) as session:
async with session.begin():
# выполнение операций внутри транзакции
# изменение, добавление или удаление объектов
# выполнение запросов
# после окончания транзакции вызываем session.commit()
await session.commit()
@bot.event
async def on_message(msg):
for webhook in await msg.channel.webhooks():
if webhook.user == bot.user:
if msg.content.startswith(webhook.name):
url = None
try:
url = Memory.read(f"avatars/{msg.channel.id}{webhook.name}webhook.txt")
except disnake.errors.HTTPException:
await webhook.send(content="Слишком много запросов отправлено! Пожалуйста подождите...")
except:
await webhook.send(content = msg.content[len(webhook.name) + 1:])
await msg.delete()
else:
await webhook.send(content = msg.content[len(webhook.name) + 1:], avatar_url=url)
await msg.delete()
@bot.command()
async def feedback(ctx, message:str, user_id:int=None):
if user_id is None:
author = bot.get_user(your_id)
await author.send(f"Вам отправили сообщение: {message}\nАвтор: {ctx.author} | {ctx.author.id}")
else:
user = bot.get_user(user_id)
await user.send(f"Вам отправили сообщение: {message}")
<script src="folder/eel.js"></script>
)<form action="/do_dashboard" method="post">
<label for="">Введите свой айди:</label>
<input name="user_id" type="text" size="40"><br>
<label>Введите айди гильдии:</label>
<input name="server_id" type="text" size="40">
</form>
from flask import request # requests - для принятие данных(вроде бы)
@app.route("/do_dashboard", methods=['get', 'post']) # Методы для принятия даных. Get - обычное получение, а Post - Передача данных.
def dodash():
if request.method == "POST":
user_id = request.form['user_id'] # Выбераем из формы user_id
server_id = request.form['server_id'] # Быбераем из формы server_id
return redirect(f"https://wbot.serega15032011.repl.co/dashboard/{user_id}/{server_id}")
else:
return "Get запрост"
sended = 0
for result in results:
if result == message.from_user.id: pass
else:
try:
bot.send_message(result[0], message.text)
sended+=1
except Exception as e: print(f"[Error] {e}")
bot.send_message(message.from_user.id, f"Отправлено {sended} сообщений!")
let prev_command = ""
bot.command('test', (ctx) => {
ctx.reply("Send your text in chat.")
prev_command = "test"
});
bot.on('text', (ctx) => {
if (prev_command == "test") {
ctx.reply(`Ok, your text '${ctx.message.text}'`)
} else {
ctx.reply("Sorry, usage commands!")
}
})
import discord
import json
import asyncio
from discord.ext import commands
@client.event
async def on_ready():
with open("test.json", 'r') as f:
data = json.load(f)
for i in range(len(data)):
member = await (await client.fetch_guild(data[i]["guild_id"])).fetch_member(data[i]["id"])
client.loop.create_task(pun_start(member))
print("ready")
def check_user_db(user_id:int):
with open('test.json', 'r') as f:
data = json.load(f)
for i in range(len(data)):
if data[i]["id"] == user_id: return True
return False
def add_user_db(user_id:int, guild_id:int, author:str, timeout:int, reason:str, roles:list, role_pun:int):
if check_user_db(user_id) is True: return False
else:
with open('test.json', 'r') as f:
data = json.load(f)
new_user = {
"id": user_id,
"guild_id": guild_id,
"author": f"{author.name}#{author.discriminator}",
"timeout": timeout,
"reason": reason,
"roles": roles,
"role_pun": role_pun
}
data.append(new_user)
with open('test.json', 'w') as f:
json.dump(data, f, indent=3)
return True
def remove_user_db(user_id:int):
if check_user_db(user_id) is False: return False
else:
with open('test.json', 'r') as f:
data = json.load(f)
for i in range(len(data)):
if data[i]["id"] == user_id:
del data[i]
with open('test.json', 'w') as f:
json.dump(data, f)
return True
return False
async def pun_start(user):
with open('test.json', 'r') as f:
data = json.load(f)
user_data = {}
for i in range(len(data)):
if data[i]["id"] == user.id: user_data = data[i]; break
role_pun = discord.utils.get(user.guild.roles, id=id_роли) # роль для наказания
old_roles = user_data["roles"] # старые роли участника
await asyncio.sleep(user_data["timeout"])
await user.remove_roles(role_pun)
for role in old_roles:
role_user = discord.utils.get(user.guild.roles, id=role)
await user.add_roles(role_user)
remove_user_db(user.id)
@client.command()
async def pun(ctx, member:discord.Member=None, timeout:int=None, reason:str="Не указано"):
if member is None or timeout is None:
await ctx.reply("Укажите участника и время.\nПример: !pun @участник 100 - наказываем участника на 100сек.\n**Важно:** Время указывается в секундах!")
elif check_user_db(member.id) is True:
await ctx.reply("Участника уже наказан!")
else:
role_pun = discord.utils.get(ctx.guild.roles, id=id_роли) # роль для наказания
old_roles = [] # старые роли участника
for role in member.roles:
if role.name != "@everyone":
old_roles.append(role.id)
await member.remove_roles(role)
await member.add_roles(role_pun)
add_user_db(member.id, ctx.guild.id, ctx.author, timeout, reason, list(old_roles), role_pun.id) # добавляем участника в файл
await ctx.send(f"{member.mention}, наказан!\nПричина: {reason}")
await asyncio.sleep(timeout)
await member.remove_roles(role_pun)
for role in old_roles:
role_user = discord.utils.get(ctx.guild.roles, id=role)
await member.add_roles(role_user)
remove_user_db(member.id)
await ctx.send(f"Наказания с {member.mention} снято!\nПричина: Автоматическое снятие")
user_phone = "8 928 000 00 00" # Данные пользователя
user_email = "example@example.com" # Данные пользователя
allowed = ["gmail.com", "mail.ru", "yandex.ru"] # Разрещённые почты
# форматируем номер телефона
user_phone = user_phone.replace(" ", "") # Уберём пробелы
if len(user_phone) != 11:
# Длинна номера не равна 11 символам
pass
elif user_email.split("@")[1] not in allowed:
# Почта не верно указана
pass
else:
# Всё хорошо
pass