fully prepare execution for interactions

This commit is contained in:
Wroclaw 2023-05-08 08:51:30 +02:00
parent 28dce0b29f
commit 56a0e686b0

View file

@ -54,6 +54,32 @@ async function getUserLimit(user: string | {id: string}, requestTimestamp: Date)
return {limit: userLimits.limit, remaining: userLimits.limit - usedLimit}; return {limit: userLimits.limit, remaining: userLimits.limit - usedLimit};
} }
/**
* Replies to a request
* @param request the request to reply to
* @param message the message
* @param replyOptions additional options if the request is a message
* @param interactionOptions additional options if the request is an interaction
* @returns Promise of the done action
*/
function requestReply(
request: request,
message: DiscordApi.MessageReplyOptions & DiscordApi.InteractionReplyOptions,
// TODO: add support for these below
replyOptions: DiscordApi.MessageReplyOptions = {},
interactionOptions: DiscordApi.InteractionReplyOptions = {},
) {
if (request instanceof DiscordApi.Message) {
return request.reply(Object.assign(message, replyOptions));
}
else {
if (!request.deferred)
return request.reply(Object.assign(message, interactionOptions));
else
return request.editReply(Object.assign(message, interactionOptions));
}
}
/** /**
* Check and queues up the request and runs it if there is nothing in queue. * Check and queues up the request and runs it if there is nothing in queue.
* @param request the message to check and queue * @param request the message to check and queue
@ -151,14 +177,10 @@ async function executeFromQueue(channel: string) {
const answerContent = answer.data.choices[0].message?.content; const answerContent = answer.data.choices[0].message?.content;
if (answerContent != undefined || answerContent != "") { if (answerContent != undefined || answerContent != "") {
const response = message.reply({
content: answerContent,
allowedMentions: {
repliedUser: false,
}
});
Moderation.checkMessage(await response); const response = requestReply(message, {content: answerContent}, {allowedMentions: { repliedUser: false }});
response.then(rval => Moderation.checkMessage(rval));
} }
else { else {
if (message instanceof DiscordApi.Message) message.react("😶"); if (message instanceof DiscordApi.Message) message.react("😶");
@ -167,15 +189,17 @@ async function executeFromQueue(channel: string) {
console.error(`Error ocurred while handling chat completion request (${(e as object).constructor.name}):`); console.error(`Error ocurred while handling chat completion request (${(e as object).constructor.name}):`);
console.error(e); console.error(e);
message.reply({ requestReply(
embeds: [{ message,
color: 0xff0000, {
description: "Something bad happened! :frowning:" embeds: [{
}], color: 0xff0000,
allowedMentions: { description: "Something bad happened! :frowning:"
repliedUser: false, }],
} },
}); {allowedMentions: { repliedUser: false } },
{ ephemeral: true },
);
} }
channelQueue.shift(); channelQueue.shift();