mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-20 13:33:30 +01:00
Merge pull request #31 from hydrabolt/permission
Add reading permissions to main branch
This commit is contained in:
182
lib/ChannelPermissions.js
Normal file
182
lib/ChannelPermissions.js
Normal file
@@ -0,0 +1,182 @@
|
|||||||
|
"use strict";
|
||||||
|
|
||||||
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
|
|
||||||
|
var ChannelPermissions = (function () {
|
||||||
|
function ChannelPermissions(data, channel) {
|
||||||
|
_classCallCheck(this, ChannelPermissions);
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
return (self.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.type = data.type; //either member or role
|
||||||
|
this.id = data.id;
|
||||||
|
|
||||||
|
if (this.type === "member") {
|
||||||
|
this.packed = channel.server.getMember("id", data.id).evalPerms.packed;
|
||||||
|
} else {
|
||||||
|
this.packed = channel.server.getRole(data.id).packed;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = this.packed & ~data.deny;
|
||||||
|
this.packed = this.packed | data.allow;
|
||||||
|
|
||||||
|
this.deny = data.deny;
|
||||||
|
this.allow = data.allow;
|
||||||
|
}
|
||||||
|
|
||||||
|
_createClass(ChannelPermissions, [{
|
||||||
|
key: "getBit",
|
||||||
|
value: function getBit(x) {
|
||||||
|
return (this.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "setBit",
|
||||||
|
value: function setBit() {}
|
||||||
|
}, {
|
||||||
|
key: "createInstantInvite",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(0);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(0, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageRoles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(3);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(3, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageChannels",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(4);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(4, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(10);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(10, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(11);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(11, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendTTSMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(12);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(12, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(13);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(13, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "embedLinks",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(14);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(14, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "attachFiles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(15);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(15, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessageHistory",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(16);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(16, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "mentionEveryone",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(17);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(17, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceConnect",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(20);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(20, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceSpeak",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(21);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(21, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMuteMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(22);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(22, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceDeafenMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(23);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(23, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMoveMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(24);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(24, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceUseVoiceActivation",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(25);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(25, val);
|
||||||
|
}
|
||||||
|
}]);
|
||||||
|
|
||||||
|
return ChannelPermissions;
|
||||||
|
})();
|
||||||
|
|
||||||
|
module.exports = ChannelPermissions;
|
||||||
@@ -1031,11 +1031,7 @@ var Client = (function () {
|
|||||||
|
|
||||||
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
||||||
|
|
||||||
if (! ~server.members.indexOf(user)) {
|
self.trigger("serverNewMember", server.addMember(user, data.roles), server);
|
||||||
server.members.push(user);
|
|
||||||
}
|
|
||||||
|
|
||||||
self.trigger("serverNewMember", user, server);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@@ -1048,9 +1044,7 @@ var Client = (function () {
|
|||||||
|
|
||||||
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
||||||
|
|
||||||
if (~server.members.indexOf(user)) {
|
server.removeMember("id", user.id);
|
||||||
server.members.splice(server.members.indexOf(user), 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
self.trigger("serverRemoveMember", user, server);
|
self.trigger("serverRemoveMember", user, server);
|
||||||
}
|
}
|
||||||
@@ -1140,6 +1134,27 @@ var Client = (function () {
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case "GUILD_ROLE_DELETE":
|
||||||
|
|
||||||
|
var server = self.getServer("id", data.guild_id);
|
||||||
|
var role = server.getRole(data.role_id);
|
||||||
|
|
||||||
|
self.trigger("serverRoleDelete", server, role);
|
||||||
|
|
||||||
|
server.removeRole(role.id);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "GUILD_ROLE_UPDATE":
|
||||||
|
|
||||||
|
var server = self.getServer("id", data.guild_id);
|
||||||
|
var role = server.getRole(data.role.id);
|
||||||
|
var newRole = server.updateRole(data.role);
|
||||||
|
|
||||||
|
self.trigger("serverRoleUpdate", server, role, newRole);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
self.debug("received unknown packet");
|
self.debug("received unknown packet");
|
||||||
self.trigger("unknown", dat);
|
self.trigger("unknown", dat);
|
||||||
|
|||||||
172
lib/EvaluatedPermissions.js
Normal file
172
lib/EvaluatedPermissions.js
Normal file
@@ -0,0 +1,172 @@
|
|||||||
|
"use strict";
|
||||||
|
|
||||||
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
|
|
||||||
|
var EvaluatedPermissions = (function () {
|
||||||
|
function EvaluatedPermissions(data) {
|
||||||
|
_classCallCheck(this, EvaluatedPermissions);
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
if ((self.packed >>> 3 & 1) === 1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return (self.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
_createClass(EvaluatedPermissions, [{
|
||||||
|
key: "getBit",
|
||||||
|
value: function getBit(x) {
|
||||||
|
return (this.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "setBit",
|
||||||
|
value: function setBit() {}
|
||||||
|
}, {
|
||||||
|
key: "createInstantInvite",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(0);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(0, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageRoles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(3);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(3, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageChannels",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(4);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(4, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(10);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(10, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(11);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(11, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendTTSMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(12);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(12, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(13);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(13, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "embedLinks",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(14);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(14, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "attachFiles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(15);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(15, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessageHistory",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(16);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(16, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "mentionEveryone",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(17);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(17, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceConnect",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(20);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(20, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceSpeak",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(21);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(21, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMuteMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(22);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(22, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceDeafenMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(23);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(23, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMoveMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(24);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(24, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceUseVoiceActivation",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(25);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(25, val);
|
||||||
|
}
|
||||||
|
}]);
|
||||||
|
|
||||||
|
return EvaluatedPermissions;
|
||||||
|
})();
|
||||||
|
|
||||||
|
module.exports = EvaluatedPermissions;
|
||||||
208
lib/Member.js
208
lib/Member.js
@@ -1,5 +1,7 @@
|
|||||||
"use strict";
|
"use strict";
|
||||||
|
|
||||||
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
|
var _get = function get(_x, _x2, _x3) { var _again = true; _function: while (_again) { var object = _x, property = _x2, receiver = _x3; desc = parent = getter = undefined; _again = false; if (object === null) object = Function.prototype; var desc = Object.getOwnPropertyDescriptor(object, property); if (desc === undefined) { var parent = Object.getPrototypeOf(object); if (parent === null) { return undefined; } else { _x = parent; _x2 = property; _x3 = receiver; _again = true; continue _function; } } else if ("value" in desc) { return desc.value; } else { var getter = desc.get; if (getter === undefined) { return undefined; } return getter.call(receiver); } } };
|
||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
@@ -7,15 +9,217 @@ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Cons
|
|||||||
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; }
|
||||||
|
|
||||||
var User = require("./user.js");
|
var User = require("./user.js");
|
||||||
|
var ServerPermissions = require("./ServerPermissions.js");
|
||||||
|
var EvaluatedPermissions = require("./EvaluatedPermissions.js");
|
||||||
|
|
||||||
var Member = (function (_User) {
|
var Member = (function (_User) {
|
||||||
_inherits(Member, _User);
|
_inherits(Member, _User);
|
||||||
|
|
||||||
function Member(data) {
|
function Member(user, server, roles) {
|
||||||
_classCallCheck(this, Member);
|
_classCallCheck(this, Member);
|
||||||
|
|
||||||
_get(Object.getPrototypeOf(Member.prototype), "constructor", this).call(this, data);
|
_get(Object.getPrototypeOf(Member.prototype), "constructor", this).call(this, user); // should work, we are basically creating a Member that has the same properties as user and a few more
|
||||||
|
this.server = server;
|
||||||
|
this.rawRoles = roles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
_createClass(Member, [{
|
||||||
|
key: "permissionsIn",
|
||||||
|
value: function permissionsIn(channel) {
|
||||||
|
|
||||||
|
if (channel.server.ownerID === this.id) {
|
||||||
|
return new EvaluatedPermissions(4294967295); //all perms
|
||||||
|
}
|
||||||
|
|
||||||
|
var affectingOverwrites = [];
|
||||||
|
var affectingMemberOverwrites = [];
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion = true;
|
||||||
|
var _didIteratorError = false;
|
||||||
|
var _iteratorError = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator = channel.roles[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||||
|
var overwrite = _step.value;
|
||||||
|
|
||||||
|
if (overwrite.id === this.id && overwrite.type === "member") {
|
||||||
|
affectingMemberOverwrites.push(overwrite);
|
||||||
|
} else if (this.rawRoles.indexOf(overwrite.id) !== -1) {
|
||||||
|
affectingOverwrites.push(overwrite);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError = true;
|
||||||
|
_iteratorError = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion && _iterator["return"]) {
|
||||||
|
_iterator["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError) {
|
||||||
|
throw _iteratorError;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion2 = true;
|
||||||
|
var _didIteratorError2 = false;
|
||||||
|
var _iteratorError2 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator2 = affectingOverwrites[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
||||||
|
var perm = _step2.value;
|
||||||
|
|
||||||
|
console.log("hey", perm.attachFiles);
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError2 = true;
|
||||||
|
_iteratorError2 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion2 && _iterator2["return"]) {
|
||||||
|
_iterator2["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError2) {
|
||||||
|
throw _iteratorError2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (affectingOverwrites.length === 0 && affectingMemberOverwrites.length === 0) {
|
||||||
|
return new EvaluatedPermissions(this.evalPerms.packed);
|
||||||
|
}
|
||||||
|
|
||||||
|
var finalPacked = affectingOverwrites.length !== 0 ? affectingOverwrites[0].packed : affectingMemberOverwrites[0].packed;
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion3 = true;
|
||||||
|
var _didIteratorError3 = false;
|
||||||
|
var _iteratorError3 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator3 = affectingOverwrites[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
|
||||||
|
var overwrite = _step3.value;
|
||||||
|
|
||||||
|
finalPacked = finalPacked & ~overwrite.deny;
|
||||||
|
finalPacked = finalPacked | overwrite.allow;
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError3 = true;
|
||||||
|
_iteratorError3 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion3 && _iterator3["return"]) {
|
||||||
|
_iterator3["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError3) {
|
||||||
|
throw _iteratorError3;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion4 = true;
|
||||||
|
var _didIteratorError4 = false;
|
||||||
|
var _iteratorError4 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator4 = affectingMemberOverwrites[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
|
||||||
|
var overwrite = _step4.value;
|
||||||
|
|
||||||
|
finalPacked = finalPacked & ~overwrite.deny;
|
||||||
|
finalPacked = finalPacked | overwrite.allow;
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError4 = true;
|
||||||
|
_iteratorError4 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion4 && _iterator4["return"]) {
|
||||||
|
_iterator4["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError4) {
|
||||||
|
throw _iteratorError4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return new EvaluatedPermissions(finalPacked);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "roles",
|
||||||
|
get: function get() {
|
||||||
|
|
||||||
|
var ufRoles = [this.server.getRole(this.server.id)];
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion5 = true;
|
||||||
|
var _didIteratorError5 = false;
|
||||||
|
var _iteratorError5 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator5 = this.rawRoles[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
|
||||||
|
var rawRole = _step5.value;
|
||||||
|
|
||||||
|
ufRoles.push(this.server.getRole(rawRole));
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError5 = true;
|
||||||
|
_iteratorError5 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion5 && _iterator5["return"]) {
|
||||||
|
_iterator5["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError5) {
|
||||||
|
throw _iteratorError5;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return ufRoles;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "evalPerms",
|
||||||
|
get: function get() {
|
||||||
|
var basePerms = this.roles,
|
||||||
|
//cache roles as it can be slightly expensive
|
||||||
|
basePerm = basePerms[0].packed;
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion6 = true;
|
||||||
|
var _didIteratorError6 = false;
|
||||||
|
var _iteratorError6 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator6 = basePerms[Symbol.iterator](), _step6; !(_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done); _iteratorNormalCompletion6 = true) {
|
||||||
|
var perm = _step6.value;
|
||||||
|
|
||||||
|
basePerm = basePerm | perm.packed;
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError6 = true;
|
||||||
|
_iteratorError6 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion6 && _iterator6["return"]) {
|
||||||
|
_iterator6["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError6) {
|
||||||
|
throw _iteratorError6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ServerPermissions({
|
||||||
|
permissions: basePerm
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}]);
|
||||||
|
|
||||||
return Member;
|
return Member;
|
||||||
})(User);
|
})(User);
|
||||||
|
|
||||||
|
module.exports = Member;
|
||||||
202
lib/ServerPermissions.js
Normal file
202
lib/ServerPermissions.js
Normal file
@@ -0,0 +1,202 @@
|
|||||||
|
"use strict";
|
||||||
|
|
||||||
|
var _createClass = (function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; })();
|
||||||
|
|
||||||
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
|
|
||||||
|
var ServerPermissions = (function () {
|
||||||
|
function ServerPermissions(data) {
|
||||||
|
_classCallCheck(this, ServerPermissions);
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
return (self.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = data.permissions;
|
||||||
|
this.name = data.name;
|
||||||
|
this.id = data.id;
|
||||||
|
}
|
||||||
|
|
||||||
|
_createClass(ServerPermissions, [{
|
||||||
|
key: "getBit",
|
||||||
|
value: function getBit(x) {
|
||||||
|
return (this.packed >>> x & 1) === 1;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "setBit",
|
||||||
|
value: function setBit() {
|
||||||
|
//dummy function for now
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "toString",
|
||||||
|
value: function toString() {
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "createInstantInvite",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(0);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(0, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "banMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(1);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(1, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "kickMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(2);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(2, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageRoles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(3);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(3, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageChannels",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(4);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(4, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageServer",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(5);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(5, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(10);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(10, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(11);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(11, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "sendTTSMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(12);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(12, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "manageMessages",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(13);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(13, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "embedLinks",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(14);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(14, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "attachFiles",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(15);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(15, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "readMessageHistory",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(16);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(16, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "mentionEveryone",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(17);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(17, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceConnect",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(20);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(20, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceSpeak",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(21);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(21, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMuteMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(22);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(22, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceDeafenMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(23);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(23, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceMoveMembers",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(24);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(24, val);
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "voiceUseVoiceActivation",
|
||||||
|
get: function get() {
|
||||||
|
return this.getBit(25);
|
||||||
|
},
|
||||||
|
set: function set(val) {
|
||||||
|
this.setBit(25, val);
|
||||||
|
}
|
||||||
|
}]);
|
||||||
|
|
||||||
|
return ServerPermissions;
|
||||||
|
})();
|
||||||
|
|
||||||
|
module.exports = ServerPermissions;
|
||||||
@@ -4,6 +4,8 @@ var _createClass = (function () { function defineProperties(target, props) { for
|
|||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
|
|
||||||
|
var ChannelPermissions = require("./ChannelPermissions.js");
|
||||||
|
|
||||||
var Channel = (function () {
|
var Channel = (function () {
|
||||||
function Channel(data, server) {
|
function Channel(data, server) {
|
||||||
_classCallCheck(this, Channel);
|
_classCallCheck(this, Channel);
|
||||||
@@ -14,10 +16,49 @@ var Channel = (function () {
|
|||||||
this.topic = data.topic;
|
this.topic = data.topic;
|
||||||
this.id = data.id;
|
this.id = data.id;
|
||||||
this.messages = [];
|
this.messages = [];
|
||||||
|
this.roles = [];
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion = true;
|
||||||
|
var _didIteratorError = false;
|
||||||
|
var _iteratorError = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator = data.permission_overwrites[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||||
|
var role = _step.value;
|
||||||
|
|
||||||
|
this.roles.push(new ChannelPermissions(role, this));
|
||||||
|
}
|
||||||
|
|
||||||
//this.isPrivate = isPrivate; //not sure about the implementation of this...
|
//this.isPrivate = isPrivate; //not sure about the implementation of this...
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError = true;
|
||||||
|
_iteratorError = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion && _iterator["return"]) {
|
||||||
|
_iterator["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError) {
|
||||||
|
throw _iteratorError;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_createClass(Channel, [{
|
_createClass(Channel, [{
|
||||||
|
key: "permissionsOf",
|
||||||
|
value: function permissionsOf(member) {
|
||||||
|
|
||||||
|
var mem = this.server.getMember("id", member.id);
|
||||||
|
|
||||||
|
if (mem) {
|
||||||
|
return mem.permissionsIn(this);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
key: "equals",
|
key: "equals",
|
||||||
value: function equals(object) {
|
value: function equals(object) {
|
||||||
return object && object.id === this.id;
|
return object && object.id === this.id;
|
||||||
@@ -39,29 +80,29 @@ var Channel = (function () {
|
|||||||
}, {
|
}, {
|
||||||
key: "getMessage",
|
key: "getMessage",
|
||||||
value: function getMessage(key, value) {
|
value: function getMessage(key, value) {
|
||||||
var _iteratorNormalCompletion = true;
|
var _iteratorNormalCompletion2 = true;
|
||||||
var _didIteratorError = false;
|
var _didIteratorError2 = false;
|
||||||
var _iteratorError = undefined;
|
var _iteratorError2 = undefined;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (var _iterator = this.messages[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
for (var _iterator2 = this.messages[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
||||||
var message = _step.value;
|
var message = _step2.value;
|
||||||
|
|
||||||
if (message[key] === value) {
|
if (message[key] === value) {
|
||||||
return message;
|
return message;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
_didIteratorError = true;
|
_didIteratorError2 = true;
|
||||||
_iteratorError = err;
|
_iteratorError2 = err;
|
||||||
} finally {
|
} finally {
|
||||||
try {
|
try {
|
||||||
if (!_iteratorNormalCompletion && _iterator["return"]) {
|
if (!_iteratorNormalCompletion2 && _iterator2["return"]) {
|
||||||
_iterator["return"]();
|
_iterator2["return"]();
|
||||||
}
|
}
|
||||||
} finally {
|
} finally {
|
||||||
if (_didIteratorError) {
|
if (_didIteratorError2) {
|
||||||
throw _iteratorError;
|
throw _iteratorError2;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -73,6 +114,16 @@ var Channel = (function () {
|
|||||||
value: function toString() {
|
value: function toString() {
|
||||||
return "<#" + this.id + ">";
|
return "<#" + this.id + ">";
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
key: "permissionOverwrites",
|
||||||
|
get: function get() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "permissions",
|
||||||
|
get: function get() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
}, {
|
}, {
|
||||||
key: "client",
|
key: "client",
|
||||||
get: function get() {
|
get: function get() {
|
||||||
|
|||||||
@@ -20,7 +20,7 @@ var Message = (function () {
|
|||||||
this.editedTimestamp = data.edited_timestamp;
|
this.editedTimestamp = data.edited_timestamp;
|
||||||
this.content = data.content.trim();
|
this.content = data.content.trim();
|
||||||
this.channel = channel;
|
this.channel = channel;
|
||||||
this.author = author;
|
this.author = this.channel.server.getMember("id", author.id);
|
||||||
this.attachments = data.attachments;
|
this.attachments = data.attachments;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
231
lib/server.js
231
lib/server.js
@@ -4,6 +4,9 @@ var _createClass = (function () { function defineProperties(target, props) { for
|
|||||||
|
|
||||||
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
||||||
|
|
||||||
|
var ServerPermissions = require("./ServerPermissions.js");
|
||||||
|
var Member = require("./Member.js");
|
||||||
|
|
||||||
var Server = (function () {
|
var Server = (function () {
|
||||||
function Server(data, client) {
|
function Server(data, client) {
|
||||||
_classCallCheck(this, Server);
|
_classCallCheck(this, Server);
|
||||||
@@ -19,25 +22,17 @@ var Server = (function () {
|
|||||||
this.afkTimeout = data.afk_timeout;
|
this.afkTimeout = data.afk_timeout;
|
||||||
this.afkChannelId = data.afk_channel_id;
|
this.afkChannelId = data.afk_channel_id;
|
||||||
|
|
||||||
if (!data.members) {
|
this.roles = [];
|
||||||
data.members = [client.user];
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var _iteratorNormalCompletion = true;
|
var _iteratorNormalCompletion = true;
|
||||||
var _didIteratorError = false;
|
var _didIteratorError = false;
|
||||||
var _iteratorError = undefined;
|
var _iteratorError = undefined;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (var _iterator = data.members[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
for (var _iterator = data.roles[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
|
||||||
var member = _step.value;
|
var permissionGroup = _step.value;
|
||||||
|
|
||||||
// first we cache the user in our Discord Client,
|
this.roles.push(new ServerPermissions(permissionGroup));
|
||||||
// then we add it to our list. This way when we
|
|
||||||
// get a user from this server's member list,
|
|
||||||
// it will be identical (unless an async change occurred)
|
|
||||||
// to the client's cache.
|
|
||||||
if (member.user) this.members.push(client.addUser(member.user));
|
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
_didIteratorError = true;
|
_didIteratorError = true;
|
||||||
@@ -53,24 +48,26 @@ var Server = (function () {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (!data.members) {
|
||||||
|
data.members = [client.user];
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
_createClass(Server, [{
|
|
||||||
key: "getChannel",
|
|
||||||
|
|
||||||
// get/set
|
|
||||||
value: function getChannel(key, value) {
|
|
||||||
var _iteratorNormalCompletion2 = true;
|
var _iteratorNormalCompletion2 = true;
|
||||||
var _didIteratorError2 = false;
|
var _didIteratorError2 = false;
|
||||||
var _iteratorError2 = undefined;
|
var _iteratorError2 = undefined;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (var _iterator2 = this.channels[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
for (var _iterator2 = data.members[Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {
|
||||||
var channel = _step2.value;
|
var member = _step2.value;
|
||||||
|
|
||||||
if (channel[key] === value) {
|
// first we cache the user in our Discord Client,
|
||||||
return channel;
|
// then we add it to our list. This way when we
|
||||||
}
|
// get a user from this server's member list,
|
||||||
|
// it will be identical (unless an async change occurred)
|
||||||
|
// to the client's cache.
|
||||||
|
if (member.user) this.addMember(client.addUser(member.user), member.roles);
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
_didIteratorError2 = true;
|
_didIteratorError2 = true;
|
||||||
@@ -86,22 +83,24 @@ var Server = (function () {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
}
|
||||||
}, {
|
|
||||||
key: "getMember",
|
_createClass(Server, [{
|
||||||
value: function getMember(key, value) {
|
key: "getRole",
|
||||||
|
|
||||||
|
// get/set
|
||||||
|
|
||||||
|
value: function getRole(id) {
|
||||||
var _iteratorNormalCompletion3 = true;
|
var _iteratorNormalCompletion3 = true;
|
||||||
var _didIteratorError3 = false;
|
var _didIteratorError3 = false;
|
||||||
var _iteratorError3 = undefined;
|
var _iteratorError3 = undefined;
|
||||||
|
|
||||||
try {
|
try {
|
||||||
for (var _iterator3 = this.members[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
|
for (var _iterator3 = this.roles[Symbol.iterator](), _step3; !(_iteratorNormalCompletion3 = (_step3 = _iterator3.next()).done); _iteratorNormalCompletion3 = true) {
|
||||||
var member = _step3.value;
|
var role = _step3.value;
|
||||||
|
|
||||||
if (member[key] === value) {
|
if (role.id === id) {
|
||||||
return member;
|
return role;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
@@ -121,6 +120,157 @@ var Server = (function () {
|
|||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
key: "updateRole",
|
||||||
|
value: function updateRole(data) {
|
||||||
|
|
||||||
|
var oldRole = this.getRole(data.id);
|
||||||
|
|
||||||
|
if (oldRole) {
|
||||||
|
|
||||||
|
var index = this.roles.indexOf(oldRole);
|
||||||
|
this.roles[index] = new ServerPermissions(data);
|
||||||
|
|
||||||
|
return this.roles[index];
|
||||||
|
} else {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "removeRole",
|
||||||
|
value: function removeRole(id) {
|
||||||
|
for (var roleId in this.roles) {
|
||||||
|
if (this.roles[roleId].id === id) {
|
||||||
|
this.roles.splice(roleId, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
var _iteratorNormalCompletion4 = true;
|
||||||
|
var _didIteratorError4 = false;
|
||||||
|
var _iteratorError4 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator4 = this.members[Symbol.iterator](), _step4; !(_iteratorNormalCompletion4 = (_step4 = _iterator4.next()).done); _iteratorNormalCompletion4 = true) {
|
||||||
|
var member = _step4.value;
|
||||||
|
|
||||||
|
for (var roleId in member.rawRoles) {
|
||||||
|
if (member.rawRoles[roleId] === id) {
|
||||||
|
member.rawRoles.splice(roleId, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError4 = true;
|
||||||
|
_iteratorError4 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion4 && _iterator4["return"]) {
|
||||||
|
_iterator4["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError4) {
|
||||||
|
throw _iteratorError4;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "getChannel",
|
||||||
|
value: function getChannel(key, value) {
|
||||||
|
var _iteratorNormalCompletion5 = true;
|
||||||
|
var _didIteratorError5 = false;
|
||||||
|
var _iteratorError5 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator5 = this.channels[Symbol.iterator](), _step5; !(_iteratorNormalCompletion5 = (_step5 = _iterator5.next()).done); _iteratorNormalCompletion5 = true) {
|
||||||
|
var channel = _step5.value;
|
||||||
|
|
||||||
|
if (channel[key] === value) {
|
||||||
|
return channel;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError5 = true;
|
||||||
|
_iteratorError5 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion5 && _iterator5["return"]) {
|
||||||
|
_iterator5["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError5) {
|
||||||
|
throw _iteratorError5;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "getMember",
|
||||||
|
value: function getMember(key, value) {
|
||||||
|
var _iteratorNormalCompletion6 = true;
|
||||||
|
var _didIteratorError6 = false;
|
||||||
|
var _iteratorError6 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator6 = this.members[Symbol.iterator](), _step6; !(_iteratorNormalCompletion6 = (_step6 = _iterator6.next()).done); _iteratorNormalCompletion6 = true) {
|
||||||
|
var member = _step6.value;
|
||||||
|
|
||||||
|
if (member[key] === value) {
|
||||||
|
return member;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError6 = true;
|
||||||
|
_iteratorError6 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion6 && _iterator6["return"]) {
|
||||||
|
_iterator6["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError6) {
|
||||||
|
throw _iteratorError6;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "removeMember",
|
||||||
|
value: function removeMember(key, value) {
|
||||||
|
var _iteratorNormalCompletion7 = true;
|
||||||
|
var _didIteratorError7 = false;
|
||||||
|
var _iteratorError7 = undefined;
|
||||||
|
|
||||||
|
try {
|
||||||
|
for (var _iterator7 = this.members[Symbol.iterator](), _step7; !(_iteratorNormalCompletion7 = (_step7 = _iterator7.next()).done); _iteratorNormalCompletion7 = true) {
|
||||||
|
var member = _step7.value;
|
||||||
|
|
||||||
|
if (member[key] === value) {
|
||||||
|
this.members.splice(key, 1);
|
||||||
|
return member;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
_didIteratorError7 = true;
|
||||||
|
_iteratorError7 = err;
|
||||||
|
} finally {
|
||||||
|
try {
|
||||||
|
if (!_iteratorNormalCompletion7 && _iterator7["return"]) {
|
||||||
|
_iterator7["return"]();
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
if (_didIteratorError7) {
|
||||||
|
throw _iteratorError7;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}, {
|
}, {
|
||||||
key: "addChannel",
|
key: "addChannel",
|
||||||
value: function addChannel(chann) {
|
value: function addChannel(chann) {
|
||||||
@@ -131,11 +281,12 @@ var Server = (function () {
|
|||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
key: "addMember",
|
key: "addMember",
|
||||||
value: function addMember(member) {
|
value: function addMember(user, roles) {
|
||||||
if (!this.getMember("id", member.id)) {
|
if (!this.getMember("id", user.id)) {
|
||||||
this.members.push(member);
|
var mem = new Member(user, this, roles);
|
||||||
|
this.members.push(mem);
|
||||||
}
|
}
|
||||||
return member;
|
return mem;
|
||||||
}
|
}
|
||||||
}, {
|
}, {
|
||||||
key: "toString",
|
key: "toString",
|
||||||
@@ -147,6 +298,16 @@ var Server = (function () {
|
|||||||
value: function equals(object) {
|
value: function equals(object) {
|
||||||
return object.id === this.id;
|
return object.id === this.id;
|
||||||
}
|
}
|
||||||
|
}, {
|
||||||
|
key: "permissionGroups",
|
||||||
|
get: function get() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
}, {
|
||||||
|
key: "permissions",
|
||||||
|
get: function get() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
}, {
|
}, {
|
||||||
key: "iconURL",
|
key: "iconURL",
|
||||||
get: function get() {
|
get: function get() {
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ var User = (function () {
|
|||||||
this.discriminator = data.discriminator;
|
this.discriminator = data.discriminator;
|
||||||
this.id = data.id;
|
this.id = data.id;
|
||||||
this.avatar = data.avatar;
|
this.avatar = data.avatar;
|
||||||
this.status = "offline";
|
this.status = data.status || "offline";
|
||||||
}
|
}
|
||||||
|
|
||||||
// access using user.avatarURL;
|
// access using user.avatarURL;
|
||||||
|
|||||||
87
src/ChannelPermissions.js
Normal file
87
src/ChannelPermissions.js
Normal file
@@ -0,0 +1,87 @@
|
|||||||
|
class ChannelPermissions{
|
||||||
|
constructor(data, channel){
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
return ((self.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.type = data.type; //either member or role
|
||||||
|
this.id = data.id;
|
||||||
|
|
||||||
|
if(this.type === "member"){
|
||||||
|
this.packed = channel.server.getMember("id", data.id).evalPerms.packed;
|
||||||
|
}else{
|
||||||
|
this.packed = channel.server.getRole(data.id).packed;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = this.packed & ~data.deny;
|
||||||
|
this.packed = this.packed | data.allow;
|
||||||
|
|
||||||
|
this.deny = data.deny;
|
||||||
|
this.allow = data.allow;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
get createInstantInvite(){return this.getBit(0);}
|
||||||
|
set createInstantInvite(val){this.setBit(0, val);}
|
||||||
|
|
||||||
|
get manageRoles(){return this.getBit(3);}
|
||||||
|
set manageRoles(val){this.setBit(3, val);}
|
||||||
|
|
||||||
|
get manageChannels(){return this.getBit(4);}
|
||||||
|
set manageChannels(val){this.setBit(4, val);}
|
||||||
|
|
||||||
|
get readMessages(){return this.getBit(10);}
|
||||||
|
set readMessages(val){this.setBit(10, val);}
|
||||||
|
|
||||||
|
get sendMessages(){return this.getBit(11);}
|
||||||
|
set sendMessages(val){this.setBit(11, val);}
|
||||||
|
|
||||||
|
get sendTTSMessages(){return this.getBit(12);}
|
||||||
|
set sendTTSMessages(val){this.setBit(12, val);}
|
||||||
|
|
||||||
|
get manageMessages(){return this.getBit(13);}
|
||||||
|
set manageMessages(val){this.setBit(13, val);}
|
||||||
|
|
||||||
|
get embedLinks(){return this.getBit(14);}
|
||||||
|
set embedLinks(val){this.setBit(14, val);}
|
||||||
|
|
||||||
|
get attachFiles(){return this.getBit(15);}
|
||||||
|
set attachFiles(val){this.setBit(15, val);}
|
||||||
|
|
||||||
|
get readMessageHistory(){return this.getBit(16);}
|
||||||
|
set readMessageHistory(val){this.setBit(16, val);}
|
||||||
|
|
||||||
|
get mentionEveryone(){return this.getBit(17);}
|
||||||
|
set mentionEveryone(val){this.setBit(17, val);}
|
||||||
|
|
||||||
|
get voiceConnect(){return this.getBit(20);}
|
||||||
|
set voiceConnect(val){this.setBit(20, val);}
|
||||||
|
|
||||||
|
get voiceSpeak(){return this.getBit(21);}
|
||||||
|
set voiceSpeak(val){this.setBit(21, val);}
|
||||||
|
|
||||||
|
get voiceMuteMembers(){return this.getBit(22);}
|
||||||
|
set voiceMuteMembers(val){this.setBit(22, val);}
|
||||||
|
|
||||||
|
get voiceDeafenMembers(){return this.getBit(23);}
|
||||||
|
set voiceDeafenMembers(val){this.setBit(23, val);}
|
||||||
|
|
||||||
|
get voiceMoveMembers(){return this.getBit(24);}
|
||||||
|
set voiceMoveMembers(val){this.setBit(24, val);}
|
||||||
|
|
||||||
|
get voiceUseVoiceActivation(){return this.getBit(25);}
|
||||||
|
set voiceUseVoiceActivation(val){this.setBit(25, val);}
|
||||||
|
|
||||||
|
getBit(x) {
|
||||||
|
return ((this.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
setBit() {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = ChannelPermissions;
|
||||||
@@ -939,11 +939,7 @@ class Client {
|
|||||||
|
|
||||||
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
||||||
|
|
||||||
if (!~server.members.indexOf(user)) {
|
self.trigger("serverNewMember", server.addMember(user, data.roles), server);
|
||||||
server.members.push(user);
|
|
||||||
}
|
|
||||||
|
|
||||||
self.trigger("serverNewMember", user, server);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
@@ -956,9 +952,7 @@ class Client {
|
|||||||
|
|
||||||
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
var user = self.addUser(data.user); //if for whatever reason it doesn't exist..
|
||||||
|
|
||||||
if (~server.members.indexOf(user)) {
|
server.removeMember("id", user.id);
|
||||||
server.members.splice(server.members.indexOf(user), 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
self.trigger("serverRemoveMember", user, server);
|
self.trigger("serverRemoveMember", user, server);
|
||||||
}
|
}
|
||||||
@@ -1049,6 +1043,27 @@ class Client {
|
|||||||
|
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case "GUILD_ROLE_DELETE":
|
||||||
|
|
||||||
|
var server = self.getServer("id", data.guild_id);
|
||||||
|
var role = server.getRole(data.role_id);
|
||||||
|
|
||||||
|
self.trigger("serverRoleDelete", server, role);
|
||||||
|
|
||||||
|
server.removeRole(role.id);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case "GUILD_ROLE_UPDATE":
|
||||||
|
|
||||||
|
var server = self.getServer("id", data.guild_id);
|
||||||
|
var role = server.getRole(data.role.id);
|
||||||
|
var newRole = server.updateRole(data.role);
|
||||||
|
|
||||||
|
self.trigger("serverRoleUpdate", server, role, newRole);
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
self.debug("received unknown packet");
|
self.debug("received unknown packet");
|
||||||
self.trigger("unknown", dat);
|
self.trigger("unknown", dat);
|
||||||
|
|||||||
76
src/EvaluatedPermissions.js
Normal file
76
src/EvaluatedPermissions.js
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
class EvaluatedPermissions {
|
||||||
|
constructor(data) {
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
if (((self.packed >>> 3) & 1) === 1) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return ((self.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = data;
|
||||||
|
}
|
||||||
|
|
||||||
|
get createInstantInvite() { return this.getBit(0); }
|
||||||
|
set createInstantInvite(val) { this.setBit(0, val); }
|
||||||
|
|
||||||
|
get manageRoles() { return this.getBit(3); }
|
||||||
|
set manageRoles(val) { this.setBit(3, val); }
|
||||||
|
|
||||||
|
get manageChannels() { return this.getBit(4); }
|
||||||
|
set manageChannels(val) { this.setBit(4, val); }
|
||||||
|
|
||||||
|
get readMessages() { return this.getBit(10); }
|
||||||
|
set readMessages(val) { this.setBit(10, val); }
|
||||||
|
|
||||||
|
get sendMessages() { return this.getBit(11); }
|
||||||
|
set sendMessages(val) { this.setBit(11, val); }
|
||||||
|
|
||||||
|
get sendTTSMessages() { return this.getBit(12); }
|
||||||
|
set sendTTSMessages(val) { this.setBit(12, val); }
|
||||||
|
|
||||||
|
get manageMessages() { return this.getBit(13); }
|
||||||
|
set manageMessages(val) { this.setBit(13, val); }
|
||||||
|
|
||||||
|
get embedLinks() { return this.getBit(14); }
|
||||||
|
set embedLinks(val) { this.setBit(14, val); }
|
||||||
|
|
||||||
|
get attachFiles() { return this.getBit(15); }
|
||||||
|
set attachFiles(val) { this.setBit(15, val); }
|
||||||
|
|
||||||
|
get readMessageHistory() { return this.getBit(16); }
|
||||||
|
set readMessageHistory(val) { this.setBit(16, val); }
|
||||||
|
|
||||||
|
get mentionEveryone() { return this.getBit(17); }
|
||||||
|
set mentionEveryone(val) { this.setBit(17, val); }
|
||||||
|
|
||||||
|
get voiceConnect() { return this.getBit(20); }
|
||||||
|
set voiceConnect(val) { this.setBit(20, val); }
|
||||||
|
|
||||||
|
get voiceSpeak() { return this.getBit(21); }
|
||||||
|
set voiceSpeak(val) { this.setBit(21, val); }
|
||||||
|
|
||||||
|
get voiceMuteMembers() { return this.getBit(22); }
|
||||||
|
set voiceMuteMembers(val) { this.setBit(22, val); }
|
||||||
|
|
||||||
|
get voiceDeafenMembers() { return this.getBit(23); }
|
||||||
|
set voiceDeafenMembers(val) { this.setBit(23, val); }
|
||||||
|
|
||||||
|
get voiceMoveMembers() { return this.getBit(24); }
|
||||||
|
set voiceMoveMembers(val) { this.setBit(24, val); }
|
||||||
|
|
||||||
|
get voiceUseVoiceActivation() { return this.getBit(25); }
|
||||||
|
set voiceUseVoiceActivation(val) { this.setBit(25, val); }
|
||||||
|
|
||||||
|
getBit(x) {
|
||||||
|
return ((this.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
setBit() {
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = EvaluatedPermissions;
|
||||||
@@ -1,12 +1,81 @@
|
|||||||
var User = require("./user.js");
|
var User = require("./user.js");
|
||||||
|
var ServerPermissions = require("./ServerPermissions.js");
|
||||||
|
var EvaluatedPermissions = require("./EvaluatedPermissions.js");
|
||||||
|
|
||||||
class Member extends User{
|
class Member extends User{
|
||||||
|
|
||||||
constructor(data){
|
constructor(user, server, roles){
|
||||||
super(data);
|
super(user); // should work, we are basically creating a Member that has the same properties as user and a few more
|
||||||
|
this.server = server;
|
||||||
|
this.rawRoles = roles;
|
||||||
|
}
|
||||||
|
|
||||||
|
get roles(){
|
||||||
|
|
||||||
|
var ufRoles = [ this.server.getRole(this.server.id) ];
|
||||||
|
|
||||||
|
for(var rawRole of this.rawRoles){
|
||||||
|
ufRoles.push( this.server.getRole(rawRole) );
|
||||||
|
}
|
||||||
|
|
||||||
|
return ufRoles;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
get evalPerms(){
|
||||||
|
var basePerms = this.roles, //cache roles as it can be slightly expensive
|
||||||
|
basePerm = basePerms[0].packed;
|
||||||
|
|
||||||
|
for(var perm of basePerms){
|
||||||
|
basePerm = basePerm | perm.packed;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new ServerPermissions({
|
||||||
|
permissions : basePerm
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
permissionsIn(channel){
|
||||||
|
|
||||||
|
if(channel.server.ownerID === this.id){
|
||||||
|
return new EvaluatedPermissions(4294967295); //all perms
|
||||||
|
}
|
||||||
|
|
||||||
|
var affectingOverwrites = [];
|
||||||
|
var affectingMemberOverwrites = [];
|
||||||
|
|
||||||
|
for(var overwrite of channel.roles){
|
||||||
|
if(overwrite.id === this.id && overwrite.type === "member"){
|
||||||
|
affectingMemberOverwrites.push(overwrite);
|
||||||
|
}else if( this.rawRoles.indexOf(overwrite.id) !== -1 ){
|
||||||
|
affectingOverwrites.push(overwrite);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var perm of affectingOverwrites){
|
||||||
|
console.log("hey", perm.attachFiles);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(affectingOverwrites.length === 0 && affectingMemberOverwrites.length === 0){
|
||||||
|
return new EvaluatedPermissions(this.evalPerms.packed);
|
||||||
|
}
|
||||||
|
|
||||||
|
var finalPacked = (affectingOverwrites.length !== 0 ? affectingOverwrites[0].packed : affectingMemberOverwrites[0].packed);
|
||||||
|
|
||||||
|
for(var overwrite of affectingOverwrites){
|
||||||
|
finalPacked = finalPacked & ~overwrite.deny;
|
||||||
|
finalPacked = finalPacked | overwrite.allow;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var overwrite of affectingMemberOverwrites){
|
||||||
|
finalPacked = finalPacked & ~overwrite.deny;
|
||||||
|
finalPacked = finalPacked | overwrite.allow;
|
||||||
|
}
|
||||||
|
|
||||||
|
return new EvaluatedPermissions(finalPacked);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
module.exports = Member;
|
||||||
@@ -1,38 +0,0 @@
|
|||||||
class Permission {
|
|
||||||
|
|
||||||
constructor(packedPermissions) {
|
|
||||||
|
|
||||||
function getBit(x) {
|
|
||||||
return ((this.packed >>> x) & 1) === 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
this.packed = packedPermissions;
|
|
||||||
|
|
||||||
this.createInstantInvite = getBit(0);
|
|
||||||
this.banMembers = getBit(1);
|
|
||||||
this.kickMembers = getBit(2);
|
|
||||||
this.manageRoles = getBit(3);
|
|
||||||
this.manageChannels = getBit(4);
|
|
||||||
this.manageServer = getBit(5);
|
|
||||||
this.readMessages = getBit(10);
|
|
||||||
this.sendMessages = getBit(11);
|
|
||||||
this.sendTTSMessages = getBit(12);
|
|
||||||
this.manageMessages = getBit(13);
|
|
||||||
this.embedLinks = getBit(14);
|
|
||||||
this.attachFiles = getBit(15);
|
|
||||||
this.readMessageHistory = getBit(16);
|
|
||||||
this.mentionEveryone = getBit(17);
|
|
||||||
|
|
||||||
this.voiceConnect = getBit(20);
|
|
||||||
this.voiceSpeak = getBit(21);
|
|
||||||
this.voiceMuteMembers = getBit(22);
|
|
||||||
this.voiceDeafenMembers = getBit(23);
|
|
||||||
this.voiceMoveMembers = getBit(24);
|
|
||||||
this.voiceUseVoiceActivation = getBit(26);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
getBit(x) {
|
|
||||||
return ((this.packed >>> x) & 1) === 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
90
src/ServerPermissions.js
Normal file
90
src/ServerPermissions.js
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
class ServerPermissions {
|
||||||
|
|
||||||
|
constructor(data) {
|
||||||
|
|
||||||
|
var self = this;
|
||||||
|
|
||||||
|
function getBit(x) {
|
||||||
|
return ((self.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
this.packed = data.permissions;
|
||||||
|
this.name = data.name;
|
||||||
|
this.id = data.id;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
get createInstantInvite(){return this.getBit(0);}
|
||||||
|
set createInstantInvite(val){this.setBit(0, val);}
|
||||||
|
|
||||||
|
get banMembers(){return this.getBit(1);}
|
||||||
|
set banMembers(val){this.setBit(1, val);}
|
||||||
|
|
||||||
|
get kickMembers(){return this.getBit(2);}
|
||||||
|
set kickMembers(val){this.setBit(2, val);}
|
||||||
|
|
||||||
|
get manageRoles(){return this.getBit(3);}
|
||||||
|
set manageRoles(val){this.setBit(3, val);}
|
||||||
|
|
||||||
|
get manageChannels(){return this.getBit(4);}
|
||||||
|
set manageChannels(val){this.setBit(4, val);}
|
||||||
|
|
||||||
|
get manageServer(){return this.getBit(5);}
|
||||||
|
set manageServer(val){this.setBit(5, val);}
|
||||||
|
|
||||||
|
get readMessages(){return this.getBit(10);}
|
||||||
|
set readMessages(val){this.setBit(10, val);}
|
||||||
|
|
||||||
|
get sendMessages(){return this.getBit(11);}
|
||||||
|
set sendMessages(val){this.setBit(11, val);}
|
||||||
|
|
||||||
|
get sendTTSMessages(){return this.getBit(12);}
|
||||||
|
set sendTTSMessages(val){this.setBit(12, val);}
|
||||||
|
|
||||||
|
get manageMessages(){return this.getBit(13);}
|
||||||
|
set manageMessages(val){this.setBit(13, val);}
|
||||||
|
|
||||||
|
get embedLinks(){return this.getBit(14);}
|
||||||
|
set embedLinks(val){this.setBit(14, val);}
|
||||||
|
|
||||||
|
get attachFiles(){return this.getBit(15);}
|
||||||
|
set attachFiles(val){this.setBit(15, val);}
|
||||||
|
|
||||||
|
get readMessageHistory(){return this.getBit(16);}
|
||||||
|
set readMessageHistory(val){this.setBit(16, val);}
|
||||||
|
|
||||||
|
get mentionEveryone(){return this.getBit(17);}
|
||||||
|
set mentionEveryone(val){this.setBit(17, val);}
|
||||||
|
|
||||||
|
get voiceConnect(){return this.getBit(20);}
|
||||||
|
set voiceConnect(val){this.setBit(20, val);}
|
||||||
|
|
||||||
|
get voiceSpeak(){return this.getBit(21);}
|
||||||
|
set voiceSpeak(val){this.setBit(21, val);}
|
||||||
|
|
||||||
|
get voiceMuteMembers(){return this.getBit(22);}
|
||||||
|
set voiceMuteMembers(val){this.setBit(22, val);}
|
||||||
|
|
||||||
|
get voiceDeafenMembers(){return this.getBit(23);}
|
||||||
|
set voiceDeafenMembers(val){this.setBit(23, val);}
|
||||||
|
|
||||||
|
get voiceMoveMembers(){return this.getBit(24);}
|
||||||
|
set voiceMoveMembers(val){this.setBit(24, val);}
|
||||||
|
|
||||||
|
get voiceUseVoiceActivation(){return this.getBit(25);}
|
||||||
|
set voiceUseVoiceActivation(val){this.setBit(25, val);}
|
||||||
|
|
||||||
|
getBit(x) {
|
||||||
|
return ((this.packed >>> x) & 1) === 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
setBit(){
|
||||||
|
//dummy function for now
|
||||||
|
}
|
||||||
|
|
||||||
|
toString(){
|
||||||
|
return this.name;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
module.exports = ServerPermissions;
|
||||||
@@ -1,3 +1,5 @@
|
|||||||
|
var ChannelPermissions = require("./ChannelPermissions.js");
|
||||||
|
|
||||||
class Channel {
|
class Channel {
|
||||||
|
|
||||||
constructor(data, server) {
|
constructor(data, server) {
|
||||||
@@ -7,13 +9,41 @@ class Channel {
|
|||||||
this.topic = data.topic;
|
this.topic = data.topic;
|
||||||
this.id = data.id;
|
this.id = data.id;
|
||||||
this.messages = [];
|
this.messages = [];
|
||||||
|
this.roles = [];
|
||||||
|
|
||||||
|
for (var role of data.permission_overwrites) {
|
||||||
|
|
||||||
|
this.roles.push( new ChannelPermissions(role, this) );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
//this.isPrivate = isPrivate; //not sure about the implementation of this...
|
//this.isPrivate = isPrivate; //not sure about the implementation of this...
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get permissionOverwrites() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
|
||||||
|
get permissions() {
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
|
||||||
get client() {
|
get client() {
|
||||||
return this.server.client;
|
return this.server.client;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
permissionsOf(member){
|
||||||
|
|
||||||
|
var mem = this.server.getMember("id", member.id);
|
||||||
|
|
||||||
|
if(mem){
|
||||||
|
return mem.permissionsIn(this);
|
||||||
|
}else{
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
equals(object) {
|
equals(object) {
|
||||||
return (object && object.id === this.id);
|
return (object && object.id === this.id);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -12,7 +12,7 @@ class Message{
|
|||||||
this.editedTimestamp = data.edited_timestamp;
|
this.editedTimestamp = data.edited_timestamp;
|
||||||
this.content = data.content.trim();
|
this.content = data.content.trim();
|
||||||
this.channel = channel;
|
this.channel = channel;
|
||||||
this.author = author;
|
this.author = this.channel.server.getMember("id", author.id);
|
||||||
this.attachments = data.attachments;
|
this.attachments = data.attachments;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -1,3 +1,6 @@
|
|||||||
|
var ServerPermissions = require("./ServerPermissions.js");
|
||||||
|
var Member = require("./Member.js");
|
||||||
|
|
||||||
class Server {
|
class Server {
|
||||||
constructor(data, client) {
|
constructor(data, client) {
|
||||||
this.client = client;
|
this.client = client;
|
||||||
@@ -11,6 +14,12 @@ class Server {
|
|||||||
this.afkTimeout = data.afk_timeout;
|
this.afkTimeout = data.afk_timeout;
|
||||||
this.afkChannelId = data.afk_channel_id;
|
this.afkChannelId = data.afk_channel_id;
|
||||||
|
|
||||||
|
this.roles = [];
|
||||||
|
|
||||||
|
for(var permissionGroup of data.roles){
|
||||||
|
this.roles.push( new ServerPermissions(permissionGroup) );
|
||||||
|
}
|
||||||
|
|
||||||
if(!data.members){
|
if(!data.members){
|
||||||
data.members = [ client.user ];
|
data.members = [ client.user ];
|
||||||
return;
|
return;
|
||||||
@@ -24,11 +33,19 @@ class Server {
|
|||||||
// it will be identical (unless an async change occurred)
|
// it will be identical (unless an async change occurred)
|
||||||
// to the client's cache.
|
// to the client's cache.
|
||||||
if(member.user)
|
if(member.user)
|
||||||
this.members.push(client.addUser(member.user));
|
this.addMember(client.addUser(member.user), member.roles);
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
get permissionGroups(){
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
|
||||||
|
get permissions(){
|
||||||
|
return this.roles;
|
||||||
|
}
|
||||||
|
|
||||||
get iconURL() {
|
get iconURL() {
|
||||||
if (!this.icon)
|
if (!this.icon)
|
||||||
return null;
|
return null;
|
||||||
@@ -55,6 +72,51 @@ class Server {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// get/set
|
// get/set
|
||||||
|
|
||||||
|
getRole(id){
|
||||||
|
for (var role of this.roles) {
|
||||||
|
if (role.id === id) {
|
||||||
|
return role;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
updateRole(data){
|
||||||
|
|
||||||
|
var oldRole = this.getRole(data.id);
|
||||||
|
|
||||||
|
if(oldRole){
|
||||||
|
|
||||||
|
var index = this.roles.indexOf(oldRole);
|
||||||
|
this.roles[index] = new ServerPermissions(data);
|
||||||
|
|
||||||
|
|
||||||
|
return this.roles[index];
|
||||||
|
|
||||||
|
}else{
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
removeRole(id){
|
||||||
|
for (var roleId in this.roles) {
|
||||||
|
if (this.roles[roleId].id === id) {
|
||||||
|
this.roles.splice(roleId, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var member of this.members){
|
||||||
|
for(var roleId in member.rawRoles){
|
||||||
|
if(member.rawRoles[roleId] === id){
|
||||||
|
member.rawRoles.splice(roleId, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
getChannel(key, value) {
|
getChannel(key, value) {
|
||||||
for (var channel of this.channels) {
|
for (var channel of this.channels) {
|
||||||
if (channel[key] === value) {
|
if (channel[key] === value) {
|
||||||
@@ -75,6 +137,17 @@ class Server {
|
|||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
removeMember(key, value){
|
||||||
|
for (var member of this.members) {
|
||||||
|
if (member[key] === value) {
|
||||||
|
this.members.splice(key, 1);
|
||||||
|
return member;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
addChannel(chann) {
|
addChannel(chann) {
|
||||||
if (!this.getChannel("id", chann.id)) {
|
if (!this.getChannel("id", chann.id)) {
|
||||||
this.channels.push(chann);
|
this.channels.push(chann);
|
||||||
@@ -82,11 +155,12 @@ class Server {
|
|||||||
return chann;
|
return chann;
|
||||||
}
|
}
|
||||||
|
|
||||||
addMember(member){
|
addMember(user, roles){
|
||||||
if (!this.getMember("id", member.id)){
|
if (!this.getMember("id", user.id)){
|
||||||
this.members.push(member);
|
var mem = new Member(user, this, roles);
|
||||||
|
this.members.push(mem);
|
||||||
}
|
}
|
||||||
return member;
|
return mem;
|
||||||
}
|
}
|
||||||
|
|
||||||
toString(){
|
toString(){
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ class User{
|
|||||||
this.discriminator = data.discriminator;
|
this.discriminator = data.discriminator;
|
||||||
this.id = data.id;
|
this.id = data.id;
|
||||||
this.avatar = data.avatar;
|
this.avatar = data.avatar;
|
||||||
this.status = "offline";
|
this.status = data.status || "offline";
|
||||||
}
|
}
|
||||||
|
|
||||||
// access using user.avatarURL;
|
// access using user.avatarURL;
|
||||||
|
|||||||
@@ -9,21 +9,26 @@ counter = 1;
|
|||||||
mybot.on("message", function (message) {
|
mybot.on("message", function (message) {
|
||||||
|
|
||||||
console.log("Everyone mentioned? " + message.everyoneMentioned);
|
console.log("Everyone mentioned? " + message.everyoneMentioned);
|
||||||
if (mybot.user.equals(message.sender)) {
|
if (message.content.substr(0,3) !== "$$$") {
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (message.content !== "$$$") {
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// we can go ahead :)
|
// we can go ahead :)
|
||||||
|
|
||||||
var onlineUsers = 0;
|
var user;
|
||||||
|
if(message.mentions.length > 0){
|
||||||
|
user = message.mentions[0];
|
||||||
|
}else{
|
||||||
|
user = message.sender;
|
||||||
|
}
|
||||||
|
|
||||||
counter++;
|
console.log("the ID is ", user.id);
|
||||||
|
|
||||||
mybot.playingGame( "Minecraft" );
|
for(key in message.channel.permissionsOf(user)){
|
||||||
|
console.log(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
mybot.reply(message, user + "'s evaluated permissions in this channel are " + message.channel.permissionsOf(user).sendTTSMessages);
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -48,8 +53,6 @@ mybot.on("unknown", function(info){
|
|||||||
|
|
||||||
mybot.on("channelUpdate", function(oldChan, newChan){
|
mybot.on("channelUpdate", function(oldChan, newChan){
|
||||||
|
|
||||||
console.log(oldChan.topic + " vs " + newChan.topic);
|
|
||||||
|
|
||||||
});
|
});
|
||||||
|
|
||||||
mybot.on("startTyping", function(user, channel){
|
mybot.on("startTyping", function(user, channel){
|
||||||
|
|||||||
Reference in New Issue
Block a user