mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-19 13:03:31 +01:00
Now caches user status
This commit is contained in:
@@ -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;
|
||||||
|
|||||||
@@ -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);
|
||||||
|
|||||||
@@ -14,7 +14,7 @@ var strictKeys = [
|
|||||||
|
|
||||||
class Server extends Equality {
|
class Server extends Equality {
|
||||||
constructor(data, client) {
|
constructor(data, client) {
|
||||||
|
|
||||||
super();
|
super();
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
@@ -31,45 +31,55 @@ class Server extends Equality {
|
|||||||
this.afkTimeout = data.afkTimeout;
|
this.afkTimeout = data.afkTimeout;
|
||||||
this.afkChannelID = data.afk_channel_id;
|
this.afkChannelID = data.afk_channel_id;
|
||||||
this.memberMap = {};
|
this.memberMap = {};
|
||||||
|
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
data.roles.forEach( (dataRole) => {
|
data.roles.forEach((dataRole) => {
|
||||||
this.roles.add( new Role(dataRole, this, client) );
|
this.roles.add(new Role(dataRole, this, client));
|
||||||
} );
|
});
|
||||||
|
|
||||||
data.members.forEach( (dataUser) => {
|
data.members.forEach((dataUser) => {
|
||||||
this.memberMap[dataUser.user.id] = {
|
this.memberMap[dataUser.user.id] = {
|
||||||
roles : dataUser.roles.map((pid) => self.roles.get("id", pid)),
|
roles: dataUser.roles.map((pid) => self.roles.get("id", pid)),
|
||||||
mute : dataUser.mute,
|
mute: dataUser.mute,
|
||||||
deaf : dataUser.deaf,
|
deaf: dataUser.deaf,
|
||||||
joinedAt : Date.parse(dataUser.joined_at)
|
joinedAt: Date.parse(dataUser.joined_at)
|
||||||
};
|
};
|
||||||
var user = client.internal.users.add(new User(dataUser.user, client));
|
var user = client.internal.users.add(new User(dataUser.user, client));
|
||||||
this.members.add( user );
|
this.members.add(user);
|
||||||
} );
|
});
|
||||||
|
|
||||||
data.channels.forEach( (dataChannel) => {
|
data.channels.forEach((dataChannel) => {
|
||||||
if(dataChannel.type === "text"){
|
if (dataChannel.type === "text") {
|
||||||
var channel = client.internal.channels.add(new TextChannel(dataChannel, client, this));
|
var channel = client.internal.channels.add(new TextChannel(dataChannel, client, this));
|
||||||
this.channels.add(channel);
|
this.channels.add(channel);
|
||||||
}else{
|
} else {
|
||||||
var channel = client.internal.channels.add(new VoiceChannel(dataChannel, client, this));
|
var channel = client.internal.channels.add(new VoiceChannel(dataChannel, client, this));
|
||||||
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) {
|
||||||
user = this.client.internal.resolver.resolveUser(user);
|
user = this.client.internal.resolver.resolveUser(user);
|
||||||
if(user){
|
if (user) {
|
||||||
return (this.memberMap[user.id] ? this.memberMap[user.id].roles : []);
|
return (this.memberMap[user.id] ? this.memberMap[user.id].roles : []);
|
||||||
}else{
|
} else {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
rolesOf(user){
|
rolesOf(user) {
|
||||||
return this.rolesOfUser(user);
|
return this.rolesOfUser(user);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -80,36 +90,36 @@ class Server extends Equality {
|
|||||||
return Endpoints.SERVER_ICON(this.id, this.icon);
|
return Endpoints.SERVER_ICON(this.id, this.icon);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
get afkChannel() {
|
get afkChannel() {
|
||||||
return this.channels.get("id", this.afkChannelID);
|
return this.channels.get("id", this.afkChannelID);
|
||||||
}
|
}
|
||||||
|
|
||||||
get defaultChannel() {
|
get defaultChannel() {
|
||||||
return this.channels.get("id", this.id);
|
return this.channels.get("id", this.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
get owner() {
|
get owner() {
|
||||||
return this.members.get("id", this.ownerID);
|
return this.members.get("id", this.ownerID);
|
||||||
}
|
}
|
||||||
|
|
||||||
toString() {
|
toString() {
|
||||||
return this.name;
|
return this.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
equalsStrict(obj){
|
equalsStrict(obj) {
|
||||||
if(obj instanceof Server){
|
if (obj instanceof Server) {
|
||||||
for(var key of strictKeys){
|
for (var key of strictKeys) {
|
||||||
if(obj[key] !== this[key]){
|
if (obj[key] !== this[key]) {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = Server;
|
module.exports = Server;
|
||||||
10
src/index.js
10
src/index.js
@@ -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);
|
||||||
|
|||||||
Reference in New Issue
Block a user