Now caches user status

This commit is contained in:
hydrabolt
2015-11-01 19:55:31 +00:00
parent b2a74be0f9
commit 641683c9d9
4 changed files with 81 additions and 59 deletions

View File

@@ -69,6 +69,29 @@ var Server = (function (_Equality) {
_this.channels.add(channel); _this.channels.add(channel);
} }
}); });
if (data.presences) {
for (var _iterator = data.presences, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) {
var _ref;
if (_isArray) {
if (_i >= _iterator.length) break;
_ref = _iterator[_i++];
} else {
_i = _iterator.next();
if (_i.done) break;
_ref = _i.value;
}
var presence = _ref;
var user = client.internal.users.get("id", presence.user.id);
if (user) {
user.status = presence.status;
user.gameId = presence.game_id;
}
}
}
} }
Server.prototype.rolesOfUser = function rolesOfUser(user) { Server.prototype.rolesOfUser = function rolesOfUser(user) {
@@ -90,19 +113,19 @@ var Server = (function (_Equality) {
Server.prototype.equalsStrict = function equalsStrict(obj) { Server.prototype.equalsStrict = function equalsStrict(obj) {
if (obj instanceof Server) { if (obj instanceof Server) {
for (var _iterator = strictKeys, _isArray = Array.isArray(_iterator), _i = 0, _iterator = _isArray ? _iterator : _iterator[Symbol.iterator]();;) { for (var _iterator2 = strictKeys, _isArray2 = Array.isArray(_iterator2), _i2 = 0, _iterator2 = _isArray2 ? _iterator2 : _iterator2[Symbol.iterator]();;) {
var _ref; var _ref2;
if (_isArray) { if (_isArray2) {
if (_i >= _iterator.length) break; if (_i2 >= _iterator2.length) break;
_ref = _iterator[_i++]; _ref2 = _iterator2[_i2++];
} else { } else {
_i = _iterator.next(); _i2 = _iterator2.next();
if (_i.done) break; if (_i2.done) break;
_ref = _i.value; _ref2 = _i2.value;
} }
var key = _ref; var key = _ref2;
if (obj[key] !== this[key]) { if (obj[key] !== this[key]) {
return false; return false;

View File

@@ -13,10 +13,7 @@ a.on("warn", function (m) {
}); });
a.on("message", function (m) { a.on("message", function (m) {
if (m.content === "$$$") a.reply(m, "you have the roles:\n" + m.channel.server.rolesOfUser(m.author).map(function (v) { if (m.content === "$$$") a.reply(m, "I have you cached as being " + m.author.status);
return "**" + v.name + "** " + v.id + "\n";
}));
if (m.content === "$$") a.reply(m, JSON.stringify(m.channel.permissionsOf(m.author).serialise(), null, 4).replace(/true/g, "**true**"));
}); });
a.on("serverMemberRemoved", function (r, s) { a.on("serverMemberRemoved", function (r, s) {
console.log(r, s); console.log(r, s);

View File

@@ -58,6 +58,16 @@ class Server extends Equality {
this.channels.add(channel); this.channels.add(channel);
} }
}); });
if (data.presences) {
for (var presence of data.presences) {
var user = client.internal.users.get("id", presence.user.id);
if (user) {
user.status = presence.status;
user.gameId = presence.game_id;
}
}
}
} }
rolesOfUser(user) { rolesOfUser(user) {

View File

@@ -8,15 +8,7 @@ a.on("warn", (m) => console.log("[warn]", m));
a.on("message", m => { a.on("message", m => {
if(m.content === "$$$") if(m.content === "$$$")
a.reply(m, a.reply(m, "I have you cached as being " + m.author.status);
"you have the roles:\n" + m.channel.server.rolesOfUser(m.author)
.map(v => "**"+v.name+"** "+v.id+"\n")
);
if(m.content === "$$")
a.reply(m, JSON.stringify(
m.channel.permissionsOf(m.author).serialise()
, null, 4
).replace(/true/g, "**true**"))
}); });
a.on("serverMemberRemoved", (r, s) => { a.on("serverMemberRemoved", (r, s) => {
console.log(r, s); console.log(r, s);