mirror of
https://github.com/discordeno/discordeno.git
synced 2026-06-16 03:18:17 +00:00
handlers
This commit is contained in:
@@ -1,21 +1,19 @@
|
||||
import { eventHandlers } from "../../bot.ts";
|
||||
import { cacheHandlers } from "../../cache.ts";
|
||||
import { structures } from "../../structures/mod.ts";
|
||||
import { Bot } from "../../bot.ts";
|
||||
import type { DiscordGatewayPayload } from "../../types/gateway/gateway_payload.ts";
|
||||
import type { GuildRoleCreate } from "../../types/guilds/guild_role_create.ts";
|
||||
import { snowflakeToBigint } from "../../util/bigint.ts";
|
||||
import { SnakeCasedPropertiesDeep } from "../../types/util.ts";
|
||||
|
||||
export async function handleGuildRoleCreate(data: DiscordGatewayPayload) {
|
||||
const payload = data.d as GuildRoleCreate;
|
||||
const guild = await cacheHandlers.get("guilds", snowflakeToBigint(payload.guildId));
|
||||
export async function handleGuildRoleCreate(bot: Bot, data: DiscordGatewayPayload) {
|
||||
const payload = data.d as SnakeCasedPropertiesDeep<GuildRoleCreate>;
|
||||
|
||||
const guildId = bot.transformers.snowflake(payload.guild_id);
|
||||
const guild = await bot.cache.guilds.get(guildId);
|
||||
if (!guild) return;
|
||||
|
||||
const role = await structures.createDiscordenoRole({
|
||||
...payload,
|
||||
guildId: guild.id,
|
||||
});
|
||||
guild.roles = guild.roles.set(snowflakeToBigint(payload.role.id), role);
|
||||
await cacheHandlers.set("guilds", guild.id, guild);
|
||||
const role = bot.transformers.role(bot, { role: payload.role, guildId });
|
||||
|
||||
eventHandlers.roleCreate?.(guild, role);
|
||||
guild.roles = guild.roles.set(role.id, role);
|
||||
await bot.cache.guilds.set(guild.id, guild);
|
||||
|
||||
bot.events.roleCreate(bot, guild, role);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user