The Unthread Discord Bot seamlessly connects your Discord community with Unthread's powerful ticket management system. This official integration transforms how you handle support requests by enabling users to create and manage tickets directly within Discord.
With simple commands and forum integration, support tickets automatically sync between both platforms, streamlining your workflow and improving response times. Whether you're managing a gaming community, running a business server, or supporting an open-source project, this bot provides the tools you need for efficient, organized customer support.
💎 Platinum Sponsor |
---|
![]() |
Unthread Streamlined support ticketing for modern teams. |
- Users create tickets via the
/support
command or by posting in configured forum channels - The bot instantly creates a corresponding ticket in your Unthread dashboard
- All replies and updates sync in real-time between Discord and Unthread
- Support staff can manage tickets from either platform seamlessly
Ready to transform your Discord support experience? Get started in minutes with our one-click deployment!
- Seamless Ticket Creation: Create support tickets with the intuitive
/support
command or through configured forum channels - Effortless Integration: Connect your Discord server to Unthread's powerful ticket management system in minutes
- Real-time Synchronization: All ticket updates and responses automatically sync between Discord and Unthread
- Forum Channel Support: Transform any forum post into a fully-managed support ticket without extra steps
- Advanced Caching: Redis-powered caching system for improved performance and reliability
- Permission Validation: Intelligent permission checking to prevent conflicts and ensure proper functionality
- Thread-based Management: Each ticket creates a dedicated thread for organized communication
- Webhook Notifications: Receive instant updates when ticket statuses change or new replies are added
- User-friendly Interface: Simple commands and clear notifications enhance the support experience for everyone
- Debug Mode: Comprehensive logging system for development and troubleshooting
- Retry Mechanism: Built-in retry logic for handling API failures and network issues
- Customer Management: Automatic customer profile creation and management integration
You can use Railway to deploy this bot with just one click. Railway offers a seamless deployment experience without any configuration hassles.
Tip
When you deploy using the Railway button above, you're directly supporting the ongoing development and maintenance of this project. Your support helps keep this bot free and continuously improving with new features. Thank you for your contribution! 🙏✨
The bot is also available as pre-built Docker images with multi-architecture support (linux/amd64, linux/arm64):
Docker Hub Images:
# Latest stable release
docker pull wgtechlabs/unthread-discord-bot:latest
# Specific version
docker pull wgtechlabs/unthread-discord-bot:1.0.0
# Development build (from dev branch)
docker pull wgtechlabs/unthread-discord-bot:dev
GitHub Container Registry:
# Latest stable release
docker pull ghcr.io/wgtechlabs/unthread-discord-bot:latest
# Specific version (with v prefix)
docker pull ghcr.io/wgtechlabs/unthread-discord-bot:v1.0.0
# Development build
docker pull ghcr.io/wgtechlabs/unthread-discord-bot:dev
Quick start with Docker:
# Create environment file
cp .env.example .env
# Edit .env with your configuration
# Run with Docker
docker run --env-file .env wgtechlabs/unthread-discord-bot:latest
# Or with Docker Compose
docker-compose up -d
All Docker images include comprehensive security features:
- SBOM Generation: Software Bill of Materials for transparency
- Vulnerability Scanning: Automated security scanning with Trivy
- Supply Chain Attestations: Build provenance and authenticity verification
- Multi-stage Builds: Minimal runtime images with security best practices
- Non-root Execution: Containers run as unprivileged
nodejs
user
Generate SBOM locally:
# For contributors and security analysis
./scripts/generate-sbom.sh unthread-discord-bot:latest
-
Using the
/support
Command:- Type
/support
in any text channel where the bot has access. - A modal will appear with fields for:
- Ticket Title: A brief description of your issue
- Summary: Detailed explanation of your problem
- Contact Email (Optional): Your email address for notifications
- Type
-
Using Forum Channels:
- Create a new post in any forum channel that has been configured for ticket creation.
- Your post will automatically be converted to a support ticket.
- A confirmation message will appear in the thread.
-
Replying to Tickets:
- Simply reply in the private thread or forum post created by the bot.
- Your messages will be synced with the Unthread system.
-
Viewing Ticket Status:
- Status updates (open/closed) will be posted in the thread automatically.
/ping
- Shows bot latency and API ping metrics./server
- Provides information about the Discord server./user
- Shows details about your user account./version
- Displays the current bot version.
This bot is built with TypeScript for enhanced maintainability, type safety, and developer experience. The codebase follows clean coding principles and implements a modern 3-layer data persistence architecture for optimal performance and reliability.
Layer 1 (L1): In-Memory Cache
- Ultra-fast access for frequently used data
- LRU eviction policy to manage memory efficiently
- Automatic cache warming from lower layers
Layer 2 (L2): Redis Cache
- Distributed cache for persistence across restarts
- Fast lookup with millisecond response times
- Shared between application instances
Layer 3 (L3): PostgreSQL Database
- Primary source of truth for all data
- ACID compliance and data integrity
- Complex queries and reporting capabilities
- TypeScript: For type safety and better code maintainability
- Discord.js v14: Modern Discord API interactions
- Express.js: RESTful API server with comprehensive monitoring
- Node.js 20+: Runtime environment
- pnpm: Fast, disk-space-efficient package manager
- ESLint: Code quality and consistent formatting
Storage & Performance:
- PostgreSQL: Primary database with full ACID compliance
- Redis: High-performance L2 cache and queue management
- BullMQ: Robust job queue system for webhook processing
- IORedis: High-performance Redis client with cluster support
Infrastructure:
- Docker Compose: Complete local development environment
- Health Monitoring: Comprehensive health checks and metrics
- Queue Processing: Async webhook handling with retry logic
The project uses TypeScript compilation with pnpm for efficient package management:
# Development with live reload
pnpm dev
# Build for production
pnpm build
# Deploy commands only
pnpm deploycommand
# Production start
pnpm start
# Linting
pnpm lint
pnpm lint:fix
The project includes comprehensive unit testing with Vitest and automated CI/CD integration:
# Run all tests
pnpm test
# Run tests with coverage report
pnpm test:coverage
# Run tests in watch mode (development)
pnpm test:watch
The test suite is organized into focused modules that mirror the source code structure:
src/__tests__/
├── vitest.setup.ts # Global test configuration and mocking
├── async-test-utils.ts # Advanced async testing utilities
├── infrastructure.test.ts # Testing infrastructure validation
├── utils/ # Utility function tests
│ ├── decodeHtmlEntities.test.ts
│ ├── retry.test.ts
│ ├── messageUtils.test.ts
│ ├── botUtils.test.ts
│ └── ...
├── config/ # Configuration tests
│ ├── defaults.test.ts
│ └── ...
├── services/ # Service integration tests
│ ├── unthread.test.ts
│ └── ...
└── events/ # Event handler tests
├── messageCreate.test.ts
└── ...
- 100+ tests covering core functionality
- Comprehensive mocking of Discord.js, Unthread API, Redis, and external dependencies
- Real-world scenarios including API failures, message processing, and attachment handling
- Performance testing for large message handling and timing-sensitive operations
- Edge case coverage with error handling and input validation
- 30% minimum coverage (informational, not enforced)
- V8 coverage provider with LCOV, JSON, and HTML reports
- Codecov integration for PR coverage tracking
- Automated coverage comments on pull requests
- Write tests first for new features (TDD approach)
- Run tests frequently during development with
pnpm test:watch
- Check coverage before submitting PRs with
pnpm test:coverage
- Review test reports in the generated
coverage/
directory
- Automated testing on every push to
dev
branch - PR validation with coverage reporting and visual indicators
- GitHub Actions workflows handle linting, type checking, and testing
- Codecov uploads provide detailed coverage tracking across commits
The project includes dedicated Docker scripts for local development and security testing:
# Build Docker image locally
pnpm docker:build
# Build with enhanced security (no cache)
pnpm docker:build:secure
# Build with SBOM and provenance generation
pnpm docker:build:sbom
# Run the Docker container
pnpm docker:run
# Generate SBOM for security analysis
pnpm sbom:generate
The project features a comprehensive CI/CD pipeline with GitHub Actions that automatically:
Development Builds (on dev
branch):
- Builds multi-architecture Docker images (linux/amd64, linux/arm64)
- Publishes to Docker Hub and GitHub Container Registry with
dev
tags - Generates Software Bill of Materials (SBOM)
- Performs vulnerability scanning with Trivy
- Creates build attestations for supply chain security
Production Releases (on release tags):
- Builds and publishes versioned Docker images with semantic versioning
- Creates multiple tag variants (latest, major, minor, patch)
- Enhanced security scanning and reporting
- Comprehensive release summaries with deployment instructions
Security Features:
- SBOM generation for transparency
- Supply chain attestations
- Vulnerability scanning results in GitHub Security tab
- Non-root container execution
For the complete development experience with all dependencies:
# Start all services (PostgreSQL, Redis, Bot)
docker-compose up -d
# View logs
docker-compose logs -f discord-bot
# Stop all services
docker-compose down
# Reset all data
docker-compose down -v
The bot operates as a pure Redis consumer without direct HTTP endpoints. Health monitoring is handled through:
Internal Health Checks:
- Storage Layers: Automatic validation of Memory (L1), Redis (L2), and PostgreSQL (L3) connectivity
- Discord Connection: Real-time monitoring of Discord client connectivity
- Webhook Consumer: Redis queue processing status and connection health
External Monitoring:
- unthread-webhook-server: Provides HTTP endpoints for external health checks at
http://localhost:3000/health
- Docker Health Checks: Container-level health monitoring via docker-compose
- Logging: Comprehensive logging system for debugging and monitoring
Health Check Methods:
// Internal storage health check
const health = await botsStore.healthCheck();
// Webhook consumer health check
const consumerHealth = await webhookConsumer.healthCheck();
Note: The bot no longer exposes direct HTTP endpoints. All webhook processing is handled through the Redis queue populated by the separate unthread-webhook-server service.
Warning
This is an advanced installation method and is not recommended for beginners. If you're new to Discord bot development, consider using the Railway deployment method instead.
- Node.js: Version 20.0.0 or higher
- pnpm: Version 9.x (latest, automatically managed via package.json)
- TypeScript: Automatically managed via pnpm
- Discord Application: Bot token and proper permissions
- Unthread Account: API access and configuration
- Go to the Discord Developer Portal.
- Click on the "New Application" button.
- Give your application a name and click "Create".
- In your newly created application, navigate to the "Bot" tab.
- Click on the "Add Bot" button and confirm by clicking "Yes, do it!".
- Under the "TOKEN" section, click "Copy" to copy your bot token. You will need this later.
- Under "Privileged Gateway Intents", enable the "Message Content Intent".
-
Navigate to the "OAuth2" tab and then to the "URL Generator" sub-tab.
-
Under "SCOPES", select
bot
andapplications.commands
. -
Under "BOT PERMISSIONS", select the following required permissions:
- Send Messages
- Send Messages in Threads
- Create Public Threads
- Create Private Threads
- Manage Threads
- Embed Links
- Read Message History
- Use Slash Commands
- View Channels
-
Use the generated URL to invite your bot to your server, or use this pre-configured link (replace
YOUR_BOT_CLIENT_ID
with your actual bot client ID):https://discord.com/oauth2/authorize?client_id=YOUR_BOT_CLIENT_ID&permissions=1084479760448&integration_type=0&scope=bot+applications.commands
Note: The bot requires these specific permissions to create and manage threads for ticket handling. Missing permissions may cause functionality issues.
For Docker Compose (Recommended):
# Use the provided Docker Compose configuration
docker-compose up -d postgres redis-cache redis-queue
For Manual Setup:
- PostgreSQL 16+: Required for L3 persistent storage
- Redis 7+: Required for L2 cache and queue processing
- Create a
.env
file in the root directory of your project. - Copy the contents of
.env.example
to.env
. - Fill in the required information:
Discord Configuration:
DISCORD_BOT_TOKEN
: The token you copied from the "Bot" tab.CLIENT_ID
: Your application's client ID, found in the "General Information" tab.GUILD_ID
: The ID of the Discord server where you want to deploy the bot. How to Get Your Discord Server ID
Unthread Configuration:
UNTHREAD_API_KEY
: Your Unthread API key.UNTHREAD_SLACK_CHANNEL_ID
: Your Unthread Slack channel ID for ticket routing.
Storage Configuration (3-Layer Architecture):
POSTGRES_URL
: PostgreSQL connection string (e.g.,postgres://user:password@localhost:5432/database
)PLATFORM_REDIS_URL
: Redis cache connection URL (e.g.,redis://localhost:6379
)WEBHOOK_REDIS_URL
: Redis queue connection URL (e.g.,redis://localhost:6380
)
Optional Configuration:
FORUM_CHANNEL_IDS
: Comma-separated list of forum channel IDs for automatic ticket creation.NODE_ENV
: Set todevelopment
for verbose debug logging, orproduction
for info-level logging (default:production
).PORT
: Port for the webhook server (default:3000
).
-
Clone the repository and navigate to the project directory:
git clone https://github.com/wgtechlabs/unthread-discord-bot.git cd unthread-discord-bot
-
Enable Corepack and install dependencies:
corepack enable pnpm install
Note: This project uses pnpm 9.x for fast, efficient dependency management. Corepack ensures you're using the correct pnpm version specified in package.json.
-
Build the TypeScript project:
pnpm build
-
Deploy the slash commands to your Discord server:
pnpm deploycommand
-
Start the bot in production mode:
pnpm start
Or for development with TypeScript compilation and auto-restart:
pnpm dev
-
The bot should now be running in your Discord server and the webhook server will be listening on the specified port.
For active development, use these commands:
# Development with live reload (TypeScript)
pnpm dev
# Type checking and linting
pnpm lint
pnpm lint:fix
# Build only (creates dist/ folder)
pnpm build
# Deploy commands only
pnpm deploycommand
- Open Discord and go to your server.
- Click on the server name at the top of the channel list to open the dropdown menu.
- Select "Server Settings".
- In the "Server Settings" menu, go to the "Widget" tab.
- Enable the "Server Widget" option if it is not already enabled.
- The "Server ID" will be displayed under the "Widget" settings.
Alternatively, you can enable Developer Mode to get the server ID:
- Go to your Discord user settings.
- Navigate to the "Advanced" tab under "App Settings".
- Enable "Developer Mode".
- Right-click on your server name in the server list.
- Select "Copy ID" to copy the server ID to your clipboard.
For local development, you'll need to expose your webhook endpoint to receive events from Unthread:
- Open your project in VS Code.
- Open the Command Palette (Ctrl+Shift+P or Cmd+Shift+P on Mac).
- Type
Ports: Focus on Ports View
and select it. - In the Ports view, click on the
+
icon to add a new port. - Enter
3000
(or your configured PORT) as the port number and press Enter. - Click on the globe icon next to the port to make it publicly accessible.
- Copy the generated public URL for use in the Unthread webhook configuration.
-
Install ngrok: https://ngrok.com/download
-
Run ngrok to expose your local port:
ngrok http 3000
-
Copy the generated HTTPS URL for use in the Unthread webhook configuration.
- Log in to your Unthread dashboard.
- Navigate to the "Settings" or "Integrations" section.
- Under "Webhook Configuration", enter the following URL:
https://<YOUR_PUBLIC_URL>/webhook/unthread
- Replace
<YOUR_PUBLIC_URL>
with the public URL from your port forwarding setup - For production: Use your actual server domain (e.g.,
https://your-bot-server.com/webhook/unthread
)
- Replace
- Configure the webhook to send events to the unthread-webhook-server, which will queue them for the bot.
- Save the settings.
Note: The Discord bot now receives events through a Redis queue from the unthread-webhook-server, similar to the Telegram bot architecture. Direct webhook signature validation has been removed.
To enable automatic ticket creation from forum posts:
-
Add forum channel IDs to your
.env
file:FORUM_CHANNEL_IDS=123456789012345678,234567890123456789
- Replace the IDs with the actual IDs of your forum channels.
- You can find the channel ID by right-clicking on the channel name in Discord and selecting "Copy ID" (make sure Developer Mode is enabled in your Discord settings).
-
Each comma-separated ID represents a forum channel that will be monitored for new posts.
-
Any new forum posts in these channels will automatically create a corresponding ticket in Unthread.
-
Replies in the forum post will be synchronized with the Unthread ticket.
-
The bot includes validation to ensure only actual forum channels are processed, preventing conflicts with text channels.
Important: Only add actual forum channel IDs to this list. The bot will validate channel types to prevent issues.
Join our community discussions to get help, share ideas, and connect with other users:
- 📣 Announcements: Official updates from the maintainer
- 📸 Showcase: Show and tell your implementation
- 💖 Wall of Love: Share your experience with the bot
- 🛟 Help & Support: Get assistance from the community
- 🧠 Ideas: Suggest new features and improvements
Need assistance with the bot? Here's how to get help:
- Community Support: Check the Help & Support category in our GitHub Discussions for answers to common questions.
- Ask a Question: Create a new discussion if you can't find answers to your specific issue.
- Documentation: Review the usage instructions in this README for common commands and features.
- Known Issues: Browse existing issues to see if your problem has already been reported.
Bot not responding to commands:
- Ensure the bot has the required permissions in your server
- Check if the bot is online in your Discord server
- Verify that slash commands are deployed with
pnpm deploycommand
Forum channel tickets not creating:
- Confirm the channel IDs in
FORUM_CHANNEL_IDS
are actual forum channels (not text channels) - Set development environment (
NODE_ENV=development
) to see detailed logs - Check bot permissions in the specific forum channels
Webhook issues:
- Verify the webhook URL is accessible from the internet
- Ensure events are being queued properly in the Redis webhook queue
- Check the unthread-webhook-server is processing and queuing events correctly
- Ensure the Express server is running on the correct port
Redis connection problems:
- Verify your
REDIS_URL
is correctly formatted - Test Redis connectivity independently
- Redis is now required for application functionality and data persistence
Please report any issues, bugs, or improvement suggestions by creating a new issue. Before submitting, please check if a similar issue already exists to avoid duplicates.
For security vulnerabilities, please do not report them publicly. Follow the guidelines in our security policy to responsibly disclose security issues.
Your contributions to improving this project are greatly appreciated! 🙏✨
Contributions are welcome, create a pull request to this repo and I will review your code. Please consider to submit your pull request to the dev
branch. Thank you!
Read the project's contributing guide for more info.
Like this project? Leave a star! ⭐⭐⭐⭐⭐
There are several ways you can support this project:
- Become a sponsor and get some perks! 💖
- Buy me a coffee if you just love what I do! ☕
- Deploy using the Railway Template which directly supports the ongoing development! 🛠️
Found this project helpful? Consider nominating me (@warengonzaga) for the GitHub Star program! This recognition supports ongoing development of this project and my other open-source projects. GitHub Stars are recognized for their significant contributions to the developer community - your nomination makes a difference and encourages continued innovation!
I'm committed to providing a welcoming and inclusive environment for all contributors and users. Please review the project's Code of Conduct to understand the community standards and expectations for participation.
This project is licensed under the GNU Affero General Public License v3.0. This license requires that all modifications to the code must be shared under the same license, especially when the software is used over a network. See the LICENSE file for the full license text.
This project is created by Waren Gonzaga under WG Technology Labs, with the help of awesome contributors.
💻 with ❤️ by Waren Gonzaga under WG Technology Labs, and Him 🙏