Introduction
MCP Confluence ADF Server
A Model Context Protocol (MCP) server for Confluence content management using Atlassian Document Format (ADF) with bidirectional Markdown conversion for easy editing.
Features
OAuth 2.0 authentication with secure token management and automatic refresh
Direct REST API integration with Confluence Cloud V2 API
ADF to Markdown bidirectional conversion for easy editing
File-based workflows with local storage in
confluence-downloads/
directoryFull CRUD operations for Confluence pages and content
User-accessible file storage with page ID prefixes to prevent overwrites
Rich content preservation (panels, tables, code blocks, mentions, emojis)
Version management with metadata tracking
Offline editing support with local Markdown files
Template system with YAML-driven documentation generation
Claude AI integration for intelligent content creation
π Complete Documentation
π View Full Documentation on GitBook
Comprehensive guides covering:
Quick Start Guide - Get up and running in minutes
Claude Template Generation - AI-powered documentation workflows
Template Process Flow - Technical deep dive
MCP Server Configuration - Advanced setup options
Confluence Content Tools - Complete tool reference
Installation
NPM Package Install (Recommended)
1. Install the package globally:
yarn global add mcp-confluence-adf
2. Add the server configuration:
Option A: Using Claude CLI (Recommended):
claude mcp add --scope user mcp-confluence-adf npx mcp-confluence-adf
Option B: Manual configuration file edit:
code ~/.config/claude/settings.json
3. (Manual option only) Add the server configuration to the "mcp"
β "servers"
section:
{
"mcp": {
"servers": {
"mcp-confluence-adf": {
"command": "npx",
"args": ["mcp-confluence-adf"]
}
}
}
}
4. Restart Claude Code
Development Install (Local)
For development or customization:
# Clone and build from source
git clone https://github.com/JeromeErasmus/mcp-confluence-adf.git
cd mcp-confluence-adf
yarn install
yarn build
Add to Claude Code MCP configuration (~/.config/claude/settings.json
):
Add this to the "mcp"
β "servers"
section:
{
"mcp": {
"servers": {
"mcp-confluence-adf": {
"command": "node",
"args": ["/absolute/path/to/mcp-confluence-adf/dist/server.js"]
}
}
}
}
Alternative Install Methods
Global install:
yarn global add mcp-confluence-adf
Quick test without install:
npx mcp-confluence-adf --help
Uninstall
To completely remove the MCP server:
1. Remove from Claude configuration:
claude mcp remove mcp-confluence-adf
2. Uninstall the package:
yarn global remove mcp-confluence-adf
How It Works
1. OAuth Authentication Setup (One Time)
You: "Set up OAuth authentication with Confluence"
Claude Code: Uses confluence_oauth_init
and confluence_oauth_complete
tools
Result: Secure OAuth 2.0 authentication with automatic token refresh for all subsequent operations
2. Download and Edit Workflow
Scenario: "Download and edit a Confluence page"
Claude Code: Uses download_page({ pageId: "123456789" })
Result:
Downloads page as Markdown with YAML frontmatter
Saves to
confluence-downloads/123456789-page-title.md
Preserves metadata for accurate re-upload
Converts ADF rich content to Markdown equivalents
Edit locally, then:
Claude Code: Uses upload_page({ filePath: "...", mode: "update" })
Result: Converts Markdown back to ADF and updates Confluence page
3. Create New Content
Scenario: "Create a new Confluence page"
Claude Code: Uses create_confluence_content
or upload_page
with mode='create'
Result: Creates new page in specified space with ADF content
4. File-Based Workflows
Local file storage with smart naming:
Files saved as
{pageId}-{safe-title}.md
Stored in
confluence-downloads/
directory (current working directory preferred)YAML frontmatter preserves page metadata
Separate
.meta.json
files track original ADF for accurate updates
MCP Tools Reference
Authentication
OAuth 2.0 Authentication (Primary Method)
OAuth 2.0 provides secure, scoped access to Confluence with automatic token refresh.
confluence_oauth_init
Initialize OAuth 2.0 authentication flow.
Input:
{
"clientId": "your-oauth-client-id",
"clientSecret": "your-oauth-client-secret",
"redirectUri": "http://localhost:9000/oauth/callback"
}
Setup Requirements:
Create an OAuth 2.0 app in Atlassian Developer Console
Configure callback URL:
http://localhost:9000/oauth/callback
(port 9000 is recommended)Required OAuth Scopes (add all of these to your Atlassian app):
read:confluence-content.all
write:confluence-content
read:content:confluence
write:content:confluence
read:space:confluence
read:page:confluence
write:page:confluence
read:confluence-content.summary
read:confluence-space.summary
search:confluence
offline_access
OAuth Flow:
# 1. Initialize OAuth flow
confluence_oauth_init({
"clientId": "your-client-id",
"clientSecret": "your-client-secret"
})
# 2. Visit the generated authorization URL in your browser
# 3. Grant permissions to the application
# 4. Complete authentication
confluence_oauth_complete({
"openBrowser": true
})
# 5. Check status
confluence_oauth_status()
confluence_oauth_complete
Complete OAuth authentication after visiting authorization URL.
Input:
{
"openBrowser": true
}
confluence_oauth_status
Check current OAuth authentication status.
confluence_oauth_clear
Clear OAuth authentication and tokens.
File-Based Workflows
confluence_download_page
Download a Confluence page as a Markdown file for local editing.
Input:
{
"pageId": "123456789",
"targetDirectory": "optional/custom/path"
}
Parameters:
pageId
: Confluence page ID (extract from page URL)targetDirectory
: Optional custom directory (defaults toconfluence-downloads/
)
File Output:
---
pageId: 123456789
title: Page Title
spaceKey: DEV
webUrl: https://company.atlassian.net/wiki/spaces/DEV/pages/123456789
---
# Page Content
> 9 **Info:** Rich content blocks are preserved as Markdown
confluence_upload_page
Upload a Markdown file to Confluence (create new or update existing).
Input:
{
"filePath": "confluence-downloads/123456789-page-title.md",
"mode": "update"
}
Create Mode Input:
{
"filePath": "new-document.md",
"mode": "create",
"spaceKey": "DEV",
"title": "New Page Title",
"parentPageId": "456789123"
}
Parameters:
filePath
: Path to Markdown filemode
: "create" or "update"spaceKey
: Required for create modetitle
: Required for create modeparentPageId
: Optional parent page for hierarchy
Core CRUD Operations
create_confluence_content
Create new Confluence pages or blog posts using ADF format.
read_confluence_content
Read content from Confluence pages in ADF format.
update_confluence_content
Update existing Confluence pages with new ADF content.
delete_confluence_content
Delete Confluence pages.
list_confluence_spaces
List all accessible Confluence spaces.
Search and Management
search_confluence_pages
Search for Confluence pages using CQL (Confluence Query Language).
get_page_versions
Get version history of a Confluence page.
manage_page_labels
Add or remove labels on Confluence pages.
File Storage System
Storage Location Priority Order
Current working directory +
/confluence-downloads
User-configured directory (if set via configuration)
Home directory +
/confluence-downloads
File Naming Convention
Format:
{pageId}-{safe-title}.md
Example:
123456789-team-onboarding-guide.md
Page ID prefix prevents filename conflicts
Metadata Preservation
YAML frontmatter in Markdown files with page metadata
Separate
.meta.json
files for upload trackingOriginal ADF stored in metadata for accurate re-upload
Permanent storage (no automatic cleanup)
Rich Content Support
ADF to Markdown Conversion
Rich Confluence content is converted to Markdown equivalents:
# ADF Panels β Markdown Blockquotes
> **Info:** Information panels
> **Warning:** Warning panels
> **Success:** Success panels
> **Note:** Note panels
# Tables β Standard Markdown Tables
| Column 1 | Column 2 |
|----------|----------|
| Data 1 | Data 2 |
# Code Blocks β Fenced Code Blocks
```javascript
function example() {
return "preserved formatting";
}
Rich Text β Markdown Formatting
Bold text, italic text, inline code
Link text @mentions and :emoji: support
## Typical Workflow
### OAuth 2.0 Authentication (Required - One-Time Setup)
```bash
# 1. Initialize OAuth (one-time setup)
confluence_oauth_init({
"clientId": "your-client-id-from-developer-console",
"clientSecret": "your-client-secret-from-developer-console"
})
# 2. Complete authentication (browser opens automatically)
confluence_oauth_complete({
"openBrowser": true
})
# 3. Verify authentication
confluence_oauth_status()
Edit Existing Page
# 1. Download page for editing
confluence_download_page({
"pageId": "123456789"
})
# β Creates confluence-downloads/123456789-page-title.md
# 2. Edit the Markdown file in your preferred editor
# 3. Upload changes back to Confluence
confluence_upload_page({
"filePath": "confluence-downloads/123456789-page-title.md"
})
Create New Page
# 1. Create local Markdown file or use existing
# 2. Upload as new page
upload_page({
"filePath": "new-document.md",
"mode": "create",
"spaceKey": "DEV",
"title": "New Team Guide"
})
Development
yarn dev # Development mode
yarn build # Build TypeScript
yarn test # Run tests
yarn clean # Clean build directory
Configuration
The system automatically handles:
File storage in appropriate directories
Content conversion between ADF and Markdown
Metadata preservation for accurate uploads
Rich content formatting preservation
OAuth 2.0 Setup
Step 1: Create OAuth 2.0 App in Atlassian Developer Console
Access Developer Console
Go to developer.atlassian.com
Select your profile icon
Choose "Developer console"
Create Your App
Select "Create app"
Give your app a descriptive name (e.g., "Confluence MCP Integration")
Configure OAuth 2.0 Authorization
Select "Authorization" in the left menu
Next to OAuth 2.0 (3LO), select "Configure"
Enter your "Callback URL" (e.g.,
http://localhost:9000/oauth/callback
)β οΈ Important: This URL must match the
redirect_uri
in your authorization requests
Click "Save changes"
Add API Permissions
Select "Permissions" in the left menu
Next to Confluence API, select "Add"
Choose these required scopes:
Required OAuth Scopes:
read:confluence-content.all
- Read all Confluence contentwrite:confluence-content
- Create and edit Confluence contentread:content:confluence
- Read content (granular scope)write:content:confluence
- Write content (granular scope)read:space:confluence
- Access spaces (granular scope)read:page:confluence
- Read pages (granular scope)write:page:confluence
- Create/edit pages (granular scope)read:confluence-content.summary
- Read content summaries (granular scope)read:confluence-space.summary
- Read space information (granular scope)search:confluence
- Search functionality (granular scope)offline_access
- Token refresh
Get Your Credentials
Go to "Settings" in the left menu
Copy your Client ID and Client Secret
Keep these credentials secure!
Step 2: Initialize OAuth in Claude Code
Start OAuth Flow
confluence_oauth_init({
"clientId": "your-client-id-from-developer-console",
"clientSecret": "your-client-secret-from-developer-console"
})
This automatically:
Starts a local callback server on an available port
Generates a secure authorization URL with PKCE security
Displays the URL to visit for authorization
Complete Authorization
confluence_oauth_complete({
"openBrowser": true
})
Step 3: Browser Authorization Flow
When you run confluence_oauth_complete
:
Browser opens to Atlassian's authorization page
Sign in to your Atlassian account
Review permissions - you'll see the scopes you configured
Click "Accept" to grant permissions to your app
Automatic redirect back to the callback server
Success confirmation displays "Authentication Successful!"
Window closes automatically
Step 4: Persistent Authentication Ready
After successful authorization:
Tokens stored securely in
~/.mcp/confluence-adf/oauth-tokens.json
(or macOS Keychain)Auto-refresh enabled - tokens refresh automatically before expiry
Survives server restarts - no need to re-authenticate
Ready for all operations - download, upload, search, CRUD
Verify Your Setup
confluence_oauth_status()
Expected output:
β
OAuth Authentication Active
π Status: Connected
π Cloud ID: [your-cloud-id]
π§ Client Configured: Yes
β‘ Ready for API calls: Yes
πΎ Token Storage: keychain (macOS Keychain) OR file (~/.mcp/confluence-adf/oauth-tokens.json)
Managing Authentication
Clear Authentication (if needed)
confluence_oauth_clear()
This is a one-time setup! Once completed, your OAuth authentication persists across all future Claude Code sessions automatically with secure token refresh.
Templates System
Overview
The MCP Confluence ADF server includes a powerful templates system that allows users and Claude to generate structured Confluence pages from YAML template definitions. Templates provide a standardized way to create consistent, high-quality documentation.
Template Structure
Templates are defined in YAML format and consist of:
Metadata - Template name, description, version, category
User Context Requirements - Variables that need to be provided
Structure Definition - The actual content structure and instructions
Example Template Structure
---
name: Simple Getting Started Guide
description: A basic getting started template for any project or service
version: 1.0.0
category: user-guide
output_type: structured_template
sections:
- introduction
- installation
- basic_usage
- troubleshooting
user_context_required:
project_name: "What is the name of your project or service?"
main_technology: "What is the main technology stack (e.g., Node.js, Python, React)?"
---
structure:
- "# Getting Started with {{project_name}}"
- type: info_panel
title: "Welcome"
content_instruction: "Create a welcoming introduction that explains what {{project_name}} does and why users should be excited to use it"
purpose: "Set a positive tone and provide project overview"
- "## Installation"
- type: code_block
title: "Quick Install"
language: "bash"
content_instruction: "Provide the simplest installation command for {{project_name}} using yarn or the most common package manager for {{main_technology}}"
purpose: "Get users up and running quickly"
Available Template Types
Content Block Types
Plain Text: Direct markdown content (headings, paragraphs)
Panels:
info_panel
,warning_panel
,success_panel
,error_panel
Code Blocks: With language specification and syntax highlighting
Expandable Sections: Collapsible content blocks
Tables: Structured data presentation
Sections: Reusable content blocks with descriptions
Template Variables
Use
{{variable_name}}
syntax for substitutionVariables defined in
user_context_required
sectionAutomatically replaced during generation
Process Flow: Templates β Confluence Pages
1. Template Selection
User Request: "Create a getting started guide for my Node.js API"
Claude Code:
Analyzes available templates in
/templates/yaml/
Selects appropriate template (e.g.,
simple-getting-started.yml
)Identifies required user context variables
2. Context Gathering
Claude Code:
Prompts user for required variables:
project_name
: "Node.js API Server"main_technology
: "Node.js with Express"
Collects additional context through conversation
3. Content Generation
Claude Code:
Processes template structure section by section
Substitutes variables:
{{project_name}}
β "Node.js API Server"Generates content based on
content_instruction
fieldsFollows
purpose
guidelines for each section
4. Markdown Creation
Generated Output (saved to test-files/
):
---
template: simple-getting-started
generated: 2024-01-15T10:30:00Z
variables:
project_name: Node.js API Server
main_technology: Node.js with Express
---
# Getting Started with Node.js API Server
> **Welcome:** This guide will help you get up and running with Node.js API Server, a powerful and flexible API solution built with Node.js and Express. You'll be building and deploying APIs in minutes!
## Prerequisites
### Requirements
Before installing Node.js API Server, ensure you have:
- Node.js v18.0.0 or higher
- yarn v1.22.0 or higher
- Git for version control
## Installation
```bash
yarn global add nodejs-api-server
Verification
Verify your installation by running:
nodejs-api-server --version
Basic Usage
First Steps
Create your first API endpoint with this simple example:
const api = require('nodejs-api-server');
api.get('/hello', (req, res) => {
res.json({ message: 'Hello, World!' });
});
api.listen(3000);
You're All Set!: Congratulations! Your Node.js API Server is now running. Visit the full documentation to learn about advanced features like authentication, middleware, and database integration.
#### 5. ADF Conversion
**Automatic Process**:
- Markdown content is automatically converted to ADF JSON format
- Rich content elements (panels, code blocks, tables) are preserved
- Saved to `test-files/converted-adf/` directory
- Ready for upload to Confluence
#### 6. Confluence Upload
**Claude Code**: Uses `confluence_upload_page` or `create_confluence_content`:
```json
{
"filePath": "test-files/generated-getting-started.md",
"mode": "create",
"spaceKey": "DOCS",
"title": "Getting Started with Node.js API Server"
}
Using Templates with Claude
For Users
Simple Request: "Create documentation for my Python web scraper using a template"
Claude Response:
Reviews available templates
Asks for required context (project name, technology stack, etc.)
Generates structured content following template guidelines
Creates both Markdown and ADF versions
Optionally uploads directly to Confluence
For Claude Code
Template Processing:
Parse YAML: Load template structure and metadata
Validate Context: Ensure all required variables are available
Process Structure: Iterate through structure array
Generate Content: Create content based on instructions and context
Apply Variables: Substitute all
{{variable}}
placeholdersOutput Format: Generate both Markdown and ADF versions
Template Development
Adding New Templates
Create YAML file in
/templates/yaml/
Define metadata and user context requirements
Structure content with clear instructions
Test with various user contexts
Generate examples in
/test-files/
Template Best Practices
Clear Instructions: Provide specific
content_instruction
for each sectionFlexible Variables: Use meaningful variable names with helpful descriptions
Rich Content: Leverage panels, code blocks, and expandables appropriately
User-Focused: Design structure around user needs and workflows
Content Update Flow
Template β Markdown β ADF β Confluence
YAML Template
β (Claude processes structure)
Markdown File (test-files/)
β (Automatic ADF conversion)
ADF JSON (test-files/converted-adf/)
β (Upload via MCP tools)
Confluence Page
Iterative Updates
Modify Template: Update YAML structure or instructions
Regenerate Content: Claude processes updated template
Review Changes: Compare new Markdown output
Update Confluence: Upload revised content to existing pages
This templates system enables rapid, consistent documentation creation while maintaining quality and structure across all generated content.
License
MIT
Important References
https://developer.atlassian.com/cloud/jira/platform/jira-entity-properties/
Last updated