|
import asyncio |
|
import logging |
|
import time |
|
import pyrogram |
|
import string |
|
import random |
|
import requests |
|
import aiohttp |
|
from inspect import getfullargspec |
|
from os import path |
|
from random import choice |
|
import aiohttp |
|
import re |
|
import os |
|
|
|
from datetime import datetime as dt |
|
from pyrogram import Client |
|
from pyrogram.types import * |
|
from pyrogram import filters |
|
from pyrogram.errors import * |
|
from pyrogram.raw.all import layer |
|
from pyrogram.handlers import MessageHandler |
|
from config import API_HASH, API_ID, BOT_TOKEN |
|
from database import db |
|
from logger import LOGS |
|
from platform import python_version |
|
from pyrogram import __version__ as pyrogram_version |
|
|
|
StartTime = time.time() |
|
START_TIME = dt.now() |
|
|
|
async def send_log(text_log: str): |
|
url = "https://private-akeno.randydev.my.id/api/v2/send_message_logs" |
|
params = { |
|
"text_log": text_log |
|
} |
|
async with aiohttp.ClientSession() as session: |
|
async with session.post(url, params=params) as response: |
|
if response.status != 200: |
|
return None |
|
data = await response.json() |
|
return data["message"] |
|
|
|
class Randydev(Client): |
|
def __init__(self, loop=None): |
|
self.loop = loop or asyncio.get_event_loop() |
|
|
|
super().__init__( |
|
"openaichat", |
|
api_id=API_ID, |
|
api_hash=API_HASH, |
|
bot_token=BOT_TOKEN, |
|
workers=300, |
|
plugins=dict(root="chatbot.plugins"), |
|
sleep_threshold=180, |
|
) |
|
async def start(self): |
|
try: |
|
await super().start() |
|
except FloodWait as e: |
|
await send_log(f"GPT-4 Bot: {e.value}") |
|
await asyncio.sleep(e.value) |
|
self.start_time = time.time() |
|
LOGS.info( |
|
"akn running with Pyrogram v%s (Layer %s) started on @%s. Hi!", |
|
pyrogram.__version__, |
|
layer, |
|
self.me.username, |
|
) |
|
await send_log(f"akn running with Pyrogram started on @{self.me.username} Hi!") |
|
async def stop(self): |
|
try: |
|
await super().stop() |
|
LOGS.warning("akn stopped, Bye!") |
|
except ConnectionError: |
|
LOGS.warning("akn is already terminated") |