mirror of
https://github.com/Cog-Creators/Red-DiscordBot.git
synced 2025-11-06 03:08:55 -05:00
API changes: - Cogs must now inherit from `commands.Cog` (see #2151 for discussion and more details) - All functions which are not decorators in the `redbot.core.checks` module are now deprecated in favour of their counterparts in `redbot.core.utils.mod`. This is to make this module more consistent and end the confusing naming convention. - `redbot.core.checks.check_overrides` function is now gone, overrideable checks can now be created with the `@commands.permissions_check` decorator - Command, Group, Cog and Context have some new attributes and methods, but they are for internal use so shouldn't concern cog creators (unless they're making a permissions cog!). - `__permissions_check_before` and `__permissions_check_after` have been replaced: A cog method named `__permissions_hook` will be evaluated as permissions hooks in the same way `__permissions_check_before` previously was. Permissions hooks can also be added/removed/verified through the new `*_permissions_hook()` methods on the bot object, and they will be verified even when permissions is unloaded. - New utility method `redbot.core.utils.chat_formatting.humanize_list` - New dependency [`schema`](https://github.com/keleshev/schema) User-facing changes: - When a `@bot_has_permissions` check fails, the bot will respond saying what permissions were actually missing. - All YAML-related `[p]permissions` subcommands now reside under the `[p]permissions acl` sub-group (tbh I still think the whole cog has too many top-level commands) - The YAML schema for these commands has been changed - A rule cannot be set as allow and deny at the same time (previously this would just default to allow) Documentation: - New documentation for `redbot.core.commands.requires` and `redbot.core.checks` modules - Renewed documentation for the permissions cog - `sphinx.ext.doctest` is now enabled Note: standard discord.py checks will still behave exactly the same way, in fact they are checked before `Requires` is looked at, so they are not overrideable. Signed-off-by: Toby Harradine <tobyharradine@gmail.com>
79 lines
2.7 KiB
Python
79 lines
2.7 KiB
Python
from pathlib import Path
|
|
import asyncio
|
|
|
|
from redbot.core import checks, commands
|
|
from redbot.core.bot import Red
|
|
from redbot.core.i18n import Translator, cog_i18n
|
|
from redbot.cogs.dataconverter.core_specs import SpecResolver
|
|
from redbot.core.utils.chat_formatting import box
|
|
|
|
_ = Translator("DataConverter", __file__)
|
|
|
|
|
|
@cog_i18n(_)
|
|
class DataConverter(commands.Cog):
|
|
"""
|
|
Cog for importing Red v2 Data
|
|
"""
|
|
|
|
def __init__(self, bot: Red):
|
|
super().__init__()
|
|
self.bot = bot
|
|
|
|
@checks.is_owner()
|
|
@commands.command(name="convertdata")
|
|
async def dataconversioncommand(self, ctx: commands.Context, v2path: str):
|
|
"""
|
|
Interactive prompt for importing data from Red v2
|
|
|
|
Takes the path where the v2 install is
|
|
|
|
Overwrites values which have entries in both v2 and v3,
|
|
use with caution.
|
|
"""
|
|
resolver = SpecResolver(Path(v2path.strip()))
|
|
|
|
if not resolver.available:
|
|
return await ctx.send(
|
|
_(
|
|
"There don't seem to be any data files I know how to "
|
|
"handle here. Are you sure you gave me the base "
|
|
"installation path?"
|
|
)
|
|
)
|
|
while resolver.available:
|
|
menu = _("Please select a set of data to import by number, or 'exit' to exit")
|
|
for index, entry in enumerate(resolver.available, 1):
|
|
menu += "\n{}. {}".format(index, entry)
|
|
|
|
menu_message = await ctx.send(box(menu))
|
|
|
|
def pred(m):
|
|
return m.channel == ctx.channel and m.author == ctx.author
|
|
|
|
try:
|
|
message = await self.bot.wait_for("message", check=pred, timeout=60)
|
|
except asyncio.TimeoutError:
|
|
return await ctx.send(_("Try this again when you are more ready"))
|
|
else:
|
|
if message.content.strip().lower() in ["quit", "exit", "-1", "q", "cancel"]:
|
|
return await ctx.tick()
|
|
try:
|
|
message = int(message.content.strip())
|
|
to_conv = resolver.available[message - 1]
|
|
except (ValueError, IndexError):
|
|
await ctx.send(_("That wasn't a valid choice."))
|
|
continue
|
|
else:
|
|
async with ctx.typing():
|
|
await resolver.convert(self.bot, to_conv)
|
|
await ctx.send(_("{} converted.").format(to_conv))
|
|
await menu_message.delete()
|
|
else:
|
|
return await ctx.send(
|
|
_(
|
|
"There isn't anything else I know how to convert here."
|
|
"\nThere might be more things I can convert in the future."
|
|
)
|
|
)
|