Diff
checker
Texto
Texto
Imágenes
Documentos
Excel
Carpetas
Legal
Enterprise
Aplicación de escritorio
Precios
Iniciar sesión
Descargar Diffchecker Desktop
Comparar texto
Encuentra la diferencia entre dos archivos de texto
Herramientas
Historial
Editor live
Ocultar sin cambios
Sin ajuste de línea
Vista
Dividido
Unificado
Nivel de detalle
Inteligente
Palabra
Letra
Resaltado de sintaxis
Elegir sintaxis
Ignorar
Transformar texto
Ir al primer cambio
Editar entrada
Diffchecker Desktop
La forma más segura de usar Diffchecker. ¡Obtén la app de Diffchecker Desktop: tus diffs nunca salen de tu computadora!
Obtener Desktop
RestoreUtils.ts
Creado
hace 4 años
El diff nunca expira
Borrar
Exportar
Compartir
Explicar
178 eliminaciones
Líneas
Total
Eliminado
Caracteres
Total
Eliminado
Para continuar usando esta función, actualice a
Diff
checker
Pro
Ver precios
259 líneas
Copiar todo
23 adiciones
Líneas
Total
Añadido
Caracteres
Total
Añadido
Para continuar usando esta función, actualice a
Diff
checker
Pro
Ver precios
150 líneas
Copiar todo
Copiar
Copiado
Copiar
Copiado
import type { BackupData,
RestoreServerOptions
} from
"
./types
"
;
import type { BackupData,
LoadOptions
} from
'
./types
'
;
import
{
import
type { ChannelType,
Emoji,
Guild,
GuildFeature,
GuildChannel,
Role,
VoiceChannel
} from
'
discord.js
'
;
Collection,
import { loadCategory, loadChannel } from
'./util'
;
Emoji,
Guild,
GuildChannel,
Role,
RoleResolvable,
Snowflake,
VoiceChannel
,
} from
"
discord.js
"
;
import { loadCategory, loadChannel } from
"./BackupUtils";
import { MemoryCache } from "../clients/MemoryCache"
;
/**
/**
* Restores the guild configuration
* Restores the guild configuration
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadConfig = (
export const loadConfig = (
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
const configPromises: Promise<Guild>[] = [];
const configPromises: Promise<Guild>[] = [];
if (backupData.name) {
if (backupData.name) {
configPromises.push(guild.setName(backupData.name));
configPromises.push(guild.setName(backupData.name));
}
}
if (backupData.iconBase64) {
if (backupData.iconBase64) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setIcon(Buffer.from(backupData.iconBase64,
'
base64
'))
);
guild.setIcon(Buffer.from(backupData.iconBase64,
"
base64
"))
);
} else if (backupData.iconURL) {
} else if (backupData.iconURL) {
configPromises.push(guild.setIcon(backupData.iconURL));
configPromises.push(guild.setIcon(backupData.iconURL));
}
}
if (backupData.splashBase64) {
if (backupData.splashBase64) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setSplash(Buffer.from(backupData.splashBase64,
'
base64
'))
);
guild.setSplash(Buffer.from(backupData.splashBase64,
"
base64
"))
);
} else if (backupData.splashURL) {
} else if (backupData.splashURL) {
configPromises.push(guild.setSplash(backupData.splashURL));
configPromises.push(guild.setSplash(backupData.splashURL));
}
}
if (backupData.bannerBase64) {
if (backupData.bannerBase64) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setBanner(Buffer.from(backupData.bannerBase64,
'
base64
'))
);
guild.setBanner(Buffer.from(backupData.bannerBase64,
"
base64
"))
);
} else if (backupData.bannerURL) {
} else if (backupData.bannerURL) {
configPromises.push(guild.setBanner(backupData.bannerURL));
configPromises.push(guild.setBanner(backupData.bannerURL));
}
}
if (backupData.verificationLevel) {
if (backupData.verificationLevel) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setVerificationLevel(backupData.verificationLevel)
);
guild.setVerificationLevel(backupData.verificationLevel)
);
}
}
if (backupData.defaultMessageNotifications) {
if (backupData.defaultMessageNotifications) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setDefaultMessageNotifications(
backupData.defaultMessageNotifications
)
);
guild.setDefaultMessageNotifications(
backupData.defaultMessageNotifications
)
);
}
}
Copiar
Copiado
Copiar
Copiado
const changeableExplicitLevel = guild.features.includes(
"COMMUNITY"
);
const changeableExplicitLevel = guild.features.includes(
GuildFeature.Community
);
if (backupData.explicitContentFilter && changeableExplicitLevel) {
if (backupData.explicitContentFilter && changeableExplicitLevel) {
Copiar
Copiado
Copiar
Copiado
configPromises.push(
configPromises.push(
guild.setExplicitContentFilter(backupData.explicitContentFilter)
);
guild.setExplicitContentFilter(backupData.explicitContentFilter)
);
}
}
return Promise.all(configPromises);
return Promise.all(configPromises);
};
};
/**
/**
* Restore the guild roles
* Restore the guild roles
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadRoles = (
export const loadRoles = (
guild: Guild,
backupData: BackupData
): Promise<Role[]> => {
guild: Guild,
backupData: BackupData
,
cache?: MemoryCache
): Promise<Role[]> => {
const rolePromises: Promise<Role>[] = [];
const rolePromises: Promise<Role>[] = [];
backupData.roles.forEach((roleData) => {
backupData.roles.forEach((roleData) => {
if (roleData.isEveryone) {
if (roleData.isEveryone) {
rolePromises.push(
rolePromises.push(
Copiar
Copiado
Copiar
Copiado
guild.roles.cache.get(guild.id)
!
.edit({
guild.roles.cache.get(guild.id)
.edit({
name: roleData.name,
name: roleData.name,
color: roleData.color,
color: roleData.color,
permissions: BigInt(roleData.permissions),
permissions: BigInt(roleData.permissions),
Copiar
Copiado
Copiar
Copiado
mentionable: roleData.mentionable
,
mentionable: roleData.mentionable
})
})
);
);
} else {
} else {
rolePromises.push(
rolePromises.push(
guild.roles.create({
guild.roles.create({
name: roleData.name,
name: roleData.name,
color: roleData.color,
color: roleData.color,
hoist: roleData.hoist,
hoist: roleData.hoist,
permissions: BigInt(roleData.permissions),
permissions: BigInt(roleData.permissions),
Copiar
Copiado
Copiar
Copiado
mentionable: roleData.mentionable
,
mentionable: roleData.mentionable
})
})
);
);
}
}
});
});
Copiar
Copiado
Copiar
Copiado
cache?.setItem(`${guild.id}_roles`, JSON.stringify({ finished: true }));
return Promise.all(rolePromises);
return Promise.all(rolePromises);
};
};
/**
/**
* Restore the guild channels
* Restore the guild channels
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadChannels = (
export const loadChannels = (
guild: Guild,
backupData: BackupData,
options:
LoadOptions
): Promise<unknown[]> => {
guild: Guild,
backupData: BackupData,
options:
RestoreServerOptions
): Promise<unknown[]> => {
const loadChannelPromises: Promise<void | unknown>[] = [];
const loadChannelPromises: Promise<void | unknown>[] = [];
backupData.channels.categories.forEach((categoryData) => {
backupData.channels.categories.forEach((categoryData) => {
loadChannelPromises.push(
loadChannelPromises.push(
new Promise((resolve) => {
new Promise((resolve) => {
Copiar
Copiado
Copiar
Copiado
loadCategory(categoryData, guild).then((createdCategory
: any
) => {
loadCategory(categoryData, guild).then((createdCategory
) => {
categoryData.children.forEach((channelData) => {
categoryData.children.forEach((channelData) => {
loadChannel(channelData, guild, createdCategory, options);
loadChannel(channelData, guild, createdCategory, options);
resolve(true);
resolve(true);
});
});
});
});
})
})
);
);
});
});
backupData.channels.others.forEach((channelData) => {
backupData.channels.others.forEach((channelData) => {
loadChannelPromises.push(loadChannel(channelData, guild, null, options));
loadChannelPromises.push(loadChannel(channelData, guild, null, options));
});
});
return Promise.all(loadChannelPromises);
return Promise.all(loadChannelPromises);
};
};
/**
/**
Copiar
Copiado
Copiar
Copiado
* Restore member roles.
*/
export const loadMemberRoles = async (
guild: Guild,
backupData: BackupData,
cache?: MemoryCache
) => {
// add roles after 10 seconds to make sure they got restored.
setTimeout(async () => {
const loadMemberRolesPromises: Promise<void | unknown>[] = [];
const members = await guild.members.fetch();
await guild.roles.fetch(undefined, {
cache: true,
});
backupData.members?.forEach((member) => {
const valid = members.find((m) => m.id === member.id);
if (!valid) return;
else {
const roles: Collection<Snowflake, Role> = new Collection<
Snowflake,
Role
>();
member.roles?.forEach((r) => {
const role = guild.roles.cache.find((v) => v.name === r.roleName);
if (role) {
if (!roles.get(role.id)) {
roles.set(role.id, role);
}
}
});
loadMemberRolesPromises.push(
valid.roles.set(roles, "Member Role Restore").catch(() => {})
);
}
});
cache?.deleteItem(`${guild.id}_roles`);
return Promise.all(loadMemberRolesPromises);
}, 10000);
};
/**
* Restore the afk configuration
* Restore the afk configuration
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadAFK = (
export const loadAFK = (
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
const afkPromises: Promise<Guild>[] = [];
const afkPromises: Promise<Guild>[] = [];
if (backupData.afk) {
if (backupData.afk) {
Copiar
Copiado
Copiar
Copiado
afkPromises.push(
afkPromises.push(
guild.setAFKChannel(
guild.channels.cache.find(
(ch) =>
ch.name === backupData.afk.name && ch.type ===
ChannelType.GuildVoice
) as VoiceChannel
)
);
guild.setAFKChannel(
guild.channels.cache.find(
(ch) =>
// @ts-ignore
ch.name === backupData.afk.name && ch.type ===
"GUILD_VOICE"
) as VoiceChannel
)
);
afkPromises.push(guild.setAFKTimeout(backupData.afk.timeout));
afkPromises.push(guild.setAFKTimeout(backupData.afk.timeout));
}
}
return Promise.all(afkPromises);
return Promise.all(afkPromises);
};
};
/**
/**
* Restore guild emojis
* Restore guild emojis
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadEmojis = (
export const loadEmojis = (
guild: Guild,
backupData: BackupData
): Promise<Emoji[]> => {
guild: Guild,
backupData: BackupData
): Promise<Emoji[]> => {
const emojiPromises: Promise<Emoji>[] = [];
const emojiPromises: Promise<Emoji>[] = [];
backupData.emojis.forEach((emoji) => {
backupData.emojis.forEach((emoji) => {
if (emoji.url) {
if (emoji.url) {
Copiar
Copiado
Copiar
Copiado
// @ts-ignore
emojiPromises.push(guild.emojis.create(emoji.url, emoji.name));
emojiPromises.push(guild.emojis.create(emoji.url, emoji.name));
} else if (emoji.base64) {
} else if (emoji.base64) {
Copiar
Copiado
Copiar
Copiado
emojiPromises.push(
emojiPromises.push(
guild.emojis.create(
Buffer.from(emoji.base64,
'
base64
'), emoji.name));
guild.emojis.create(
Buffer.from(emoji.base64,
"
base64
"),
// @ts-ignore
emoji.name
)
);
}
}
});
});
return Promise.all(emojiPromises);
return Promise.all(emojiPromises);
};
};
/**
/**
* Restore guild bans
* Restore guild bans
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadBans = (
export const loadBans = (
guild: Guild,
backupData: BackupData
): Promise<string[]> => {
guild: Guild,
backupData: BackupData
): Promise<string[]> => {
const banPromises: Promise<string>[] = [];
const banPromises: Promise<string>[] = [];
backupData.bans.forEach((ban) => {
backupData.bans.forEach((ban) => {
banPromises.push(
banPromises.push(
guild.members.ban(ban.id, {
guild.members.ban(ban.id, {
Copiar
Copiado
Copiar
Copiado
reason: ban.reason
?? undefined,
reason: ban.reason
}) as Promise<string>
}) as Promise<string>
);
);
});
});
return Promise.all(banPromises);
return Promise.all(banPromises);
};
};
/**
/**
* Restore embedChannel configuration
* Restore embedChannel configuration
*/
*/
Copiar
Copiado
Copiar
Copiado
export const loadEmbedChannel = (
export const loadEmbedChannel = (
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
guild: Guild,
backupData: BackupData
): Promise<Guild[]> => {
const embedChannelPromises: Promise<Guild>[] = [];
const embedChannelPromises: Promise<Guild>[] = [];
if (backupData.widget.channel) {
if (backupData.widget.channel) {
embedChannelPromises.push(
embedChannelPromises.push(
guild.setWidgetSettings({
guild.setWidgetSettings({
Copiar
Copiado
Copiar
Copiado
// @ts-ignore
enabled: backupData.widget.enabled,
enabled: backupData.widget.enabled,
Copiar
Copiado
Copiar
Copiado
// @ts-ignore
channel: guild.channels.cache.find(
(ch) => ch.name === backupData.widget.channel
)
channel: guild.channels.cache.find(
(ch) => ch.name === backupData.widget.channel
),
})
})
);
);
}
}
return Promise.all(embedChannelPromises);
return Promise.all(embedChannelPromises);
};
};
Copiar
Copiado
Copiar
Copiado
Diferencias guardadas
Texto original
Abrir archivo
import type { BackupData, RestoreServerOptions } from "./types"; import { Collection, Emoji, Guild, GuildChannel, Role, RoleResolvable, Snowflake, VoiceChannel, } from "discord.js"; import { loadCategory, loadChannel } from "./BackupUtils"; import { MemoryCache } from "../clients/MemoryCache"; /** * Restores the guild configuration */ export const loadConfig = ( guild: Guild, backupData: BackupData ): Promise<Guild[]> => { const configPromises: Promise<Guild>[] = []; if (backupData.name) { configPromises.push(guild.setName(backupData.name)); } if (backupData.iconBase64) { configPromises.push( guild.setIcon(Buffer.from(backupData.iconBase64, "base64")) ); } else if (backupData.iconURL) { configPromises.push(guild.setIcon(backupData.iconURL)); } if (backupData.splashBase64) { configPromises.push( guild.setSplash(Buffer.from(backupData.splashBase64, "base64")) ); } else if (backupData.splashURL) { configPromises.push(guild.setSplash(backupData.splashURL)); } if (backupData.bannerBase64) { configPromises.push( guild.setBanner(Buffer.from(backupData.bannerBase64, "base64")) ); } else if (backupData.bannerURL) { configPromises.push(guild.setBanner(backupData.bannerURL)); } if (backupData.verificationLevel) { configPromises.push( guild.setVerificationLevel(backupData.verificationLevel) ); } if (backupData.defaultMessageNotifications) { configPromises.push( guild.setDefaultMessageNotifications( backupData.defaultMessageNotifications ) ); } const changeableExplicitLevel = guild.features.includes("COMMUNITY"); if (backupData.explicitContentFilter && changeableExplicitLevel) { configPromises.push( guild.setExplicitContentFilter(backupData.explicitContentFilter) ); } return Promise.all(configPromises); }; /** * Restore the guild roles */ export const loadRoles = ( guild: Guild, backupData: BackupData, cache?: MemoryCache ): Promise<Role[]> => { const rolePromises: Promise<Role>[] = []; backupData.roles.forEach((roleData) => { if (roleData.isEveryone) { rolePromises.push( guild.roles.cache.get(guild.id)!.edit({ name: roleData.name, color: roleData.color, permissions: BigInt(roleData.permissions), mentionable: roleData.mentionable, }) ); } else { rolePromises.push( guild.roles.create({ name: roleData.name, color: roleData.color, hoist: roleData.hoist, permissions: BigInt(roleData.permissions), mentionable: roleData.mentionable, }) ); } }); cache?.setItem(`${guild.id}_roles`, JSON.stringify({ finished: true })); return Promise.all(rolePromises); }; /** * Restore the guild channels */ export const loadChannels = ( guild: Guild, backupData: BackupData, options: RestoreServerOptions ): Promise<unknown[]> => { const loadChannelPromises: Promise<void | unknown>[] = []; backupData.channels.categories.forEach((categoryData) => { loadChannelPromises.push( new Promise((resolve) => { loadCategory(categoryData, guild).then((createdCategory: any) => { categoryData.children.forEach((channelData) => { loadChannel(channelData, guild, createdCategory, options); resolve(true); }); }); }) ); }); backupData.channels.others.forEach((channelData) => { loadChannelPromises.push(loadChannel(channelData, guild, null, options)); }); return Promise.all(loadChannelPromises); }; /** * Restore member roles. */ export const loadMemberRoles = async ( guild: Guild, backupData: BackupData, cache?: MemoryCache ) => { // add roles after 10 seconds to make sure they got restored. setTimeout(async () => { const loadMemberRolesPromises: Promise<void | unknown>[] = []; const members = await guild.members.fetch(); await guild.roles.fetch(undefined, { cache: true, }); backupData.members?.forEach((member) => { const valid = members.find((m) => m.id === member.id); if (!valid) return; else { const roles: Collection<Snowflake, Role> = new Collection< Snowflake, Role >(); member.roles?.forEach((r) => { const role = guild.roles.cache.find((v) => v.name === r.roleName); if (role) { if (!roles.get(role.id)) { roles.set(role.id, role); } } }); loadMemberRolesPromises.push( valid.roles.set(roles, "Member Role Restore").catch(() => {}) ); } }); cache?.deleteItem(`${guild.id}_roles`); return Promise.all(loadMemberRolesPromises); }, 10000); }; /** * Restore the afk configuration */ export const loadAFK = ( guild: Guild, backupData: BackupData ): Promise<Guild[]> => { const afkPromises: Promise<Guild>[] = []; if (backupData.afk) { afkPromises.push( guild.setAFKChannel( guild.channels.cache.find( (ch) => // @ts-ignore ch.name === backupData.afk.name && ch.type === "GUILD_VOICE" ) as VoiceChannel ) ); afkPromises.push(guild.setAFKTimeout(backupData.afk.timeout)); } return Promise.all(afkPromises); }; /** * Restore guild emojis */ export const loadEmojis = ( guild: Guild, backupData: BackupData ): Promise<Emoji[]> => { const emojiPromises: Promise<Emoji>[] = []; backupData.emojis.forEach((emoji) => { if (emoji.url) { // @ts-ignore emojiPromises.push(guild.emojis.create(emoji.url, emoji.name)); } else if (emoji.base64) { emojiPromises.push( guild.emojis.create( Buffer.from(emoji.base64, "base64"), // @ts-ignore emoji.name ) ); } }); return Promise.all(emojiPromises); }; /** * Restore guild bans */ export const loadBans = ( guild: Guild, backupData: BackupData ): Promise<string[]> => { const banPromises: Promise<string>[] = []; backupData.bans.forEach((ban) => { banPromises.push( guild.members.ban(ban.id, { reason: ban.reason ?? undefined, }) as Promise<string> ); }); return Promise.all(banPromises); }; /** * Restore embedChannel configuration */ export const loadEmbedChannel = ( guild: Guild, backupData: BackupData ): Promise<Guild[]> => { const embedChannelPromises: Promise<Guild>[] = []; if (backupData.widget.channel) { embedChannelPromises.push( guild.setWidgetSettings({ // @ts-ignore enabled: backupData.widget.enabled, // @ts-ignore channel: guild.channels.cache.find( (ch) => ch.name === backupData.widget.channel ), }) ); } return Promise.all(embedChannelPromises); };
Texto modificado
Abrir archivo
import type { BackupData, LoadOptions } from './types'; import type { ChannelType, Emoji, Guild, GuildFeature, GuildChannel, Role, VoiceChannel } from 'discord.js'; import { loadCategory, loadChannel } from './util'; /** * Restores the guild configuration */ export const loadConfig = (guild: Guild, backupData: BackupData): Promise<Guild[]> => { const configPromises: Promise<Guild>[] = []; if (backupData.name) { configPromises.push(guild.setName(backupData.name)); } if (backupData.iconBase64) { configPromises.push(guild.setIcon(Buffer.from(backupData.iconBase64, 'base64'))); } else if (backupData.iconURL) { configPromises.push(guild.setIcon(backupData.iconURL)); } if (backupData.splashBase64) { configPromises.push(guild.setSplash(Buffer.from(backupData.splashBase64, 'base64'))); } else if (backupData.splashURL) { configPromises.push(guild.setSplash(backupData.splashURL)); } if (backupData.bannerBase64) { configPromises.push(guild.setBanner(Buffer.from(backupData.bannerBase64, 'base64'))); } else if (backupData.bannerURL) { configPromises.push(guild.setBanner(backupData.bannerURL)); } if (backupData.verificationLevel) { configPromises.push(guild.setVerificationLevel(backupData.verificationLevel)); } if (backupData.defaultMessageNotifications) { configPromises.push(guild.setDefaultMessageNotifications(backupData.defaultMessageNotifications)); } const changeableExplicitLevel = guild.features.includes(GuildFeature.Community); if (backupData.explicitContentFilter && changeableExplicitLevel) { configPromises.push(guild.setExplicitContentFilter(backupData.explicitContentFilter)); } return Promise.all(configPromises); }; /** * Restore the guild roles */ export const loadRoles = (guild: Guild, backupData: BackupData): Promise<Role[]> => { const rolePromises: Promise<Role>[] = []; backupData.roles.forEach((roleData) => { if (roleData.isEveryone) { rolePromises.push( guild.roles.cache.get(guild.id).edit({ name: roleData.name, color: roleData.color, permissions: BigInt(roleData.permissions), mentionable: roleData.mentionable }) ); } else { rolePromises.push( guild.roles.create({ name: roleData.name, color: roleData.color, hoist: roleData.hoist, permissions: BigInt(roleData.permissions), mentionable: roleData.mentionable }) ); } }); return Promise.all(rolePromises); }; /** * Restore the guild channels */ export const loadChannels = (guild: Guild, backupData: BackupData, options: LoadOptions): Promise<unknown[]> => { const loadChannelPromises: Promise<void | unknown>[] = []; backupData.channels.categories.forEach((categoryData) => { loadChannelPromises.push( new Promise((resolve) => { loadCategory(categoryData, guild).then((createdCategory) => { categoryData.children.forEach((channelData) => { loadChannel(channelData, guild, createdCategory, options); resolve(true); }); }); }) ); }); backupData.channels.others.forEach((channelData) => { loadChannelPromises.push(loadChannel(channelData, guild, null, options)); }); return Promise.all(loadChannelPromises); }; /** * Restore the afk configuration */ export const loadAFK = (guild: Guild, backupData: BackupData): Promise<Guild[]> => { const afkPromises: Promise<Guild>[] = []; if (backupData.afk) { afkPromises.push(guild.setAFKChannel(guild.channels.cache.find((ch) => ch.name === backupData.afk.name && ch.type === ChannelType.GuildVoice) as VoiceChannel)); afkPromises.push(guild.setAFKTimeout(backupData.afk.timeout)); } return Promise.all(afkPromises); }; /** * Restore guild emojis */ export const loadEmojis = (guild: Guild, backupData: BackupData): Promise<Emoji[]> => { const emojiPromises: Promise<Emoji>[] = []; backupData.emojis.forEach((emoji) => { if (emoji.url) { emojiPromises.push(guild.emojis.create(emoji.url, emoji.name)); } else if (emoji.base64) { emojiPromises.push(guild.emojis.create(Buffer.from(emoji.base64, 'base64'), emoji.name)); } }); return Promise.all(emojiPromises); }; /** * Restore guild bans */ export const loadBans = (guild: Guild, backupData: BackupData): Promise<string[]> => { const banPromises: Promise<string>[] = []; backupData.bans.forEach((ban) => { banPromises.push( guild.members.ban(ban.id, { reason: ban.reason }) as Promise<string> ); }); return Promise.all(banPromises); }; /** * Restore embedChannel configuration */ export const loadEmbedChannel = (guild: Guild, backupData: BackupData): Promise<Guild[]> => { const embedChannelPromises: Promise<Guild>[] = []; if (backupData.widget.channel) { embedChannelPromises.push( guild.setWidgetSettings({ enabled: backupData.widget.enabled, channel: guild.channels.cache.find((ch) => ch.name === backupData.widget.channel) }) ); } return Promise.all(embedChannelPromises); };
Encontrar la diferencia