sparkytron3000/sparkytron3000.py

77 lines
2.1 KiB
Python
Raw Normal View History

2023-07-09 00:57:11 -07:00
import discord
2023-07-10 10:38:28 -07:00
from discord.ext import commands, tasks
2023-07-09 00:57:11 -07:00
import shutil
import time
import os
from dotenv import load_dotenv
import aiohttp
2024-01-25 01:38:15 -08:00
import src.logger as logger
2023-07-09 00:57:11 -07:00
load_dotenv()
discord_token = os.getenv('discord_token')
2024-01-25 01:38:15 -08:00
logger = logger.logging.getLogger("bot")
2024-01-20 23:04:12 -08:00
intents = discord.Intents.all()
2023-07-09 00:57:11 -07:00
intents.message_content = True
bot = commands.Bot(command_prefix='!', intents=intents)
2023-07-09 18:02:15 -07:00
2023-07-09 01:57:35 -07:00
async def folder_setup():
folder_names = ["tmp", "extensions", "data"]
2023-07-09 01:57:35 -07:00
for folder_name in folder_names:
if not os.path.exists(folder_name):
os.mkdir(folder_name)
return folder_names
2023-07-09 16:06:45 -07:00
async def delete_all_files(path):
2023-07-09 16:06:45 -07:00
for filename in os.listdir(path):
if os.path.isdir(path+filename):
2023-07-09 16:06:45 -07:00
shutil.rmtree(path+filename)
elif os.path.isfile(path+filename):
os.remove(path+filename)
2023-07-10 17:44:15 -07:00
@tasks.loop(seconds=1) # Run the task every second
2023-07-10 10:38:28 -07:00
async def task_loop():
current_time = time.localtime()
2023-07-10 17:44:15 -07:00
#Run daily tasks
if current_time.tm_hour == 0 and current_time.tm_min == 0 and current_time.tm_sec == 0:
2023-07-10 11:23:05 -07:00
try:
await delete_all_files("tmp/")
2024-01-25 01:38:15 -08:00
logger.info("Deleted tmp/ files.")
2023-07-10 11:23:05 -07:00
except Exception as error:
2024-01-25 01:38:15 -08:00
logger.exception("Failed to delete files!")
async def create_session():
2023-07-25 17:13:23 -07:00
return aiohttp.ClientSession()
async def close_session(http_session):
await http_session.close()
@bot.event
async def on_connect():
bot.http_session = await create_session()
@bot.event
async def on_resumed():
bot.http_session = await create_session()
@bot.event
async def on_disconnect():
await close_session(bot.http_session)
2023-07-09 00:57:11 -07:00
@bot.event
async def on_ready():
await delete_all_files("tmp/")
2024-01-20 00:34:54 -08:00
# Import plugins from extensions folder
for plugin_file in os.listdir('extensions/'):
if plugin_file[0] != '_' and plugin_file[-3:] == '.py':
2024-01-20 00:34:54 -08:00
await bot.load_extension(f'extensions.{plugin_file[:-3]}')
2024-01-25 01:38:15 -08:00
logger.info('We have logged in as {0.user}'.format(bot))
2023-07-10 10:38:28 -07:00
task_loop.start()
2023-07-09 00:57:11 -07:00
@bot.event
async def on_message(ctx):
await bot.process_commands(ctx)
2023-07-09 00:57:11 -07:00
2024-01-25 01:38:15 -08:00
bot.run(discord_token, root_logger=True)