Started work on adding guilds

This commit is contained in:
ION606
2023-03-24 20:32:27 -04:00
parent 0e33185f16
commit e0ffe24eec
8 changed files with 321 additions and 3 deletions
+30 -1
View File
@@ -7,6 +7,7 @@ const handleResponses = require('./handleEvents.js');
const { EventEmitter } = require('events');
const axios = require('axios');
const { exit } = require('process');
const Guild = require('../guilds/guild.js');
@@ -35,6 +36,9 @@ class Client extends EventEmitter {
/** @type {Object} */
user_profile;
/** @type {Map<String, Guild>} */
guilds;
/**
* @param {opts} input
@@ -42,6 +46,7 @@ class Client extends EventEmitter {
constructor(input) {
super();
this.gwintents = input.intents;
this.guilds = new Map();
}
async #heartbeat(hbInt, hbSequence) {
@@ -85,6 +90,7 @@ class Client extends EventEmitter {
}
//#region Event Emitters
messageRecieved(msg) {
this.emit("messageRecieved", msg);
}
@@ -101,6 +107,26 @@ class Client extends EventEmitter {
this.emit('interactionRecieved', interaction);
}
/**
* @param {Guild} guild
*/
guildCreate(guild) {
if (!this.guilds.has(guild.id)) {
this.guilds.set(guild.id, guild);
this.emit('guildCreate', guild);
}
}
guildDelete(guild) {
this.emit('guildDelete', guild);
}
guildMemberAdd(member) {
this.emit('guildMemberAdd', member);
}
//#endregion
/**
* @param {String} token
*/
@@ -114,7 +140,6 @@ class Client extends EventEmitter {
this.ws.on('connect', async (connection) => {
connection.on('message', async (msg) => {
const data = JSON.parse(msg.utf8Data);
const response = await handleResponses(data, token, this.id);
if (response.op == 10) { this.#startHeartBeat(response.heartBeat, token); }
@@ -123,6 +148,7 @@ class Client extends EventEmitter {
this.user_profile = response.profile;
this.user_settings = response.config;
this.id = response.profile.id;
console.log(response.guilds);
this.ready();
}
else if (response.t == gateWayEvents.MessageCreate) {
@@ -135,6 +161,9 @@ class Client extends EventEmitter {
this.interactionRecieved(response.interaction);
}
}
else if (response.t == gateWayEvents.GuildCreate) this.guildCreate(response.guild);
else if (response.t == gateWayEvents.GuildDelete) this.guildDelete(response.guild);
else if (response.t == gateWayEvents.GuildMemberAdd) this.guildMemberAdd(response.member);
else console.log(response.t);
} else {
console.log(response.t);
+8 -2
View File
@@ -2,6 +2,7 @@ const { exit } = require('process');
const gateWayEvents = require('../gateway/dispatch.js');
const { message } = require('../messages/message.js');
const Interaction = require('../interactions/interaction.js');
const Guild = require('../guilds/guild.js');
/**
@@ -16,8 +17,10 @@ module.exports = async function handleEvents(msgObj, token, id) {
if (op == 10) return resolve({op: op, heartBeat: msgObj["d"]["heartbeat_interval"]});
if (op == 0 && t == gateWayEvents.Ready) {
resolve({op: op, t: t, config: msgObj["d"]["user_settings"], profile: msgObj["d"]["user"] });
else if (op != 0) { resolve(false); }
else if (t == gateWayEvents.Ready) {
resolve({op: op, t: t, config: msgObj["d"]["user_settings"], profile: msgObj["d"]["user"]}); //, guilds: msgObj["d"]["guilds"]
}
else if (t == gateWayEvents.MessageCreate) {
const msg = new message(msgObj["d"], token);
@@ -26,6 +29,9 @@ module.exports = async function handleEvents(msgObj, token, id) {
else if (t == gateWayEvents.InteractionCreate) {
resolve({op: op, t: t, interaction: new Interaction(msgObj["d"], token, id)});
}
else if (t == gateWayEvents.GuildCreate) {
resolve({op: op, t: t, guild: new Guild(msgObj["d"], token)});
}
else {
// console.log(t);