HN-MCP
Enables browsing Hacker News, searching discussions, analyzing users, and tracking tech trends with zero setup requiredβno API keys or authentication needed.
README
<img src="assets/hn-mcp-icon-white-background.png" width="48" align="center"/> HN-MCP
Hacker News Browser for Claude Desktop and AI Assistants
A Model Context Protocol (MCP) server that enables Claude Desktop and other AI assistants to browse Hacker News, search discussions, and analyze tech trends. Clean, fast, and actually works - no API keys required.
Table of Contents
- What makes HN-MCP different?
- Quick Start
- What can it do?
- Available Tools
- Installation Options
- Troubleshooting
- Development
- Support
What makes HN-MCP different?
- π Zero setup - Works instantly! Unlike Reddit, Twitter, or other platforms, Hacker News API requires no authentication, no API keys, no registration. Just install and go.
- β‘ Smart caching - 50MB LRU cache with adaptive TTLs delivers 50ms cached responses (vs 200-500ms uncached). Popular content stays cached longer automatically.
- π― Clean data - Direct from HN's Firebase API and Algolia Search. No fake metrics, no made-up sentiment scores, no hallucinated data.
- π§ LLM-optimized - Response formats designed specifically for AI assistants. Structured JSON that Claude can parse perfectly every time.
- π¦ TypeScript - 100% TypeScript with strict typing. Zod schemas validate every input and output. Reliable and maintainable.
- β Multi-channel distribution - Available via npm, Docker Hub, MCP Registry, and .mcpb extension. Choose your preferred installation method.
- π³ Docker ready - Multi-platform images (amd64, arm64) with health checks and optimized builds. Deploy anywhere in seconds.
Quick Start (30 seconds)
For Claude Desktop
Add this to your claude_desktop_config.json:
{
"mcpServers": {
"hn": {
"command": "npx",
"args": ["hn-mcp"]
}
}
}
That's it! HN-MCP is now available in Claude.
What can it do?
Ask your AI assistant to:
- π "What's trending on Hacker News?" - Browse top stories
- π "Search for discussions about AI" - Search across all content
- π¬ "Get comments on story 12345678" - Fetch full discussion threads
- π€ "Analyze user pg" - Get user karma, submissions, and activity
- π "Explain HN karma" - Understand Hacker News terminology
Perfect for:
- π Startup founders - Monitor YC companies, track competitor launches, discover market trends
- πΌ Tech recruiters - Find talented developers, understand the tech community pulse
- π Market researchers - Analyze tech sentiment, identify emerging technologies, track discussion trends
- βοΈ Content creators - Find trending topics, research technical subjects, engage with developer community
- π Developers - Stay updated on latest tools, frameworks, and best practices discussed by peers
- π° Tech journalists - Source breaking stories, find expert opinions, track industry discussions
- π Researchers - Analyze tech community behavior, study information diffusion, collect discussion data
Available Tools
browse_stories
Browse posts from Hacker News by category.
- Types: top, new, best, ask (Ask HN), show (Show HN), job
- Limit: 1-100 stories (default: 30)
- Returns: Title, score, author, comments, URL
search_hn
Search across all Hacker News content.
- Query: Your search terms
- Filter by: Type, date range, author
- Sort by: relevance or date
- Uses: Algolia's HN Search API
get_story_details
Get a story with all its comments.
- Input: Story ID
- Returns: Full story + nested comment threads
- Options: Max comments, thread depth
user_analysis
Analyze a Hacker News user's profile.
- Username: Any HN user
- Returns: Karma, account age, recent submissions
- Insights: Activity patterns, top posts
hn_explain
Get explanations of HN terms.
- Terms: karma, flagged, dupe, Show HN, Ask HN, etc.
- Returns: Definition + context
Installation Options
Claude Desktop Extension (.mcpb)
Easiest method - One-click install for Claude Desktop:
- Download
hn-mcp.mcpbfrom latest release - Open Claude Desktop
- Click on the extension file to install
- Restart Claude Desktop
That's it! HN-MCP will be available immediately.
Quick Start with npx
# Claude Desktop - add to config (see Quick Start above)
npx hn-mcp
# HTTP mode for testing
HN_MCP_HTTP=true npx hn-mcp
Global Install
npm install -g hn-mcp
hn-mcp # Run in stdio mode
HN_MCP_HTTP=true hn-mcp # Run in HTTP mode
Using Docker
# Quick start - HTTP mode for API access
docker run -e HN_MCP_HTTP=true -p 3000:3000 karanb192/hn-mcp:latest
# stdio mode for development
docker run -it karanb192/hn-mcp:latest
# With docker-compose
docker-compose up
From Source
git clone https://github.com/karanb192/hn-mcp.git
cd hn-mcp
npm install
npm run build
npm link
Rate Limits
| API | Official Limit | Our Limit | Notes |
|---|---|---|---|
| HN Firebase | None β | 300/min | Self-imposed for courtesy |
| Algolia Search | None β | 300/min | Max 1000 results per query |
Why HN-MCP?
What others do wrong:
- β Scoped npm names -
@someone/hn-somethingis hard to remember - β Not published to npm - Manual installation only
- β No caching - Slow repeated requests
- β Poor documentation - Unclear how to use
What we do right:
- β
Clean package name - Just
hn-mcp - β Smart caching - 50MB LRU cache with adaptive TTLs
- β Clear documentation - You're reading it
- β TypeScript - Type-safe and maintainable
Examples
Your AI can now answer:
"What are the top posts about GPT-4 today?"
β search_hn with query="GPT-4", dateRange="last24h", sortBy="relevance"
"Show me what's trending on Hacker News"
β browse_stories with type="top", limit=10
"What are people saying about this article?"
β search_hn with the article URL to find discussions
"Analyze the user dang"
β user_analysis with username="dang"
"Get the comments from HN story 12345678"
β get_story_details with id="12345678"
Troubleshooting
Common Issues
"Command not found" error
# Ensure npm is installed
node --version
npm --version
# Try with full npx path
$(npm bin -g)/hn-mcp
Connection issues
- Hacker News may be down (check https://status.ycombinator.com)
- Firewall blocking requests
- Try restarting the MCP server
Search returns max 1000 results
- This is Algolia's hard limit
- Use date filters to narrow results
- Try more specific search queries
Environment Variables
Configure HN-MCP using environment variables. See .env.example for detailed documentation.
| Variable | Description | Default |
|---|---|---|
HN_MCP_HTTP |
Run as HTTP server instead of stdio | false |
HN_MCP_PORT |
HTTP server port | 3000 |
HN_MCP_NO_CACHE |
Disable caching for real-time data | false |
HN_MCP_RATE_LIMIT |
Override rate limit (requests/minute) | 300 |
Quick setup:
# Copy example file
cp .env.example .env
# Edit with your preferences
nano .env
Development
# Install dependencies
npm install
# Run in development
npm run dev
# Build
npm run build
# Run tests
npm run typecheck
# Deploy locally
./deploy-server.sh # Port 3000
./deploy-server.sh -p 8080 # Custom port
# Docker build
docker build -t karanb192/hn-mcp .
docker run -e HN_MCP_HTTP=true -p 3000:3000 karanb192/hn-mcp
# Docker development with hot reload
docker-compose --profile dev up
Requirements
- Node.js >= 18.0.0
- npm or yarn
- TypeScript 5.5+
Contributing
PRs welcome! See CONTRIBUTING.md for guidelines.
We keep things simple:
- Clean TypeScript code
- Smart caching
- Clear documentation
- Fast responses
Support
- π Report bugs
- π‘ Request features
- β Star on GitHub
License
MIT - Use it however you want!
Made with β€οΈ for the MCP community by the creator of reddit-mcp-buddy. No venture capital, no tracking, just a good MCP server.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.