add permission checks to everything user-facing

This commit is contained in:
derpystuff 2023-06-15 12:09:40 +02:00
parent 9e9c53e1bd
commit 61274d6be5
66 changed files with 276 additions and 27 deletions

View file

@ -4,6 +4,8 @@ const { icon, highlight, link } = require('../../../labscore/utils/markdown');
const superagent = require('superagent');
const { Permissions } = require("detritus-client/lib/constants");
const applicationFlags = {
EMBEDDED_RELEASED: 1,
GATEWAY_PRESENCE: 12,
@ -43,6 +45,7 @@ module.exports = {
category: 'info',
usage: 'appinfo <application id>'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context, args) => {
context.triggerTyping();
let id;

View file

@ -4,6 +4,8 @@ const { getMember, getUser } = require("../../../labscore/utils/users");
const { paginator } = require('../../../labscore/client');
const { Permissions } = require("detritus-client/lib/constants");
module.exports = {
name: 'avatar',
label: 'user',
@ -15,6 +17,7 @@ module.exports = {
category: 'info',
usage: 'avatar [<user>]'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context, args) => {
context.triggerTyping();
if(!args.user) args.user = context.userId;

View file

@ -5,6 +5,8 @@ const { editOrReply } = require("../../../labscore/utils/message");
const { paginator } = require('../../../labscore/client');
const { Permissions } = require("detritus-client/lib/constants");
module.exports = {
name: 'server',
label: 'user',
@ -16,6 +18,7 @@ module.exports = {
category: 'info',
usage: 'server'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context) => {
try{
const emojis = context.message.guild.emojis

View file

@ -1,6 +1,8 @@
const { createEmbed } = require('../../../labscore/utils/embed')
const { editOrReply } = require('../../../labscore/utils/message')
const { Permissions } = require("detritus-client/lib/constants");
module.exports = {
name: 'servericon',
aliases: ["guildicon","gi","si","groupicon"],
@ -11,6 +13,7 @@ module.exports = {
category: 'info',
usage: 'guildicon'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context) => {
context.triggerTyping();
if(!context.guild.iconUrl) return editOrReply(context, createEmbed("warning", context, "Server doesn't have an icon."))

View file

@ -7,6 +7,8 @@ const { STATICS } = require("../../../labscore/utils/statics");
const { paginator } = require('../../../labscore/client');
const { Permissions } = require("detritus-client/lib/constants");
module.exports = {
name: 'invite',
label: 'invite',
@ -18,6 +20,7 @@ module.exports = {
category: 'info',
usage: 'invite <invite code>'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context, args) => {
context.triggerTyping();
if(!args.invite) return editOrReply(context, { content: `https://canary.discord.com/application-directory/${context.client.user.id}`, embed:createEmbed("default", context, {

View file

@ -6,6 +6,8 @@ const { getUser, renderBadges } = require("../../../labscore/utils/users");
const { Constants } = require('detritus-client')
const { UserFlags } = Constants
const { Permissions } = require("detritus-client/lib/constants");
module.exports = {
name: 'user',
label: 'user',
@ -17,6 +19,7 @@ module.exports = {
category: 'info',
usage: 'user [<user>]'
},
permissionsClient: [Permissions.EMBED_LINKS, Permissions.SEND_MESSAGES, Permissions.USE_EXTERNAL_EMOJIS],
run: async (context, args) => {
context.triggerTyping();
try{