Add DM permission "check" when sending system token
This commit is contained in:
parent
147e1fdc1a
commit
de010fde76
@ -1,6 +1,7 @@
|
|||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
using DSharpPlus.Entities;
|
using DSharpPlus.Entities;
|
||||||
|
using DSharpPlus.Exceptions;
|
||||||
|
|
||||||
using PluralKit.Core;
|
using PluralKit.Core;
|
||||||
|
|
||||||
@ -21,16 +22,24 @@ namespace PluralKit.Bot
|
|||||||
// Get or make a token
|
// Get or make a token
|
||||||
var token = ctx.System.Token ?? await MakeAndSetNewToken(ctx.System);
|
var token = ctx.System.Token ?? await MakeAndSetNewToken(ctx.System);
|
||||||
|
|
||||||
// If we're not already in a DM, reply with a reminder to check
|
try
|
||||||
if (!(ctx.Channel is DiscordDmChannel))
|
|
||||||
{
|
{
|
||||||
await ctx.Reply($"{Emojis.Success} Check your DMs!");
|
// DM the user a security disclaimer, and then the token in a separate message (for easy copying on mobile)
|
||||||
}
|
var dm = await ctx.Rest.CreateDmAsync(ctx.Author.Id);
|
||||||
|
await dm.SendMessageFixedAsync(
|
||||||
|
$"{Emojis.Warn} Please note that this grants access to modify (and delete!) all your system data, so keep it safe and secure. If it leaks or you need a new one, you can invalidate this one with `pk;token refresh`.\n\nYour token is below:");
|
||||||
|
await dm.SendMessageFixedAsync(token);
|
||||||
|
|
||||||
// DM the user a security disclaimer, and then the token in a separate message (for easy copying on mobile)
|
// If we're not already in a DM, reply with a reminder to check
|
||||||
var dm = await ctx.Rest.CreateDmAsync(ctx.Author.Id);
|
if (!(ctx.Channel is DiscordDmChannel))
|
||||||
await dm.SendMessageFixedAsync($"{Emojis.Warn} Please note that this grants access to modify (and delete!) all your system data, so keep it safe and secure. If it leaks or you need a new one, you can invalidate this one with `pk;token refresh`.\n\nYour token is below:");
|
await ctx.Reply($"{Emojis.Success} Check your DMs!");
|
||||||
await dm.SendMessageFixedAsync(token);
|
}
|
||||||
|
catch (UnauthorizedException)
|
||||||
|
{
|
||||||
|
// Can't check for permission errors beforehand, so have to handle here :/
|
||||||
|
if (!(ctx.Channel is DiscordDmChannel))
|
||||||
|
await ctx.Reply($"{Emojis.Error} Could not send token in DMs. Are your DMs closed?");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private async Task<string> MakeAndSetNewToken(PKSystem system)
|
private async Task<string> MakeAndSetNewToken(PKSystem system)
|
||||||
@ -52,19 +61,26 @@ namespace PluralKit.Bot
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make a new token from scratch
|
try {
|
||||||
var token = await MakeAndSetNewToken(ctx.System);
|
// DM the user an invalidation disclaimer, and then the token in a separate message (for easy copying on mobile)
|
||||||
|
var dm = await ctx.Rest.CreateDmAsync(ctx.Author.Id);
|
||||||
|
await dm.SendMessageFixedAsync($"{Emojis.Warn} Your previous API token has been invalidated. You will need to change it anywhere it's currently used.\n\nYour token is below:");
|
||||||
|
|
||||||
// If we're not already in a DM, reply with a reminder to check
|
// Make the new token after sending the first DM; this ensures if we can't DM, we also don't end up
|
||||||
if (!(ctx.Channel is DiscordDmChannel))
|
// breaking their existing token as a side effect :)
|
||||||
{
|
var token = await MakeAndSetNewToken(ctx.System);
|
||||||
await ctx.Reply($"{Emojis.Success} Check your DMs!");
|
await dm.SendMessageFixedAsync(token);
|
||||||
|
|
||||||
|
// If we're not already in a DM, reply with a reminder to check
|
||||||
|
if (!(ctx.Channel is DiscordDmChannel))
|
||||||
|
await ctx.Reply($"{Emojis.Success} Check your DMs!");
|
||||||
|
}
|
||||||
|
catch (UnauthorizedException)
|
||||||
|
{
|
||||||
|
// Can't check for permission errors beforehand, so have to handle here :/
|
||||||
|
if (!(ctx.Channel is DiscordDmChannel))
|
||||||
|
await ctx.Reply($"{Emojis.Error} Could not send token in DMs. Are your DMs closed?");
|
||||||
}
|
}
|
||||||
|
|
||||||
// DM the user an invalidation disclaimer, and then the token in a separate message (for easy copying on mobile)
|
|
||||||
var dm = await ctx.Rest.CreateDmAsync(ctx.Author.Id);
|
|
||||||
await dm.SendMessageFixedAsync($"{Emojis.Warn} Your previous API token has been invalidated. You will need to change it anywhere it's currently used.\n\nYour token is below:");
|
|
||||||
await dm.SendMessageFixedAsync(token);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user