Skip to content

Commit

Permalink
Fix things
Browse files Browse the repository at this point in the history
  • Loading branch information
Steffo99 committed Jan 25, 2022
1 parent 264f0ca commit f9a8342
Show file tree
Hide file tree
Showing 3 changed files with 159 additions and 4 deletions.
132 changes: 132 additions & 0 deletions .npmignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
.dockerignore

# Compiled js
*.js

# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
lerna-debug.log*
.pnpm-debug.log*

# Diagnostic reports (https://nodejs.org/api/report.html)
report.[0-9]*.[0-9]*.[0-9]*.[0-9]*.json

# Runtime data
pids
*.pid
*.seed
*.pid.lock

# Directory for instrumented libs generated by jscoverage/JSCover
lib-cov

# Coverage directory used by tools like istanbul
coverage
*.lcov

# nyc test coverage
.nyc_output

# Grunt intermediate storage (https://gruntjs.com/creating-plugins#storing-task-files)
.grunt

# Bower dependency directory (https://bower.io/)
bower_components

# node-waf configuration
.lock-wscript

# Compiled binary addons (https://nodejs.org/api/addons.html)
build/Release

# Dependency directories
node_modules/
jspm_packages/

# Snowpack dependency directory (https://snowpack.dev/)
web_modules/

# TypeScript cache
*.tsbuildinfo

# Optional npm cache directory
.npm

# Optional eslint cache
.eslintcache

# Optional stylelint cache
.stylelintcache

# Microbundle cache
.rpt2_cache/
.rts2_cache_cjs/
.rts2_cache_es/
.rts2_cache_umd/

# Optional REPL history
.node_repl_history

# Output of 'npm pack'
*.tgz

# Yarn Integrity file
.yarn-integrity

# dotenv environment variable files
.env
.env.development.local
.env.test.local
.env.production.local
.env.local

# parcel-bundler cache (https://parceljs.org/)
.cache
.parcel-cache

# Next.js build output
.next
out

# Nuxt.js build / generate output
.nuxt
dist

# Gatsby files
.cache/
# Comment in the public line in if your project uses Gatsby and not Next.js
# https://nextjs.org/blog/next-9-1#public-directory-support
# public

# vuepress build output
.vuepress/dist

# vuepress v2.x temp and cache directory
.temp
.cache

# Serverless directories
.serverless/

# FuseBox cache
.fusebox/

# DynamoDB Local files
.dynamodb/

# TernJS port file
.tern-port

# Stores VSCode versions used for testing VSCode extensions
.vscode-test

# yarn v2
.yarn/cache
.yarn/unplugged
.yarn/build-state.yml
.yarn/install-state.gz
.pnp.*
27 changes: 25 additions & 2 deletions src/setup.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ import {Snowflake} from "discord-api-types"
import {ApplicationCommandPermissions, Collection, Guild, GuildApplicationCommandPermissionData, TextChannel, Webhook} from "discord.js"
import {createEmptyPermission, createRolePermission} from "./slashPermissionsUtils"
import {rest as impressiveRest} from "./impressive"
import {client as dsclient} from "./discord"
import {WebhookFull, WebhookKind} from "./types"


Expand All @@ -28,8 +29,30 @@ export async function linkImpressiveWebhook(discordWebhook: Webhook): Promise<We
return response.data
}

export async function setCommandPermissions(guild: Guild, adminRoleId: Snowflake): Promise<Collection<string, ApplicationCommandPermissions[]>> {
console.debug("[Setup/Discord] Fetching slash commands...")
export async function setGlobalCommandPermissions(guild: Guild, adminRoleId: Snowflake): Promise<Collection<string, ApplicationCommandPermissions[]>> {
console.debug("[Setup/Discord] Fetching global slash commands...")
const commands = await dsclient.application.commands.fetch()

console.debug("[Setup/Discord] Setting command permissions for guild...")
const fullPermissions = commands.map<GuildApplicationCommandPermissionData>(cmd => {
if(["list", "view"].includes(cmd.name)) {
return createRolePermission(cmd.id, guild.id)
}
else if(["create", "edit", "delete", "unlock", "relock"].includes(cmd.name)) {
return createRolePermission(cmd.id, adminRoleId)
}
else {
return createEmptyPermission(cmd.id)
}
})
const result = await dsclient.application.commands.permissions.set({fullPermissions, guild: guild.id})

console.debug("[Setup/Discord] Successfully set up command permissions!")
return result
}

export async function setGuildCommandPermissions(guild: Guild, adminRoleId: Snowflake): Promise<Collection<string, ApplicationCommandPermissions[]>> {
console.debug("[Setup/Discord] Fetching guild slash commands...")
const commands = await guild.commands.fetch()

console.debug("[Setup/Discord] Setting command permissions for guild...")
Expand Down
4 changes: 2 additions & 2 deletions src/slashHandling.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import {AxiosError} from "axios"
import {Collection, CommandInteraction, Permissions, TextChannel} from "discord.js"
import {makeGroup, makeUser} from "./make"
import {renderAchievementEmbed, renderImpressiveError, renderMultilineCode, renderUnlockEmbed} from "./render"
import {linkImpressiveWebhook, setCommandPermissions, setupDiscordWebhook} from "./setup"
import {linkImpressiveWebhook, setGlobalCommandPermissions, setGuildCommandPermissions, setupDiscordWebhook} from "./setup"
import {AchievementFull, UnlockFull, Alloy} from "./types"
import {client as dsclient} from "./discord"
import {editResource, rest as impressiveRest} from "./impressive"
Expand Down Expand Up @@ -74,7 +74,7 @@ async function handleSetup(interaction: CommandInteraction): Promise<void> {
const channel = await findTargetChannel(interaction)
const dsWebhook = await setupDiscordWebhook(channel)
const isWebhook = await linkImpressiveWebhook(dsWebhook)
const permissions = await setCommandPermissions(guild, interaction.options.get("role").role.id)
const permissions = await setGlobalCommandPermissions(guild, interaction.options.get("role").role.id)

await interaction.reply({
content: `:hammer: Set up achievements in channel <#${channel.id}> and enabled the other Strawberry commands!`,
Expand Down

0 comments on commit f9a8342

Please sign in to comment.