Ошибка типа: _new_message () отсутствует 1 обязательный позиционный аргумент: 'сообщение' - PullRequest
0 голосов
/ 14 сентября 2018

Привет, я получаю TypeError, и я не уверен, что я делаю неправильно, ошибка типа TypeError: _new_message() missing 1 required positional argument: 'message', что, как я предполагаю, означает, что мне нужно создать экземпляр класса?

Это то, что я сделал, как вы видите, я добавил message = ctx.message к коду.

Вот с чем я работаю:

class antilink:
"""
Anti URL spam
"""

def __init__(self, bot):
    self.bot = bot
    self.regex = re.compile(r"<?(https?:\/\/)?(www\.)?(discord\.gg|discordapp\.com\/invite)\b([-a-zA-Z0-9/]*)>?")
    self.regex_discordme = re.compile(r"<?(https?:\/\/)?(www\.)?(discord\.me\/)\b([-a-zA-Z0-9/]*)>?")
    self.regex_url = re.compile(r'(?i)\b((?:[a-z][\w-]+:(?:/{1,3}|[a-z0-9%])|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:\'".,<>?«»“”‘’]))')


async def _new_message(self, ctx, message):
    """Finds the message and checks it for regex"""
    server = ctx.message.server
    user = message.author
    excluded = []
    message = ctx.message
    if ctx.message.server:
        if self.regex.search(ctx.message.content) is not None or self.regex_discordme.search(ctx.message.content) is not None \
            or self.regex_url.search(ctx.message.content)is not None and ctx.message.server:

                roles = [r.name for r in user.roles]
                bot_admin = settings.get_server_admin(ctx.message.server)
                bot_mod = settings.get_server_mod(ctx.message.server)
                if ctx.message.channel.id is excluded:
                    return
                elif user.id == settings.owner:
                    return
                elif bot_admin in roles:
                    return
                elif bot_mod in roles:
                    return
                elif user.permissions_in(ctx.message.channel).manage_messages is True:
                    return
                else:
                    asyncio.sleep(0.5)
                    await self.bot.delete_message(message)


def setup(bot):
    q = antilink(bot)
    bot.add_listener(q._new_message, 'on_message')
    bot.add_cog(q)

Если бы кто-нибудь мог помочь мне здесь, я был бы очень благодарен.

Спасибо

1 Ответ

0 голосов
/ 14 сентября 2018

Если вы регистрируете q._new_message как обратный вызов on_message, то он будет вызываться с теми же аргументами on_message, что означает один аргумент Message, представляющий сообщениекоторый был отправлен.

async def _new_message(self, message):
    """Finds the message and checks it for regex"""
    server = message.server
    user = message.author
    excluded = []
    if server:
        if self.regex.search(message.content) is not None or self.regex_discordme.search(message.content) is not None \
            or self.regex_url.search(message.content)is not None and message.server:

                roles = [r.name for r in user.roles]
                bot_admin = settings.get_server_admin(message.server)
                bot_mod = settings.get_server_mod(message.server)
                if message.channel.id is excluded:
                    return
                elif user.id == settings.owner:
                    return
                elif bot_admin in roles:
                    return
                elif bot_mod in roles:
                    return
                elif user.permissions_in(message.channel).manage_messages is True:
                    return
                else:
                    asyncio.sleep(0.5)
                    await self.bot.delete_message(message)

Вы также можете просто определить метод async def on_message(self, message), который механизм add_cog автоматически зарегистрирует в качестве обратного вызова для события с таким именем.

...