all permisisons checks complete

This commit is contained in:
Skillz
2020-03-11 13:13:39 -04:00
parent f21142b7c2
commit e40946aa35
4 changed files with 119 additions and 66 deletions

View File

@@ -123,15 +123,15 @@ export const create_channel = (data: Channel_Create_Payload, client: Client) =>
mention: () => `<#${data.id}>`,
/** Delete messages from the channel. 2-100. Requires the MANAGE_MESSAGES permission */
delete_messages: (ids: string[], reason?: string) => {
// TODO: Requires the MANAGE_MESSAGES permission.
if (ids.length < 2) {
throw "This endpoint will only accept 2-100 message ids."
}
if (ids.length > 100) {
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
if (ids.length < 2) throw new Error(Errors.DELETE_MESSAGES_MIN)
if (ids.length > 100)
console.warn(
`This endpoint only accepts a maximum of 100 messages. Deleting the first 100 message ids provided.`
)
}
return client.discordRequestManager.post(endpoints.CHANNEL_BULK_DELETE(data.id), {
messages: ids.splice(0, 100),
reason
@@ -139,17 +139,20 @@ export const create_channel = (data: Channel_Create_Payload, client: Client) =>
},
/** Gets the invites for this channel. Requires MANAGE_CHANNEL */
get_invites: () => {
// TODO: Requires the MANAGE_CHANNELS permission
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_CHANNELS]))
throw new Error(Errors.MISSING_MANAGE_CHANNELS)
return client.discordRequestManager.get(endpoints.CHANNEL_INVITES(data.id))
},
/** Creates a new invite for this channel. Requires CREATE_INSTANT_INVITE */
create_invite: (options: Create_Invite_Options) => {
// TODO: Requires CREATE_INSTANT_INVITE permissin.
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.CREATE_INSTANT_INVITE]))
throw new Error(Errors.MISSING_CREATE_INSTANT_INVITE)
return client.discordRequestManager.post(endpoints.CHANNEL_INVITES(data.id), options)
},
/** Gets the webhooks for this channel. Requires MANAGE_WEBHOOKS */
get_webhooks: () => {
// TODO: Requires MANAGE_WEBHOOKS
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_WEBHOOKS]))
throw new Error(Errors.MISSING_MANAGE_WEBHOOKS)
return client.discordRequestManager.get(endpoints.CHANNEL_WEBHOOKS(data.id))
}
}

View File

@@ -20,6 +20,8 @@ import { create_channel } from "./channel.ts"
import { Channel_Create_Options } from "../types/channel.ts"
import { Image_Size, Image_Formats } from "../types/cdn.ts"
import { Permissions, Permission } from "../types/permission.ts"
import { bot_has_permission } from "../utils/permissions.ts"
import { Errors } from "../types/errors.ts"
export const create_guild = (data: Create_Guild_Payload, client: Client) => {
const guild = {
@@ -98,7 +100,8 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
data.banner ? format_image_url(endpoints.GUILD_BANNER(data.id, data.banner), size, format) : undefined,
/** Create a channel in your server. Bot needs MANAGE_CHANNEL permissions in the server. */
create_channel: (name: string, options: Channel_Create_Options) => {
// TODO: Check if the bot has `MANAGE_CHANNELS` permission before making a channel
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_CHANNELS]))
throw new Error(Errors.MISSING_MANAGE_CHANNELS)
return client.discordRequestManager.post(endpoints.GUILD_CHANNELS(data.id), {
name,
type: options?.type ? ChannelTypes[options.type] : undefined,
@@ -135,7 +138,8 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Create an emoji in the server. Emojis and animated emojis have a maximum file size of 256kb. Attempting to upload an emoji larger than this limit will fail and return 400 Bad Request and an error message, but not a JSON status code. */
create_emoji: (name: string, image: string, options: Create_Emojis_Options) => {
// TODO: Check if the bot has `MANAGE_EMOJIS` permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_EMOJIS]))
throw new Error(Errors.MISSING_MANAGE_EMOJIS)
return client.discordRequestManager.post(endpoints.GUILD_EMOJIS(data.id), {
...options,
name,
@@ -144,7 +148,8 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Modify the given emoji. Requires the MANAGE_EMOJIS permission. */
edit_emoji: (id: string, options: Edit_Emojis_Options) => {
// TODO: check if the bot has `MANAGE_EMOJIS` permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_EMOJIS]))
throw new Error(Errors.MISSING_MANAGE_EMOJIS)
return client.discordRequestManager.patch(endpoints.GUILD_EMOJI(data.id, id), {
name: options.name,
roles: options.roles
@@ -152,12 +157,14 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Delete the given emoji. Requires the MANAGE_EMOJIS permission. Returns 204 No Content on success. */
delete_emoji: (id: string, reason?: string) => {
// TODO: check if the bot has `MANAGE_EMOJIS` permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_EMOJIS]))
throw new Error(Errors.MISSING_MANAGE_EMOJIS)
return client.discordRequestManager.delete(endpoints.GUILD_EMOJI(data.id, id), { reason })
},
/** Create a new role for the guild. Requires the MANAGE_ROLES permission. */
create_role: async (options: Create_Role_Options) => {
// TODO: check if the bot has the `MANAGE_ROLES` permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_ROLES]))
throw new Error(Errors.MISSING_MANAGE_ROLES)
const role = await client.discordRequestManager.post(endpoints.GUILD_ROLES(data.id), {
...options,
permissions: options.permissions?.map(perm => Permissions[perm])
@@ -168,12 +175,14 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Edit a guild role. Requires the MANAGE_ROLES permission. */
edit_role: (id: string, options: Create_Role_Options) => {
// TODO: check if the bot has the `MANAGE_ROLES` permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_ROLES]))
throw new Error(Errors.MISSING_MANAGE_ROLES)
return client.discordRequestManager.patch(endpoints.GUILD_ROLE(data.id, id), options)
},
/** Delete a guild role. Requires the MANAGE_ROLES permission. */
delete_role: (id: string) => {
// TODO: check if the bot has the `MANAGE_ROLES` permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_ROLES]))
throw new Error(Errors.MISSING_MANAGE_ROLES)
return client.discordRequestManager.delete(endpoints.GUILD_ROLE(data.id, id))
},
/** Returns a list of role objects for the guild.
@@ -181,27 +190,29 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
* ⚠️ **If you need this, you are probably doing something wrong. This is not intended for use. Your roles will be cached in your guild.**
*/
get_roles: () => {
// TODO: check if the bot has the `MANAGE_ROLES` permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_ROLES]))
throw new Error(Errors.MISSING_MANAGE_ROLES)
return client.discordRequestManager.get(endpoints.GUILD_ROLES(data.id))
},
/** Modify the positions of a set of role objects for the guild. Requires the MANAGE_ROLES permission. */
swap_roles: (rolePositons: Position_Swap) => {
// TODO: check if the bot has the `MANAGE_ROLES` permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_ROLES]))
throw new Error(Errors.MISSING_MANAGE_ROLES)
return client.discordRequestManager.patch(endpoints.GUILD_ROLES(data.id), rolePositons)
},
/** Check how many members would be removed from the server in a prune operation. Requires the KICK_MEMBERS permission */
get_prune_count: async (days: number) => {
if (days < 1) {
throw `The number of days to count prune for must be 1 or more.`
}
// TODO: check if the bot has `KICK_MEMBERS` permission
if (days < 1) throw new Error(Errors.PRUNE_MIN_DAYS)
if (!bot_has_permission(data.id, client.bot_id, [Permissions.KICK_MEMBERS]))
throw new Error(Errors.MISSING_KICK_MEMBERS)
const result = (await client.discordRequestManager.get(endpoints.GUILD_PRUNE(data.id), { days })) as PrunePayload
return result.pruned
},
/** Begin pruning all members in the given time period */
prune_members: (days: number) => {
if (days < 1) throw `The number of days must be 1 or more.`
// TODO: check if the bot has `KICK_MEMBERS` permission.
if (days < 1) throw new Error(Errors.PRUNE_MIN_DAYS)
if (!bot_has_permission(data.id, client.bot_id, [Permissions.KICK_MEMBERS]))
throw new Error(Errors.MISSING_KICK_MEMBERS)
return client.discordRequestManager.post(endpoints.GUILD_PRUNE(data.id), { days })
},
// TODO: REQUEST THIS OVER WEBSOCKET WITH GET_GUILD_MEMBERS ENDPOINT
@@ -209,7 +220,9 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
// },
/** Returns the audit logs for the guild. Requires VIEW AUDIT LOGS permission */
get_audit_logs: (options: Get_Audit_Logs_Options) => {
// TODO: check if the bot has VIEW_AUDIT_LOGS permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.VIEW_AUDIT_LOG]))
throw new Error(Errors.MISSING_VIEW_AUDIT_LOG)
return client.discordRequestManager.get(endpoints.GUILD_AUDIT_LOGS(data.id), {
...options,
limit: options.limit && options.limit >= 1 && options.limit <= 100 ? options.limit : 50
@@ -217,12 +230,14 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Returns the guild embed object. Requires the MANAGE_GUILD permission. */
get_embed: () => {
// TODO: check if the bot has the MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.get(endpoints.GUILD_EMBED(data.id))
},
/** Modify a guild embed object for the guild. Requires the MANAGE_GUILD permission. */
edit_embed: (enabled: boolean, channel_id?: string | null) => {
// TODO: Requires the MANAGE_GUILD permission.
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.patch(endpoints.GUILD_EMBED(data.id), { enabled, channel_id })
},
/** Returns the code and uses of the vanity url for this server if it is enabled. Requires the MANAGE_GUILD permission. */
@@ -231,37 +246,44 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Returns a list of integrations for the guild. Requires the MANAGE_GUILD permission. */
get_integrations: () => {
// TODO: requires the MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.get(endpoints.GUILD_INTEGRATIONS(data.id))
},
/** Modify the behavior and settings of an integration object for the guild. Requires the MANAGE_GUILD permission. */
edit_integration: (id: string, options: Edit_Integration_Options) => {
// TODO: requires the MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.patch(endpoints.GUILD_INTEGRATION(data.id, id), options)
},
/** Delete the attached integration object for the guild with this id. Requires MANAGE_GUILD permission. */
delete_integration: (id: string) => {
// TODO: requires the MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.delete(endpoints.GUILD_INTEGRATION(data.id, id))
},
/** Sync an integration. Requires teh MANAGE_GUILD permission. */
sync_integration: (id: string) => {
// TODO: requires MANAGE_GUILD
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.post(endpoints.GUILD_INTEGRATION_SYNC(data.id, id))
},
/** Returns a list of ban objects for the users banned from this guild. Requires the BAN_MEMBERS permission. */
get_bans: () => {
// TODO: requires the BAN_MEMBERS permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.BAN_MEMBERS]))
throw new Error(Errors.MISSING_BAN_MEMBERS)
return client.discordRequestManager.get(endpoints.GUILD_BANS(data.id))
},
/** Ban a user from the guild and optionally delete previous messages sent by the user. Requires teh BAN_MEMBERS permission. */
ban: (id: string, options: BanOptions) => {
// TODO: requires the BAN_MEMBERS permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.BAN_MEMBERS]))
throw new Error(Errors.MISSING_BAN_MEMBERS)
return client.discordRequestManager.put(endpoints.GUILD_BAN(data.id, id), options)
},
/** Remove the ban for a user. REquires BAN_MEMBERS permission */
unban: (id: string) => {
// TODO: requires the BAN_MEMBERS permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.BAN_MEMBERS]))
throw new Error(Errors.MISSING_BAN_MEMBERS)
return client.discordRequestManager.delete(endpoints.GUILD_BAN(data.id, id))
},
/** Check whether a member has certain permissions in this channel. */
@@ -297,12 +319,14 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Modify a guilds settings. Requires the MANAGE_GUILD permission. */
edit: (options: Guild_Edit_Options) => {
// TODO: requires the MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.patch(endpoints.GUILD(data.id), options)
},
/** Get all the invites for this guild. Requires MANAGE_GUILD permission */
get_invites: () => {
// TODO: requires MANAGE_GUILD permission
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_GUILD]))
throw new Error(Errors.MISSING_MANAGE_GUILD)
return client.discordRequestManager.get(endpoints.GUILD_INVITES(data.id))
},
/** Leave a guild */
@@ -315,7 +339,9 @@ export const create_guild = (data: Create_Guild_Payload, client: Client) => {
},
/** Returns a list of guild webhooks objects. Requires the MANAGE_WEBHOOKs permission. */
get_webhooks: () => {
// TODO: requires MANAGE_WEBHOOKS
if (!bot_has_permission(data.id, client.bot_id, [Permissions.MANAGE_WEBHOOKS]))
throw new Error(Errors.MISSING_MANAGE_WEBHOOKS)
return client.discordRequestManager.get(endpoints.GUILD_WEBHOOKS(data.id))
}
}

View File

@@ -1,16 +1,19 @@
import Client from '../module/client.ts'
import { Message_Create_Options } from '../types/message.ts'
import { endpoints } from '../constants/discord.ts'
import { Channel_Types, MessageContent } from '../types/channel.ts'
import { cache } from '../utils/cache.ts'
import { create_user } from './user.ts'
import { User_Payload } from '../types/guild.ts'
import { Channel } from '../types/return-type.ts'
import Client from "../module/client.ts"
import { Message_Create_Options } from "../types/message.ts"
import { endpoints } from "../constants/discord.ts"
import { MessageContent } from "../types/channel.ts"
import { cache } from "../utils/cache.ts"
import { create_user } from "./user.ts"
import { User_Payload } from "../types/guild.ts"
import { Channel } from "../types/return-type.ts"
import { bot_has_permission } from "../utils/permissions.ts"
import { Errors } from "../types/errors.ts"
import { Permissions } from "../types/permission.ts"
export const create_message = (data: Message_Create_Options, client: Client) => {
const base_message = {
raw: () => data,
author: () => create_user({ ...data.author, avatar: data.author.avatar || '' }),
author: () => create_user({ ...data.author, avatar: data.author.avatar || "" }),
id: () => data.id,
type: () => data.type,
timestamp: () => Date.parse(data.timestamp),
@@ -39,18 +42,22 @@ export const create_message = (data: Message_Create_Options, client: Client) =>
channel: () => cache.channels.get(data.channel_id) as Channel,
delete: (reason: string) => {
// TODO: Requires MANAGE_MESSAGES
if (data.author.id !== client.bot_id) {}
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
if (data.author.id !== client.bot_id) {
}
client.discordRequestManager.delete(endpoints.CHANNEL_MESSAGE(data.channel_id, data.id), { reason })
},
/** Pin a message in a channel. Requires MANAGE_MESSAGES. Max pins allowed in a channel = 50. */
pin: () => {
// TODO: Requires MANAGE_MESSAGES
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
client.discordRequestManager.put(endpoints.CHANNEL_MESSAGE(data.channel_id, data.id))
},
unpin: () => {
// TODO: Requires MANAGE_MESSAGES
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
client.discordRequestManager.delete(endpoints.CHANNEL_MESSAGE(data.channel_id, data.id))
},
/** Create a reaction for the message. Reaction takes the form of **name:id** for custom guild emoji, or Unicode characters. Requires READ_MESSAGE_HISTORY and ADD_REACTIONS */
@@ -63,32 +70,38 @@ export const create_message = (data: Message_Create_Options, client: Client) =>
},
/** Removes all reactions for all emojis on this message. */
remove_all_reactions: () => {
// TODO: Requires MANAGE_MESSAGES
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
client.discordRequestManager.delete(endpoints.CHANNEL_MESSAGE_REACTIONS(data.channel_id, data.id))
},
/** Removes all reactions for a single emoji on this message. Reaction takes the form of **name:id** for custom guild emoji, or Unicode characters. */
remove_reaction_emoji: (reaction: string) => {
// TODO: Requires MANAGE_MESSAGES
if (data.guild_id && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.MANAGE_MESSAGES]))
throw new Error(Errors.MISSING_MANAGE_MESSAGES)
client.discordRequestManager.delete(endpoints.CHANNEL_MESSAGE_REACTION(data.channel_id, data.id, reaction))
},
/** Get a list of users that reacted with this emoji. */
get_reactions: async (reaction: string) => {
const result = await client.discordRequestManager.get(endpoints.CHANNEL_MESSAGE_REACTION(data.channel_id, data.id, reaction)) as User_Payload[]
const result = (await client.discordRequestManager.get(
endpoints.CHANNEL_MESSAGE_REACTION(data.channel_id, data.id, reaction)
)) as User_Payload[]
return result.map(res => create_user(res))
},
/** Edit the message. */
edit: async (content: string | MessageContent) => {
if (data.author.id !== client.bot_id) throw 'You can only edit a message that was sent by the bot.'
if (data.type !== Channel_Types.DM) {
// TODO: check if the bot has SEND_MESSAGES permission
if (data.author.id !== client.bot_id) throw "You can only edit a message that was sent by the bot."
if (typeof content === "string") content = { content }
if (data.guild_id) {
if (!bot_has_permission(data.guild_id, client.bot_id, [Permissions.SEND_MESSAGES]))
throw new Error(Errors.MISSING_SEND_MESSAGES)
if (content.tts && !bot_has_permission(data.guild_id, client.bot_id, [Permissions.SEND_TTS_MESSAGES]))
throw new Error(Errors.MISSING_SEND_TTS_MESSAGE)
}
if (typeof content === 'string') content = { content }
if (content.tts) {
// TODO: check if the bot has SEND_TTS_MESSAGE
}
// TODO: Check content length
if (content.content && content.content.length > 2000) throw new Error(Errors.MESSAGE_MAX_LENGTH)
const result = await client.discordRequestManager.patch(endpoints.CHANNEL_MESSAGES(data.id), content)
return create_message(result, client)

View File

@@ -6,8 +6,19 @@ export enum Errors {
MISSING_READ_MESSAGE_HISTORY = "MISSING_READ_MESSAGE_HISTORY",
MISSING_MANAGE_NICKNAMES = "MISSING_MANAGE_NICKNAMES",
MISSING_MUTE_MEMBERS = "MISSING_MUTE_MEMBERS",
MISSING_DEAFEN_MEMBERS = "MISSING_DEAFEN_MEMBERS",
MISSING_SEND_TTS_MESSAGE = 'MISSING_SEND_TTS_MESSAGE',
MESSAGE_MAX_LENGTH = 'MESSAGE_MAX_LENGTH',
NICKNAMES_MAX_LENGTH = "NICKNAMES_MAX_LENGTH"
MISSING_DEAFEN_MEMBERS = "MISSING_DEAFEN_MEMBERS",
MISSING_SEND_TTS_MESSAGE = "MISSING_SEND_TTS_MESSAGE",
MISSING_MANAGE_MESSAGES = "MISSING_MANAGE_MESSAGES",
MISSING_MANAGE_CHANNELS = "MISSING_MANAGE_CHANNELS",
MISSING_CREATE_INSTANT_INVITE = "MISSING_CREATE_INSTANT_INVITE",
MISSING_MANAGE_WEBHOOKS = "MISSING_MANAGE_WEBHOOKS",
MISSING_MANAGE_EMOJIS = "MISSING_MANAGE_EMOJIS",
MISSING_BAN_MEMBERS = "MISSING_BAN_MEMBERS",
MISSING_MANAGE_GUILD = "MISSING_MANAGE_GUILD",
MISSING_VIEW_AUDIT_LOG = "MISSING_VIEW_AUDIT_LOG",
DELETE_MESSAGES_MIN = "DELETE_MESSAGES_MIN",
DELETE_MESSAGES_MAX = "DELETE_MESSAGES_MAX",
MESSAGE_MAX_LENGTH = "MESSAGE_MAX_LENGTH",
NICKNAMES_MAX_LENGTH = "NICKNAMES_MAX_LENGTH",
PRUNE_MIN_DAYS = "PRUNE_MIN_DAYS"
}