Obsidian GitHub MCP
A Model Context Protocol server that connects AI assistants to GitHub repositories containing Obsidian vaults, enabling them to read, search, and analyze notes and documentation stored on GitHub.
Tools
getFileContents
Retrieve the contents of a specific note, document, or file from your Obsidian vault stored in GitHub (my-organization/obsidian-vault). Perfect for accessing your knowledge base content.
searchFiles
Search for notes, documents, and files within your Obsidian vault on GitHub (my-organization/obsidian-vault). Find specific knowledge base content using GitHub's powerful search syntax.
searchIssues
Search for issues and discussions in your Obsidian vault repository (my-organization/obsidian-vault). Great for tracking tasks, project management, and collaborative knowledge work.
getCommitHistory
Track the evolution of your Obsidian vault knowledge base by retrieving commit history from GitHub (my-organization/obsidian-vault). See how your notes and ideas have developed over time with detailed diffs.
README
Obsidian GitHub MCP
A Model Context Protocol (MCP) server that connects AI assistants to GitHub repositories containing Obsidian vaults. This server enables seamless integration with your knowledge base stored on GitHub, allowing AI assistants to read, search, and analyze your Obsidian notes and documentation.
Why This Tool?
Many Obsidian users store their vaults in GitHub for backup, versioning, and collaboration. This MCP server bridges the gap between your GitHub-hosted Obsidian vault and AI assistants, enabling:
- Knowledge Base Access: Retrieve specific notes and documents from your Obsidian vault
- Intelligent Search: Find relevant content across your entire knowledge base
- Evolution Tracking: See how your ideas and notes have developed over time
- Task Integration: Connect with issues and project management workflows
Features
- GitHub Repository Access: Connect to any GitHub repository containing your Obsidian vault
- Type-Safe Implementation: Written in TypeScript with comprehensive type definitions
- Input Validation: Robust validation for all API inputs using Zod schemas
- Error Handling: Graceful error handling with informative messages
- MCP Integration: Full compatibility with Claude, Cursor, Windsurf, Cline, and other MCP hosts
Available Tools
Knowledge Base Access
- getFileContents: Retrieve the contents of specific notes, documents, or files from your Obsidian vault
- searchFiles: Enhanced search with multiple modes:
filename: Find files by exact filename (perfect for "OKR 2025" type searches)path: Search anywhere in file pathscontent: Search within file contentsall: Comprehensive search across filenames, paths, and content
Project Management Integration
- searchIssues: Search for issues and discussions related to your knowledge base projects
- getCommitHistory: Track how your knowledge base has evolved over time with detailed commit history and diffs
Use Cases
For Knowledge Workers
- Research Assistant: AI can access your research notes and reference materials
- Writing Support: Pull relevant background information from your knowledge base
- Idea Development: Track how concepts have evolved across your notes
For Developers
- Documentation Access: Retrieve project documentation and technical notes
- Learning Journals: Access your learning notes and code examples
- Project Planning: Integrate with GitHub issues for comprehensive project management
For Students & Academics
- Study Materials: Access lecture notes and study guides
- Research Papers: Retrieve research notes and citations
- Collaboration: Work with shared knowledge bases stored in GitHub
Installation
Using Smithery (Recommended)
The easiest way to install Obsidian GitHub MCP is using Smithery:
# For Claude Desktop
npx -y @smithery/cli install @Hint-Services/obsidian-github-mcp --client claude
# For Cursor
npx -y @smithery/cli install @Hint-Services/obsidian-github-mcp --client cursor
# For Windsurf
npx -y @smithery/cli install @Hint-Services/obsidian-github-mcp --client windsurf
# For Cline
npx -y @smithery/cli install @Hint-Services/obsidian-github-mcp --client cline
Manual Installation
npm install obsidian-github-mcp
Configuration
Add the server to your MCP settings file with the following configuration:
{
"mcpServers": {
"obsidianGithub": {
"command": "npx",
"args": ["-y", "obsidian-github-mcp"],
"env": {
"GITHUB_TOKEN": "your-github-token",
"GITHUB_OWNER": "your-github-username",
"GITHUB_REPO": "your-obsidian-vault-repo"
}
}
}
}
Required Environment Variables
GITHUB_TOKEN: Your GitHub personal access token (create one here)GITHUB_OWNER: The owner/organization of the GitHub repositoryGITHUB_REPO: The name of the repository containing your Obsidian vault
GitHub Token Permissions
Your GitHub token needs the following permissions:
repo(for private repositories) orpublic_repo(for public repositories)read:org(if accessing organization repositories)
Example Workflows
Accessing Your Daily Notes
{
"tool": "getFileContents",
"arguments": {
"filePath": "Daily Notes/2024-01-15.md"
}
}
Finding Files by Name (Perfect for "OKR 2025" example!)
{
"tool": "searchFiles",
"arguments": {
"query": "OKR 2025",
"searchIn": "filename"
}
}
Finding Files by Path
{
"tool": "searchFiles",
"arguments": {
"query": "Daily Notes",
"searchIn": "path"
}
}
Finding Research on a Topic (Content Search)
{
"tool": "searchFiles",
"arguments": {
"query": "machine learning algorithms",
"searchIn": "content",
"perPage": 10
}
}
Comprehensive Search (Filename, Path, and Content)
{
"tool": "searchFiles",
"arguments": {
"query": "project planning",
"searchIn": "all"
}
}
Advanced GitHub Search Syntax
{
"tool": "searchFiles",
"arguments": {
"query": "path:*.md extension:md",
"searchIn": "content"
}
}
Tracking Knowledge Evolution
{
"tool": "getCommitHistory",
"arguments": {
"days": 30,
"includeDiffs": true,
"maxCommits": 10
}
}
Search Tips & Troubleshooting
Can't Find Your File by Name?
Problem: Searching for "OKR 2025" doesn't find your file named "OKR 2025.md"
Solution: Use the searchIn: "filename" parameter:
{
"tool": "searchFiles",
"arguments": {
"query": "OKR 2025",
"searchIn": "filename"
}
}
Advanced Search Techniques
-
Exact Phrases: Use quotes for multi-word searches
{ "query": "\"project planning 2025\"", "searchIn": "content" } -
File Extensions: Find specific file types
{ "query": "path:*.md", "searchIn": "content" } -
Directory Specific: Search within folders
{ "query": "path:\"Daily Notes/\"", "searchIn": "content" }
Project Structure
obsidian-github-mcp/
├── src/
│ ├── index.ts # Main MCP server entry point
│ └── github/ # GitHub API integration
│ ├── client.ts # GitHub client implementation
│ └── types.ts # TypeScript type definitions
├── docs/ # Documentation
├── package.json # Project configuration
└── tsconfig.json # TypeScript configuration
For Developers
If you're interested in contributing to this project or developing your own tools with this server, please see the Development Guide.
Development Commands
pnpm install- Install dependenciespnpm run build- Build the projectpnpm run dev- Run in development mode with inspectorpnpm run inspector- Launch MCP inspector for testing
Migration from mcp-private-github-search
If you're migrating from the older mcp-private-github-search package:
-
Update your package name in configuration:
{ "mcpServers": { "obsidianGithub": { "command": "npx", "args": ["-y", "obsidian-github-mcp"] } } } -
The functionality remains the same - all existing tools work identically
-
Consider the new Obsidian-focused use cases and workflows
Learn More
For further information on the MCP ecosystem, refer to:
- Model Context Protocol Documentation: Detailed coverage of MCP architecture and design principles
- Smithery - MCP Server Registry: Guidelines for publishing MCP servers
- MCP TypeScript SDK Documentation: Comprehensive TypeScript SDK documentation
- Obsidian: The knowledge management app that inspired this tool
About Hint Services
"The future is already here, it's just unevenly distributed"
— William Gibson, Author
Hint Services is a boutique consultancy with a mission to develop and expand how user interfaces leverage artificial intelligence technology. We architect ambition at the intersection of AI and User Experience, founded and led by Ben Hofferber.
We offer specialized AI workshops for design teams looking to embrace AI tools without becoming developers. Learn more about our training and workshops.
推荐服务器
Baidu Map
百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。
Playwright MCP Server
一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。
Magic Component Platform (MCP)
一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。
Audiense Insights MCP Server
通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。
VeyraX
一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。
graphlit-mcp-server
模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。
Kagi MCP Server
一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。
e2b-mcp-server
使用 MCP 通过 e2b 运行代码。
Neon MCP Server
用于与 Neon 管理 API 和数据库交互的 MCP 服务器
Exa MCP Server
模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。