mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-09 16:13:31 +01:00
Merge pull request #238 from nicholastay/friends_support
Friends (relationships) support
This commit is contained in:
@@ -173,6 +173,9 @@ var InternalClient = (function () {
|
||||
|
||||
// creates 4 caches with discriminators based on ID
|
||||
this.users = new _UtilCache2["default"]();
|
||||
this.friends = new _UtilCache2["default"]();
|
||||
this.outgoing_friend_requests = new _UtilCache2["default"]();
|
||||
this.incoming_friend_requests = new _UtilCache2["default"]();
|
||||
this.channels = new _UtilCache2["default"]();
|
||||
this.servers = new _UtilCache2["default"]();
|
||||
this.private_channels = new _UtilCache2["default"]();
|
||||
@@ -1349,6 +1352,33 @@ var InternalClient = (function () {
|
||||
return this.setChannelNameAndTopic(chann, data.name, data.topic);
|
||||
};
|
||||
|
||||
//def addFriend
|
||||
|
||||
InternalClient.prototype.addFriend = function addFriend(user) {
|
||||
if (this.user.bot) return Promise.reject(new Error("user is a bot, bot's do not have friends support"));
|
||||
|
||||
var id;
|
||||
if (user instanceof String || typeof user === "string") id = user;else if (user instanceof _StructuresUser2["default"]) {
|
||||
user = this.resolver.resolveUser(user);
|
||||
id = user.id;
|
||||
} else {
|
||||
if (user.username && user.discriminator) // add by username and discriminator (pass in an object)
|
||||
return this.apiRequest("put", _Constants.Endpoints.FRIENDS, true, user);else return Promise.reject("invalid user");
|
||||
}
|
||||
|
||||
return this.apiRequest("put", _Constants.Endpoints.FRIENDS + "/" + id, true, {});
|
||||
};
|
||||
|
||||
//def removeFriend
|
||||
|
||||
InternalClient.prototype.removeFriend = function removeFriend(user) {
|
||||
if (this.user.bot) return Promise.reject(new Error("user is a bot, bot's do not have friends support"));
|
||||
|
||||
user = this.resolver.resolveUser(user);
|
||||
|
||||
return this.apiRequest("delete", _Constants.Endpoints.FRIENDS + "/" + user.id, true);
|
||||
};
|
||||
|
||||
//def ack
|
||||
|
||||
InternalClient.prototype.ack = function ack(msg) {
|
||||
@@ -1444,6 +1474,27 @@ var InternalClient = (function () {
|
||||
data.private_channels.forEach(function (pm) {
|
||||
self.private_channels.add(new _StructuresPMChannel2["default"](pm, client));
|
||||
});
|
||||
if (!data.user.bot) {
|
||||
// bots dont have friends
|
||||
data.relationships.forEach(function (friend) {
|
||||
if (friend.type === 1) {
|
||||
// is a friend
|
||||
self.friends.add(new _StructuresUser2["default"](friend.user, client));
|
||||
} else if (friend.type === 3) {
|
||||
// incoming friend requests
|
||||
self.incoming_friend_requests.add(new _StructuresUser2["default"](friend.user, client));
|
||||
} else if (friend.type === 4) {
|
||||
// outgoing friend requests
|
||||
self.outgoing_friend_requests.add(new _StructuresUser2["default"](friend.user, client));
|
||||
} else {
|
||||
client.emit("warn", "unknown friend type " + friend.type);
|
||||
}
|
||||
});
|
||||
} else {
|
||||
data.friends = null;
|
||||
data.incoming_friend_requests = null;
|
||||
data.outgoing_friend_requests = null;
|
||||
}
|
||||
self.state = _ConnectionState2["default"].READY;
|
||||
|
||||
client.emit("debug", "ready packet took " + (Date.now() - startTime) + "ms to process");
|
||||
@@ -1986,6 +2037,53 @@ var InternalClient = (function () {
|
||||
client.emit("warn", "chunk update received but server not in cache");
|
||||
}
|
||||
|
||||
break;
|
||||
case _Constants.PacketType.FRIEND_ADD:
|
||||
if (data.type === 1) {
|
||||
// accepted/got accepted a friend request
|
||||
var inUser = self.incoming_friend_requests.get("id", data.id);
|
||||
if (inUser) {
|
||||
// client accepted another user
|
||||
self.incoming_friend_requests.remove(self.friends.add(new _StructuresUser2["default"](data.user, client)));
|
||||
return;
|
||||
}
|
||||
|
||||
var outUser = self.outgoing_friend_requests.get("id", data.id);
|
||||
if (outUser) {
|
||||
// another user accepted the client
|
||||
self.outgoing_friend_requests.remove(self.friends.add(new _StructuresUser2["default"](data.user, client)));
|
||||
client.emit("friendRequestAccepted", outUser);
|
||||
return;
|
||||
}
|
||||
} else if (data.type === 3) {
|
||||
// client received friend request
|
||||
client.emit("friendRequestReceived", self.incoming_friend_requests.add(new _StructuresUser2["default"](data.user, client)));
|
||||
} else if (data.type === 4) {
|
||||
// client sent friend request
|
||||
self.outgoing_friend_requests.add(new _StructuresUser2["default"](data.user, client));
|
||||
}
|
||||
break;
|
||||
case _Constants.PacketType.FRIEND_REMOVE:
|
||||
var user = self.friends.get("id", data.id);
|
||||
if (user) {
|
||||
self.friends.remove(user);
|
||||
client.emit("friendRemoved", user);
|
||||
return;
|
||||
}
|
||||
|
||||
user = self.incoming_friend_requests.get("id", data.id);
|
||||
if (user) {
|
||||
// they rejected friend request
|
||||
client.emit("friendRequestRejected", self.outgoing_friend_requests.remove(user));
|
||||
return;
|
||||
}
|
||||
|
||||
user = self.outgoing_friend_requests.get("id", data.id);
|
||||
if (user) {
|
||||
// client cancelled friend request
|
||||
self.incoming_friend_requests.remove(user);
|
||||
return;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
client.emit("unknown", packet);
|
||||
|
||||
Reference in New Issue
Block a user