github-wiki-mcp
MCP server for managing GitHub wiki pages programmatically, enabling create, read, update, delete, and list operations via git cloning and pushing.
README
GitHub Wiki MCP Server
MCP (Model Context Protocol) server for managing GitHub wiki pages programmatically.
Features
This MCP server exposes the following tools:
write_wiki_page- Create or update a wiki pageread_wiki_page- Read the content of a wiki pageappend_to_wiki_page- Append content to an existing pagelist_wiki_pages- List all wiki pages in the repositorydelete_wiki_page- Delete a wiki page
Installation
# Install dependencies
pnpm install
# Build the TypeScript project
pnpm build
Configuration
1. Create a GitHub Personal Access Token
- Go to GitHub → Settings → Developer settings → Personal access tokens → Tokens (classic)
- Click "Generate new token (classic)"
- Select the
reposcope (to access repository wikis) - Copy the generated token
2. Add the MCP server to Claude Desktop configuration
Edit the configuration file:
- macOS:
~/Library/Application Support/Claude/claude_desktop_config.json - Windows:
%APPDATA%\Claude\claude_desktop_config.json
Add this configuration:
{
"mcpServers": {
"github-wiki": {
"command": "node",
"args": [
"/absolute/path/to/github_wiki_mcp/dist/index.js"
]
}
}
}
Replace /absolute/path/to/github_wiki_mcp with the actual path to the project directory.
3. Restart Claude Desktop
Close and reopen Claude Desktop to load the new MCP server.
Usage
Example: Write a wiki page about architecture
You can tell Claude:
Analyze the codebase using code-analysis-context-mcp to extract
all information about the repository architecture and write
a dedicated wiki page on GitHub called Architecture.
Claude will:
- Use the
code_analysistool to get architecture information - Generate structured markdown content
- Use
write_wiki_pageto create the page on GitHub
Direct Example: Create a wiki page
Create a wiki page called "API Documentation" on the repository
myusername/myrepo with this content:
# API Documentation
## Main Endpoints
- GET /api/users
- POST /api/users
- DELETE /api/users/:id
Example: Read an existing page
Read the content of the wiki page "Architecture" from the repository
myusername/myrepo
Example: Update an existing page
Add a "Deployment" section to the wiki page "Architecture"
with deployment instructions
Tool Reference
write_wiki_page
Creates or completely overwrites a wiki page.
Parameters:
owner(string, required): GitHub username or organizationrepo(string, required): Repository nametoken(string, required): GitHub personal access tokenpageName(string, required): Page name (e.g., "Architecture")content(string, required): Markdown content of the pagecommitMessage(string, optional): Custom commit message
Output:
{
"success": true,
"page": "Architecture.md",
"url": "https://github.com/owner/repo/wiki/Architecture"
}
read_wiki_page
Reads the content of an existing wiki page.
Parameters:
owner,repo,token: Same as abovepageName(string, required): Name of the page to read
Output:
{
"success": true,
"page": "Architecture.md",
"content": "# Architecture\n\n..."
}
append_to_wiki_page
Appends content to the end of an existing page (or creates it if it doesn't exist).
Parameters:
owner,repo,token: Same as abovepageName(string, required): Page namecontent(string, required): Content to appendcommitMessage(string, optional): Commit message
list_wiki_pages
Lists all wiki pages in the repository.
Parameters:
owner,repo,token: Same as above
Output:
[
{
"name": "Architecture",
"path": "Architecture.md",
"size": 2048
},
{
"name": "API-Documentation",
"path": "API-Documentation.md",
"size": 1024
}
]
delete_wiki_page
Deletes a wiki page.
Parameters:
owner,repo,token: Same as abovepageName(string, required): Name of the page to deletecommitMessage(string, optional): Commit message
How It Works
The server uses the wiki Git repository (.wiki.git) instead of GitHub's REST API:
- Clones the wiki repository to a temporary directory
- Performs the requested operations (create/modify/delete
.mdfiles) - Commits and pushes the changes
- Cleans up the temporary directory
This approach:
- Is more reliable than REST APIs for wikis
- Supports all standard Git operations
- Has no content size limitations
- Works with private repositories (if the token has permissions)
Integration with Other MCPs
With code-analysis-context-mcp
You can combine this server with your code-analysis-context-mcp to:
- Automatically analyze the codebase
- Extract documentation, architecture, APIs
- Automatically write updated wiki pages
Example workflow:
Analyze the repository using code-analysis-context-mcp,
extract the complete architecture and create three wiki pages:
1. Architecture - overall project structure
2. API - endpoint documentation
3. Database - schema and relationships
Claude will use:
code_analysis.get_repository_architecture→ analysisgithub_wiki.write_wiki_page→ Architecture pagegithub_wiki.write_wiki_page→ API pagegithub_wiki.write_wiki_page→ Database page
Security
- Never share your GitHub token: The token has full access to repositories
- Use tokens with minimum scope: Only
repois necessary - Consider using expiring tokens: For production environments
- Don't commit the token: Ensure it's only provided at runtime
Development
# Watch mode during development
pnpm dev
# Production build
pnpm build
# Local installation for testing
pnpm link
Troubleshooting
Server doesn't connect
- Verify that the path in
claude_desktop_config.jsonis absolute and correct - Check that
pnpm buildhas been executed - Verify Claude Desktop logs
Authentication error
- Verify that the GitHub token is valid
- Check that the token has the
reposcope - Ensure the repository has wiki enabled (Settings → Wiki)
Wiki doesn't exist
GitHub automatically creates the wiki repository only when the first page is created manually. If the repository has never had a wiki:
- Go to
https://github.com/owner/repo/wiki - Click "Create the first page"
- Create a test page
- Now the MCP server will be able to access the wiki
License
MIT
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.