Merge pull request 'Configuration (Part 1)' (#2) from BodgeMaster/os-release-bot:master into master
Reviewed-on: #2master
commit
898369683e
|
@ -160,3 +160,4 @@ cython_debug/
|
||||||
# option (not recommended) you can uncomment the following to ignore the entire idea folder.
|
# option (not recommended) you can uncomment the following to ignore the entire idea folder.
|
||||||
#.idea/
|
#.idea/
|
||||||
|
|
||||||
|
*.swp
|
||||||
|
|
158
bot.py
158
bot.py
|
@ -2,18 +2,22 @@
|
||||||
# Code revised by BodgeMaster
|
# Code revised by BodgeMaster
|
||||||
# Code Licensed under GPL 3.0
|
# Code Licensed under GPL 3.0
|
||||||
|
|
||||||
|
import sys, time, json
|
||||||
|
|
||||||
import discord
|
import discord
|
||||||
from discord import app_commands
|
from discord import app_commands
|
||||||
import typing
|
import typing
|
||||||
from discord.ext import commands
|
from discord.ext import commands
|
||||||
import discord.utils
|
import discord.utils
|
||||||
import time
|
|
||||||
import sys
|
|
||||||
|
|
||||||
BOOT_TIME = time.time()
|
BOOT_TIME = time.time()
|
||||||
|
|
||||||
|
config_file = open("config.json", "r")
|
||||||
|
config = json.loads(config_file.read());
|
||||||
|
config_file.close()
|
||||||
|
|
||||||
def seconds_elapsed():
|
def seconds_elapsed():
|
||||||
return time.time() - BOOT_TIME
|
return int(time.time() - BOOT_TIME)
|
||||||
|
|
||||||
|
|
||||||
class MyClient(discord.Client):
|
class MyClient(discord.Client):
|
||||||
|
@ -36,142 +40,30 @@ async def on_ready():
|
||||||
print('------')
|
print('------')
|
||||||
|
|
||||||
|
|
||||||
@client.tree.command(guild=discord.Object(id=813127962881818624), name="change_hostname")
|
@client.tree.command(name="change_hostname")
|
||||||
@app_commands.describe(distro='Assign yourself a role')
|
@app_commands.describe(distro='Assign yourself a role')
|
||||||
async def distro(interaction: discord.Interaction, distro: typing.Literal['LFS', 'Kiss', 'Gentoo', 'Void', 'NixOS', 'Alpine', 'Arch', 'Arch-based', 'Red Hat', 'Bedrock', 'SuSE Based', 'OpenSuSE',
|
async def distro(interaction: discord.Interaction, distro: eval("typing.Literal[\""+ "\", \"".join(config["roles"].keys()) +"\"]")):
|
||||||
'Debian', 'Debian based', 'Solus', 'Fedora', 'Ubuntu', 'Ubuntu Based', 'BSD', 'MacOS', 'Windows']):
|
if not interaction.guild.id==config["guild"]:
|
||||||
|
print("Role assignment attempted from unknown guild.")
|
||||||
|
return
|
||||||
|
|
||||||
user = interaction.user
|
user = interaction.user
|
||||||
if distro == 'LFS':
|
role = discord.utils.get(interaction.guild.roles, id=config["roles"][distro])
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813200239778856971)
|
try:
|
||||||
await user.add_roles(role)
|
await user.add_roles(role)
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
await interaction.response.send_message(content=f'Added {role}.')
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
prnt("Added role.")
|
||||||
if distro == 'Kiss':
|
except:
|
||||||
user = interaction.user
|
await interaction.response.send_message(content='Something went wrong.')
|
||||||
role = discord.utils.get(user.guild.roles, id=884819839212982342)
|
print("Failed to add role. Permissions set correctly?")
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Gentoo':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=1813139495049232384)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Void':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813139633797988394)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'NixOS':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=827228988585279538)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Alpine':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=932684264967925850)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Arch':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813139868678225991)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Arch-based':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813186782534828043)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Red Hat':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=816823482318979094)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Bedrock':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=825427559604027412)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'SuSE Based':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=1034793985715224587)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'OpenSuSE':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813147179367661589)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Debian':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813142935247388672)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Debian based':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=842882283504926756)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Solus':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=820840553704325160)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Fedora':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=820621219040591884)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Ubuntu':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813139746180038697)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Ubuntu Based':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813581408052183042)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'BSD':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=879444277330055228)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'MacOS':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813147204772167680)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
if distro == 'Windows':
|
|
||||||
user = interaction.user
|
|
||||||
role = discord.utils.get(user.guild.roles, id=813147019631788083)
|
|
||||||
await user.add_roles(role)
|
|
||||||
await interaction.response.send_message(content=f'`{role}` assigned to {user.mention}.')
|
|
||||||
print(f"`{role}` assigned to {user.mention}.")
|
|
||||||
|
|
||||||
|
|
||||||
# This context menu command only works on messages
|
# This context menu command only works on messages
|
||||||
@client.tree.context_menu(guild=discord.Object(id=813127962881818624), name='Report to Moderators')
|
@client.tree.context_menu(name='Report to Moderators')
|
||||||
async def report_message(interaction: discord.Interaction, message: discord.Message):
|
async def report_message(interaction: discord.Interaction, message: discord.Message):
|
||||||
|
if not interaction.guild.id==config["guild"]:
|
||||||
|
return
|
||||||
await interaction.response.send_message(
|
await interaction.response.send_message(
|
||||||
f'Thanks for reporting this message by {message.author.mention} to our moderators.', ephemeral=True
|
f'Thanks for reporting this message by {message.author.mention} to our moderators.', ephemeral=True
|
||||||
)
|
)
|
||||||
|
@ -193,7 +85,7 @@ async def status(interaction: discord.Interaction):
|
||||||
System: {sys.platform}"""
|
System: {sys.platform}"""
|
||||||
url_view = discord.ui.View()
|
url_view = discord.ui.View()
|
||||||
await interaction.response.send_message(embed=embed, view=url_view)
|
await interaction.response.send_message(embed=embed, view=url_view)
|
||||||
|
print("Status queried.")
|
||||||
|
|
||||||
|
|
||||||
client.tree.sync()
|
|
||||||
client.run(sys.argv[1])
|
client.run(sys.argv[1])
|
||||||
|
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"guild": 750955881348464651,
|
||||||
|
"roles": {
|
||||||
|
"assign0": 1063506453308125274,
|
||||||
|
"assign1": 1063506544962064414
|
||||||
|
},
|
||||||
|
"report channel": 1063507041697677312
|
||||||
|
}
|
Loading…
Reference in New Issue