status-bot/main.py

239 lines
7.7 KiB
Python
Raw Normal View History

2022-08-26 17:39:38 +02:00
#!/usr/bin/python3
import asyncio
2022-09-04 15:33:39 +02:00
import json
2022-08-26 17:39:38 +02:00
import os
import subprocess
import time
2022-08-26 17:39:38 +02:00
import discord
import requests
2022-08-26 17:39:38 +02:00
from discord.ext import commands
import config
def login_required(fn):
async def decorated_fn(ctx, *args):
2022-11-05 13:42:18 +01:00
if str(ctx.author.id) not in config.allowed_users.keys():
await ctx.reply("Vous n'êtes pas autorisé à exécuter cette commande.")
return None
return await fn(ctx, *args)
return decorated_fn
def root_required(fn):
async def decorated_fn(ctx, *args):
if str(ctx.author.id) not in config.allowed_users.keys():
await ctx.reply("Vous n'êtes pas autorisé à exécuter cette commande.")
return None
if config.allowed_users[str(ctx.author.id)] != "*":
2022-08-26 17:54:30 +02:00
await ctx.reply("Vous n'êtes pas autorisé à exécuter cette commande.")
2022-08-26 17:39:38 +02:00
return None
return await fn(ctx, *args)
return decorated_fn
def check_status(service):
"""Renvoie le statut d'un service"""
service_status = os.system(f"systemctl is-active --quiet {service}")
if service_status == 0:
return "✅ Running"
return "❌ Stopped"
2022-09-04 15:33:39 +02:00
def get_temperature():
try:
return json.loads(subprocess.check_output(["sensors", "-Aj"]))
except subprocess.CalledProcessError as err:
return {}
2022-11-05 13:42:18 +01:00
intents = discord.Intents.default()
intents.messages = True
intents.message_content = True
2022-09-04 15:33:39 +02:00
2022-11-05 13:42:18 +01:00
bot = commands.Bot(command_prefix=config.command_prefix, intents=intents)
2022-08-26 17:39:38 +02:00
@bot.event
async def on_ready():
"""On ready"""
print("Connecté en tant que:")
print(bot.user.name)
print(bot.user.id)
print("------")
game = discord.Game(f"Disponible ✅ | {bot.command_prefix}help")
await bot.change_presence(status=discord.Status.idle, activity=game)
2022-09-04 15:33:39 +02:00
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
embed.add_field(
name="Redémarrage", value="Le bot est à nouveau en ligne"
)
temperature = get_temperature()
for key1 in temperature.keys():
for key2 in temperature[key1].keys():
for key3 in temperature[key1][key2].keys():
if "input" in key3:
embed.add_field(
name=f"Temp: {key1} > {key2} > {key3}", value=str(temperature[key1][key2][key3])
)
embed.add_field(
name="Uptime", value=subprocess.check_output(["uptime", "-p"]).decode("utf-8")
)
2022-11-05 13:42:18 +01:00
for discord_id in config.allowed_users.keys():
if config.allowed_users[discord_id] == "*":
user = await bot.fetch_user(discord_id)
await user.send(embed=embed)
2022-09-04 15:33:39 +02:00
2022-08-26 17:39:38 +02:00
services_status = {service:check_status(service) for service in config.services}
while True:
new_services_status = {service:check_status(service) for service in config.services}
for service in new_services_status.keys():
if new_services_status[service] != services_status[service]:
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
embed.add_field(
2022-09-04 15:33:39 +02:00
name=service, value=new_services_status[service], inline=True
2022-08-26 17:39:38 +02:00
)
2022-11-05 13:42:18 +01:00
for discord_id in config.allowed_users.keys():
if config.allowed_users[discord_id] == "*":
user = await bot.fetch_user(discord_id)
await user.send(embed=embed)
2022-08-26 17:39:38 +02:00
services_status = new_services_status
await asyncio.sleep(300)
@bot.command(name="status")
@login_required
async def status(ctx, *args):
2022-08-26 17:39:38 +02:00
"""Renvoie le statut des différents services"""
2022-11-05 13:42:18 +01:00
if config.allowed_users[str(ctx.author.id)] == "*":
user_services = config.services
else:
user_services = config.allowed_users[str(ctx.author.id)]
if len(args) == 0:
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
2022-11-05 13:42:18 +01:00
for service in user_services:
service_status = check_status(service)
embed.add_field(
name=service, value=service_status, inline=False
)
await ctx.reply(embed=embed)
else:
2022-11-05 13:42:18 +01:00
if args[0] not in user_services:
await ctx.reply(f"Service inconnu ou inaccessible `{args[0]}`")
return None
try:
out = subprocess.check_output(["systemctl", "status", args[0]], stderr=subprocess.STDOUT)
except Exception as e:
out = e.output
out = out.decode("UTF-8")
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
2022-08-26 17:39:38 +02:00
embed.add_field(
name=args[0], value=f"```\n{out[:min(len(out)-1, 1017)]}```"
)
await ctx.reply(embed=embed)
2022-08-26 17:39:38 +02:00
2022-08-26 17:54:30 +02:00
@bot.command(name="service")
@login_required
async def service(ctx, *args):
2022-08-26 17:54:30 +02:00
"""Exécute une commande systemd"""
2022-11-05 13:42:18 +01:00
if config.allowed_users[str(ctx.author.id)] == "*":
user_services = config.services
else:
user_services = config.allowed_users[str(ctx.author.id)]
2022-08-26 17:54:30 +02:00
error = None
2022-08-26 17:56:01 +02:00
commands = ["start", "stop", "enable", "disable", "restart"]
2022-08-26 17:54:30 +02:00
if len(args) < 2:
error = "Paramètres manquants."
elif args[0] not in commands:
error = f"Commande invalide `{args[0]}`"
2022-11-05 13:42:18 +01:00
elif args[1] not in user_services:
error= f"Service inconnu ou inaccessible `{args[1]}`"
2022-08-26 17:54:30 +02:00
if error is not None:
await ctx.reply(error)
return None
os.system(f"systemctl {args[0]} {args[1]}")
await ctx.message.add_reaction("🆗")
@bot.command(name="logs")
2022-11-05 13:42:18 +01:00
@root_required
async def logs(ctx, *args):
"""Renvoie des fichier logs"""
logs_files = [
i[:-4] for i in os.listdir(config.logs_dir) if i.endswith(".txt") and os.path.isfile(os.path.join(config.logs_dir, i))
]
if len(args) == 0:
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
embed.add_field(
name="Fichiers de logs disponibles", value="\n".join(logs_files)
)
await ctx.reply(embed=embed)
return None
if args[0] not in logs_files:
print(logs_files)
await ctx.reply("Ce fichier n'existe pas.")
return None
with open(os.path.join(config.logs_dir, f"{args[0]}.txt"), "r") as fp:
await ctx.reply(file=discord.File(fp, filename=f"{args[0]}.txt"))
2022-09-04 15:33:39 +02:00
@bot.command(name="temperature")
2022-11-05 13:42:18 +01:00
@root_required
2022-09-04 15:33:39 +02:00
async def temperature(ctx):
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
temperature = get_temperature()
for key1 in temperature.keys():
for key2 in temperature[key1].keys():
for key3 in temperature[key1][key2].keys():
if "input" in key3:
embed.add_field(
name=f"Temp: {key1} > {key2} > {key3}", value=str(temperature[key1][key2][key3])
)
await ctx.reply(embed=embed)
@bot.command(name="uptime")
@login_required
async def uptime(ctx):
embed = discord.Embed(colour=discord.Colour.blue())
embed.set_author(name=time.strftime("%m-%d-%Y %H:%M"))
embed.add_field(
name="Uptime", value=subprocess.check_output(["uptime", "-p"]).decode("utf-8")
)
await ctx.reply(embed=embed)
2024-04-09 19:36:55 +02:00
@bot.command(name="ip")
@root_required
async def get_ip(ctx):
r = requests.get("https://ifconfig.me")
await ctx.reply("Current IP: `"+ r.content.decode("utf-8")+"`")
2024-04-09 20:59:50 +02:00
@bot.command(name="reboot")
@root_required
async def reboot(ctx):
await ctx.message.add_reaction("🆗")
os.system("reboot")
2022-08-26 17:39:38 +02:00
bot.run(config.TOKEN)