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);
+145
View File
@@ -0,0 +1,145 @@
const axios = require('axios');
const member = require('./member.js');
const guildRole = require('./guildRoles.js');
const GuildEmoji = require('./guildEmoji.js');
const { Channel } = require('../messages/message.js');
//See https://discord.com/developers/docs/resources/guild
class Guild {
/** @type {String[]} */
embeded_activities;
/** @type {String} */
description;
/** @type {String} */
id;
/** @type {String} */
name;
/** @type {String} */
icon;
/** @type {Boolean} */
nsfw;
/** @type {member[]} */
members;
/** @type {String} */
hub_type;
/** @type {Number} */
max_video_channel_users;
/** @type {String[]} */
stickers;
/** @type {String} */
hub_type;
/** @type {Map<String, member>} */
members;
/** @type {guildRole[]} */
roles;
/** @type {String} */
banner;
/** @type {String} */
application_id;
/** @type {String} */
owner_id;
/** @type {Map<String, Channel>} */
channels;
/** @type {String} */
home_header;
/** @type {Number} */
premium_tier;
/** @type {Number} */
nsfw_level;
/** @type {Number} */
verification_level;
/** @type {Number} */
mfa_level;
// /** @type {String} */ //FIXME
// threads;
/** @type {Number} */
system_channel_flags;
/** @type {String} */
safety_alerts_channel_id;
/** @type {object[]} */
presences;
/** @type {GuildEmoji[]} */
emojis;
/** @type {String} */
public_updates_channel_id;
/** @type {Object[]} */
stage_instances
async #getChannels(token) {
const config = {
headers: {
Authorization: token
}
}
const response = await axios.get(`https://discord.com/api/guilds/${this.id}/channels`, config);
for (const channel of response.data) {
if (channel.type == 4) continue;
this.channels.set(channel.id, new Channel(token, channel.id));
}
}
constructor(o, token) {
this.members = new Map();
this.channels = new Map();
this.roles = [];
this.stickers = [];
for (const field in this) {
if (o[field] == undefined || field == "channels") continue;
if (field == 'members') {
for (const m of o[field]) {
const mem = new member(m);
this.members.set(mem.user.id);
}
}
else if (field == 'roles') {
for (const r of o[field]) {
this.roles.push(new guildRole(r));
}
}
else {
this[field] = o[field];
}
}
this.#getChannels(token);
}
}
module.exports = Guild;
+28
View File
@@ -0,0 +1,28 @@
class GuildEmoji {
/** @type {Number} */
version;
/** @type {Object[]} */
roles;
/** @type {Boolean} */
require_colons;
/** @type {String} */
name;
/** @type {Boolean} */
managed;
/** @type {String} */
id;
/** @type {Boolean} */
available;
/** @type {Boolean} */
animated;
}
module.exports = GuildEmoji;
+51
View File
@@ -0,0 +1,51 @@
class guildRole {
/** @type {Number} */
version;
/** @type {String} */
unicode_emoji;
/** @type {Object} */
tags;
/** @type {Number} */
position;
/** @type {String} */
permissions;
/** @type {String} */
name;
/** @type {Boolean} */
mentionable;
/** @type {Boolean} */
managed;
/** @type {String} */
id;
/** @type {String} */
icon;
/** @type {Boolean} */
hoist;
/** @type {Number} */
flags;
/** @type {Number} */
color;
constructor(o) {
for (const k in this) {
if (o[k]) {
this[k] = o[k];
}
}
}
}
module.exports = guildRole;
+45
View File
@@ -0,0 +1,45 @@
class member {
/** @type {Object} */
user;
/** @type {Object[]} */
roles;
/** @type {String} */
premium_since;
/** @type {Boolean} */
pending;
/** @type {String} */
nick;
/** @type {Boolean} */
mute;
/** @type {Strnig} */
joined_at;
/** @type {Number} */
flags;
/** @type {Boolean} */
deaf;
/** @type {String} */
communication_disabled_until;
/** @type {String} */
avatar;
constructor(o) {
for (const k in this) {
if (o[k]) {
this[k] = o[k];
}
}
}
}
module.exports = member;
+9
View File
@@ -0,0 +1,9 @@
const Guild = require("../structures/guilds/guild");
const { Client } = require("../structures/types");
const delay = ms => new Promise(resolve => setTimeout(resolve, ms));
module.exports = /** @param {Client} c */ async (c) => {
c.guilds.forEach(/** @param {Guild} guild */ (guild) => {
console.log(guild);
});
}
+5
View File
@@ -32,6 +32,11 @@ c.on('interactionRecieved', /** @param {Interaction} interaction*/ async (intera
});
c.on('guildCreate', async (guild) => {
require('./guildTests.js')(c);
});
c.on('ready', () => {
console.log("BOT ONLINE!");
});