hive-mcp
Integrates Jira and Sourcegraph, enabling LLMs to retrieve and comment on Jira issues and perform code searches using Sourcegraph.
README
Hive MCP Server
A Model Context Protocol (MCP) server that provides integrations for Jira and Sourcegraph. This allows LLMs to interact with Jira issues and search code across repositories using Sourcegraph.
Package name: hive-mcp
Tool prefix: Service name (e.g., jira_*, sourcegraph_*)
Full tool names in LLM: mcp__hive-mcp__jira_get_issue etc.
Features
Jira Integration
- Get Issue: Retrieve detailed information about Jira issues
- Download Attachments: Download attachments from Jira issues
- Add Comments: Post comments to Jira issues
Sourcegraph Integration
- Code Search: Search code across repositories with powerful query operators (GraphQL)
- Deep Search: AI-powered conversational code search that understands natural language questions (REST API v6.7+)
Installation
Prerequisites
- Node.js 18 or higher
- Jira Server/Data Center instance with API access
- Sourcegraph instance with API access
- GitHub account with access to the @ocuco organization
Install from GitHub Packages
This package is published as a private package on GitHub Packages. To install it, you need to authenticate with GitHub first.
1. Create a GitHub Personal Access Token (PAT)
- Go to GitHub Settings > Developer Settings > Personal Access Tokens > Tokens (classic)
- Click "Generate new token" > "Generate new token (classic)"
- Give it a descriptive name (e.g., "NPM Package Access")
- Select the following scopes:
read:packages- Download packages from GitHub Package Registrywrite:packages- Upload packages to GitHub Package Registry (only needed for publishing)
- Click "Generate token" and copy the token
2. Configure NPM to use GitHub Packages
Create or edit your ~/.npmrc file (in your home directory) and add:
@ocuco:registry=https://npm.pkg.github.com
//npm.pkg.github.com/:_authToken=YOUR_GITHUB_TOKEN
Replace YOUR_GITHUB_TOKEN with the token you created in step 1.
Note: On Windows, your home directory is %USERPROFILE% (usually C:\Users\YourUsername)
3. Install the package
npm install -g @ocuco/hive-mcp
Install from Source
git clone https://github.com/ocuco/hive-mcp.git
cd hive-mcp
npm install
npm run build
npm link
Configuration
Create a .env file in your project root or set environment variables:
# Jira Configuration (On-Premise Server/Data Center)
JIRA_BASE_URL=https://jira.your-company.com
JIRA_API_TOKEN=your_personal_access_token
# Sourcegraph Configuration
SOURCEGRAPH_URL=https://sourcegraph.company.com
SOURCEGRAPH_TOKEN=your_sourcegraph_token
Getting API Credentials
Jira Personal Access Token (PAT)
For Jira Server/Data Center on-premise installations:
- Log in to your Jira instance
- Navigate to your Profile → Personal Access Tokens
- Click Create token
- Give it a name (e.g., "MCP Server Access")
- Set expiration date (optional, recommended for security)
- Click Create and copy the token
- Use this token as
JIRA_API_TOKEN
Important Notes:
- Personal Access Tokens are available in Jira 8.14 and later
- For older versions, contact your Jira administrator for API access options
- Keep your token secure and never commit it to version control
- The token is used with Bearer authentication
- Self-signed SSL certificates are automatically handled
Sourcegraph Token
- Go to your Sourcegraph instance
- Navigate to Settings > Access tokens
- Create a new access token
- Copy the token and use it as
SOURCEGRAPH_TOKEN
Usage with Claude Desktop
Add to your Claude Desktop configuration file:
MacOS: ~/Library/Application Support/Claude/claude_desktop_config.json
Windows: %APPDATA%\Claude\claude_desktop_config.json
{
"mcpServers": {
"hive-mcp": {
"command": "node",
"args": ["/path/to/hive-mcp/dist/index.js"],
"env": {
"JIRA_BASE_URL": "https://jira.your-company.com",
"JIRA_API_TOKEN": "your_personal_access_token",
"SOURCEGRAPH_URL": "https://sourcegraph.company.com",
"SOURCEGRAPH_TOKEN": "your_sourcegraph_token"
}
}
}
}
Or if installed globally from GitHub Packages:
{
"mcpServers": {
"hive-mcp": {
"command": "hive-mcp",
"env": {
"JIRA_BASE_URL": "https://jira.your-company.com",
"JIRA_API_TOKEN": "your_personal_access_token",
"SOURCEGRAPH_URL": "https://sourcegraph.company.com",
"SOURCEGRAPH_TOKEN": "your_sourcegraph_token"
}
}
}
}
Note: After installing from GitHub Packages with npm install -g @ocuco/hive-mcp, the command name remains hive-mcp (defined in package.json bin field).
Available Tools & Resources
Tools
All tools are prefixed with their service name for easy identification in LLM tool lists.
Full name format in LLM: mcp__hive-mcp__<tool_name>
Jira Tools
jira_get_issue
Get detailed information about a Jira issue.
Parameters:
issueIdOrKey(string): The issue key (e.g., "PROJ-123") or ID
Example:
{
"issueIdOrKey": "PROJ-123"
}
jira_get_comments
Get all comments from a Jira issue. Returns comment history with authors and timestamps.
Parameters:
issueIdOrKey(string): The issue key (e.g., "PROJ-123") or ID
Returns:
- Total comment count
- Array of comments with:
- Author name and email
- Created and updated timestamps
- Comment body (Atlassian Document Format)
Example:
{
"issueIdOrKey": "PROJ-123"
}
jira_add_comment
Add a comment to a Jira issue.
Parameters:
issueIdOrKey(string): The issue key (e.g., "PROJ-123") or IDcomment(string): The comment text to add
Sourcegraph Tools
sourcegraph_search_code
Search code across repositories.
Parameters:
query(string): Search query with optional operatorsrepo:owner/name- Filter by repositoryfile:path- Filter by file pathlang:python- Filter by language- And more...
Example:
{
"query": "function handleRequest repo:myorg/myrepo lang:typescript"
}
sourcegraph_deep_search
AI-powered Deep Search using natural language questions. This feature creates a conversation with Sourcegraph's AI agent (requires v6.7+).
Parameters:
question(string): Natural language question about your codebasetimeout_seconds(number, optional): Max wait time for answer (default: 60)
Example:
{
"question": "How does authentication work in this codebase?"
}
Response includes:
- AI-generated answer
- Relevant source code references
- Suggested follow-up questions
- Conversation ID for follow-ups
- Shareable URL
Note: Deep Search is async and may take 10-60 seconds. It uses credits/quota on Sourcegraph Enterprise.
Resources
MCP Resources allow LLMs to read Jira attachments like local files. The server handles caching and download automatically.
Resource URI Format:
jira://issues/{issueKey}/attachments
List all attachments for a specific Jira issue.
Example:
jira://issues/PROJ-123/attachments
Returns:
- List of all attachments with metadata
- Each attachment includes its resource URI for direct access
jira://attachments/{attachmentId}
Read specific attachment content.
Example:
jira://attachments/10041
Behavior:
- Images <500KB: Returns image blob (viewable directly)
- Files <500KB: Returns base64 content
- Files >500KB: Returns metadata + warning
- Automatic caching: Small files cached for 5 minutes
Advantages:
- ✅ LLM reads attachments like local files
- ✅ No repeated downloads (smart caching)
- ✅ No authentication errors (handled by MCP)
- ✅ Automatic size management
Usage in Claude:
"Read jira://attachments/10041"
"Show me all attachments from PROJ-123"
Development
# Install dependencies
npm install
# Build
npm run build
# Development mode (watch for changes)
npm run dev
# Run the server
npm start
Publishing to GitHub Packages
Note: Only maintainers with write access to the @ocuco organization can publish.
Prerequisites for Publishing
- Create a GitHub Personal Access Token with
write:packagesscope (see Installation section) - Ensure your local
~/.npmrchas the authentication configured - Make sure you're logged in to npm:
npm whoami --registry=https://npm.pkg.github.com
Publishing Steps
-
Update version (choose one):
npm version patch # 1.0.0 -> 1.0.1 npm version minor # 1.0.0 -> 1.1.0 npm version major # 1.0.0 -> 2.0.0 -
Build the project:
npm run build -
Publish to GitHub Packages:
npm publish -
Push changes and tags:
git push git push --tags
Package Visibility
The package is set as private ("access": "restricted" in publishConfig). Only members of the @ocuco organization with proper permissions can:
- View the package
- Download and install the package
- Publish new versions (with write access)
To manage package access:
- Go to the package page on GitHub
- Find the
hive-mcppackage - Go to "Package settings" > "Manage Actions access" to configure permissions
Architecture
hive-mcp/
├── src/
│ ├── index.ts # MCP server entry point
│ ├── config.ts # Environment configuration
│ ├── types.ts # Shared types
│ ├── jira/
│ │ ├── client.ts # Jira REST API client
│ │ ├── tools.ts # Jira MCP tools
│ │ └── types.ts # Jira types
│ └── sourcegraph/
│ ├── client.ts # Sourcegraph GraphQL client
│ ├── tools.ts # Sourcegraph MCP tools
│ └── types.ts # Sourcegraph types
└── dist/ # Compiled output
License
MIT
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
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.