Add support for messageTarget input in commands that take a message id

This commit is contained in:
Dragory 2020-08-06 01:54:46 +03:00
parent 28afb5b8d3
commit 76d4efcaf3
No known key found for this signature in database
GPG key ID: 5F387BA66DF8AAC1
6 changed files with 42 additions and 41 deletions

View file

@ -8,12 +8,12 @@ export const EditCmd = postCmd({
permission: "can_post", permission: "can_post",
signature: { signature: {
messageId: ct.string(), message: ct.messageTarget(),
content: ct.string({ catchAll: true }), content: ct.string({ catchAll: true }),
}, },
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
const savedMessage = await pluginData.state.savedMessages.find(args.messageId); const savedMessage = await pluginData.state.savedMessages.find(args.message.messageId);
if (!savedMessage) { if (!savedMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message"); sendErrorMessage(pluginData, msg.channel, "Unknown message");
return; return;

View file

@ -12,7 +12,7 @@ export const EditEmbedCmd = postCmd({
permission: "can_post", permission: "can_post",
signature: { signature: {
messageId: ct.string(), message: ct.messageTarget(),
maincontent: ct.string({ catchAll: true }), maincontent: ct.string({ catchAll: true }),
title: ct.string({ option: true }), title: ct.string({ option: true }),
@ -21,7 +21,7 @@ export const EditEmbedCmd = postCmd({
}, },
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
const savedMessage = await pluginData.state.savedMessages.find(args.messageId); const savedMessage = await pluginData.state.savedMessages.find(args.message.messageId);
if (!savedMessage) { if (!savedMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message"); sendErrorMessage(pluginData, msg.channel, "Unknown message");
return; return;

View file

@ -8,26 +8,19 @@ export const ClearReactionRolesCmd = reactionRolesCmd({
permission: "can_manage", permission: "can_manage",
signature: { signature: {
messageId: ct.string(), message: ct.messageTarget(),
}, },
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
const savedMessage = await pluginData.state.savedMessages.find(args.messageId); const existingReactionRoles = pluginData.state.reactionRoles.getForMessage(args.message.messageId);
if (!savedMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message");
return;
}
const existingReactionRoles = pluginData.state.reactionRoles.getForMessage(args.messageId);
if (!existingReactionRoles) { if (!existingReactionRoles) {
sendErrorMessage(pluginData, msg.channel, "Message doesn't have reaction roles on it"); sendErrorMessage(pluginData, msg.channel, "Message doesn't have reaction roles on it");
return; return;
} }
pluginData.state.reactionRoles.removeFromMessage(args.messageId); pluginData.state.reactionRoles.removeFromMessage(args.message.messageId);
const channel = pluginData.guild.channels.get(savedMessage.channel_id) as TextChannel; const targetMessage = await args.message.channel.getMessage(args.message.messageId);
const targetMessage = await channel.getMessage(savedMessage.id);
await targetMessage.removeReactions(); await targetMessage.removeReactions();
sendSuccessMessage(pluginData, msg.channel, "Reaction roles cleared"); sendSuccessMessage(pluginData, msg.channel, "Reaction roles cleared");

View file

@ -5,6 +5,7 @@ import { TextChannel } from "eris";
import { RecoverablePluginError, ERRORS } from "src/RecoverablePluginError"; import { RecoverablePluginError, ERRORS } from "src/RecoverablePluginError";
import { canUseEmoji, noop } from "../../../utils"; import { canUseEmoji, noop } from "../../../utils";
import { applyReactionRoleReactionsToMessage } from "../util/applyReactionRoleReactionsToMessage"; import { applyReactionRoleReactionsToMessage } from "../util/applyReactionRoleReactionsToMessage";
import { canReadChannel } from "../../../utils/canReadChannel";
const CLEAR_ROLES_EMOJI = "❌"; const CLEAR_ROLES_EMOJI = "❌";
@ -13,26 +14,19 @@ export const InitReactionRolesCmd = reactionRolesCmd({
permission: "can_manage", permission: "can_manage",
signature: { signature: {
messageId: ct.string(), message: ct.messageTarget(),
reactionRolePairs: ct.string({ catchAll: true }), reactionRolePairs: ct.string({ catchAll: true }),
exclusive: ct.bool({ option: true, isSwitch: true, shortcut: "e" }), exclusive: ct.bool({ option: true, isSwitch: true, shortcut: "e" }),
}, },
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
const savedMessage = await pluginData.state.savedMessages.find(args.messageId); if (!canReadChannel(args.message.channel, msg.member.id)) {
if (!savedMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message"); sendErrorMessage(pluginData, msg.channel, "Unknown message");
return; return;
} }
const channel = (await pluginData.guild.channels.get(savedMessage.channel_id)) as TextChannel; const targetMessage = await args.message.channel.getMessage(args.message.messageId);
if (!channel || !(channel instanceof TextChannel)) {
sendErrorMessage(pluginData, msg.channel, "Channel no longer exists");
return;
}
const targetMessage = await channel.getMessage(args.messageId);
if (!targetMessage) { if (!targetMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message (2)"); sendErrorMessage(pluginData, msg.channel, "Unknown message (2)");
return; return;
@ -97,7 +91,13 @@ export const InitReactionRolesCmd = reactionRolesCmd({
// Save the new reaction roles to the database // Save the new reaction roles to the database
for (const pair of emojiRolePairs) { for (const pair of emojiRolePairs) {
await pluginData.state.reactionRoles.add(channel.id, targetMessage.id, pair[0], pair[1], args.exclusive); await pluginData.state.reactionRoles.add(
args.message.channel.id,
targetMessage.id,
pair[0],
pair[1],
args.exclusive,
);
} }
// Apply the reactions themselves // Apply the reactions themselves

View file

@ -8,22 +8,16 @@ export const RefreshReactionRolesCmd = reactionRolesCmd({
permission: "can_manage", permission: "can_manage",
signature: { signature: {
messageId: ct.string(), message: ct.messageTarget(),
}, },
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
const savedMessage = await pluginData.state.savedMessages.find(args.messageId); if (pluginData.state.pendingRefreshes.has(`${args.message.channel.id}-${args.message.messageId}`)) {
if (!savedMessage) {
sendErrorMessage(pluginData, msg.channel, "Unknown message");
return;
}
if (pluginData.state.pendingRefreshes.has(`${savedMessage.channel_id}-${savedMessage.id}`)) {
sendErrorMessage(pluginData, msg.channel, "Another refresh in progress"); sendErrorMessage(pluginData, msg.channel, "Another refresh in progress");
return; return;
} }
await refreshReactionRoles(pluginData, savedMessage.channel_id, savedMessage.id); await refreshReactionRoles(pluginData, args.message.channel.id, args.message.messageId);
sendSuccessMessage(pluginData, msg.channel, "Reaction roles refreshed"); sendSuccessMessage(pluginData, msg.channel, "Reaction roles refreshed");
}, },

View file

@ -3,6 +3,7 @@ import { commandTypeHelpers as ct } from "../../../commandTypes";
import { messageLink } from "../../../utils"; import { messageLink } from "../../../utils";
import { sendErrorMessage } from "../../../pluginUtils"; import { sendErrorMessage } from "../../../pluginUtils";
import { TextChannel } from "eris"; import { TextChannel } from "eris";
import { canReadChannel } from "../../../utils/canReadChannel";
export const ContextCmd = utilityCmd({ export const ContextCmd = utilityCmd({
trigger: "context", trigger: "context",
@ -10,18 +11,31 @@ export const ContextCmd = utilityCmd({
usage: "!context 94882524378968064 650391267720822785", usage: "!context 94882524378968064 650391267720822785",
permission: "can_context", permission: "can_context",
signature: { signature: [
channel: ct.channel(), {
messageId: ct.string(), message: ct.messageTarget(),
}, },
{
channel: ct.channel(),
messageId: ct.string(),
},
],
async run({ message: msg, args, pluginData }) { async run({ message: msg, args, pluginData }) {
if (!(args.channel instanceof TextChannel)) { if (args.channel && !(args.channel instanceof TextChannel)) {
sendErrorMessage(pluginData, msg.channel, "Channel must be a text channel"); sendErrorMessage(pluginData, msg.channel, "Channel must be a text channel");
return; return;
} }
const previousMessage = (await pluginData.client.getMessages(args.channel.id, 1, args.messageId))[0]; const channel = args.channel || args.message.channel;
const messageId = args.messageId || args.message.messageId;
if (!canReadChannel(channel, msg.member.id)) {
sendErrorMessage(pluginData, msg.channel, "Message context not found");
return;
}
const previousMessage = (await pluginData.client.getMessages(channel.id, 1, messageId))[0];
if (!previousMessage) { if (!previousMessage) {
sendErrorMessage(pluginData, msg.channel, "Message context not found"); sendErrorMessage(pluginData, msg.channel, "Message context not found");
return; return;