Private GitHub Search

Private GitHub Search

hint-services

Connects AI assistants to private GitHub repositories containing Obsidian vaults for reading notes, searching content, and tracking changes. Requires GitHub authentication to access your knowledge base.

Provides authenticated access to a specific private GitHub repository for file content retrieval, code search, issue search, and detailed commit history with file diffs.

8318 views9Local (stdio)

What it does

  • Retrieve specific notes and files from Obsidian vaults
  • Search across filenames, paths, and content
  • Track note evolution through commit history
  • Browse issues and project management workflows
  • Access file diffs and detailed change tracking

Best for

Obsidian users with GitHub-hosted vaultsKnowledge workers tracking idea evolutionTeams collaborating on documentation
Requires GitHub authenticationType-safe TypeScript implementationMultiple search modes

About Private GitHub Search

Private GitHub Search is a community-built MCP server published by hint-services that provides AI assistants with tools and capabilities via the Model Context Protocol. Private GitHub Search gives secure, authenticated access to private repositories for code, file, commit, and issue searc It is categorized under productivity.

How to install

You can install Private GitHub Search in your AI client of choice. Use the install panel on this page to get one-click setup for Cursor, Claude Desktop, VS Code, and other MCP-compatible clients. This server runs locally on your machine via the stdio transport.

License

Private GitHub Search is released under the MIT license. This is a permissive open-source license, meaning you can freely use, modify, and distribute the software.

smithery badge npm version

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 paths
    • content: Search within file contents
    • all: 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 repository
  • GITHUB_REPO: The name of the repository containing your Obsidian vault

GitHub Token Permissions

Your GitHub token needs the following permissions:

  • repo (for private repositories) or public_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

  1. Exact Phrases: Use quotes for multi-word searches

    {
      "query": "\"project planning 2025\"",
      "searchIn": "content"
    }
    
  2. File Extensions: Find specific file types

    {
      "query": "path:*.md",
      "searchIn": "content"
    }
    
  3. 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 dependencies
  • pnpm run build - Build the project
  • pnpm run dev - Run in development mode with inspector
  • pnpm 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:

  1. Update your package name in configuration:

    {
      "mcpServers": {
        "obsidianGithub": {
          "command": "npx",
          "args": ["-y", "obsidian-github-mcp"]
        }
      }
    }
    
  2. The functionality remains the same - all existing tools work identically

  3. Consider the new Obsidian-focused use cases and workflows

Learn More

For further information on the MCP ecosystem, refer to:

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.

Alternatives

Related Skills

Browse all skills
context7

Search GitHub issues, pull requests, and discussions across any repository. Activates when researching external dependencies (whisper.cpp, NAudio), looking for similar bugs, or finding implementation examples.

58
skill-installer

Install Codex skills into $CODEX_HOME/skills from a curated list or a GitHub repo path. Use when a user asks to list installable skills, install a curated skill, or install a skill from another repo (including private repos).

26
smithery-ai-cli

Find, connect, and use MCP tools and skills via the Smithery CLI. Use when the user searches for new tools or skills, wants to discover integrations, connect to an MCP, install a skill, or wants to interact with an external service (email, Slack, Discord, GitHub, Jira, Notion, databases, cloud APIs, monitoring, etc.).

6
exa-web-search-free

Free AI search via Exa MCP. Web search for news/info, code search for docs/examples from GitHub/StackOverflow, company research for business intel. No API key needed.

5
skill-hub

OpenClaw skill discovery, security vetting & install. Searches 3000+ curated skills from ClawHub registry and awesome-openclaw-skills catalog. Scores credibility, detects prompt injection & malicious patterns, manages installations. Quick-checks GitHub for new skills.

5
librarian

Multi-repository codebase exploration. Research library internals, find code patterns, understand architecture, compare implementations across GitHub/npm/PyPI/crates. Use when needing deep understanding of how libraries work, finding implementations across open source, or exploring remote repository structure.

3