npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

@chat-adapter/discord

v4.23.0

Published

Discord adapter for chat

Downloads

90,470

Readme

@chat-adapter/discord

npm version npm downloads

Discord adapter for Chat SDK. Configure with HTTP Interactions and Gateway WebSocket support.

Installation

pnpm add @chat-adapter/discord

Usage

The adapter auto-detects DISCORD_BOT_TOKEN, DISCORD_PUBLIC_KEY, DISCORD_APPLICATION_ID, and DISCORD_MENTION_ROLE_IDS from environment variables:

import { Chat } from "chat";
import { createDiscordAdapter } from "@chat-adapter/discord";

const bot = new Chat({
  userName: "mybot",
  adapters: {
    discord: createDiscordAdapter(),
  },
});

bot.onNewMention(async (thread, message) => {
  await thread.post("Hello from Discord!");
});

Discord application setup

1. Create application

  1. Go to the Discord Developer Portal
  2. Click New Application and give it a name
  3. Note the Application ID from the General Information page
  4. Copy the Public Key from the General Information page

2. Create bot

  1. Go to the Bot section in the left sidebar
  2. Click Reset Token to generate a new bot token
  3. Copy and save the token (you won't see it again)
  4. Enable these Privileged Gateway Intents:
    • Message Content Intent
    • Server Members Intent (if needed)

3. Configure interactions endpoint

  1. Go to General Information
  2. Set Interactions Endpoint URL to https://your-domain.com/api/webhooks/discord
  3. Discord sends a PING to verify the endpoint

4. Add bot to server

  1. Go to OAuth2 then URL Generator
  2. Select scopes: bot, applications.commands
  3. Select bot permissions: Send Messages, Send Messages in Threads, Create Public Threads, Read Message History, Add Reactions, Attach Files
  4. Copy the generated URL and open it to invite the bot to your server

Architecture: HTTP Interactions vs Gateway

Discord has two ways to receive events:

HTTP Interactions (default):

  • Receives button clicks, slash commands, and verification pings
  • Works out of the box with serverless
  • Does not receive regular messages

Gateway WebSocket (required for messages):

  • Receives regular messages and reactions
  • Requires a persistent connection
  • In serverless environments, use a cron job to maintain the connection

Gateway setup for serverless

1. Create Gateway route

import { after } from "next/server";
import { bot } from "@/lib/bot";

export const maxDuration = 800;

export async function GET(request: Request): Promise<Response> {
  const cronSecret = process.env.CRON_SECRET;
  if (!cronSecret) {
    return new Response("CRON_SECRET not configured", { status: 500 });
  }

  const authHeader = request.headers.get("authorization");
  if (authHeader !== `Bearer ${cronSecret}`) {
    return new Response("Unauthorized", { status: 401 });
  }

  const durationMs = 600 * 1000;
  const webhookUrl = `https://${process.env.VERCEL_URL}/api/webhooks/discord`;

  await bot.initialize();

  return bot.adapters.discord.startGatewayListener(
    { waitUntil: (task) => after(() => task) },
    durationMs,
    undefined,
    webhookUrl
  );
}

2. Configure Vercel Cron

{
  "crons": [
    {
      "path": "/api/discord/gateway",
      "schedule": "*/9 * * * *"
    }
  ]
}

This runs every 9 minutes, ensuring overlap with the 10-minute listener duration.

3. Add environment variables

Add CRON_SECRET to your Vercel project settings.

Role mentions

By default, only direct user mentions (@BotName) trigger onNewMention handlers. To also trigger on role mentions (e.g., @AI):

  1. Create a role in your Discord server (e.g., "AI")
  2. Assign the role to your bot
  3. Copy the role ID (right-click role in server settings with Developer Mode enabled)
  4. Add to mentionRoleIds:
createDiscordAdapter({
  mentionRoleIds: ["1457473602180878604"],
});

Or set DISCORD_MENTION_ROLE_IDS as a comma-separated string in your environment variables.

Configuration

All options are auto-detected from environment variables when not provided.

| Option | Required | Description | |--------|----------|-------------| | botToken | No* | Discord bot token. Auto-detected from DISCORD_BOT_TOKEN | | publicKey | No* | Application public key. Auto-detected from DISCORD_PUBLIC_KEY | | applicationId | No* | Discord application ID. Auto-detected from DISCORD_APPLICATION_ID | | mentionRoleIds | No | Array of role IDs that trigger mention handlers. Auto-detected from DISCORD_MENTION_ROLE_IDS (comma-separated) | | logger | No | Logger instance (defaults to ConsoleLogger("info")) |

*botToken, publicKey, and applicationId are required — either via config or env vars.

Environment variables

DISCORD_BOT_TOKEN=your-bot-token
DISCORD_PUBLIC_KEY=your-application-public-key
DISCORD_APPLICATION_ID=your-application-id
DISCORD_MENTION_ROLE_IDS=1234567890,0987654321  # Optional
CRON_SECRET=your-random-secret                   # For Gateway cron

Features

Messaging

| Feature | Supported | |---------|-----------| | Post message | Yes | | Edit message | Yes | | Delete message | Yes | | File uploads | Yes | | Streaming | Post+Edit fallback |

Rich content

| Feature | Supported | |---------|-----------| | Card format | Embeds | | Buttons | Yes | | Link buttons | Yes | | Select menus | No | | Tables | GFM | | Fields | Yes | | Images in cards | Yes | | Modals | No |

Conversations

| Feature | Supported | |---------|-----------| | Slash commands | Yes | | Mentions | Yes | | Add reactions | Yes | | Remove reactions | Yes | | Typing indicator | Yes | | DMs | Yes | | Ephemeral messages | No (DM fallback) |

Message history

| Feature | Supported | |---------|-----------| | Fetch messages | Yes | | Fetch single message | No | | Fetch thread info | Yes | | Fetch channel messages | Yes | | List threads | Yes | | Fetch channel info | Yes | | Post channel message | Yes |

Testing

Run a local tunnel (e.g., ngrok) to test webhooks locally:

ngrok http 3000

Update the Interactions Endpoint URL in the Discord Developer Portal to your ngrok URL.

Troubleshooting

Bot not responding to messages

  1. Check Gateway connection: Messages require the Gateway WebSocket, not just HTTP interactions
  2. Verify Message Content Intent: Enable this in the Bot settings
  3. Check bot permissions: Ensure the bot can read messages in the channel

Role mentions not triggering

  1. Verify role ID: Enable Developer Mode in Discord settings, then right-click the role
  2. Check mentionRoleIds config: Ensure the role ID is in the array
  3. Confirm bot has the role: The bot must have the role assigned

Signature verification failing

  1. Check public key format: Should be a 64-character hex string (lowercase)
  2. Verify endpoint URL: Must exactly match what's configured in Discord Developer Portal
  3. Check for body parsing: Don't parse the request body before verification

License

MIT