async def user_information(client: discord.Client, message: discord.Message,
                           args: List[str], config):
    if not PermissionChecker.is_moderator(message.author):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions nécessaires."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Rappel de la commande d'information utilisateur :**\n\n"
                "`!ui <@user>`."))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Erreur dans la commande. Vous devez mentionner un utilisateur."))

    await message.channel.send(embed=EmbedsManager.sanction_embed(
        f"Voici les informations de {target.name}#{target.discriminator} :",
    ).set_thumbnail(url=target.avatar_url).add_field(
        name='Surnom', value=target.display_name, inline=True
    ).add_field(name='Tag', value=target.discriminator, inline=True).add_field(
        name='ID', value=target.id, inline=True).add_field(
            name='Compte créé le',
            value=target.created_at.strftime('%d/%m/%Y à %H:%M:%S'),
            inline=True).add_field(
                name='A rejoint le serveur le',
                value=target.joined_at.strftime('%d/%m/%Y à %H:%M:%S'),
                inline=True).set_footer(icon_url=client.user.avatar_url,
                                        text='Made By Gastbob40'))
async def remove_customcommands(client: discord.Client,
                                message: discord.Message, args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'custom_commands'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}remove_command <command_id>`"))

    # Check inputs
    if len(args) != 1:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(f":x: Erreur dans la commande."))

    command_name = args[0]
    custom_commands: List[CustomCommand] = session.query(
        CustomCommand).filter_by(command=command_name).all()

    if len(custom_commands) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur. Je ne trouve pas cette commande."))

    session.delete(custom_commands[0])
    session.commit()

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"Je viens de supprimer la commande **{command_name}**."))
async def take_whitelist(client: discord.Client, message: discord.Message):
    if message.channel.id != data['command_channel']:
        return

    if not message.author.permissions_in(message.channel).manage_messages:
        return await message.author.send(
            embed=EmbedsManager.error_embed(
                "Erreur",
                "Vous n'avez pas les permissions nécessaires"
            )
        )

    if message.author.voice is None:
        return await message.author.send(
            embed=EmbedsManager.error_embed(
                "Erreur",
                "Vous devez être connecté en vocal pour faire une whitelist."
            )
        )

    if WhiteListQueue.is_empty():
        return await message.author.send(
            embed=EmbedsManager.error_embed(
                "Erreur",
                "Il n'y a personne à faire passer."
            )
        )

    await WhiteListQueue.take_player(message.author)
Beispiel #4
0
async def get_user(client: discord.Client, message: discord.Message,
                   args: List[str]):
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        await message.channel.send(embed=EmbedsManager.error_embed(results))

    if results == 0:
        await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))
        return

    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Server command reminder:** \n\n"
                "`!user`.\n"
                "You can optionally add a mention to a user to get it profile")
        )

    if not message.mentions:
        await message.channel.send(embed=EmbedsManager.complete_embed(
            f"https://epimodo.gastbob40.ovh/moderation/profile/"))
    else:
        await message.channel.send(embed=EmbedsManager.complete_embed(
            f"https://epimodo.gastbob40.ovh/moderation/profile/{message.mentions[0].id}"
        ))
Beispiel #5
0
async def change_prefix(client: discord.Client, message: discord.Message,
                        args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'prefix'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}prefix <nouveau prefix>`"))

    # Check input
    if len(args) != 1:
        await message.channel.send(embed=EmbedsManager.error_embed(
            f"Erreur dans la commande.\nRappel : `{config['prefix']}prefix <nouveau prefix>`"
        ))
        return

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"⚙ Le préfix `{config['prefix']}` a été changé par `{args[0]}`."))

    with open('run/config/config.yml', 'w', encoding='utf8') as outfile:
        yaml.dump(config,
                  outfile,
                  default_flow_style=False,
                  allow_unicode=True)
Beispiel #6
0
async def warn_member(client: discord.Client, message: discord.Message,
                      args: List[str], config):
    api_manager = APIManager(config['api']['url'], config['api']['token'])

    if not PermissionChecker.is_moderator(message.author):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Warning command reminder:**\n\n"
                "`!av <@user> <reason>`."))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must mention an user."))

    args = args[1:]

    if len(args) == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must add a reason."))

    warn = Warn()
    warn.user_id = target.id
    warn.moderator_id = message.author.id
    warn.reason = ' '.join(args)
    warn.save()

    _, res = api_manager.get_data('warns', user_id=target.id)
    nb_warns = len(res)

    await message.channel.send(embed=EmbedsManager.sanction_embed(
        f"Avertissement du membre {target.display_name}.",
        f"Vous venez de l'avertir pour : `{warn.reason}`.").add_field(
            name="Nombre :", value=nb_warns, inline=False).set_footer(
                icon_url=client.user.avatar_url, text='Made By Gastbob40'))

    await client.get_channel(
        config['channels']['log_reactions']
    ).send(embed=EmbedsManager.sanction_embed(
        f"Avertissement du membre {target.display_name}.",
        f"Il a été averti pour : `{warn.reason}`.").set_footer(
            icon_url=client.user.avatar_url, text='Made By Gastbob40').
           add_field(name="Auteur :", value=message.author.display_name))

    await target.send(embed=EmbedsManager.sanction_embed(
        f"Vous venez de subir un avertissement.",
        f"Vous venez d'être averti pour : `{warn.reason}`.").set_footer(
            icon_url=client.user.avatar_url, text='Made By Gastbob40'
        ).add_field(name="Auteur :", value=message.author.display_name))
Beispiel #7
0
async def kick_member(client: discord.Client, message: discord.Message,
                      args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'kick'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}kick <@pseudo> <reason>`\n"
                f"`{config['prefix']}kick <@pseudo> -r <reason_id>`"))

    # Check inputs
    if len(message.mentions) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            ":x: Erreur dans la commande. Merci de mentionner un utilisateur.")
                                          )

    if len(args) < 2:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            ":x: Erreur dans la commande. Merci de mettre une raison."))

    with open('run/config/reasons.yml', 'r', encoding='utf8') as file:
        reasons = yaml.safe_load(file)

    current_reason = ""

    if args[0] == '-r':
        # Saved reason
        try:
            for reason_index in args[1:]:
                current_reason += f"- {reasons[int(reason_index)]}\n"
        except:
            return await message.channel.send(embed=EmbedsManager.error_embed(
                ":x: Erreur dans la commande. Merci de mettre un index d'erreur valide."
            ))

    else:
        # Custom reason
        current_reason = " ".join(args)

    new_kick = Kick(message.mentions[0].id, message.author.id, current_reason)
    session.add(new_kick)
    session.commit()

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"👢 Le membre **{message.mentions[0]}** a été kické (id `k{new_kick.id}`):\n{current_reason}"
    ))

    await message.mentions[0].kick()
Beispiel #8
0
async def unmute(client: discord.Client, message: discord.Message,
                 args: List[str]):
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(results))

    # Check lvl permissions
    if results == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**UnMuting command reminder:**\n\n"
                "`!unmute <@user> (<#channel>)`.\n"))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must mention an user."))

    # Check role
    _, target_results = permissions_manager.get_permissions(
        target, message.guild)

    if target_results >= results:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You cannot unmute someone greater than or equal to you."))

    channels = message.channel_mentions if len(
        message.channel_mentions) >= 1 else [message.channel]
    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"You just unmuted {target.display_name} in channel(s) : "
        f"{' '.join([chan.name for chan in channels]) }."))

    await LogManager.complete_log(
        client, 'unmutes', message.author, message.guild,
        f"unmuted {target.display_name} in channel(s) : "
        f"{' '.join([chan.name for chan in channels]) }.", '')

    for channel in channels:
        try:
            if not target.permissions_in(channel).send_messages:
                await channel.set_permissions(target, overwrite=None)
        except:
            pass
async def unfreeze_server(client: discord.Client, message: discord.Message,
                          args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'freeze'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}rfreeze`"))

    # Check inputs
    current_message: discord.Message = await message.channel.send(
        embed=EmbedsManager.complete_embed(
            f"{message.author.mention} Vous avez décidé de dégeler le serveur.\n"
            + f"Confirmer vous ce choix ?"))

    await current_message.add_reaction('✅')
    await current_message.add_reaction('❌')

    def check(reaction: discord.Reaction, user: discord.User):
        return user == message.author and (str(reaction.emoji) == '✅'
                                           or str(reaction.emoji) == '❌')

    try:
        reaction, user = await client.wait_for('reaction_add',
                                               timeout=20.0,
                                               check=check)
    except asyncio.TimeoutError:
        await message.channel.send(embed=EmbedsManager.error_embed(
            f"Vous avez __refusé__ le dégel du serveur."))
    else:
        if str(reaction.emoji) == '❌':
            return await message.channel.send(embed=EmbedsManager.error_embed(
                f"Vous avez __refusé__ le dégel du serveur."))

        await message.channel.send(
            embed=EmbedsManager.complete_embed(f"Le serveur a été dégelé"))

        members: List[discord.Member] = message.guild.members

        for member in members:
            if not member.guild_permissions.manage_messages:
                for channel in message.guild.channels:
                    if not member.permissions_in(channel).send_messages:
                        await channel.set_permissions(member, overwrite=None)
Beispiel #10
0
async def get_mutes(client: discord.Client, message: discord.Message, args: List[str]):
    state, results = permissions_manager.get_permissions(message.author, message.guild)

    if not state:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(results)
        )

    # Check lvl permissions
    if results == 0:
        return await message.channel.send(
            embed=EmbedsManager.error_embed("You don't have the necessary permissions.")
        )

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed("**Muting command reminder:**\n\n"
                                                  "`!get_mute <@user>`.\n")
        )

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(message.mentions) == 1 else False

    if not target:
        return await message.channel.send(
            embed=EmbedsManager.error_embed("Error in the command. You must mention an user.")
        )

    # Check role
    _, target_results = permissions_manager.get_permissions(target, message.guild)

    if target_results >= results:
        return await message.channel.send(
            embed=EmbedsManager.error_embed("You cannot get mutes for someone greater than or equal to you.")
        )
    channels = []
    try:
        for channel in message.guild.channels:
            if not target.permissions_in(channel).send_messages:
                channels.append(channel)
        await message.channel.send(
            embed=EmbedsManager.complete_embed(f"{target.display_name} is muted in the following channel(s) : " +
                                               "{}.".format(',\n '.join([chan.name for chan in channels])))
        )

    except Exception as e:
        await message.channel.send(
            embed=EmbedsManager.error_embed(f"Error in muting the member. : {e}")
        )
Beispiel #11
0
async def revoke_mute(client: discord.Client, message: discord.Message,
                      args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    if not PermissionsManager.has_perm(message.author, 'mute'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}rmute <mute_id>`"))

    if len(args) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande, merci de spécifier l'index du mute."
        ))

    if not args[0].startswith("m"):
        return await message.channel.send(
            embed=EmbedsManager.error_embed(":x: Erreur, index invalide."))

    index = int(args[0][1:])
    current_mute: Mute = session.query(Mute).filter_by(id=index).first()

    if current_mute is None:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(":x: Erreur, index invalide."))

    if not current_mute.is_active:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            ":x: Erreur, ce mute est déjà révoqué."))

    current_mute.is_active = False
    session.commit()

    target: discord.Member = message.guild.get_member(current_mute.target_id)
    for channel in message.guild.channels:
        if not target.permissions_in(channel).send_messages:
            await channel.set_permissions(target, overwrite=None)

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"⚠ Le mute **{args[0]}** a été révoqué."))
Beispiel #12
0
async def revoke_warn(client: discord.Client, message: discord.Message,
                      args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'warn'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}rwarn <warn_id>`"))

    # Check inputs
    if len(args) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande, merci de spécifier l'index de l'avertissement."
        ))

    if not args[0].startswith("w"):
        return await message.channel.send(
            embed=EmbedsManager.error_embed(f":x: Erreur, index invalide."))

    # Process code
    index = int(args[0][1:])
    current_warn: Warn = session.query(Warn).filter_by(id=index).first()

    if current_warn is None:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(f":x: Erreur, index invalide."))

    if not current_warn.is_active:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            ":x: Erreur, cet avertissement est déjà révoqué."))

    current_warn.is_active = False
    session.commit()

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"🔨 L'avertissement **{args[0]}** a été révoqué."))
Beispiel #13
0
async def unban(client: discord.Client, message: discord.Message,
                args: List[str]):
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(results))

    # Check lvl permissions
    if results == 0 or results == 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Unbanning command reminder:**\n\n"
                "`!unban <@user>`."))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must mention an user."))

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"You just unbanned {target.display_name}."))

    await LogManager.complete_log(client, 'bans', message.author,
                                  message.guild, "", "")

    try:
        await target.send(embed=EmbedsManager.information_embed(
            "You have been unbanned"
            " from the server {}".format(message.guild.name)))
        await target.unban(reason="")
    except:
        await message.channel.send(
            embed=EmbedsManager.error_embed("Error in banning the member."))
Beispiel #14
0
async def add_customcommands(client: discord.Client, message: discord.Message, args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'custom_commands'):
        return await message.channel.send(
            embed=EmbedsManager.error_embed(
                "Vous n'avez pas les permissions pour cette commande."
            )
        )

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}add_command <name> <content>`"
            )
        )

    # Process code
    if len(args) < 2:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(
                f":x: Erreur dans la commande."
            )
        )

    command_name = args[0]
    command_content = ' '.join(args[1:])

    await message.channel.send(
        embed=EmbedsManager.complete_embed(
            f"{message.author.mention} vient de créer une nouvelle commande :\n"
            f"**Nom :** {command_name}\n"
            f"**Contenue :** {command_content}."
        )
    )

    custom_command = CustomCommand(command_name, command_content)
    session.add(custom_command)
    session.commit()
Beispiel #15
0
async def report_message(client: discord.Client, reaction: discord.Reaction, user: discord.User):
    guild = reaction.message.guild

    await reaction.remove(user)

    state, results = permissions_manager.get_permissions(user, guild)

    if not state:
        return await reaction.message.channel.send(
            embed=EmbedsManager.error_embed(results)
        )

    # Check lvl permissions
    if results == 0:
        return await reaction.message.channel.send(
            embed=EmbedsManager.error_embed("You don't have the necessary permissions.")
        )

    # Check role
    _, target_results = permissions_manager.get_permissions(reaction.message.author, guild)

    if target_results >= results:
        return await reaction.message.channel.send(
            embed=EmbedsManager.error_embed("You cannot warn someone greater than or equal to you.")
        )

    reason = reaction.message.content

    api_manager.post_data('warns',
                          target_id=reaction.message.author.id,
                          author_id=user.id,
                          server_id=guild.id,
                          reason='Reported Message: ' + reason,
                          )

    await LogManager.complete_log(client, 'warns', user, guild, reason)

    try:
        await reaction.message.author.send(
            embed=EmbedsManager.sanction_embed('Reported Message', guild, reason)
        )
    except Exception as e:
        print(e)
async def add_reason(client: discord.Client, message: discord.Message, args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'manage_reason'):
        return await message.channel.send(
            embed=EmbedsManager.error_embed(
                "Vous n'avez pas les permissions pour cette commande."
            )
        )

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}reason_add <reason>`"
            )
        )

    # Check inputs
    if len(args) < 2:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(
                f":x: Merci de mettre une raison d'au moins deux mots."
            )
        )

    # Process code
    with open('run/config/reasons.yml', 'r', encoding='utf8') as file:
        reasons = yaml.safe_load(file)
    reasons.append((' '.join(args)))

    with open('run/config/reasons.yml', 'w', encoding='utf8') as outfile:
        yaml.dump(reasons, outfile, default_flow_style=False, allow_unicode=True)

    await message.channel.send(
        embed=EmbedsManager.complete_embed(
            f"{message.author.mention} La raison `{reasons[-1]}` a été ajouté à la liste.\n"
            f"Son numéro d'attribution est le {len(reasons)}."
        )
    )
Beispiel #17
0
async def load_custom_commands(client: discord.Client,
                               message: discord.Message, args: List[str],
                               config):

    api_manager = APIManager(config['api']['url'], config['api']['token'])

    if not PermissionChecker.is_owner(message.author):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    state, res = api_manager.get_data('custom-commands')

    if not state:
        return await message.channel.send(embed=EmbedsManager.error_embed(res))

    with open('src/_data/custom_commands.yml', 'w') as file:
        documents = yaml.dump(res, file, sort_keys=True)

    return await message.channel.send(embed=EmbedsManager.complete_embed(
        "The command was successful.",
        f'{len(res)} custom commands have been loaded.'))
Beispiel #18
0
async def annonce_msg(client: discord.Client, message: discord.Message,
                      args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'annonce'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(embed=EmbedsManager.information_embed(
            "Rappel de la commande : \n"
            f"`{config['prefix']}annonce <#channel> <couleur> <contenue>`\n"
            f"La couleur doit etre au format hexadécimale (FFFFFF) sans le #."
            f" Une image peut etre ajouté à la commande."))

    if len(message.channel_mentions) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de specifier un channel"))

    # Get channel
    channel: discord.TextChannel = message.channel_mentions[0]
    args.pop(0)

    # Get color
    if not args:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de specifier une couleur valide."
        ))

    try:
        color = int(args.pop(0), 16)
    except:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de specifier une couleur valide."
        ))

    # Get content
    if not args:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de specifier un contenue valide."
        ))

    content = ' '.join(args)
    embed = discord.Embed(color=color)
    embed.description = content

    # Get image
    if message.attachments:
        embed.set_image(url=message.attachments[0].url)

    try:
        await channel.send(embed=embed)
        await message.channel.send(embed=EmbedsManager.complete_embed(
            f"Le message a bien été envoyé dans {channel} : \n {content}"))
    except:
        await message.channel.send(embed=EmbedsManager.error_embed(
            "Je n'ai pas les permissions pour ce salon."))
Beispiel #19
0
async def init_server(client: discord.Client, message: discord.Message,
                      args: List[str]):
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        await message.channel.send(embed=EmbedsManager.error_embed(results))

    if results != 3:
        await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))
        return

    state, results = api_manager.get_data('servers',
                                          discord_id=message.guild.id)
    if not state:
        await message.channel.send(embed=EmbedsManager.error_embed(results))
        return

    elif len(results) != 0:
        await message.channel.send(embed=EmbedsManager.error_embed(
            'This server is already initialized.'))
        return

    state, results = api_manager.post_data(
        'servers',
        discord_id=message.guild.id,
        discord_name=message.guild.name,
        discord_icon=message.guild.icon_url._url,
        discord_admin_role_id=1,
        discord_modo_role_id=1)

    if not state:
        await message.channel.send(embed=EmbedsManager.error_embed(results))

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"The `{message.guild.name}` server has been successfully added.\n"
        f"Please modify the ids of the admin and modo roles directly on the site."
    ))
async def mention_moderator(client: discord.Client, message: discord.Message,
                            config):
    role: discord.Role

    for role in message.role_mentions:
        if role.id == 490155585371766814:
            archer_role: discord.Role = message.guild.get_role(
                497451928058462221)

            if not archer_role in message.author.roles:
                return await message.channel.send(embed=EmbedsManager.error_embed(
                    f"Erreur, il faut être niveau 7 (soit {archer_role.name}) afin de mentionner un modérateur.\n"
                    f"Vous pouvez cependant vous adresser à un modérateur connecté."
                ).set_footer(icon_url=client.user.avatar_url,
                             text='Made By Gastbob40'))

            await client.get_channel(
                config['channels']['moderator']
            ).send(embed=EmbedsManager.sanction_embed(
                f"{message.author.name}#{message.author.discriminator} vient de mentionner les modérateurs."
            ).add_field(
                name='Message', value=message.content, inline=True).add_field(
                    name='Salon', value=message.channel.mention, inline=True).
                   add_field(name="Lien",
                             value=f"[{message.jump_url}]({message.jump_url})",
                             inline=False).set_footer(
                                 icon_url=client.user.avatar_url,
                                 text='Made By Gastbob40'))

            await client.get_channel(
                config['channels']['log_reactions']
            ).send(embed=EmbedsManager.sanction_embed(
                f"{message.author.name}#{message.author.discriminator} vient de mentionner les modérateurs."
            ).add_field(
                name='Message', value=message.content, inline=True).add_field(
                    name='Salon', value=message.channel.mention, inline=True).
                   add_field(name="Lien",
                             value=f"[{message.jump_url}]({message.jump_url})",
                             inline=False).set_footer(
                                 icon_url=client.user.avatar_url,
                                 text='Made By Gastbob40'))

            mentionable_message = ''
            for modo in message.guild.get_role(278656056228315136).members:
                mentionable_message += modo.mention

            msg: discord.Message = await message.channel.send(
                mentionable_message)
            await msg.delete()
Beispiel #21
0
async def get_reasons_list(client: discord.Client, message: discord.Message):
    if not PermissionsManager.has_perm(message.author, 'manage_reason'):
        await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))
        return

    with open('run/config/reasons.yml', 'r', encoding='utf8') as file:
        reasons = yaml.safe_load(file)

    content = f"{message.author.mention} voici la liste des **raisons** des sanctions :\n"

    for i in range(len(reasons)):
        content += f"\n**Raison {i+1} :** {reasons[i]}"

    await message.channel.send(embed=EmbedsManager.complete_embed(content))
Beispiel #22
0
async def mute(client: discord.Client, reaction: discord.Reaction,
               user: discord.User):
    state, results = permissions_manager.get_permissions(
        user, reaction.message.guild)

    if not state:
        return await reaction.message.channel.send(
            embed=EmbedsManager.error_embed(results))

    # Check lvl permissions
    if results == 0:
        return

    target: discord.Member = reaction.message.author

    # Check role
    _, target_results = permissions_manager.get_permissions(
        target, reaction.message.guild)

    if target_results >= results:
        return

    try:
        if target.permissions_in(reaction.message.channel).read_messages:
            await reaction.message.channel.set_permissions(target,
                                                           send_messages=False)
        else:
            return
    except Exception as e:
        await reaction.message.channel.send(embed=EmbedsManager.error_embed(
            f"Error in muting the member : {e}"))

    await LogManager.complete_log(
        client, 'mutes', user, reaction.message.guild,
        f"muted {target.display_name} in channel(s) : "
        f"{reaction.message.channel.name}.", '')
Beispiel #23
0
    async def error_log(client: discord.Client, error_content: str,
                        guild: discord.Guild):
        state, results = api_manager.get_data('servers', discord_id=guild.id)

        if not state:
            return

        log_channel_id = results[0]['discord_log_channel_id']
        log_channel: discord.TextChannel = client.get_channel(log_channel_id)
        embed = EmbedsManager.error_embed(error_content)

        if log_channel:
            await log_channel.send(embed=embed)

        main_channel_log = client.get_channel(553974648258166800)
        if main_channel_log:
            embed.set_thumbnail(url=guild.icon_url)
            await main_channel_log.send(embed=embed)
Beispiel #24
0
    async def error_log(client: discord.Client, error_content: str,
                        guild: discord.Guild):
        main_channel_log = client.get_channel(692055209429565498)
        embed = EmbedsManager.error_embed(error_content)
        if main_channel_log:
            if guild is not None:
                embed.set_thumbnail(url=guild.icon_url)
            await main_channel_log.send(embed=embed)
        if guild is None:
            return
        state, results = api_manager.get_data('servers', discord_id=guild.id)

        if not state:
            return

        log_channel_id = results[0]['discord_log_channel_id']
        log_channel: discord.TextChannel = client.get_channel(log_channel_id)

        if log_channel:
            await log_channel.send(embed=embed)
Beispiel #25
0
    async def remove_player(member: discord.Member, contact=True):
        if member.id not in WhiteListQueue.requests:
            return

        WhiteListQueue.requests.remove(member.id)

        if contact:
            await member.send(
                embed=EmbedsManager.error_embed(
                    "Vous venez de quitter la file d'attente",
                    f"Vous perdez donc votre priorité dans la file d'attente."
                )
            )

        for i in range(len(WhiteListQueue.requests)):
            target: discord.User = await WhiteListQueue.client.fetch_user(WhiteListQueue.requests[i])

            await target.send(
                embed=EmbedsManager.complete_embed(
                    "Avancement dans la file d'attente",
                    f"Vous êtes maintenant en position **{i + 1}** dans la file d'attente.\n\n"
                )
            )
async def add_general_mute(client: discord.Client, message: discord.Message,
                           args: List[str]):
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(results))

    # Check lvl permissions
    if results == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(embed=EmbedsManager.information_embed(
            "**General Muting command reminder:**\n\n"
            "`!g_mute <@user> <reason>`.\n"
            "An image can be added to the command (it will be saved for logs)."
        ))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must mention an user."))

    # Check role
    _, target_results = permissions_manager.get_permissions(
        target, message.guild)

    if target_results >= results:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You cannot mute someone greater than or equal to you."))

    args = args[1:]

    if len(args) == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must add a reason."))

    reason = ' '.join(args)

    image_url = message.attachments[0].proxy_url if len(
        message.attachments) == 1 else ''

    api_manager.post_data('mutes',
                          target_id=target.id,
                          author_id=message.author.id,
                          server_id=message.guild.id,
                          reason=reason,
                          is_active=True,
                          image=image_url)

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"You just muted {target.display_name} for {reason}."))

    await LogManager.complete_log(client, 'general mutes', message.author,
                                  message.guild, reason, image_url)

    await target.send(embed=EmbedsManager.sanction_embed(
        'Mute', message.guild, reason, image_url))

    for channel in message.guild.channels:
        try:
            if target.permissions_in(channel).read_messages:
                await channel.set_permissions(target, send_messages=False)
        except:
            pass
Beispiel #27
0
async def mute_member(client: discord.Client, message: discord.Message,
                      args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Check permissions
    if not PermissionsManager.has_perm(message.author, 'mute'):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions pour cette commande."))

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}mute <@pseudo> <reason>`\n"
                f"`{config['prefix']}mute <@pseudo> -r <reason_id>`"))

    # Check inputs
    if len(message.mentions) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de mentionner un utilisateur."
        ))

    if len(args) < 3:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de mettre une raison."))

    # Process code
    args = args[1:]

    if not args[0].isdigit():
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f":x: Erreur dans la commande. Merci de mettre une durée valide."))

    duration: int = int(args[0])

    args = args[1:]

    with open('run/config/reasons.yml', 'r', encoding='utf8') as file:
        reasons = yaml.safe_load(file)

    current_reason = ""

    if args[0] == '-r':
        # Saved reason
        try:
            for reason_index in args[1:]:
                current_reason += f"- {reasons[int(reason_index)]}\n"
        except:
            return await message.channel.send(embed=EmbedsManager.error_embed(
                f":x: Erreur dans la commande. Merci de mettre un index d'erreur valide."
            ))

    else:
        # Custom reason
        current_reason = " ".join(args)

    new_mute = Mute(message.mentions[0].id, message.author.id, current_reason,
                    duration)
    session.add(new_mute)
    session.commit()

    # Remove permission
    target: discord.Member = message.mentions[0]
    for channel in message.guild.channels:
        if target.permissions_in(channel).read_messages:
            await channel.set_permissions(target, send_messages=False)

    await message.channel.send(embed=EmbedsManager.complete_embed(
        f"⚠ Le membre **{message.mentions[0]}** a été mute (id `m{new_mute.id}`):\n{current_reason}"
    ))
Beispiel #28
0
async def get_mod(client: discord.Client, message: discord.Message,
                  args: List[str]):
    with open('run/config/config.yml', 'r') as file:
        config = yaml.safe_load(file)

    # Help message
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "Rappel de la commande : \n"
                f"`{config['prefix']}mod <@user>`"))

    # Check inputs
    if len(message.mentions) != 1:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            ":x: Erreur dans la commande. Merci de mentionner un utilisateur.")
                                          )

    target: discord.Member = message.mentions[0]

    infos = {
        'warns':
        session.query(Warn).filter_by(target_id=target.id,
                                      is_active=True).all(),
        'rwarns':
        session.query(Warn).filter_by(target_id=target.id,
                                      is_active=False).all(),
        'kicks':
        session.query(Kick).filter_by(target_id=target.id,
                                      is_active=True).all(),
        'rkicks':
        session.query(Kick).filter_by(target_id=target.id,
                                      is_active=False).all(),
        'bans':
        session.query(Ban).filter_by(target_id=target.id,
                                     is_active=True).all(),
        'rbans':
        session.query(Ban).filter_by(target_id=target.id,
                                     is_active=False).all(),
        'mutes':
        session.query(Mute).filter_by(target_id=target.id,
                                      is_active=True).all(),
        'rmutes':
        session.query(Mute).filter_by(target_id=target.id,
                                      is_active=False).all()
    }

    embed = discord.Embed()
    embed.set_author(name=f'{target.display_name} (ID: {target.id})', icon_url=target.avatar_url) \
        .add_field(name=f'Voici les informations sur {target.display_name}:',
                   value=f'Sourdine : {len(infos["mutes"]) + len(infos["rmutes"])}'
                         f' (dont {len(infos["rmutes"])} révoqués).\n'
                         f'Avertissements : {len(infos["warns"]) + len(infos["rwarns"])}'
                         f' (dont {len(infos["rwarns"])} révoqués).\n'
                         f'Exclusions : {len(infos["kicks"]) + len(infos["rkicks"])}'
                         f' (dont {len(infos["rkicks"])} révoqués).\n'
                         f'Bannissements : {len(infos["bans"]) + len(infos["rbans"])}'
                         f' (dont {len(infos["rbans"])} révoqués).\n') \
        .set_footer(text=f"{client.user.display_name}", icon_url=client.user.avatar_url)
    embed.timestamp = datetime.now() - timedelta(hours=2)

    await message.channel.send(embed=embed)

    for type in ['warns', 'kicks', 'bans']:
        embed = discord.Embed() \
            .set_author(name=f'{type} de {target.display_name} (ID: {target.id})', icon_url=target.avatar_url)

        if infos[type]:
            for things in infos[type]:
                embed.add_field(
                    name=
                    f"{type} par {message.guild.get_member(things.author_id)}"
                    f" (ID: {type[0]}{things.id})",
                    value=
                    f"Le {things.date.day}/{things.date.month}/{things.date.year}"
                    f" à {things.date.hour}:{things.date.minute}"
                    f" pour : \n {things.reason}")
            await message.channel.send(embed=embed)
Beispiel #29
0
async def clear_messages(client: discord.Client, message: discord.Message,
                         args: List[str]):
    channel: discord.TextChannel = message.channel
    state, results = permissions_manager.get_permissions(
        message.author, message.guild)

    if not state:
        return await message.channel.send(
            embed=EmbedsManager.error_embed(results))

    # Check lvl permissions
    if results != 3 and not message.author.permissions_in(
            message.channel).manage_messages:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "You don't have the necessary permissions."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Clearing command reminder:**\n\n"
                "`!clear <number of message>`."))

    # Check argument validity
    if not args:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must add a number of message (limit to 100)."
        ))

    if not args[0].isdigit():
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must specify a valid number of message (limit to 100)."
        ))

    message_count = int(args[0]) + 2

    if message_count <= 0 or message_count > 100:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Error in the command. You must specify a number of message between  1 and 98."
        ))

    # Send message
    sent_message: discord.Message = await message.channel.send(
        embed=EmbedsManager.complete_embed(
            f"Do you really want to delete {message_count - 2} messages ?\n"
            f"*You have 20s to accept.*"))

    # Add reaction
    await sent_message.add_reaction('🆗')

    # Check response
    def check(reaction, user):
        return user == message.author and (str(reaction.emoji) == '🆗')

    try:
        reaction, user = await client.wait_for('reaction_add',
                                               timeout=20.0,
                                               check=check)
    except asyncio.TimeoutError:
        await message.channel.send(f"You have canceled the clear.")
    else:
        # check response
        messages = await channel.history(limit=message_count).flatten()

        try:
            await message.channel.delete_messages(messages)
            await message.channel.send(embed=EmbedsManager.complete_embed(
                f"The deletion of the messages was successfully completed"))

        except discord.errors.HTTPException:
            await message.channel.send(embed=EmbedsManager.error_embed(
                "You can only bulk delete messages that are under 14 days old."
            ))
async def bantemp_member(client: discord.Client, message: discord.Message,
                         args: List[str], config):
    api_manager = APIManager(config['api']['url'], config['api']['token'])

    if not PermissionChecker.is_moderator(message.author):
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Vous n'avez pas les permissions nécessaires."))

    # Display help
    if args and args[0] == '-h':
        return await message.channel.send(
            embed=EmbedsManager.information_embed(
                "**Rappel de la commande de bannissement temporaire :**\n\n"
                "`!bt <@user> <durée> <reason>`."))

    # Check if target exist
    target: discord.Member = message.mentions[0] if len(
        message.mentions) == 1 else False

    if not target:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Erreur dans la commande. Vous devez mentionner un utilisateur."))

    args = args[1:]

    if len(args) == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Erreur dans la commande. Vous devez spécifié une durée."))

    bantemp = TempBan()
    bantemp.user_id = target.id
    bantemp.moderator_id = message.author.id

    if args[0].isdigit():
        if int(args[0]) < 24:
            delta = f'{int(args[0])} heure(s)'
        elif int(args[0]) % 24 == 0:
            delta = f'{int(args[0]) / 24} jour(s)'
        else:
            delta = f'{math.floor(int(args[0]) / 24)} jour(s) et {int(args[0]) % 24} heure(s)'

        bantemp.end_time += timedelta(hours=int(args[0]))

    elif args[0] and args[0][-1] == 'd' and args[0][:-1].isdigit():
        delta = f'{int(args[0][:-1])} jour(s)'
        bantemp.end_time += timedelta(days=int(args[0][:-1]))

    else:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            f"Erreur dans la commande. La date spécifiée est incorrecte (`{args[0]}`)."
        ))

    args = args[1:]

    if len(args) == 0:
        return await message.channel.send(embed=EmbedsManager.error_embed(
            "Erreur dans la commande. Vous devez spécifié une raison."))

    bantemp.reason = ' '.join(args)
    bantemp.save()

    _, res = api_manager.get_data('temp-bans', user_id=target.id)
    nb_bt = len(res)

    await message.channel.send(embed=EmbedsManager.sanction_embed(
        f"Bannissement temporaire du membre {target.display_name} pour une durée de {delta}.",
        f"Ce joueur ne respecte toujours pas les règles malgré un rappel d'un Modérateur, il prend donc un BanTemp"
    ).set_footer(
        icon_url=client.user.avatar_url, text='Made By Gastbob40'
    ).add_field(
        name="Rappel :",
        value=
        "Sachez que plusieurs BanTemp peuvent conduire à un Bannissement définitif du serveur!\n\n"
        f"Pour évitez cela, prenez connaissance des {client.get_channel(280735672527224842).mention} qui ne"
        f" sont pas nombreuses mais importantes pour le bon fonctionnement du serveur.",
        inline=False
    ).add_field(name="Raison :", value=bantemp.reason, inline=True).add_field(
        name="Durée :", value=delta, inline=True
    ).add_field(name="Nombre :", value=nb_bt, inline=True).set_image(
        url=
        'https://cdn.discordapp.com/attachments/377179445640822784/663478346763599872'
        '/photostudio_15295854416791.png'))

    await client.get_channel(
        config['channels']['log_reactions']
    ).send(embed=EmbedsManager.sanction_embed(
        f"Bannissement temporaire du membre {target.display_name} pour une durée de {delta}.",
        f"Il a été bantemp pour : `{bantemp.reason}`.").set_footer(
            icon_url=client.user.avatar_url, text='Made By Gastbob40'
        ).add_field(name="Durée :", value=delta, inline=True).add_field(
            name="Auteur :", value=message.author.display_name, inline=True))

    try:
        await target.send(embed=EmbedsManager.sanction_embed(
            f"Vous venez de subir un bannissement temporaire de {delta}.",
            f"Vous venez d'être bantemp pour : `{bantemp.reason}`.\n\n"
            f"Sachez que plusieurs bans temporaires conduisent à un ban définitif."
        ).set_footer(
            icon_url=client.user.avatar_url, text='Made By Gastbob40'
        ).add_field(name="Durée :", value=delta, inline=True).add_field(
            name="Auteur :", value=message.author.display_name, inline=True))
    except:
        pass

    # Add roles

    with open("src/_data/roles.yml", 'r') as stream:
        roles = yaml.safe_load(stream)

    role = [Role(data=x) for x in roles if x['slug'].startswith('ban')]

    for r in role:
        await target.add_roles(
            message.guild.get_role(r.role_id),
            reason=f"Bantemp pour {bantemp.reason} pour une durée de {delta}")

    for channel in message.guild.channels:
        try:
            if isinstance(channel, discord.TextChannel):
                if target.permissions_in(channel).read_messages:
                    await channel.set_permissions(target, send_messages=False)
            elif isinstance(channel, discord.VoiceChannel):
                if target.permissions_in(channel).connect:
                    await channel.set_permissions(target, connect=False)
        except:
            print("Cannot do magic in " + channel.name)