Compare commits

...

68 Commits

Author SHA1 Message Date
RakVhalate
c3b6e56010 #5 old posts delete function 2024-01-23 06:33:53 +10:00
RakVhalate
150472a2de Deleter Temlpate 2024-01-22 05:16:36 +10:00
RakVhalate
10df69242d Some refactor 2024-01-21 17:00:25 +10:00
Pavel_Durov
deac88534a CHANGE TIME TO NEWS YEAR 2023-12-17 20:59:37 +03:00
Pavel_Durov
50504b14ce Merge branch 'main' of https://git.guaranteedstruggle.host/Pavel_Durov/python_bot 2023-07-20 23:13:36 +03:00
Pavel_Durov
3965b11643 add generate images 2023-07-20 23:10:49 +03:00
Simple_Not
4e128198b7 Merge branch 'main' of https://git.guaranteedstruggle.host/Pavel_Durov/python_bot 2023-07-20 16:10:27 +10:00
Simple_Not
0cf7423806 fix /golbal 2023-07-20 16:09:27 +10:00
Pavel_Durov
28d0e6fdbf Merge branch 'main' of https://git.guaranteedstruggle.host/Pavel_Durov/python_bot 2023-07-18 18:49:53 +03:00
Pavel_Durov
49ac3b7a48 пробуем 2023-07-18 18:42:04 +03:00
Simple_Not
2b7cbb0664 Merge branch 'main' of https://git.guaranteedstruggle.host/Pavel_Durov/python_bot 2023-07-18 15:41:55 +10:00
Simple_Not
bba000877e check drone-jobs 2023-07-18 15:41:39 +10:00
Pavel_Durov
6c22fa72d1 сука 2023-07-18 01:04:31 +03:00
Pavel_Durov
1a6d0e7e91 fix 2023-07-18 01:02:29 +03:00
Pavel_Durov
9315a123f1 не починилось 2023-07-18 00:41:21 +03:00
Pavel_Durov
1f31c5155b fix replys 2023-07-18 00:39:15 +03:00
Pavel_Durov
fc437530e4 fix 2023-07-17 23:52:36 +03:00
Pavel_Durov
cbd8e13d79 add reply to davinci 2023-07-17 23:39:33 +03:00
Pavel_Durov
8fc70c267d now commands work onnly in groups except for adms 2023-07-17 23:24:10 +03:00
Pavel_Durov
f49233b811 fix 2023-07-17 22:22:12 +03:00
Pavel_Durov
3831d4e8d4 added start command, replace comands in __init__.py 2023-07-17 22:19:25 +03:00
Simple_Not
0278189ded bring it back 2023-07-17 15:21:28 +10:00
Simple_Not
a842b3ae01 bring it back 2023-07-17 15:19:03 +10:00
Simple_Not
d427d189b1 bring it back 2023-07-17 15:18:56 +10:00
Simple_Not
08cc6b40c1 remake many certs 2023-07-17 14:41:29 +10:00
Simple_Not
ba0867f662 remake many certs 2023-07-17 12:36:06 +10:00
Simple_Not
c764b71af0 fixxxxx 2023-07-16 14:45:35 +10:00
Simple_Not
b9cd608d9b fixxxxx 2023-07-16 14:45:12 +10:00
Simple_Not
77b6293ea6 fixxxxx 2023-07-16 14:34:49 +10:00
Simple_Not
8c269fd768 fixxxxx 2023-07-16 14:29:54 +10:00
Simple_Not
256bdfb89b fixxxxx 2023-07-16 14:24:23 +10:00
Simple_Not
b5903bf79f ZERO worked 2023-07-16 02:00:21 +10:00
Simple_Not
11ddb1536c unittest pipisa 2023-07-16 01:53:33 +10:00
Simple_Not
19999b28ad fixxed pipisa 2023-07-16 01:51:52 +10:00
Simple_Not
e8190a500d fixxed pipisa 2023-07-16 01:50:12 +10:00
Pavel_Durov
76d14126a1 -9 2 10 2023-07-14 22:21:27 +03:00
Pavel_Durov
345168aa80 test 2023-07-13 19:38:51 +03:00
Pavel_Durov
e2467803c5 back sendalarm 2023-07-13 19:28:16 +03:00
Simple_Not
489a3304a4 HARD core 2023-07-13 15:19:31 +10:00
Simple_Not
456d0619df another wut 2023-07-13 14:39:20 +10:00
Simple_Not
360f8d4c55 another wut 2023-07-13 13:48:52 +10:00
Simple_Not
c39f1cde04 now we counting 2023-07-13 01:16:26 +10:00
Simple_Not
3f04de5cb1 now we counting 2023-07-13 01:00:50 +10:00
Simple_Not
53c48dbb44 now we counting 2023-07-13 00:40:55 +10:00
Simple_Not
361648f1c7 now we counting 2023-07-13 00:39:35 +10:00
Simple_Not
2de30513b2 now we counting 2023-07-13 00:31:00 +10:00
Simple_Not
f46ba32473 now we counting 2023-07-13 00:05:06 +10:00
Simple_Not
8d599c239b now we counting 2023-07-13 00:03:16 +10:00
Simple_Not
9403350e15 now we counting 2023-07-13 00:01:25 +10:00
Simple_Not
9f27070585 now we counting 2023-07-12 22:40:45 +10:00
Simple_Not
40927b95cc bring dick back. 2023-07-12 22:33:36 +10:00
Simple_Not
460fccc6ab bring dick back. 2023-07-12 22:07:03 +10:00
Simple_Not
1e4e6fa4d6 bring dick back. 2023-07-12 22:00:17 +10:00
Simple_Not
c4ca3a98a1 bring dick back. 2023-07-12 21:58:56 +10:00
Simple_Not
25e82e28d5 bring dick back. 2023-07-12 21:58:19 +10:00
Simple_Not
e93d2c0ef7 bring dick back. 2023-07-12 21:54:24 +10:00
Simple_Not
b673b43c93 no idia what i changed 2023-07-12 19:39:57 +10:00
Simple_Not
c02215574d no idia what i changed 2023-07-12 19:39:26 +10:00
Pavel_Durov
dea7805dff новый год сука 2023-06-22 19:11:51 +03:00
Pavel_Durov
40abc7065d add poitive random for first user (69) 2023-06-20 22:44:03 +03:00
Pavel_Durov
c02458b209 add poitive random for first user (69) 2023-06-20 22:34:39 +03:00
fe64756bc4 #DICKBOT-1 Done 2023-06-20 11:30:43 +10:00
6923cd2aa8 Update 'README.md' 2023-06-20 11:28:25 +10:00
b73468c73f Update 'README.md' 2023-06-20 11:24:38 +10:00
671c39be27 d
d
2023-06-20 11:23:56 +10:00
b9813528b1 Add 'README.md' 2023-06-20 11:22:59 +10:00
293d90fb29 Update '.drone.yml' 2023-06-19 08:57:33 -04:00
9432f67ada Update '.drone.yml' 2023-06-19 08:57:15 -04:00
19 changed files with 525 additions and 201 deletions

View File

@ -15,11 +15,18 @@ steps:
- name: test it first - name: test it first
commands: commands:
- /usr/bin/python3 -m py_compile bot.py - /usr/bin/python3 -m py_compile bot.py
- /usr/bin/python3 pipisa_functions/pipisa_time.py
- name: pull into the folduh - name: pull into the folduh
commands: commands:
- cd /usr/share/$DRONE_REPO_NAME - cd /usr/share/$DRONE_REPO_NAME
- git pull - su -c "git pull" jack
- chown -R jack:jack . #- chown -R jack:jack .
when:
branch:
- main
- name: restart systemd unit - name: restart systemd unit
commands: commands:
- systemctl restart jack_bot - systemctl restart jack_bot
when:
branch:
- main

18
DBChat/user_operations.py Normal file
View File

@ -0,0 +1,18 @@
import datetime
def UserCreate(DBName, message, result, replyId): #create new user
new_user = { #описание класса пользователя
'user_id': message.from_user.id, #уникальный идентификатор пользователя
'user_fullname': message.from_user.full_name, #никнэйм
'dick_size': result, #размер пиписы
'datetimes': datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"), #время прокрута
'attempts': 1, #общее количество попыток прокрутки
'chat_id': message.chat.id, #уникальный идентификатор конфы, в которой этот пользователь крутит
'reply_id': replyId.id #идентификатор последнего ответа для этого пользователя
}
try:
metadata = DBName.insert(new_user, overwrite_mode='update')
except Exception as add_err:
print('ошибка в добавлении нового пользователя')
print(add_err)

13
README.md Normal file
View File

@ -0,0 +1,13 @@
Пробуем проверять что-либо.
```mermaid
journey
title Пиписа
section Наш Чат
Оче больше пипис: 5: ГЕГЕМОН
Обычно большепенис: 3: Догоняющие
Скромный дик: 1: Отставшие
section Не наш чат
Не запустил: -1: Отставшие
Не крутил: 1: Отставшие
```

64
TopMsg/topdicks.py Normal file
View File

@ -0,0 +1,64 @@
async def topdicks_conf(chatId): # тело метода лучших результатов отдельной конфы
arango_client = ArangoClient(hosts='https://arango.guaranteedstruggle.host')
pipisa_db = arango_client.db('pipisa', username='root', password='stolendick527')
dicks_collection = pipisa_db.collection('dicks')
try:
dicks = dicks_collection.find({'chat_id': chatId}, skip=0, limit=1100)
dicks = [d for d in dicks]
except Exception as e:
print('ошибка DB в /topdick')
print(e)
top_dicks = sorted(dicks, key=lambda dick: dick['dick_size'], reverse=True)
dick_limit = min(len(top_dicks), 10)
top_dicks = top_dicks[:dick_limit]
conf_top = ''
emo = ['🏆','🚀','🍆','🍌','🐍','🐎','🌭','🌶','👌','💩']
if len(top_dicks) == 0:
await bot.send_message(message.chat.id, '🍆 Никто ничего не нарастил! 🍌')
else:
for i in range(len(top_dicks)):
conf_top += f' {emo[i]} {i+1}. {top_dicks[i]["user_fullname"]}: {top_dicks[i]["dick_size"]}см\n'
i += 1
return conf_top
async def topdicks_global(chatId): #тело метода глобальных лучших результатов
arango_client = ArangoClient(hosts='https://arango.guaranteedstruggle.host')
pipisa_db = arango_client.db('pipisa', username='root', password='stolendick527')
dicks_collection = pipisa_db.collection('dicks')
try:
dicks = dicks_collection.all( )
dicks = [d for d in dicks if d['user_id'] != d['chat_id']]
except Exception as e:
print('ошибка DB в /glovaldick')
print(e)
top_dicks = sorted(dicks, key=lambda dick: dick['dick_size'], reverse=True)
dick_limit = min(len(top_dicks), 10)
top_dicks = top_dicks[:dick_limit]
global_top = ''
emo = ['🏆','🚀','💫','🍆','🍌','🐍','🐎','🌭','🌶','👌']
if len(top_dicks) == 0:
await bot.send_message(chatId, '🍆 Никто ничего не нарастил! 🍌')
else:
for i in range(len(top_dicks)):
global_top += f' {emo[i]} {i+1}. {top_dicks[i]["user_fullname"]}: {top_dicks[i]["dick_size"]}см\n'
i += 1
return global_top

0
__init__.py Normal file
View File

8
bot.py
View File

@ -1,20 +1,12 @@
import logging import logging
import graypy
from aiogram import executor from aiogram import executor
from create_bot import dp from create_bot import dp
import handlers import handlers
logging.basicConfig(level=logging.DEBUG) logging.basicConfig(level=logging.DEBUG)
logging.basicConfig(
level = logging.DEBUG,
handlers = [ graypy.GELFUDPHandler('localhost', 12201) ]
)
# pipisa.register_handlers_pipisa(dp) # pipisa.register_handlers_pipisa(dp)
# time_new_year.register_handlers_time(dp) # time_new_year.register_handlers_time(dp)

View File

@ -1,4 +1,7 @@
from aiogram import Bot, Dispatcher from aiogram import Bot, Dispatcher
API_TOKEN = '5724991559:AAEuLvpLsgP6LHRGMSyFtQLlR5qPQUO4b_w' API_TOKEN = '5724991559:AAEuLvpLsgP6LHRGMSyFtQLlR5qPQUO4b_w'
bot = Bot(token=API_TOKEN, parse_mode="HTML") bot = Bot(token=API_TOKEN, parse_mode="HTML")
dp = Dispatcher(bot) dp = Dispatcher(bot)

34
dicktxt/change_words.py Normal file
View File

@ -0,0 +1,34 @@
import random
def ChangeWord(result): #выбирает рандомное слово для изменения размера пиписы
if result > 0:
size_change = random.choice(dick_inc) + '🚀'
elif result == 0:
size_change = random.choice(dick_static) + '🤨'
else:
size_change = random.choice(dick_decr) + ''
dick_inc = (
'<b>вырос</b>',
'<b>подрос</b>',
'<b>привстал</b>',
'<b>увеличился</b>',
'<b>преисполнился</b>'
)
dick_static = (
'<b>продвинулся</b>',
'<b>наноуменьшился</b>',
'<b>познал стабильность</b>',
'<b>зафиксировал прибыль</b>'
)
dick_decr = (
'<b>неудачно потусил на сходке</b>',
'<b>уменьшился</b>',
'<b>откусила злая гадюка</b>',
'<b>продали евреи, он стал дешевле</b>',
'<b>схуднул</b>'
'<b>отрицательно вырос</b>'
)
return size_change

View File

@ -1,4 +1,4 @@
Кожаный бабах кожаный бабах
пистон пистон
дуршлаг дуршлаг
елдак елдак
@ -93,3 +93,4 @@
венерический суккуб венерический суккуб
боец невидимого фронта боец невидимого фронта
сморчок сморчок
джечник

View File

@ -1,7 +1,8 @@
from handlers import pipisa from handlers import pipisa
from handlers import davinci
from handlers import time_new_year
from handlers import sendalarm
from handlers import start_help from handlers import start_help
from handlers import time_new_year
from handlers import sendalarm
from handlers import davinci

View File

@ -1,14 +1,49 @@
import openai import openai
from aiogram import types, Dispatcher from aiogram import types, Dispatcher
from create_bot import dp, bot from create_bot import dp, bot
import logging
token = '5947963644:AAF_GKgMmU5ovqMpc1KXIpcf4aN0JMyKPqc' token = '5947963644:AAF_GKgMmU5ovqMpc1KXIpcf4aN0JMyKPqc'
openai.api_key = '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' #openai.api_key = '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'
openai.api_key = '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'
ban_comands = ['/dick','/topdick']
# Image_promt =['тупица сгенерируй','тупица сгенерируй картинку',\
# 'тупица отправь картинку', 'тупица отправь картинку']
@dp.message_handler(commands=['image'])
async def send_image(message: types.Message):
try:
description = message.text.replace('/image', '').strip()
if not description:
await message.reply('Ты даун, описание запроса напиши после пробела')
return
except Exception as e:
logging.error(f'Error in send_image: {e}')
try:
response = openai.Image.create(
prompt=message.text,
n=1,
size="1024x1024",
response_format="url",
)
image_url = response['data'][0]['url']
await message.answer('Генерирую изображение...')
await message.reply_photo(image_url)
except Exception as e:
await message.reply('у меня не получилось')
@dp.message_handler() @dp.message_handler()
async def send(message: types.Message): async def send(message: types.Message):
if 'тупица' in message.text.lower(): if message.text.lower().startswith('тупица'):
## TODO уточнить остатки токенов и денег
response = openai.Completion.create( response = openai.Completion.create(
model="text-davinci-003", model="text-davinci-003",
prompt=message.text[7:], prompt=message.text[7:],
@ -21,5 +56,24 @@ async def send(message: types.Message):
) )
await message.reply(response['choices'][0]['text']) await message.reply(response['choices'][0]['text'])
elif message.reply_to_message.from_user.is_bot:
response = openai.Completion.create(
model="text-davinci-003",
prompt=message.text,
temperature=0.7,
max_tokens=1000,
top_p=1.0,
frequency_penalty=0.0,
presence_penalty=0.6,
stop=["сброс"]
)
await message.reply(response['choices'][0]['text'])

View File

@ -1,179 +1,155 @@
from aiogram import types, Dispatcher from aiogram import types, Dispatcher
from sqlalchemy.orm.session import close_all_sessions
from create_bot import bot, dp from create_bot import bot, dp
from sqdb import user, session
import random import random
from random import randint from random import randint
import datetime import datetime
from dicktxt import ForReadDict from dicktxt import ForReadDict
from dicktxt import change_words
from pipisa_functions import pipisa_time
from DBChat import user_operations
from TopMsg import topdicks
from handlers import post_cleaner
#### https://docs.python-arango.com/en/main/
from arango import ArangoClient
admins = [317051301, 226765676]
@dp.message_handler(commands=["dick"]) @dp.message_handler(commands=["dick"])
async def up_dick(message: types.Message): async def up_dick(message: types.Message):
# рандомайзер #global size_change, dick_plus, dick_minus
numb = randint(-6,10)
global size_change, dick_plus, dick_minus if message.from_user.id in admins or message.chat.type != 'private':
dick_plus = ('<b>вырос</b>', '<b>подрос</b>', '<b>привстал</b>')
dick_minus = ('<b>уменьшился</b>', '<b>откусила злая гадюка</b>', '<b>продали евреи, он стал дешевле</b>')
if numb > 0: arango_client = ArangoClient(hosts='https://arango.guaranteedstruggle.host')
size_change = random.choice(dick_plus) + '🚀' pipisa_db = arango_client.db('pipisa', username='root', password='stolendick527')
#if numb = 0 size_change = random.choice(const) TODO dicks_collection = pipisa_db.collection('dicks')
else: size_change = random.choice(dick_minus) + ''
result = randint(-9,10) # главный рандомайзер
try: ## Тело метода прокрутки
candidate_cursor = dicks_collection.find( ## Проверить наличие пользователя в базе
{
'user_id': message.from_user.id,
'chat_id': message.chat.id
},
skip=0, limit=1488)
if candidate_cursor.count() > 0: ## Если пользователь есть то нарастить и отправить сообщение
user = candidate_cursor.pop()
if pipisa_time.rolltime(check_datetime=user['datetimes'], curr_time=datetime.datetime.now()):
updetedDick = user["dick_size"] + result ## получение итогового результата
pipisa_word = ForReadDict.RandomDick()
change_word = change_words.ChangeWord(result)
enl_message = await bot.send_message(message.chat.id, f"@\
{message.from_user.username}, \
ваш <em>{pipisa_word}</em> ,{change_word(result)} на <b>{abs(result)}</b> см!\n\ \
Теперь он равен <b>{updetedDick}</b> см! ")
post_cleaner.cleanup_sequence(user['user_id'], enl_message.id, message.chat.id)
# работа с таблицей
try: try:
b = session.query(user).filter(user.user_id == message.from_user.id).first() dt = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S")
if b: metadata = dicks_collection.insert(
last_time = b.datetimes {
now_time = datetime.datetime.now() '_key': user['_key'], ## этот нужен чтобы апдейт прилетал тому же юзеру
diff = now_time.day - last_time.day 'user_id': user['user_id'],
'user_fullname': message.from_user.full_name,
if abs(diff) <= 0: 'dick_size': updetedDick,
try: 'datetimes': datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S"),
current_dick = b.dick_size 'attempts': user['attempts'] + 1,
'chat_id': message.chat.id
},
await bot.send_message(message.chat.id, f'@{message.from_user.username},🚫 вы уже крутили пипису, ее размер <b>{current_dick}</b> см! ') overwrite_mode='update'
except: )
print('ошибка в if diff <=0') print(f'Успешно апдейтнули пипису @{message.from_user.username}')
session.rollback() except Exception as update_err:
finally: print(f'ошибка в обновлении пиписы @{message.from_user.username}')
session.close_all() print(update_err)
print('пользователь уже крутил')
else: else:
error_msg = await bot.send_message(message.chat.id, f'@\
{message.from_user.username},🚫 вы уже крутили пипису, \
ее размер <b>{user["dick_size"]}</b> см! ')
post_cleaner.cleanup_sequence(user['user_id'], error_msg.id, error_msg.chat.id)
try: try:
a = session.query(user).filter(user.user_id == message.from_user.id).first() # запрос на поиск в таблице metadata = dicks_collection.insert(
updetedDick = a.dick_size = (a.dick_size + numb) {
a.datetimes = datetime.datetime.now() '_key': user['_key'], ### этот нужен чтобы апдейт прилетал тому же юзеру
session.flush() 'user_id': user['user_id'] ,
session.commit() #обновляет запись 'user_fullname': message.from_user.full_name,
randomword = ForReadDict.RandomDick() 'dick_size': user['dick_size'] ,
'datetimes': user['datetimes'] ,
await bot.send_message(message.chat.id, f'@{message.from_user.username}, ваш <em>{randomword}</em> {size_change}\ 'attempts': user['attempts'] + 1,
на <b>{abs(numb)}</b> см!\n\ 'chat_id': message.chat.id,
Теперь он равен <b>{updetedDick}</b> см! ') },
except: overwrite_mode='update'
session.rollback() )
print('ошибка в обновлении пиписы') print(f'Успешно апдейтнули попытку крутить пипису @{message.from_user.username}')
finally: except Exception as roll_err:
session.close_all() print(f'ошибка в обновлении попытки крутить пипису @{message.from_user.username}')
print('пиписа обновлена') print(roll_err)
print(f'пользователь @{message.from_user.username} уже крутил')
else: ## если пользователь не найден то создаём ему запись в БД
if result > 0:
new_reply = await bot.send_message(message.chat.id, f'@\
{message.from_user.username}, ваш писюн показал головку 🚀\n\
на <b>{abs(result)}</b> см!\n\
Теперь он равен <b>{result}</b> см!')
else: else:
session.close() new_reply =await bot.send_message(message.chat.id, f'@\
try: {message.from_user.username}, добро пожаловать в игру!🚀\n\
int_table = user(user_id = message.from_user.id, user_fullname = message.from_user.full_name, dick_size = numb, datetimes = datetime.datetime.now(),\ Ты стартуешь не с лучшей позиции, природа наградила тебя всего <b>{result}</b> см 😬')
chat_id = message.chat.id)
user_operations.UserCreate(dicks_collection, message, result, new_reply.id)
print(f'Успешно добавлен пользователь @{message.from_user.username}')
except Exception as crit_err:
print('ошибка DB в /dick')
print(crit_err)
else:
await message.reply('Растить елду можно только в общих чатах!')
session.add(int_table)
session.flush()
session.commit()
session.close()
await bot.send_message(message.chat.id, f'@{message.from_user.username}, ваш писюн {size_change}\n\
на <b>{abs(numb)}</b> см!\n\
Теперь он равен <b>{numb}</b> см!')
except:
print('ошибка в добавлении нового пользователя')
session.rollback()
finally:
session.close_all()
print('Успешно добавлен пользователь')
except:
session.rollback()
print('ошибка в основном коде')
finally:
session.close_all()
@dp.message_handler(commands=["topdick"]) @dp.message_handler(commands=["topdick"])
async def send_topchat(message: types.Message): async def send_topchat(message: types.Message): # тело метода лучших результатов отдельной конфы
try: if message.from_user.id in admins or message.chat.type != 'private':
changechat_id = session.query(user).filter(user.user_id == message.from_user.id).first()
chats = message.chat.id dickos = topdicks.topdicks_conf(message.chat.id)
if changechat_id.chat_id != chats: await bot.send_message(message.chat.id, '🏆Топ 10 бубылд чата🏆\n\n' + dickos)
changechat_id.chat_id = chats
session.commit()
session.close()
else: else:
session.close() await message.reply('Работает только в общих чатах!\n'\
top = session.query(user.user_fullname, user.dick_size).order_by(user.dick_size.desc()).filter(user.chat_id == chats).limit(10).all() 'Вы мсжете посмотреть топ по миру: /globaldick')
delimiter = ': '
# проверка на длину списка, если меньше limit, то:
sizelen = len(top)
if sizelen < 10:
lenminus = 10 - sizelen
top.extend(('-'*lenminus))
await bot.send_message(message.chat.id, f'🏆Топ 10 бубылд чата🏆\n\n\
🚀 {delimiter.join(map(str, top[0]))}\n\
💫 {delimiter.join(map(str, top[1]))}\n\
🍆 {delimiter.join(map(str, top[2]))}\n\
🍌 {delimiter.join(map(str, top[3]))}\n\
🐍 {delimiter.join(map(str, top[4]))}\n\
🐎 {delimiter.join(map(str, top[5]))}\n\
🌭 {delimiter.join(map(str, top[6]))}\n\
🌶 {delimiter.join(map(str, top[7]))}\n\
👌 {delimiter.join(map(str, top[8]))}\n\
💩 {delimiter.join(map(str, top[9]))}\n')
session.close()
# если все нормально и участников минимум 10
else:
await bot.send_message(message.chat.id, f'🏆Топ 10 бубылд чата🏆\n\n\
🚀 {delimiter.join(map(str, top[0]))}\n\
💫 {delimiter.join(map(str, top[1]))}\n\
🍆 {delimiter.join(map(str, top[2]))}\n\
🍌 {delimiter.join(map(str, top[3]))}\n\
🐍 {delimiter.join(map(str, top[4]))}\n\
🐎 {delimiter.join(map(str, top[5]))}\n\
🌭 {delimiter.join(map(str, top[6]))}\n\
🌶 {delimiter.join(map(str, top[7]))}\n\
👌 {delimiter.join(map(str, top[8]))}\n\
💩 {delimiter.join(map(str, top[9]))}\n')
except:
session.rollback()
print('ошибка в /topdick')
finally:
session.close_all()
@dp.message_handler(commands=["globaldick"]) @dp.message_handler(commands=["globaldick"])
async def send_global_top(message: types.Message): async def send_global_top(message: types.Message): # тело метода лучших результатов
try: tops = topdicks.topdicks_global(message.chat.id,)
top_chat = session.query(user.user_fullname, user.dick_size).order_by(user.dick_size.desc()).limit(10).all()
delimiter = ': ' await bot.send_message(message.chat.id, '🏆Топ 10 пипис в мире🏆\n\n' + tops)
await bot.send_message(message.chat.id, f'🏆Топ 10 пипис в мире🏆\n\n\
1. {delimiter.join(map(str, top_chat[0]))}\n\
2. {delimiter.join(map(str, top_chat[1]))}\n\
3. {delimiter.join(map(str, top_chat[2]))}\n\
4. {delimiter.join(map(str, top_chat[3]))}\n\
5. {delimiter.join(map(str, top_chat[4]))}\n\
6. {delimiter.join(map(str, top_chat[5]))}\n\
7. {delimiter.join(map(str, top_chat[6]))}\n\
8. {delimiter.join(map(str, top_chat[7]))}\n\
9. {delimiter.join(map(str, top_chat[8]))}\n\
10. {delimiter.join(map(str, top_chat[9]))}\n')
except:
session.rollback()
print('ошибка в /glovaldick')
finally:
session.close_all()
# def register_handlers_pipisa(dp: Dispatcher):
# dp.register_message_handler(up_dick)
# dp.register_message_handler(send_topchat)
# dp.register_message_handler(send_global_top)

69
handlers/post_cleaner.py Normal file
View File

@ -0,0 +1,69 @@
import datetime
from arango import ArangoClient
from create_bot import bot
def get_remove_collection():
arango_client = ArangoClient(hosts=CONFIG['databaso']['host'] )
pipisa_db = arango_client.db(
CONFIG['databaso']['base'],
username=CONFIG['databaso']['user'],
password=CONFIG['databaso']['pass']
)
remove_collection = pipisa_db.collection(CONFIG['databaso']['deleteCollection'])
return remove_collection
async def cleanup_sequence(userID: int, messageID:int, chatID:int):
#remove last reply and check posts older than 5 minutes to delete
remove_collection = get_remove_collection
try:
clean_candidate = remove_collection.find(
{
'_key': userID,
'chat_id': chatID
},
skip=0, limit=1000)
prev_enl_message_id = clean_candidate["messageID"]
await bot.delete_message(prev_enl_message_id) #delete last reply to this user
current_time = datetime.datetime.now()
too_old = current_time-datetime.timedelta(min=5)
old_posts = remove_collection.find(
{
'chat_id': chatID,
},
skip=0, limit=1000)
for old_Post in old_posts:
if old_Post["datetimes"] <= too_old:
to_delete_ID = old_Post["messageID"]
to_delete_UserId = old_Post['_key']
await bot.delete_message(to_delete_ID) #delete old message
old_posts.delete(to_delete_UserId) #delete old message DB entry
except Exception as autoCleanErr:
print(autoCleanErr)
#write last reply post ID to db
remove_collection = get_remove_collection
message_time = datetime.datetime.now()
try:
lastReply = {
'_key': userID,
'datetimes': message_time,
'chat_id': chatID,
'messageID': messageID
}
metadata = remove_collection.insert(lastReply, overwrite_mode='update') #write last reply time
except Exception as lastWriteErr:
print(lastWriteErr)
return 0

View File

@ -12,10 +12,10 @@ async def sendall(message: types.Message):
if message.from_user.id == 226765676: if message.from_user.id == 226765676:
text = message.text[9:] text = message.text[9:]
try: try:
chats_id = session.query(user.chat_id).distinct() chats_id = -1001355646177
for row in chats_id:
try: try:
await bot.send_message(row[0], text) await bot.send_message(chats_id, text)
except: except:
print('вероятно бота нет в чате') print('вероятно бота нет в чате')
await bot.send_message(message.from_user.id, 'Сообщение успешно отправлено во все чаты') await bot.send_message(message.from_user.id, 'Сообщение успешно отправлено во все чаты')

View File

@ -1,22 +1,27 @@
from aiogram import types, Dispatcher from aiogram import types, Dispatcher
from aiogram.types import InlineKeyboardMarkup, InlineKeyboardButton
from create_bot import dp, bot from create_bot import dp, bot
@dp.message_handler(commands=['start']) @dp.message_handler(commands=['start'])
async def start_func(message: types.Message): async def start_func(message: types.Message):
await message.reply('похуй') if message.chat.type == 'private':
lkb = InlineKeyboardMarkup(row_width=1).add(InlineKeyboardButton(text = 'Добавить в группу', callback_data='add_2_group'))
await message.answer(f'<b>Добро пожаловать, {message.from_user.full_name}!</b>\n'
'Это бот, который растит члены. Чтобы начать, добавь бота в чат'\
, reply_markup=lkb
)
# TODO добавить кнопку, по которой смогут добавлять юзера в чат
@dp.callback_query_handler(text = 'add_2_group')
async def addgroup(callback: types.CallbackQuery):
await callback.answer('жмав')
@dp.message_handler(commands=['photo'])
async def send_image(message: types.Message):
await bot.send_photo(message.chat.id, photo='https://memepedia.ru/wp-content/uploads/2018/08/ya-pidoras.jpg', reply_to_message_id=message.message_id)
@dp.message_handler(content_types=types.ContentTypes.TEXT)
async def send_faggot(message: types.Message):
print(message.text)
if message.text == 'хто я':
await bot.send_photo(message.chat.id, photo='https://www.meme-arsenal.com/memes/ecebd2339c7eab40e09874bd86a38a09.jpg')
def register_handlers_StartHelp(dp: Dispatcher):
dp.register_message_handler(start_func)
dp.register_message_handler(send_faggot)
dp.register_message_handler(send_image)

View File

@ -4,7 +4,7 @@ import datetime
@dp.message_handler(commands=["time"]) @dp.message_handler(commands=["time"])
async def send_time(message: types.Message): async def send_time(message: types.Message):
new_year = datetime.datetime(2022, 12, 31) #дата нового года new_year = datetime.datetime(datetime.now().year, 12, 31) #дата нового года
ct = datetime.datetime.now() #датавремя ct = datetime.datetime.now() #датавремя
cd = datetime.datetime.now().strftime("%d/%m/%Y") #дата (д,м,г) cd = datetime.datetime.now().strftime("%d/%m/%Y") #дата (д,м,г)
ct1 = ct+datetime.timedelta(hours=15) # +14 часов от сервера ct1 = ct+datetime.timedelta(hours=15) # +14 часов от сервера

View File

@ -0,0 +1 @@
from . import pipisa_time

View File

@ -0,0 +1,88 @@
import unittest
import datetime
def rolltime(check_datetime , curr_time=datetime.datetime.now()):
last_time = datetime.datetime.strptime(check_datetime, '%Y-%m-%d %H:%M:%S')
time_to_grow = curr_time.replace(hour=14, minute=8, second=8, microsecond=0) #+ datetime.timedelta(days=0)
timediff = (time_to_grow - last_time).total_seconds()
# print()
# print(f'\tlast_time : {last_time}')
# print(f'\ttime_to_grow : {time_to_grow}')
# print(f'\tcurr_time : {curr_time.strftime("%Y-%m-%d %H:%M:%S")}')
# print(f'\t\tsecs diff : {timediff}')
if timediff > 86400 or (curr_time > time_to_grow and last_time < time_to_grow):
return True
else:
return False
class TestPipisa(unittest.TestCase):
def test_very_long_ago(self):
self.assertEqual(rolltime('2021-10-11 23:44:00'), True, "Пиписа прокручена очень давно. Очевидный прокрут")
def test_just_after(self):
self.assertEqual(rolltime(
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0).strftime('%Y-%m-%d %H:%M:%S')
), False, "Попытка крутить когда старый прокрут был через 1 минуту после сегодняшнего обновления роллов. Фейл.")
def test_yesterdayroll(self):
self.assertEqual(
rolltime(
(
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0) - datetime.timedelta(days=1)
).strftime('%Y-%m-%d %H:%M:%S'),
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0)
), True, "Крутилась вчера через минуту после обновления роллов. Должно пропускать ")
def test_hour_before_roll(self):
self.assertEqual(
rolltime(
(
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0) - datetime.timedelta(hours=1)
).strftime('%Y-%m-%d %H:%M:%S'),
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0)
), True, "Крутилась последний раз за час до прокрута. Надо разрешать заново!")
def test_after_midnight(self):
self.assertEqual(
rolltime(
(
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0) - datetime.timedelta(hours=14)
).strftime('%Y-%m-%d %H:%M:%S'),
datetime.datetime.now().replace(hour=0, minute=11, second=8, microsecond=0)
), False, "Где-то ночью прокручивается повторно. Фейл.")
def test_before_midnight(self):
self.assertEqual(
rolltime(
(
datetime.datetime.now().replace(hour=14, minute=9, second=8, microsecond=0) - datetime.timedelta(hours=15)
).strftime('%Y-%m-%d %H:%M:%S'),
datetime.datetime.now().replace(hour=0, minute=11, second=8, microsecond=0) - datetime.timedelta(hours=15)
), False, "Где-то ночью прокручивается повторно. Фейл.")
def test_somewhere_after(self):
self.assertEqual(
rolltime(
(
datetime.datetime.now().replace(hour=14, minute=26, second=8, microsecond=0)
).strftime('%Y-%m-%d %H:%M:%S'),
datetime.datetime.now().replace(hour=14, minute=27, second=8, microsecond=0)
), False, "Сегодня уже открутили а хотят ещё. Фейл.")
if __name__ == "__main__":
unittest.main(verbosity=2)

View File

@ -1,4 +1,2 @@
aiogram aiogram
sqdb python-arango
sqlalchemy
graypy