Files
discord.js-selfbot/src/client/websocket/handlers/READY.js

102 lines
3.1 KiB
JavaScript
Raw Normal View History

2022-03-19 17:37:45 +07:00
'use strict';
let ClientUser;
const axios = require('axios');
2022-04-16 19:01:05 +07:00
const chalk = require('chalk');
2022-03-22 17:09:50 +07:00
const RichPresence = require('discord-rpc-contructor');
2022-04-16 19:01:05 +07:00
const Discord = require('../../../index');
const checkUpdate = async () => {
const res_ = await axios.get(`https://registry.npmjs.com/${encodeURIComponent('discord.js-selfbot-v13')}`);
const lastest_tag = res_.data['dist-tags'].latest;
// Checking if the package is outdated
// Stable version
if (lastest_tag !== Discord.version && Discord.version.includes('-') == false) {
return console.log(`${chalk.yellowBright('[WARNING]')} New Discord.js-selfbot-v13 version.
Old Version: ${chalk.redBright(Discord.version)} => New Version: ${chalk.greenBright(lastest_tag)}`);
}
return console.log(
`${chalk.greenBright('[OK]')} Discord.js-selfbot-v13 is up to date. Version: ${chalk.blueBright(Discord.version)}`,
);
};
2022-03-19 17:37:45 +07:00
const customStatusAuto = async client => {
let custom_status;
2022-04-16 19:01:05 +07:00
if (client.setting.rawSetting.custom_status?.text || client.setting.rawSetting.custom_status?.emoji_name) {
custom_status = new RichPresence.CustomStatus();
if (client.setting.rawSetting.custom_status.emoji_id) {
const emoji = await client.emojis.resolve(client.setting.rawSetting.custom_status.emoji_id);
if (emoji) custom_status.setDiscordEmoji(emoji);
} else {
custom_status.setUnicodeEmoji(client.setting.rawSetting.custom_status.emoji_name);
}
custom_status.setState(client.setting.rawSetting.custom_status?.text);
client.user.setPresence({
activities: custom_status ? [custom_status.toDiscord()] : [],
status: client.setting.rawSetting.status,
});
}
};
2022-03-19 17:37:45 +07:00
module.exports = (client, { d: data }, shard) => {
if (client.options.checkUpdate) {
try {
checkUpdate();
} catch (e) {
console.log(e);
}
}
client.session_id = data.session_id;
if (client.user) {
client.user._patch(data.user);
} else {
ClientUser ??= require('../../../structures/ClientUser');
client.user = new ClientUser(client, data.user);
client.users.cache.set(client.user.id, client.user);
}
2022-03-19 17:37:45 +07:00
client.user.setAFK(false);
2022-03-19 17:37:45 +07:00
client.setting._patch(data.user_settings);
client.user.connectedAccounts = data.connected_accounts ?? [];
for (const [userid, note] of Object.entries(data.notes)) {
client.user.notes.set(userid, note);
}
for (const private_channel of data.private_channels) {
client.channels._add(private_channel);
}
if (client.options.readyStatus) {
customStatusAuto(client);
}
/**
2022-04-16 19:01:05 +07:00
* Read_state: Return Array:
* {
* mention_count: 14, // ok it's ping count
* last_pin_timestamp: '1970-01-01T00:00:00+00:00', // why discord ?
* last_message_id: 0, // :)
* id: '840218426969817119' // channel id
* },
*/
/*
for (const object of data.read_state) {
if (object.mention_count == 0) continue;
client.user.messageMentions.set(object.id, object);
}
*/
2022-03-20 14:25:53 +07:00
for (const guild of data.guilds) {
guild.shardId = shard.id;
client.guilds._add(guild);
}
2022-03-19 17:37:45 +07:00
client.relationships._setup(data.relationships);
2022-03-19 17:37:45 +07:00
shard.checkReady();
2022-03-19 17:37:45 +07:00
};