mirror of
https://github.com/discordjs/discord.js.git
synced 2026-03-15 11:03:30 +01:00
feat: allow multiple permission overwrites when editing channel (#2370)
* feat: allow multiple permission overwrites when editing channel * undo Permissions#resolve change
This commit is contained in:
@@ -1,9 +1,8 @@
|
|||||||
const Collection = require('../util/Collection');
|
|
||||||
const Channel = require('../structures/Channel');
|
const Channel = require('../structures/Channel');
|
||||||
const { ChannelTypes } = require('../util/Constants');
|
const { ChannelTypes } = require('../util/Constants');
|
||||||
const DataStore = require('./DataStore');
|
const DataStore = require('./DataStore');
|
||||||
const GuildChannel = require('../structures/GuildChannel');
|
const GuildChannel = require('../structures/GuildChannel');
|
||||||
const Permissions = require('../util/Permissions');
|
const resolvePermissions = require('../structures/shared/resolvePermissions');
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Stores guild channels.
|
* Stores guild channels.
|
||||||
@@ -24,9 +23,9 @@ class GuildChannelStore extends DataStore {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Can be used to overwrite permissions when creating a channel.
|
* Can be used to overwrite permissions when creating a channel.
|
||||||
* @typedef {Object} ChannelCreationOverwrites
|
* @typedef {Object} PermissionOverwriteOptions
|
||||||
* @property {PermissionResolvable[]|number} [allow] The permissions to allow
|
* @property {PermissionResolvable[]|number} [allowed] The permissions to allow
|
||||||
* @property {PermissionResolvable[]|number} [deny] The permissions to deny
|
* @property {PermissionResolvable[]|number} [denied] The permissions to deny
|
||||||
* @property {RoleResolvable|UserResolvable} id ID of the role or member this overwrite is for
|
* @property {RoleResolvable|UserResolvable} id ID of the role or member this overwrite is for
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@@ -39,7 +38,7 @@ class GuildChannelStore extends DataStore {
|
|||||||
* @param {number} [options.bitrate] Bitrate of the new channel in bits (only voice)
|
* @param {number} [options.bitrate] Bitrate of the new channel in bits (only voice)
|
||||||
* @param {number} [options.userLimit] Maximum amount of users allowed in the new channel (only voice)
|
* @param {number} [options.userLimit] Maximum amount of users allowed in the new channel (only voice)
|
||||||
* @param {ChannelResolvable} [options.parent] Parent of the new channel
|
* @param {ChannelResolvable} [options.parent] Parent of the new channel
|
||||||
* @param {Array<PermissionOverwrites|ChannelCreationOverwrites>} [options.overwrites] Permission overwrites
|
* @param {Array<PermissionOverwrites|PermissionOverwriteOptions>} [options.overwrites] Permission overwrites
|
||||||
* @param {string} [options.reason] Reason for creating the channel
|
* @param {string} [options.reason] Reason for creating the channel
|
||||||
* @returns {Promise<GuildChannel>}
|
* @returns {Promise<GuildChannel>}
|
||||||
* @example
|
* @example
|
||||||
@@ -47,33 +46,19 @@ class GuildChannelStore extends DataStore {
|
|||||||
* guild.channels.create('new-general', { reason: 'Needed a cool new channel' })
|
* guild.channels.create('new-general', { reason: 'Needed a cool new channel' })
|
||||||
* .then(console.log)
|
* .then(console.log)
|
||||||
* .catch(console.error);
|
* .catch(console.error);
|
||||||
|
* @example
|
||||||
|
* // Create a new channel with overwrites
|
||||||
|
* guild.channels.create('new-voice', {
|
||||||
|
* type: 'voice',
|
||||||
|
* overwrites: [
|
||||||
|
* {
|
||||||
|
* id: message.author.id,
|
||||||
|
* denied: ['VIEW_CHANNEL'],
|
||||||
|
* },
|
||||||
|
* ],
|
||||||
|
* })
|
||||||
*/
|
*/
|
||||||
create(name, { type, nsfw, bitrate, userLimit, parent, overwrites, reason } = {}) {
|
create(name, { type, nsfw, bitrate, userLimit, parent, overwrites, reason } = {}) {
|
||||||
if (overwrites instanceof Collection || overwrites instanceof Array) {
|
|
||||||
overwrites = overwrites.map(overwrite => {
|
|
||||||
let allow = overwrite.allow || (overwrite.allowed ? overwrite.allowed.bitfield : 0);
|
|
||||||
let deny = overwrite.deny || (overwrite.denied ? overwrite.denied.bitfield : 0);
|
|
||||||
if (allow instanceof Array) allow = Permissions.resolve(allow);
|
|
||||||
if (deny instanceof Array) deny = Permissions.resolve(deny);
|
|
||||||
|
|
||||||
const role = this.guild.roles.resolve(overwrite.id);
|
|
||||||
if (role) {
|
|
||||||
overwrite.id = role.id;
|
|
||||||
overwrite.type = 'role';
|
|
||||||
} else {
|
|
||||||
overwrite.id = this.client.users.resolveID(overwrite.id);
|
|
||||||
overwrite.type = 'member';
|
|
||||||
}
|
|
||||||
|
|
||||||
return {
|
|
||||||
allow,
|
|
||||||
deny,
|
|
||||||
type: overwrite.type,
|
|
||||||
id: overwrite.id,
|
|
||||||
};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
if (parent) parent = this.client.channels.resolveID(parent);
|
if (parent) parent = this.client.channels.resolveID(parent);
|
||||||
return this.client.api.guilds(this.guild.id).channels.post({
|
return this.client.api.guilds(this.guild.id).channels.post({
|
||||||
data: {
|
data: {
|
||||||
@@ -83,7 +68,7 @@ class GuildChannelStore extends DataStore {
|
|||||||
bitrate,
|
bitrate,
|
||||||
user_limit: userLimit,
|
user_limit: userLimit,
|
||||||
parent_id: parent,
|
parent_id: parent,
|
||||||
permission_overwrites: overwrites,
|
permission_overwrites: resolvePermissions.call(this, overwrites),
|
||||||
},
|
},
|
||||||
reason,
|
reason,
|
||||||
}).then(data => this.client.actions.ChannelCreate.handle(data).channel);
|
}).then(data => this.client.actions.ChannelCreate.handle(data).channel);
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
const Channel = require('./Channel');
|
const Channel = require('./Channel');
|
||||||
const Role = require('./Role');
|
const Role = require('./Role');
|
||||||
const Invite = require('./Invite');
|
const Invite = require('./Invite');
|
||||||
|
const resolvePermissions = require('./shared/resolvePermissions');
|
||||||
const PermissionOverwrites = require('./PermissionOverwrites');
|
const PermissionOverwrites = require('./PermissionOverwrites');
|
||||||
const Util = require('../util/Util');
|
const Util = require('../util/Util');
|
||||||
const Permissions = require('../util/Permissions');
|
const Permissions = require('../util/Permissions');
|
||||||
@@ -176,6 +177,28 @@ class GuildChannel extends Channel {
|
|||||||
.freeze();
|
.freeze();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Updates the permission overwrites for a channel
|
||||||
|
* @param {Object} [options] Options
|
||||||
|
* @param {Array<PermissionOverwrites|PermissionOverwriteOptions>} [options.overwrites] Permission overwrites
|
||||||
|
* @param {string} [options.reason] Reason for updating the channel overwrites
|
||||||
|
* @returns {Promise<GuildChannel>}
|
||||||
|
* @example
|
||||||
|
* channel.overwritePermissions({
|
||||||
|
* overwrites: [
|
||||||
|
* {
|
||||||
|
* id: message.author.id,
|
||||||
|
* denied: ['VIEW_CHANNEL'],
|
||||||
|
* },
|
||||||
|
* ],
|
||||||
|
* reason: 'Needed to change permissions'
|
||||||
|
* });
|
||||||
|
*/
|
||||||
|
overwritePermissions({ overwrites, reason } = {}) {
|
||||||
|
return this.edit({ permissionOverwrites: resolvePermissions.call(this, overwrites), reason })
|
||||||
|
.then(() => this);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* An object mapping permission flags to `true` (enabled), `null` (default) or `false` (disabled).
|
* An object mapping permission flags to `true` (enabled), `null` (default) or `false` (disabled).
|
||||||
* ```js
|
* ```js
|
||||||
@@ -185,24 +208,24 @@ class GuildChannel extends Channel {
|
|||||||
* 'ATTACH_FILES': false,
|
* 'ATTACH_FILES': false,
|
||||||
* }
|
* }
|
||||||
* ```
|
* ```
|
||||||
* @typedef {Object} PermissionOverwriteOptions
|
* @typedef {Object} PermissionOverwriteOption
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Overwrites the permissions for a user or role in this channel.
|
* Overwrites the permissions for a user or role in this channel.
|
||||||
* @param {RoleResolvable|UserResolvable} userOrRole The user or role to update
|
* @param {RoleResolvable|UserResolvable} userOrRole The user or role to update
|
||||||
* @param {PermissionOverwriteOptions} options The options for the update
|
* @param {PermissionOverwriteOption} options The options for the update
|
||||||
* @param {string} [reason] Reason for creating/editing this overwrite
|
* @param {string} [reason] Reason for creating/editing this overwrite
|
||||||
* @returns {Promise<GuildChannel>}
|
* @returns {Promise<GuildChannel>}
|
||||||
* @example
|
* @example
|
||||||
* // Overwrite permissions for a message author
|
* // Overwrite permissions for a message author
|
||||||
* message.channel.overwritePermissions(message.author, {
|
* message.channel.updateOverwrite(message.author, {
|
||||||
* SEND_MESSAGES: false
|
* SEND_MESSAGES: false
|
||||||
* })
|
* })
|
||||||
* .then(() => console.log('Done!'))
|
* .then(channel => console.log(channel.permissionOverwrites.get(message.author.id)))
|
||||||
* .catch(console.error);
|
* .catch(console.error);
|
||||||
*/
|
*/
|
||||||
overwritePermissions(userOrRole, options, reason) {
|
updateOverwrite(userOrRole, options, reason) {
|
||||||
const allow = new Permissions(0);
|
const allow = new Permissions(0);
|
||||||
const deny = new Permissions(0);
|
const deny = new Permissions(0);
|
||||||
let type;
|
let type;
|
||||||
|
|||||||
26
src/structures/shared/resolvePermissions.js
Normal file
26
src/structures/shared/resolvePermissions.js
Normal file
@@ -0,0 +1,26 @@
|
|||||||
|
const Permissions = require('../../util/Permissions');
|
||||||
|
const Collection = require('../../util/Collection');
|
||||||
|
|
||||||
|
module.exports = function resolvePermissions(overwrites) {
|
||||||
|
if (overwrites instanceof Collection || overwrites instanceof Array) {
|
||||||
|
overwrites = overwrites.map(overwrite => {
|
||||||
|
const role = this.guild.roles.resolve(overwrite.id);
|
||||||
|
if (role) {
|
||||||
|
overwrite.id = role.id;
|
||||||
|
overwrite.type = 'role';
|
||||||
|
} else {
|
||||||
|
overwrite.id = this.client.users.resolveID(overwrite.id);
|
||||||
|
overwrite.type = 'member';
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
allow: Permissions.resolve(overwrite.allowed || 0),
|
||||||
|
deny: Permissions.resolve(overwrite.denied || 0),
|
||||||
|
type: overwrite.type,
|
||||||
|
id: overwrite.id,
|
||||||
|
};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return overwrites;
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user