Skip to content

Serverless Discord bot template using Next.js and Discord's slash commands webhook.

License

Notifications You must be signed in to change notification settings

roxxel/nextjs-discord-bot

 
 

Repository files navigation

NextBot: Serverless Discord Bot with Next.js

Serverless Discord bot using Discord's slash commands webhook and Next.js.

Demo GIF

Try it out

Discord Invite

Join https://discord.gg/NmXuqGgkb3 and use one of the available slash commands.

  • /ping
  • /randompic

Or, add NextBot to your own server: https://discord.com/api/oauth2/authorize?client_id=837427503059435530&permissions=2147483648&scope=bot%20applications.commands

You can also send slash commands through DM the bot once you're in a mutual server with the bot!

An accompanying static web app also shows the registered commands: https://nextjs-discord-bot.vercel.app/

Technologies

Development

Requires a Node.js version that can run Next.js.

Setup

Follow the one-time setup as follows:

  • Clone the repo
  • Create a Discord app and bot
  • Copy .env.local.example into a new file .env.local and fill in the blanks with the values from your Discord app
  • Register the slash commands. You can learn more about registering commands in the Discord API docs. I created the commands by leveraging createGlobalCommand in services/discord.ts. I added this togetServerSideProps in pages/index.tsx and ran it ONCE (i.e. refresh the page ONCE).
await createGlobalCommand({
  name: "randompic",
  description: "Get a random picture",
  options: [
    {
      name: "type",
      description: "What type of picture would you like?",
      type: 3,
      required: true,
      choices: [
        { name: "cat", value: "cat" },
        { name: "dog", value: "dog" },
        { name: "generic", value: "picsum" },
      ],
    },
  ],
})

await createGlobalCommand({
  name: "ping",
  description: "Ping pong! I'll respond with pong.",
})

You could also make the request via Postman, curl, etc. but I'm lazy

Local Development

  • Run yarn dev
  • Tunnel your localhost:3000 with a tool like ngrok. ngrok http 3000
  • Add the <YOUR_PUBLIC_TUNNELED_NGROK_URL>/api/interactions as the Interactions Endpoint URL in your Discord app.
  • Add the app to a server and slide in its DMs! Your registered slash commands should be available now.

Deploy on Vercel

Deploy with Vercel

After deploying, add <YOUR_VERCEL_URL>/api/interactions as the Interactions Endpoint URL in your Discord app.

About

Serverless Discord bot template using Next.js and Discord's slash commands webhook.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • TypeScript 100.0%