mirror of
https://github.com/Cog-Creators/Red-DiscordBot.git
synced 2025-11-21 10:17:59 -05:00
Allow central storage of API keys (#2389)
This creates a central location to store external API tokens that can be used between cogs without requiring each cog to be loaded for it to work. A new set option for `[p]set api` is created to assist in forming bot readable API token locations. This also updates the Streams cog to utilize the central database. Tokens are moved from the old data locations in core cogs on load.
This commit is contained in:
committed by
Toby Harradine
parent
722aaa225b
commit
3f1d416526
@@ -56,6 +56,7 @@ class RedBase(commands.GroupMixin, commands.bot.BotBase, RPCMixin):
|
||||
help__tagline="",
|
||||
disabled_commands=[],
|
||||
disabled_command_msg="That command is disabled.",
|
||||
api_tokens={},
|
||||
)
|
||||
|
||||
self.db.register_guild(
|
||||
|
||||
@@ -39,3 +39,29 @@ class GuildConverter(discord.Guild):
|
||||
raise BadArgument(_('Server "{name}" not found.').format(name=argument))
|
||||
|
||||
return ret
|
||||
|
||||
|
||||
class APIToken(discord.ext.commands.Converter):
|
||||
"""Converts to a `dict` object.
|
||||
|
||||
This will parse the input argument separating the key value pairs into a
|
||||
format to be used for the core bots API token storage.
|
||||
|
||||
This will split the argument by eiher `;` or `,` and return a dict
|
||||
to be stored. Since all API's are different and have different naming convention,
|
||||
this leaves the owness on the cog creator to clearly define how to setup the correct
|
||||
credential names for their cogs.
|
||||
"""
|
||||
|
||||
async def convert(self, ctx, argument) -> dict:
|
||||
bot = ctx.bot
|
||||
result = {}
|
||||
match = re.split(r";|,", argument)
|
||||
# provide two options to split incase for whatever reason one is part of the api key we're using
|
||||
if len(match) > 1:
|
||||
result[match[0]] = "".join(r for r in match[1:])
|
||||
else:
|
||||
raise BadArgument(_("The provided tokens are not in a valid format."))
|
||||
if not result:
|
||||
raise BadArgument(_("The provided tokens are not in a valid format."))
|
||||
return result
|
||||
|
||||
@@ -1036,6 +1036,25 @@ class Core(commands.Cog, CoreLogic):
|
||||
else:
|
||||
await ctx.bot.send(_("Characters must be fewer than 1024."))
|
||||
|
||||
@_set.command()
|
||||
@checks.is_owner()
|
||||
async def api(self, ctx: commands.Context, service: str, *tokens: commands.converter.APIToken):
|
||||
"""Set various external API tokens.
|
||||
|
||||
This setting will be asked for by some 3rd party cogs and some core cogs.
|
||||
|
||||
To add the keys provide the service name and the tokens as a comma separated
|
||||
list of key,values as described by the cog requesting this command.
|
||||
|
||||
Note: API tokens are sensitive and should only be used in a private channel
|
||||
or in DM with the bot.
|
||||
"""
|
||||
if ctx.channel.permissions_for(ctx.me).manage_messages:
|
||||
await ctx.message.delete()
|
||||
entry = {k: v for t in tokens for k, v in t.items()}
|
||||
await ctx.bot.db.api_tokens.set_raw(service, value=entry)
|
||||
await ctx.send(_("`{service}` API tokens have been set.").format(service=service))
|
||||
|
||||
@commands.group()
|
||||
@checks.is_owner()
|
||||
async def helpset(self, ctx: commands.Context):
|
||||
|
||||
Reference in New Issue
Block a user