Add support for messageTarget input in commands that take a message id
This commit is contained in:
parent
28afb5b8d3
commit
76d4efcaf3
6 changed files with 42 additions and 41 deletions
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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");
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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");
|
||||||
},
|
},
|
||||||
|
|
|
@ -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: [
|
||||||
|
{
|
||||||
|
message: ct.messageTarget(),
|
||||||
|
},
|
||||||
|
{
|
||||||
channel: ct.channel(),
|
channel: ct.channel(),
|
||||||
messageId: ct.string(),
|
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;
|
||||||
|
|
Loading…
Add table
Reference in a new issue