Skip to content

MCP सर्वर

Repomix Model Context Protocol (MCP) का समर्थन करता है, जो AI असिस्टेंट्स को आपके कोडबेस के साथ सीधे इंटरैक्ट करने की अनुमति देता है। जब MCP सर्वर के रूप में चलाया जाता है, तो Repomix ऐसे टूल्स प्रदान करता है जो AI असिस्टेंट्स को मैन्युअल फ़ाइल तैयारी की आवश्यकता के बिना विश्लेषण के लिए स्थानीय या रिमोट रिपॉजिटरी को पैकेज करने की अनुमति देते हैं।

NOTE

यह एक प्रयोगात्मक सुविधा है जिसे हम उपयोगकर्ता फीडबैक और वास्तविक-जगत के उपयोग के आधार पर सक्रिय रूप से सुधारेंगे

Repomix को MCP सर्वर के रूप में चलाना

Repomix को MCP सर्वर के रूप में चलाने के लिए, --mcp फ्लैग का उपयोग करें:

bash
repomix --mcp

यह Repomix को MCP सर्वर मोड में शुरू करता है, इसे Model Context Protocol का समर्थन करने वाले AI असिस्टेंट्स के लिए उपलब्ध बनाता है।

MCP सर्वर कॉन्फ़िगरेशन

Claude जैसे AI असिस्टेंट्स के साथ Repomix को MCP सर्वर के रूप में उपयोग करने के लिए, आपको MCP सेटिंग्स कॉन्फ़िगर करनी होंगी:

VS Code के लिए

आप निम्नलिखित तरीकों में से एक का उपयोग करके VS Code में Repomix MCP सर्वर इंस्टॉल कर सकते हैं:

  1. इंस्टॉलेशन बैज का उपयोग करके:

Install in VS Code
Install in VS Code Insiders

  1. कमांड लाइन का उपयोग करके:
bash
code --add-mcp '{"name":"repomix","command":"npx","args":["-y","repomix","--mcp"]}'

VS Code Insiders के लिए:

bash
code-insiders --add-mcp '{"name":"repomix","command":"npx","args":["-y","repomix","--mcp"]}'

Cline (VS Code एक्सटेंशन) के लिए

cline_mcp_settings.json फ़ाइल को संपादित करें:

json
{
  "mcpServers": {
    "repomix": {
      "command": "npx",
      "args": [
        "-y",
        "repomix",
        "--mcp"
      ]
    }
  }
}

Cursor के लिए

Cursor में, Cursor Settings > MCP > + Add new global MCP server से एक नया MCP सर्वर जोड़ें, जो Cline के समान कॉन्फ़िगरेशन के साथ हो।

Claude Desktop के लिए

claude_desktop_config.json फ़ाइल को Cline के समान कॉन्फ़िगरेशन के साथ संपादित करें।

Claude Code के लिए

Claude Code में Repomix को MCP सर्वर के रूप में कॉन्फ़िगर करने के लिए, निम्नलिखित कमांड का उपयोग करें:

bash
claude mcp add repomix -- npx -y repomix --mcp

वैकल्पिक रूप से, आप अधिक सुविधाजनक अनुभव के लिए आधिकारिक Repomix प्लगइन्स का उपयोग कर सकते हैं। प्लगइन्स प्राकृतिक भाषा कमांड और आसान सेटअप प्रदान करते हैं। विवरण के लिए Claude Code प्लगइन्स दस्तावेज़ीकरण देखें।

npx के बजाय Docker का उपयोग करना

npx का उपयोग करने के बजाय, आप Repomix को MCP सर्वर के रूप में चलाने के लिए Docker का उपयोग कर सकते हैं:

json
{
  "mcpServers": {
    "repomix-docker": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "ghcr.io/yamadashy/repomix",
        "--mcp"
      ]
    }
  }
}

उपलब्ध MCP टूल्स

जब MCP सर्वर के रूप में चलाया जाता है, तो Repomix निम्नलिखित टूल्स प्रदान करता है:

pack_codebase

यह टूल स्थानीय कोड डायरेक्टरी को AI विश्लेषण के लिए XML फ़ाइल में पैकेज करता है। यह कोडबेस संरचना का विश्लेषण करता है, प्रासंगिक कोड सामग्री निकालता है, और मेट्रिक्स, फ़ाइल ट्री, और फॉर्मेटेड कोड सामग्री सहित एक व्यापक रिपोर्ट जेनरेट करता है।

पैरामीटर:

पैरामीटरआवश्यकडिफ़ॉल्टविवरण
directoryहाँपैकेज करने के लिए डायरेक्टरी का पूर्ण पथ
compressनहींfalseइम्प्लीमेंटेशन विवरण हटाते समय आवश्यक कोड हस्ताक्षर और संरचना निकालने के लिए Tree-sitter संपीड़न सक्षम करें। सिमेंटिक अर्थ संरक्षित रखते हुए टोकन उपयोग को ~70% कम करता है। आमतौर पर आवश्यक नहीं क्योंकि grep_repomix_output वृद्धिशील सामग्री पुनर्प्राप्ति की अनुमति देता है।
includePatternsनहींfast-glob पैटर्न का उपयोग करके शामिल करने के लिए फ़ाइलें। कॉमा से अलग (जैसे "**/*.{js,ts}", "src/**,docs/**")
ignorePatternsनहींfast-glob पैटर्न का उपयोग करके बाहर करने के लिए अतिरिक्त फ़ाइलें। कॉमा से अलग (जैसे "test/**,*.spec.js")। .gitignore और बिल्ट-इन एक्सक्लूज़न को पूरक करते हैं।
topFilesLengthनहीं10मेट्रिक्स सारांश में दिखाने के लिए आकार के अनुसार सबसे बड़ी फ़ाइलों की संख्या
styleनहींxmlआउटपुट फॉर्मेट स्टाइल: xml, markdown, json, या plain

उदाहरण:

json
{
  "directory": "/path/to/your/project",
  "compress": false,
  "includePatterns": "src/**/*.ts,**/*.md",
  "ignorePatterns": "**/*.log,tmp/",
  "topFilesLength": 10
}

pack_remote_repository

यह टूल GitHub रिपॉजिटरी को fetch, clone और AI विश्लेषण के लिए XML फ़ाइल में पैकेज करता है। यह स्वचालित रूप से रिमोट रिपॉजिटरी को clone करता है, इसकी संरचना का विश्लेषण करता है, और एक व्यापक रिपोर्ट जेनरेट करता है।

पैरामीटर:

पैरामीटरआवश्यकडिफ़ॉल्टविवरण
remoteहाँGitHub रिपॉजिटरी URL या user/repo फॉर्मेट (जैसे "yamadashy/repomix", "https://github.com/user/repo", या "https://github.com/user/repo/tree/branch")
compressनहींfalseइम्प्लीमेंटेशन विवरण हटाते समय आवश्यक कोड हस्ताक्षर और संरचना निकालने के लिए Tree-sitter संपीड़न सक्षम करें। सिमेंटिक अर्थ संरक्षित रखते हुए टोकन उपयोग को ~70% कम करता है। आमतौर पर आवश्यक नहीं क्योंकि grep_repomix_output वृद्धिशील सामग्री पुनर्प्राप्ति की अनुमति देता है।
includePatternsनहींfast-glob पैटर्न का उपयोग करके शामिल करने के लिए फ़ाइलें। कॉमा से अलग (जैसे "**/*.{js,ts}", "src/**,docs/**")
ignorePatternsनहींfast-glob पैटर्न का उपयोग करके बाहर करने के लिए अतिरिक्त फ़ाइलें। कॉमा से अलग (जैसे "test/**,*.spec.js")। .gitignore और बिल्ट-इन एक्सक्लूज़न को पूरक करते हैं।
topFilesLengthनहीं10मेट्रिक्स सारांश में दिखाने के लिए आकार के अनुसार सबसे बड़ी फ़ाइलों की संख्या
styleनहींxmlआउटपुट फॉर्मेट स्टाइल: xml, markdown, json, या plain

उदाहरण:

json
{
  "remote": "yamadashy/repomix",
  "compress": false,
  "includePatterns": "src/**/*.ts,**/*.md",
  "ignorePatterns": "**/*.log,tmp/",
  "topFilesLength": 10
}

read_repomix_output

यह टूल Repomix द्वारा जेनरेट की गई आउटपुट फ़ाइल की सामग्री पढ़ता है। बड़ी फ़ाइलों के लिए लाइन रेंज स्पेसिफिकेशन के साथ आंशिक पढ़ने का समर्थन करता है। यह टूल उन वातावरणों के लिए डिज़ाइन किया गया है जहाँ प्रत्यक्ष फ़ाइल सिस्टम पहुंच सीमित है।

पैरामीटर:

पैरामीटरआवश्यकडिफ़ॉल्टविवरण
outputIdहाँपढ़ने के लिए Repomix आउटपुट फ़ाइल की ID
startLineनहींफ़ाइल की शुरुआतशुरुआती लाइन नंबर (1-आधारित, समावेशी)
endLineनहींफ़ाइल का अंतअंतिम लाइन नंबर (1-आधारित, समावेशी)

विशेषताएं:

  • विशेष रूप से वेब-आधारित वातावरण या सैंडबॉक्स एप्लिकेशन के लिए डिज़ाइन किया गया
  • उनकी ID का उपयोग करके पहले से जेनरेट किए गए आउटपुट की सामग्री पुनर्प्राप्त करता है
  • फ़ाइल सिस्टम पहुंच की आवश्यकता के बिना पैकेज्ड कोडबेस तक सुरक्षित पहुंच प्रदान करता है
  • बड़ी फ़ाइलों के लिए आंशिक पढ़ने का समर्थन करता है

उदाहरण:

json
{
  "outputId": "8f7d3b1e2a9c6054",
  "startLine": 100,
  "endLine": 200
}

grep_repomix_output

यह टूल JavaScript RegExp सिंटैक्स के साथ grep-जैसी कार्यक्षमता का उपयोग करके Repomix आउटपुट फ़ाइल में पैटर्न खोजता है। मैचों के आसपास वैकल्पिक संदर्भ लाइनों के साथ मैचिंग लाइनें वापस करता है।

पैरामीटर:

पैरामीटरआवश्यकडिफ़ॉल्टविवरण
outputIdहाँखोजने के लिए Repomix आउटपुट फ़ाइल की ID
patternहाँखोज पैटर्न (JavaScript RegExp सिंटैक्स)
contextLinesनहीं0प्रत्येक मैच से पहले और बाद में दिखाने के लिए संदर्भ लाइनों की संख्या। beforeLines/afterLines निर्दिष्ट होने पर ओवरराइड होता है।
beforeLinesनहींप्रत्येक मैच से पहले दिखाने के लिए लाइनें (grep -B की तरह)। contextLines पर प्राथमिकता लेता है।
afterLinesनहींप्रत्येक मैच के बाद दिखाने के लिए लाइनें (grep -A की तरह)। contextLines पर प्राथमिकता लेता है।
ignoreCaseनहींfalseकेस-इनसेंसिटिव मैचिंग करें

विशेषताएं:

  • शक्तिशाली पैटर्न मैचिंग के लिए JavaScript RegExp सिंटैक्स का उपयोग करता है
  • मैचों की बेहतर समझ के लिए संदर्भ लाइनों का समर्थन करता है
  • पहले/बाद की संदर्भ लाइनों का अलग नियंत्रण की अनुमति देता है
  • केस-सेंसिटिव और केस-इनसेंसिटिव खोज विकल्प

उदाहरण:

json
{
  "outputId": "8f7d3b1e2a9c6054",
  "pattern": "function\\s+\\w+\\(",
  "contextLines": 3,
  "ignoreCase": false
}

file_system_read_file और file_system_read_directory

Repomix का MCP सर्वर दो फ़ाइल सिस्टम टूल्स प्रदान करता है जो AI असिस्टेंट्स को स्थानीय फ़ाइल सिस्टम के साथ सुरक्षित रूप से इंटरैक्ट करने की अनुमति देते हैं:

  1. file_system_read_file
  • पूर्ण पथों का उपयोग करके स्थानीय फ़ाइल सिस्टम से फ़ाइल सामग्री पढ़ता है
  • संवेदनशील जानकारी वाली फ़ाइलों तक पहुंच का पता लगाने और रोकने के लिए बिल्ट-इन सुरक्षा सत्यापन शामिल करता है
  • Secretlint का उपयोग करके सुरक्षा सत्यापन लागू करता है
  • संवेदनशील जानकारी (API कीज़, पासवर्ड, सीक्रेट्स) वाली फ़ाइलों तक पहुंच को रोकता है
  • डायरेक्टरी ट्रैवर्सल हमलों को रोकने के लिए पूर्ण पथों को सत्यापित करता है
  • अमान्य पथों और सुरक्षा समस्याओं के लिए स्पष्ट त्रुटि संदेश वापस करता है
  1. file_system_read_directory
  • पूर्ण पथ का उपयोग करके डायरेक्टरी की सामग्री सूचीबद्ध करता है
  • स्पष्ट संकेतकों के साथ फ़ाइलें और उप-डायरेक्टरी दिखाने वाली एक फॉर्मेटेड सूची वापस करता है
  • स्पष्ट संकेतकों ([FILE] या [DIR]) के साथ फ़ाइलें और डायरेक्टरी दिखाता है
  • उचित त्रुटि हैंडलिंग के साथ सुरक्षित डायरेक्टरी नेवीगेशन प्रदान करता है
  • पथों को सत्यापित करता है और सुनिश्चित करता है कि वे पूर्ण हैं
  • प्रोजेक्ट संरचना का अन्वेषण और कोडबेस संगठन की समझ के लिए उपयोगी

दोनों टूल्स मजबूत सुरक्षा उपाय शामिल करते हैं:

  • डायरेक्टरी ट्रैवर्सल हमलों को रोकने के लिए पूर्ण पथ सत्यापन
  • उचित पहुंच अधिकार सुनिश्चित करने के लिए अनुमति जांच
  • संवेदनशील जानकारी का पता लगाने के लिए Secretlint के साथ एकीकरण
  • बेहतर डीबगिंग और सुरक्षा जागरूकता के लिए स्पष्ट त्रुटि संदेश

उदाहरण:

typescript
// फ़ाइल पढ़ना
const fileContent = await tools.file_system_read_file({
  path: '/absolute/path/to/file.txt'
});

// डायरेक्टरी सामग्री सूचीबद्ध करना
const dirContent = await tools.file_system_read_directory({
  path: '/absolute/path/to/directory'
});

ये टूल्स विशेष रूप से उपयोगी हैं जब AI असिस्टेंट्स को निम्नलिखित की आवश्यकता होती है:

  • कोडबेस में विशिष्ट फ़ाइलों का विश्लेषण करना
  • डायरेक्टरी संरचनाओं को नेविगेट करना
  • फ़ाइलों की उपस्थिति और पहुंच की पुष्टि करना
  • सुरक्षित फ़ाइल सिस्टम ऑपरेशन सुनिश्चित करना

Repomix को MCP सर्वर के रूप में उपयोग करने के लाभ

Repomix को MCP सर्वर के रूप में उपयोग करने से कई फायदे मिलते हैं:

  1. प्रत्यक्ष एकीकरण: AI असिस्टेंट्स मैन्युअल फ़ाइल तैयारी के बिना आपके कोडबेस का सीधे विश्लेषण कर सकते हैं।
  2. कुशल वर्कफ़्लो: मैन्युअल रूप से फ़ाइलें जेनरेट और अपलोड करने की आवश्यकता को समाप्त करके कोड विश्लेषण प्रक्रिया को सुव्यवस्थित करता है।
  3. सुसंगत आउटपुट: सुनिश्चित करता है कि AI असिस्टेंट को एक सुसंगत, अनुकूलित प्रारूप में कोडबेस प्राप्त होता है।
  4. उन्नत सुविधाएं: कोड संपीड़न, टोकन गिनती, और सुरक्षा जांच जैसी Repomix की सभी सुविधाओं का लाभ उठाता है।

एक बार कॉन्फ़िगर होने के बाद, आपका AI असिस्टेंट कोडबेस का विश्लेषण करने के लिए Repomix की क्षमताओं का सीधे उपयोग कर सकता है, जिससे कोड विश्लेषण वर्कफ़्लो अधिक कुशल हो जाते हैं।

संबंधित संसाधन

Released under the MIT License.