mcp-jira-confluence-corp
A Model Context Protocol server for Atlassian Jira and Confluence that bypasses corporate proxies and self-signed certificates, enabling read/write operations on issues, projects, pages, and spaces using Personal Access Tokens.
README
mcp-jira-confluence-corp
A Model Context Protocol server for Atlassian Jira and Confluence, designed for corporate networks. It transparently bypasses system HTTP proxies for internal domains, handles self-signed certificates, and supports Personal Access Token (PAT) authentication.
Why this package exists
Generic MCP servers like mcp-atlassian work well against Atlassian Cloud but
struggle inside many corporate environments where:
- A global
HTTP_PROXYorHTTPS_PROXY(typically an SSH tunnel for a cloud API) silently intercepts on-prem traffic and causes timeouts. - Internal Jira and Confluence instances use self-signed TLS certificates.
- The only available credential is a Personal Access Token rather than a username/password pair.
mcp-jira-confluence-corp addresses all three by:
- Clearing
HTTP_PROXY-style environment variables on client construction. - Listing internal domains that should bypass any proxy (via the
MCP_BYPASS_DOMAINSenvironment variable orProxyConfig.bypass_domains). - Disabling SSL verification by default (configurable via
verify_ssl). - Accepting PATs through
JIRA_PERSONAL_TOKEN/CONFLUENCE_PERSONAL_TOKEN.
Installation
pip install mcp-jira-confluence-corp
Or run it without installing using uvx:
uvx mcp-jira-confluence-corp
Configuration
The server is configured through environment variables:
| Variable | Description |
|---|---|
JIRA_URL |
Base URL of your Jira instance |
JIRA_PERSONAL_TOKEN |
Personal Access Token for Jira |
JIRA_USERNAME / JIRA_TOKEN |
Optional Basic Auth pair (alternative to PAT) |
CONFLUENCE_URL |
Base URL of your Confluence instance |
CONFLUENCE_PERSONAL_TOKEN |
Personal Access Token for Confluence |
MCP_BYPASS_DOMAINS |
Comma-separated list of internal domains to bypass any proxy. Supports *.example.com wildcards. |
MCP client configuration
{
"mcpServers": {
"jira-confluence": {
"command": "uvx",
"args": ["mcp-jira-confluence-corp"],
"env": {
"JIRA_URL": "https://jira.example.com",
"JIRA_PERSONAL_TOKEN": "<your-token>",
"CONFLUENCE_URL": "https://confluence.example.com",
"CONFLUENCE_PERSONAL_TOKEN": "<your-token>",
"MCP_BYPASS_DOMAINS": "*.example.com,internal.corp",
"HTTP_PROXY": "",
"HTTPS_PROXY": ""
}
}
}
}
Available tools
Jira (read-only)
| Tool | Description |
|---|---|
jira_get_issue |
Get a Jira issue by key |
jira_search_issues |
Search issues using JQL with pagination |
jira_get_issue_comments |
List comments on an issue |
jira_get_issue_transitions |
List available workflow transitions |
jira_get_issue_changelog |
Get issue history (status, field changes) |
jira_list_projects |
List accessible projects |
jira_get_project |
Get details of a specific project |
jira_get_user |
Get a user profile |
Jira (write)
| Tool | Description |
|---|---|
jira_create_issue |
Create a new issue |
jira_update_issue |
Update fields of an existing issue |
jira_add_comment |
Add a comment to an issue |
jira_transition_issue |
Move an issue through its workflow |
jira_assign_issue |
Assign or unassign an issue |
Confluence (read-only)
| Tool | Description |
|---|---|
confluence_get_page |
Get a page by ID |
confluence_get_page_by_title |
Get a page by title and space |
confluence_search |
Search using CQL |
confluence_get_page_children |
List child pages |
confluence_get_page_comments |
List page comments |
confluence_get_page_labels |
List labels applied to a page |
confluence_list_spaces |
List Confluence spaces |
Confluence (write)
| Tool | Description |
|---|---|
confluence_create_page |
Create a new page |
confluence_update_page |
Update an existing page |
confluence_add_comment |
Add a comment to a page |
confluence_add_label |
Add a label to a page |
confluence_remove_label |
Remove a label from a page |
All tools support both markdown (default) and json response formats for
human-readability vs. programmatic consumption.
Programmatic usage
JiraConfluenceClient is a thin wrapper around
atlassian-python-api and is
fully usable outside of the MCP server.
from mcp_jira_confluence import JiraConfluenceClient
client = JiraConfluenceClient()
issue = client.get_issue("PROJ-123")
print(issue["fields"]["summary"])
page = client.get_page("123456")
print(page["title"])
client.update_page(
page_id="123456",
title="Release notes",
body="<p>Updated content in Confluence Storage Format.</p>",
)
Customizing proxy bypass
from mcp_jira_confluence import JiraConfluenceClient, ProxyConfig
proxy_config = ProxyConfig(
bypass_domains=["*.example.com", "internal.corp"],
verify_ssl=False,
)
client = JiraConfluenceClient(proxy_config=proxy_config)
Development
git clone https://github.com/mshegolev/mcp-jira-confluence-corp.git
cd mcp-jira-confluence-corp
pip install -e ".[dev]"
pytest tests/
ruff check src/
black --check src/
Releasing
This project uses PyPI Trusted Publishing, so no API tokens are stored in GitHub.
- Bump the version in
pyproject.toml. - Update
CHANGELOG.md. - Tag the release:
git tag v0.1.1 && git push --tags. - Create a GitHub release — the publish workflow runs automatically.
License
Author
Mikhail Shegolev — mshegolev@gmail.com
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
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.
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.