mirror of
https://github.com/swc-project/swc.git
synced 2024-12-21 12:41:54 +03:00
d60c3242af
swc_bundler: - Fix cycle detection for complex circular imports. (denoland/deno#10752) swc_ecma_transforms_typescript: - Allow using large values for an enum variant.
58 lines
2.3 KiB
TypeScript
58 lines
2.3 KiB
TypeScript
// Loaded from https://deno.land/x/discordeno@11.0.0-rc.2/src/helpers/interactions/commands/edit_slash_response.ts
|
|
|
|
|
|
import { applicationId } from "../../../bot.ts";
|
|
import { rest } from "../../../rest/rest.ts";
|
|
import { structures } from "../../../structures/mod.ts";
|
|
import type { DiscordenoEditWebhookMessage } from "../../../types/discordeno/edit_webhook_message.ts";
|
|
import { Errors } from "../../../types/discordeno/errors.ts";
|
|
import { DiscordAllowedMentionsTypes } from "../../../types/messages/allowed_mentions_types.ts";
|
|
import { endpoints } from "../../../util/constants.ts";
|
|
|
|
/** To edit your response to a slash command. If a messageId is not provided it will default to editing the original response. */
|
|
export async function editSlashResponse(token: string, options: DiscordenoEditWebhookMessage) {
|
|
if (options.content && options.content.length > 2000) {
|
|
throw Error(Errors.MESSAGE_MAX_LENGTH);
|
|
}
|
|
|
|
if (options.embeds && options.embeds.length > 10) {
|
|
options.embeds.splice(10);
|
|
}
|
|
|
|
if (options.allowedMentions) {
|
|
if (options.allowedMentions.users?.length) {
|
|
if (options.allowedMentions.parse?.includes(DiscordAllowedMentionsTypes.UserMentions)) {
|
|
options.allowedMentions.parse = options.allowedMentions.parse.filter((p) => p !== "users");
|
|
}
|
|
|
|
if (options.allowedMentions.users.length > 100) {
|
|
options.allowedMentions.users = options.allowedMentions.users.slice(0, 100);
|
|
}
|
|
}
|
|
|
|
if (options.allowedMentions.roles?.length) {
|
|
if (options.allowedMentions.parse?.includes(DiscordAllowedMentionsTypes.RoleMentions)) {
|
|
options.allowedMentions.parse = options.allowedMentions.parse.filter((p) => p !== "roles");
|
|
}
|
|
|
|
if (options.allowedMentions.roles.length > 100) {
|
|
options.allowedMentions.roles = options.allowedMentions.roles.slice(0, 100);
|
|
}
|
|
}
|
|
}
|
|
|
|
const result = await rest.runMethod(
|
|
"patch",
|
|
options.messageId
|
|
? endpoints.WEBHOOK_MESSAGE(applicationId, token, options.messageId)
|
|
: endpoints.INTERACTION_ORIGINAL_ID_TOKEN(applicationId, token),
|
|
options
|
|
);
|
|
|
|
// If the original message was edited, this will not return a message
|
|
if (!options.messageId) return result as undefined;
|
|
|
|
const message = await structures.createDiscordenoMessage(result);
|
|
return message;
|
|
}
|