mirror of
https://github.com/discordeno/discordeno.git
synced 2026-06-02 08:50:07 +00:00
* refactor(helpers): Organise functions. (#2425) * refactor: Move stage instance helper functions into `/stages` subdirectory. * refactor: Move `followChannel.ts` to `/announcements` subdirectory. * refactor: Move `updateVoiceState.ts` to `/guilds` directory. * refactor: Move `getPins.ts` to `/messages` directory. * refactor: Move voice-related helper functions into `/voice` subdirectory. * refactor: Rename `/scheduledEvents` to `/events`. * refactor: Move widget-related helper functions into `/widgets` subdirectory. * refactor: Make `/integrations` a subdirectory of `/guilds`. * refactor: Move helper functions related to interaction responses into the `/responses` subdirectory. * refactor: Move `verifySignature.ts` to `/util` directory. * refactor: Move `getChannelInvites.ts` to `/channels` directory. * refactor: Make `/invites` a subdirectory of `/guilds`. * refactor: Move reaction-related helper functions into the /reactions subdirectory. * refactor: Move `getApplicationInfo.ts` into the `/misc` directory. * refactor: Move voice-related helper functions from `/voice` to `/guilds/voice`. * fix: Update and simplify type imports. * refactor!(helpers): Rename helpers to match Discord API. Create a 1:1 helper-to-endpoint correspondence. (#2427) * refactor: Move stage instance helper functions into `/stages` subdirectory. * refactor: Move `followChannel.ts` to `/announcements` subdirectory. * refactor: Move `updateVoiceState.ts` to `/guilds` directory. * refactor: Move `getPins.ts` to `/messages` directory. * refactor: Move voice-related helper functions into `/voice` subdirectory. * refactor: Rename `/scheduledEvents` to `/events`. * refactor: Move widget-related helper functions into `/widgets` subdirectory. * refactor: Make `/integrations` a subdirectory of `/guilds`. * refactor: Move helper functions related to interaction responses into the `/responses` subdirectory. * refactor: Move `verifySignature.ts` to `/util` directory. * refactor: Move `getChannelInvites.ts` to `/channels` directory. * refactor: Make `/invites` a subdirectory of `/guilds`. * refactor: Move reaction-related helper functions into the /reactions subdirectory. * refactor: Move `getApplicationInfo.ts` into the `/misc` directory. * refactor: Move voice-related helper functions from `/voice` to `/guilds/voice`. * fix: Update and simplify type imports. * refactor: Rename `followChannel` -> `followAnnouncementChannel`. * refactor: Rename `createForumPost` -> `startForumThread`. * refactor: Normalise keyword `update` -> `edit`. * refactor: Rename `addToThread` -> `addThreadMember`. * refactor: Rename `ChannelOverwrite` -> `ChannelPermissions`. * refactor: Rename `startTyping` -> `triggerTypingIndicator`. * refactor: Rename `swapChannels` -> `editChannelPositions`. * refactor: Rename `getPins` -> `getPinnedMessages`. * refactor: Rename `publish` -> `crosspost`. * refactor: Normalise keyword `modify` -> `edit`. * refactor: Normalise naming. * fix: Imports. * style: Remove empty object. * refactor: Split `getArchivedThreads` into three files for public, private and private joined threads. * refactor: Split `getApplicationCommands` into two files, for guild and global commands respectively. * refactor: Split `getApplicationCommand` into two files, for guild and global commands respectively. * fmt: Organise imports. * misc: Include application command reverse transformer. * misc: Make ordering of fields match up with the Discord API. * fix: Add missing payload properties. * refactor: Split `createApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommands` into two files, for guild and global commands respectively. * fix: Update exports. * refactor: Split `deleteApplicationCommand` into two files, for guild and global commands respectively. * fix: Add missing exports. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * feat: Create `getInteractionResponse.ts`. * refactor: Matching API: `InteractionResponse` -> `FollowupMessage`. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Remove `/followups` directory in favour of newly created files in `/responses`. * refactor: Rename `bot`/`self` -> `own`, `others` -> `user`. * refactor: Split function into `deleteOwnReaction` and `deleteUserReaction`. * refactor: Reduce code duplication in processing reaction string. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Rename function name. * misc: Add aliases to functions to reduce breakage. * refactor: Rename `startForumThread` -> `createForumThread`. * misc: Move types from helper file to `/types` and create transformer. * fix: Imports. * style: Rename parameter `command` -> `payload`. * feat: Create interaction response transformer. * misc: Adapt code to use the interaction response transformer. * misc: Adapt code to use interaction response transformer. * refactor: Re-include the keyword `Override` in the file + function names. * refactor: Rename `updateVoiceState` -> `editVoiceState` for consistency reasons. Co-authored-by: Skillz4Killz <23035000+Skillz4Killz@users.noreply.github.com> * BREAKING: docs(helpers): Document helper functions. (#2437) * refactor: Move stage instance helper functions into `/stages` subdirectory. * refactor: Move `followChannel.ts` to `/announcements` subdirectory. * refactor: Move `updateVoiceState.ts` to `/guilds` directory. * refactor: Move `getPins.ts` to `/messages` directory. * refactor: Move voice-related helper functions into `/voice` subdirectory. * refactor: Rename `/scheduledEvents` to `/events`. * refactor: Move widget-related helper functions into `/widgets` subdirectory. * refactor: Make `/integrations` a subdirectory of `/guilds`. * refactor: Move helper functions related to interaction responses into the `/responses` subdirectory. * refactor: Move `verifySignature.ts` to `/util` directory. * refactor: Move `getChannelInvites.ts` to `/channels` directory. * refactor: Make `/invites` a subdirectory of `/guilds`. * refactor: Move reaction-related helper functions into the /reactions subdirectory. * refactor: Move `getApplicationInfo.ts` into the `/misc` directory. * refactor: Move voice-related helper functions from `/voice` to `/guilds/voice`. * fix: Update and simplify type imports. * refactor: Rename `followChannel` -> `followAnnouncementChannel`. * refactor: Rename `createForumPost` -> `startForumThread`. * refactor: Normalise keyword `update` -> `edit`. * refactor: Rename `addToThread` -> `addThreadMember`. * refactor: Rename `ChannelOverwrite` -> `ChannelPermissions`. * refactor: Rename `startTyping` -> `triggerTypingIndicator`. * refactor: Rename `swapChannels` -> `editChannelPositions`. * refactor: Rename `getPins` -> `getPinnedMessages`. * refactor: Rename `publish` -> `crosspost`. * refactor: Normalise keyword `modify` -> `edit`. * refactor: Normalise naming. * fix: Imports. * style: Remove empty object. * refactor: Split `getArchivedThreads` into three files for public, private and private joined threads. * refactor: Split `getApplicationCommands` into two files, for guild and global commands respectively. * refactor: Split `getApplicationCommand` into two files, for guild and global commands respectively. * fmt: Organise imports. * misc: Include application command reverse transformer. * misc: Make ordering of fields match up with the Discord API. * fix: Add missing payload properties. * refactor: Split `createApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommands` into two files, for guild and global commands respectively. * fix: Update exports. * refactor: Split `deleteApplicationCommand` into two files, for guild and global commands respectively. * fix: Add missing exports. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * feat: Create `getInteractionResponse.ts`. * refactor: Matching API: `InteractionResponse` -> `FollowupMessage`. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Remove `/followups` directory in favour of newly created files in `/responses`. * refactor: Rename `bot`/`self` -> `own`, `others` -> `user`. * refactor: Split function into `deleteOwnReaction` and `deleteUserReaction`. * refactor: Reduce code duplication in processing reaction string. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Rename function name. * misc: Add aliases to functions to reduce breakage. * refactor: Rename `startForumThread` -> `createForumThread`. * misc: Move types from helper file to `/types` and create transformer. * fix: Imports. * style: Rename parameter `command` -> `payload`. * feat: Create interaction response transformer. * misc: Adapt code to use the interaction response transformer. * misc: Adapt code to use interaction response transformer. * docs: Document announcement channel helpers. * docs: Document forum channel helpers. * docs: Document stage instance helpers. * misc: Update wording. * docs: Document thread channel helpers. * refactor: Re-include the keyword `Override` in the file + function names. * refactor: Rename `updateVoiceState` -> `editVoiceState` for consistency reasons. * docs: Document channel helpers. * docs: Use `parameters` instead of `options` for descriptions. * docs: Document guild discovery helpers. * docs: Document emoji helpers. * docs: Add missing information about which gateway events are fired. * docs: Document auto moderation helpers. * docs: Document scheduled event helpers. * docs: Document integration helpers. * docs: Document invite helpers. * refactor: Rename `editWidget` -> `editWidgetSettings`. * docs: Document guild widget helpers. * docs: 'event' -> 'gateway event'. * refactor: Rename `getAuditLogs` -> `getAuditLog`. * docs: Document guild helpers. * refactor: Rename `upsert*ApplicationCommand` -> `edit*ApplicationCommand`. * docs: Document application command helpers. * docs: Improve consistency in indentation. * docs: Document interaction response + follow-up message helpers. * docs: Document gateway event firings for endpoints. * refactor: Delete `editBotNickname` due to being a subset of `editMember`. * docs: Fix inconsistency. * docs: Document member helpers. * docs: Document reaction helpers. * docs: Improve consistency. * docs: Document message helpers. * docs: Document role helpers. * docs: Document guild template helpers. * docs: Fix incorrect gateway event. * refactor: Rename `sendWebhookMessage` -> `executeWebhook`. * docs: Document webhook helpers. * docs: Document voice helpers. * fmt: Run Deno formatter. * docs: Improve consistency. * refactor: Rename the `/widgets` directory to `/widget`. * fmt: Run Deno formatter. * misc: Re-add the deleted `editBotNickname()` helper. (#2443) * refactor: Move stage instance helper functions into `/stages` subdirectory. * refactor: Move `followChannel.ts` to `/announcements` subdirectory. * refactor: Move `updateVoiceState.ts` to `/guilds` directory. * refactor: Move `getPins.ts` to `/messages` directory. * refactor: Move voice-related helper functions into `/voice` subdirectory. * refactor: Rename `/scheduledEvents` to `/events`. * refactor: Move widget-related helper functions into `/widgets` subdirectory. * refactor: Make `/integrations` a subdirectory of `/guilds`. * refactor: Move helper functions related to interaction responses into the `/responses` subdirectory. * refactor: Move `verifySignature.ts` to `/util` directory. * refactor: Move `getChannelInvites.ts` to `/channels` directory. * refactor: Make `/invites` a subdirectory of `/guilds`. * refactor: Move reaction-related helper functions into the /reactions subdirectory. * refactor: Move `getApplicationInfo.ts` into the `/misc` directory. * refactor: Move voice-related helper functions from `/voice` to `/guilds/voice`. * fix: Update and simplify type imports. * refactor: Rename `followChannel` -> `followAnnouncementChannel`. * refactor: Rename `createForumPost` -> `startForumThread`. * refactor: Normalise keyword `update` -> `edit`. * refactor: Rename `addToThread` -> `addThreadMember`. * refactor: Rename `ChannelOverwrite` -> `ChannelPermissions`. * refactor: Rename `startTyping` -> `triggerTypingIndicator`. * refactor: Rename `swapChannels` -> `editChannelPositions`. * refactor: Rename `getPins` -> `getPinnedMessages`. * refactor: Rename `publish` -> `crosspost`. * refactor: Normalise keyword `modify` -> `edit`. * refactor: Normalise naming. * fix: Imports. * style: Remove empty object. * refactor: Split `getArchivedThreads` into three files for public, private and private joined threads. * refactor: Split `getApplicationCommands` into two files, for guild and global commands respectively. * refactor: Split `getApplicationCommand` into two files, for guild and global commands respectively. * fmt: Organise imports. * misc: Include application command reverse transformer. * misc: Make ordering of fields match up with the Discord API. * fix: Add missing payload properties. * refactor: Split `createApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommand` into two files, for guild and global commands respectively. * refactor: Split `upsertApplicationCommands` into two files, for guild and global commands respectively. * fix: Update exports. * refactor: Split `deleteApplicationCommand` into two files, for guild and global commands respectively. * fix: Add missing exports. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * feat: Create `getInteractionResponse.ts`. * refactor: Matching API: `InteractionResponse` -> `FollowupMessage`. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Remove `/followups` directory in favour of newly created files in `/responses`. * refactor: Rename `bot`/`self` -> `own`, `others` -> `user`. * refactor: Split function into `deleteOwnReaction` and `deleteUserReaction`. * refactor: Reduce code duplication in processing reaction string. * refactor: Separate file into two to make 1 file correspond to 1 endpoint. * refactor: Rename function name. * misc: Add aliases to functions to reduce breakage. * refactor: Rename `startForumThread` -> `createForumThread`. * misc: Move types from helper file to `/types` and create transformer. * fix: Imports. * style: Rename parameter `command` -> `payload`. * feat: Create interaction response transformer. * misc: Adapt code to use the interaction response transformer. * misc: Adapt code to use interaction response transformer. * docs: Document announcement channel helpers. * docs: Document forum channel helpers. * docs: Document stage instance helpers. * misc: Update wording. * docs: Document thread channel helpers. * refactor: Re-include the keyword `Override` in the file + function names. * refactor: Rename `updateVoiceState` -> `editVoiceState` for consistency reasons. * docs: Document channel helpers. * docs: Use `parameters` instead of `options` for descriptions. * docs: Document guild discovery helpers. * docs: Document emoji helpers. * docs: Add missing information about which gateway events are fired. * docs: Document auto moderation helpers. * docs: Document scheduled event helpers. * docs: Document integration helpers. * docs: Document invite helpers. * refactor: Rename `editWidget` -> `editWidgetSettings`. * docs: Document guild widget helpers. * docs: 'event' -> 'gateway event'. * refactor: Rename `getAuditLogs` -> `getAuditLog`. * docs: Document guild helpers. * refactor: Rename `upsert*ApplicationCommand` -> `edit*ApplicationCommand`. * docs: Document application command helpers. * docs: Improve consistency in indentation. * docs: Document interaction response + follow-up message helpers. * docs: Document gateway event firings for endpoints. * refactor: Delete `editBotNickname` due to being a subset of `editMember`. * docs: Fix inconsistency. * docs: Document member helpers. * docs: Document reaction helpers. * docs: Improve consistency. * docs: Document message helpers. * docs: Document role helpers. * docs: Document guild template helpers. * docs: Fix incorrect gateway event. * refactor: Rename `sendWebhookMessage` -> `executeWebhook`. * docs: Document webhook helpers. * docs: Document voice helpers. * fmt: Run Deno formatter. * docs: Improve consistency. * refactor: Rename the `/widgets` directory to `/widget`. * fmt: Run Deno formatter. * feat: Re-add `editBotNickname.ts`. * Update helpers/members/editBotNickname.ts Co-authored-by: Skillz4Killz <23035000+Skillz4Killz@users.noreply.github.com> * fix: tests * fix: bot member tests * fix: remove submode * fix: edit bot member returns full member Co-authored-by: Dorian Oszczęda <vxern@wordcollector.co.uk>
86 lines
3.4 KiB
TypeScript
86 lines
3.4 KiB
TypeScript
import type { Bot } from "../../bot.ts";
|
|
import { Embed } from "../../transformers/embed.ts";
|
|
import { Message } from "../../transformers/message.ts";
|
|
import { DiscordMessage } from "../../types/discord.ts";
|
|
import { AllowedMentions, FileContent, MessageComponents } from "../../types/discordeno.ts";
|
|
|
|
export const sendWebhookMessage = executeWebhook;
|
|
|
|
/**
|
|
* Executes a webhook, causing a message to be posted in the channel configured for the webhook.
|
|
*
|
|
* @param bot - The bot instance to use to make the request.
|
|
* @param webhookId - The ID of the webhook to execute.
|
|
* @param token - The webhook token, used to execute the webhook.
|
|
* @param options - The parameters for the execution of the webhook.
|
|
* @returns An instance of the created {@link Message}, or `undefined` if the {@link ExecuteWebhook.wait | wait} property of the {@link options} object parameter is set to `false`.
|
|
*
|
|
* @remarks
|
|
* If the webhook channel is a forum channel, you must provide a value for either `threadId` or `threadName`.
|
|
*
|
|
* @see {@link https://discord.com/developers/docs/resources/webhook#execute-webhook}
|
|
*/
|
|
export async function executeWebhook(
|
|
bot: Bot,
|
|
webhookId: bigint,
|
|
token: string,
|
|
options: ExecuteWebhook,
|
|
): Promise<Message | undefined> {
|
|
const allowedMentions = options.allowedMentions
|
|
? {
|
|
parse: options.allowedMentions.parse,
|
|
replied_user: options.allowedMentions.repliedUser,
|
|
users: options.allowedMentions.users?.map((id) => id.toString()),
|
|
roles: options.allowedMentions.roles?.map((id) => id.toString()),
|
|
}
|
|
: { parse: [] };
|
|
|
|
const result = await bot.rest.runMethod<DiscordMessage>(
|
|
bot.rest,
|
|
"POST",
|
|
bot.constants.routes.WEBHOOK(webhookId, token, options),
|
|
{
|
|
wait: options.wait,
|
|
thread_id: options.threadId,
|
|
thread_name: options.threadName,
|
|
content: options.content,
|
|
username: options.username,
|
|
avatar_url: options.avatarUrl,
|
|
tts: options.tts,
|
|
file: options.file,
|
|
embeds: options.embeds?.map((embed) => bot.transformers.reverse.embed(bot, embed)),
|
|
allowed_mentions: allowedMentions,
|
|
components: options.components?.map((component) => bot.transformers.reverse.component(bot, component)),
|
|
},
|
|
);
|
|
if (!options.wait) return;
|
|
|
|
return bot.transformers.message(bot, result);
|
|
}
|
|
|
|
/** https://discord.com/developers/docs/resources/webhook#execute-webhook */
|
|
export interface ExecuteWebhook {
|
|
/** Waits for server confirmation of message send before response, and returns the created message body (defaults to `false`; when `false` a message that is not saved does not return an error) */
|
|
wait?: boolean;
|
|
/** Send a message to the specified thread within a webhook's channel. The thread will automatically be unarchived. */
|
|
threadId?: bigint;
|
|
/** Name of the thread to create (target channel has to be type of forum channel) */
|
|
threadName?: string;
|
|
/** The message contents (up to 2000 characters) */
|
|
content?: string;
|
|
/** Override the default username of the webhook */
|
|
username?: string;
|
|
/** Override the default avatar of the webhook */
|
|
avatarUrl?: string;
|
|
/** True if this is a TTS message */
|
|
tts?: boolean;
|
|
/** The contents of the file being sent */
|
|
file?: FileContent | FileContent[];
|
|
/** Embedded `rich` content */
|
|
embeds?: Embed[];
|
|
/** Allowed mentions for the message */
|
|
allowedMentions?: AllowedMentions;
|
|
/** the components to include with the message */
|
|
components?: MessageComponents;
|
|
}
|