Added presence updates, typing and ban adds

This commit is contained in:
hydrabolt
2015-11-02 16:52:22 +00:00
parent 641683c9d9
commit 576715f531
8 changed files with 195 additions and 8 deletions

View File

@@ -385,7 +385,7 @@ var InternalClient = (function () {
};
InternalClient.prototype.sendWS = function sendWS(object) {
this.websocket.send(JSON.stringify(object));
if (this.websocket) this.websocket.send(JSON.stringify(object));
};
InternalClient.prototype.createWS = function createWS(url) {
@@ -726,6 +726,77 @@ var InternalClient = (function () {
client.emit("warn", "server member updated but server doesn't exist in cache");
}
break;
case PacketType.PRESENCE_UPDATE:
var user = self.users.get("id", data.user.id);
if (user) {
data.user.username = data.user.username || user.username;
data.user.id = data.user.id || user.id;
data.user.avatar = data.user.avatar || user.avatar;
data.user.discriminator = data.user.discriminator || user.discriminator;
var presenceUser = new User(data.user, client);
if (presenceUser.equalsStrict(user)) {
// a real presence update
client.emit("presence", user, data.status, data.game_id);
user.status = data.status;
user.gameID = data.game_id;
} else {
// a name change or avatar change
client.emit("userUpdate", user, presenceUser);
self.users.update(user, presenceUser);
}
} else {
client.emit("warn", "presence update but user not in cache");
}
break;
case PacketType.TYPING:
var user = self.users.get("id", data.user_id);
var channel = self.channels.get("id", data.channel_id);
if (user && channel) {
user.typing.since = Date.now();
user.typing.channel = channel;
client.emit("userTypingStart", user, channel);
setTimeout(function () {
if (Date.now() - user.typing.since > 5990) {
// they haven't typed since
user.typing.since = null;
user.typing.channel = null;
client.emit("userTypingStop", user, channel);
}
}, 6000);
} else {
client.emit("warn", "user typing but user or channel not existant in cache");
}
break;
case PacketType.SERVER_BAN_ADD:
var user = self.users.get("id", data.user.id);
var server = self.servers.get("id", data.guild_id);
if (user && server) {
client.emit("userBanned", user, server);
} else {
client.emit("warn", "user banned but user/server not in cache.");
}
break;
case PacketType.SERVER_BAN_REMOVE:
var user = self.users.get("id", data.user.id);
var server = self.servers.get("id", data.guild_id);
if (user && server) {
client.emit("userUnbanned", user, server);
} else {
client.emit("warn", "user unbanned but user/server not in cache.");
}
break;
}
};
};

View File

@@ -114,7 +114,11 @@ var PacketType = {
SERVER_ROLE_UPDATE: "GUILD_ROLE_UPDATE",
SERVER_MEMBER_ADD: "GUILD_MEMBER_ADD",
SERVER_MEMBER_REMOVE: "GUILD_MEMBER_REMOVE",
SERVER_MEMBER_UPDATE: "GUILD_MEMBER_UPDATE"
SERVER_MEMBER_UPDATE: "GUILD_MEMBER_UPDATE",
PRESENCE_UPDATE: "PRESENCE_UPDATE",
TYPING: "TYPING_START",
SERVER_BAN_ADD: "GUILD_BAN_ADD",
SERVER_BAN_REMOVE: "GUILD_BAN_REMOVE"
};
exports.API_ENDPOINT = API;

View File

@@ -23,6 +23,10 @@ var User = (function (_Equality) {
this.avatar = data.avatar;
this.status = data.status || "offline";
this.gameID = data.game_id || null;
this.typing = {
since: null,
channel: null
};
}
User.prototype.mention = function mention() {
@@ -33,6 +37,10 @@ var User = (function (_Equality) {
return this.mention();
};
User.prototype.equalsStrict = function equalsStrict(obj) {
if (obj instanceof User) return this.id === obj.id && this.username === obj.username && this.discriminator === obj.discriminator && this.avatar === obj.avatar && this.status === obj.status && this.gameID === obj.gameID;else return false;
};
_createClass(User, [{
key: "avatarURL",
get: function get() {

View File

@@ -15,8 +15,11 @@ a.on("warn", function (m) {
a.on("message", function (m) {
if (m.content === "$$$") a.reply(m, "I have you cached as being " + m.author.status);
});
a.on("serverMemberRemoved", function (r, s) {
console.log(r, s);
a.on("userTypingStart", function (user, chan) {
console.log(user.username + " typing");
});
a.on("userTypingStop", function (user, chan) {
console.log(user.username + " stopped typing");
});
a.login(process.env["discordEmail"], process.env["discordPass"])["catch"](function (e) {

View File

@@ -415,7 +415,8 @@ class InternalClient {
}
sendWS(object) {
this.websocket.send(JSON.stringify(object));
if(this.websocket)
this.websocket.send(JSON.stringify(object));
}
createWS(url) {
@@ -751,6 +752,80 @@ class InternalClient {
client.emit("warn", "server member updated but server doesn't exist in cache");
}
break;
case PacketType.PRESENCE_UPDATE:
var user = self.users.get("id", data.user.id);
if(user){
data.user.username = data.user.username || user.username;
data.user.id = data.user.id || user.id;
data.user.avatar = data.user.avatar || user.avatar;
data.user.discriminator = data.user.discriminator || user.discriminator;
var presenceUser = new User(data.user, client);
if(presenceUser.equalsStrict(user)){
// a real presence update
client.emit("presence", user, data.status, data.game_id);
user.status = data.status;
user.gameID = data.game_id;
}else{
// a name change or avatar change
client.emit("userUpdate", user, presenceUser);
self.users.update(user, presenceUser);
}
}else{
client.emit("warn", "presence update but user not in cache");
}
break;
case PacketType.TYPING:
var user = self.users.get("id", data.user_id);
var channel = self.channels.get("id", data.channel_id);
if(user && channel){
user.typing.since = Date.now();
user.typing.channel = channel;
client.emit("userTypingStart", user, channel);
setTimeout( () => {
if(Date.now() - user.typing.since > 5990){
// they haven't typed since
user.typing.since = null;
user.typing.channel = null;
client.emit("userTypingStop", user, channel);
}
}, 6000);
}else{
client.emit("warn", "user typing but user or channel not existant in cache");
}
break;
case PacketType.SERVER_BAN_ADD:
var user = self.users.get("id", data.user.id);
var server = self.servers.get("id", data.guild_id);
if(user && server){
client.emit("userBanned", user, server);
}else{
client.emit("warn", "user banned but user/server not in cache.");
}
break;
case PacketType.SERVER_BAN_REMOVE:
var user = self.users.get("id", data.user.id);
var server = self.servers.get("id", data.guild_id);
if(user && server){
client.emit("userUnbanned", user, server);
}else{
client.emit("warn", "user unbanned but user/server not in cache.");
}
break;
}
}
}

View File

@@ -76,7 +76,11 @@ var PacketType = {
SERVER_ROLE_UPDATE : "GUILD_ROLE_UPDATE",
SERVER_MEMBER_ADD : "GUILD_MEMBER_ADD",
SERVER_MEMBER_REMOVE : "GUILD_MEMBER_REMOVE",
SERVER_MEMBER_UPDATE : "GUILD_MEMBER_UPDATE"
SERVER_MEMBER_UPDATE : "GUILD_MEMBER_UPDATE",
PRESENCE_UPDATE : "PRESENCE_UPDATE",
TYPING : "TYPING_START",
SERVER_BAN_ADD : "GUILD_BAN_ADD",
SERVER_BAN_REMOVE : "GUILD_BAN_REMOVE"
}
exports.API_ENDPOINT = API;

View File

@@ -13,6 +13,10 @@ class User extends Equality{
this.avatar = data.avatar;
this.status = data.status || "offline";
this.gameID = data.game_id || null;
this.typing = {
since : null,
channel : null
};
}
get avatarURL(){
@@ -30,6 +34,20 @@ class User extends Equality{
toString(){
return this.mention();
}
equalsStrict(obj){
if(obj instanceof User)
return (
this.id === obj.id &&
this.username === obj.username &&
this.discriminator === obj.discriminator &&
this.avatar === obj.avatar &&
this.status === obj.status &&
this.gameID === obj.gameID
);
else
return false;
}
}
module.exports = User;

View File

@@ -10,8 +10,12 @@ a.on("message", m => {
if(m.content === "$$$")
a.reply(m, "I have you cached as being " + m.author.status);
});
a.on("serverMemberRemoved", (r, s) => {
console.log(r, s);
a.on("userTypingStart", (user, chan) => {
console.log(user.username + " typing");
});
a.on("userTypingStop", (user, chan) => {
console.log(user.username + " stopped typing");
});
a.login(process.env["discordEmail"], process.env["discordPass"]).catch((e)=>console.log(e));