No description
Find a file
2025-12-27 11:19:37 +03:00
.gitattributes Initial commit 2025-06-01 19:36:29 +03:00
.gitignore Update gitignore 2025-12-26 18:34:17 +03:00
5ire-settings.png Create 5ire-settings.png 2025-06-03 17:06:19 +03:00
cache.py Performance improvements and bug fixes 2025-12-26 18:29:35 +03:00
client.py Remove Playwright, use HTTPX-only 2025-12-26 19:16:19 +03:00
LICENSE Initial commit 2025-06-01 19:36:29 +03:00
models.py Remove Playwright, use HTTPX-only 2025-12-26 19:16:19 +03:00
ornek.png Create ornek.png 2025-06-03 16:40:18 +03:00
pyproject.toml Remove Playwright, use HTTPX-only 2025-12-26 19:16:19 +03:00
README.md Update README with Google Antigravity instructions 2025-12-27 11:19:37 +03:00
requirements.txt Performance improvements and bug fixes 2025-12-26 18:29:35 +03:00
yoktez_mcp_server.py Disable disk cache by default for read-only containers 2025-12-27 10:16:42 +03:00

YokTez MCP: YÖK Ulusal Tez Merkezi için MCP Sunucusu

Bu proje, Yükseköğretim Kurulu (YÖK) Ulusal Tez Merkezi'ne erişimi kolaylaştıran bir FastMCP sunucusu oluşturur. Bu sayede, YÖK Tez Merkezi'nden tez arama ve tezlerin PDF içeriklerini Markdown formatında getirme işlemleri, Model Context Protocol (MCP) destekleyen LLM (Büyük Dil Modeli) uygulamaları (örneğin Claude Desktop veya 5ire) ve diğer istemciler tarafından araç (tool) olarak kullanılabilir hale gelir.

YÖK Tez MCP Örneği

🎯 Temel Özellikler

  • YÖK Ulusal Tez Merkezi'ne programatik erişim için standart bir MCP arayüzü.
  • Aşağıdaki yetenekler:
    • Detaylı Tez Arama: Başlık, yazar, danışman, üniversite, enstitü, anabilim/bilim dalı, tez türü, yıl aralığı, izin durumu, tez numarası, konu, dizin ve özet metni gibi çeşitli kriterlere göre tez arama.
    • Tez Belgesi Getirme: Belirli bir tezin PDF içeriğini, PDF sayfa bazında, işlenmiş Markdown formatında getirme.
    • Metadata Çıkarımı: Tez detay sayfalarından başlık, yazar, yıl, özet gibi önemli üst verilerin çıkarılması.
    • PDF İzin Kontrolü: Erişilemeyen veya yayın izni olmayan tezler için uygun bildirim.
  • Karar metinlerinin LLM'ler tarafından daha kolay işlenebilmesi için Markdown formatına çevrilmesi.
  • Claude Desktop uygulaması ile fastmcp install komutu (veya manuel yapılandırma) kullanılarak kolay entegrasyon.
  • YokTez MCP 5ire gibi Claude Desktop haricindeki MCP istemcilerini de destekler.

🚀 5 Dakikada Başla (Remote MCP)

Kurulum Gerektirmez! Hemen Kullan!

🔗 Remote MCP Adresi: https://yoktezmcp.fastmcp.app/mcp

Claude Desktop ile Kullanım

  1. Claude Desktop'ıın
  2. Settings → Connectors → Add Custom Connector
  3. Bilgileri girin:
    • Name: YokTez MCP
    • URL: https://yoktezmcp.fastmcp.app/mcp
  4. Add butonuna tıklayın
  5. Hemen kullanmaya başlayın! 🎉

Google Antigravity ile Kullanım

  1. Agent sessionın ve editörün yan panelindeki "…" dropdown menüsüne tıklayın
  2. MCP Servers seçeneğini seçin - MCP Store açılacak
  3. Üstteki Manage MCP Servers butonuna tıklayın
  4. View raw config seçeneğine tıklayın
  5. mcp_config.json dosyasına aşağıdaki yapılandırmayı ekleyin:
{
  "mcpServers": {
    "yoktez-mcp": {
      "serverUrl": "https://yoktezmcp.fastmcp.app/mcp/",
      "headers": {
        "Content-Type": "application/json"
      }
    }
  }
}

💡 İpucu: Remote MCP sayesinde Python, uv veya herhangi bir kurulum yapmadan doğrudan Claude Desktop üzerinden YÖK Ulusal Tez Merkezi'ne erişebilirsiniz!


🚀 Claude Haricindeki Modellerle Kullanmak İçin Çok Kolay Kurulum (Örnek: 5ire için)

Bu bölüm, YokTez MCP aracını 5ire gibi Claude Desktop dışındaki MCP istemcileriyle kullanmak isteyenler içindir.

  • Python Kurulumu: Sisteminizde Python 3.11 kurulu olmalıdır. Kurulum sırasında "Add Python to PATH" (Python'ı PATH'e ekle) seçeneğini işaretlemeyi unutmayın. Buradan 3.11 sürümünü indirebilirsiniz.
  • Git Kurulumu (Windows): Bilgisayarınıza git yazılımını indirip kurun. "Git for Windows/x64 Setup" seçeneğini indirmelisiniz.
  • uv Kurulumu:
    • Windows Kullanıcıları (PowerShell): Bir CMD ekranıın ve bu kodu çalıştırın: powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
    • Mac/Linux Kullanıcıları (Terminal): Bir Terminal ekranıın ve bu kodu çalıştırın: curl -LsSf https://astral.sh/uv/install.sh | sh
  • Microsoft Visual C++ Redistributable (Windows): Bazı Python paketlerinin doğru çalışması için gereklidir. Buradan indirip kurun.
  • İşletim sisteminize uygun 5ire MCP istemcisini indirip kurun.
  • 5ire'ıın. Workspace -> Providers menüsünden kullanmak istediğiniz LLM servisinin API anahtarını girin.
  • Tools menüsüne girin. +Local veya New yazan butona basın.
    • Tool Key: yoktezmcp
    • Name: YokTez MCP
    • Command:
      uvx --from git+https://github.com/saidsurucu/yoktez-mcp yoktez-mcp
      
    • Save butonuna basarak kaydedin.

5ire YokTez MCP Ayarları

  • Şimdi Tools altında YokTez MCP'yi görüyor olmalısınız. Üstüne geldiğinizde sağda çıkan butona tıklayıp etkinleştirin (yeşil ışık yanmalı).
  • Artık YokTez MCP ile konuşabilirsiniz.

⚙️ Claude Desktop Manuel Kurulumu

  1. Ön Gereksinimler: Python, uv, (Windows için) Microsoft Visual C++ Redistributable'ın sisteminizde kurulu olduğundan emin olun. Detaylı bilgi için yukarıdaki "5ire için Kurulum" bölümündeki ilgili adımlara bakabilirsiniz.

  2. Claude Desktop Settings -> Developer -> Edit Config.

  3. ılan claude_desktop_config.json dosyasına mcpServers altına ekleyin:

    {
      "mcpServers": {
        // ... (varsa diğer sunucularınız) ...
        "YokTez MCP": {
          "command": "uvx",
          "args": [
            "--from", "git+https://github.com/saidsurucu/yoktez-mcp",
            "yoktez-mcp"
          ]
        }
      }
    }
    
  4. Claude Desktop'ı kapatıp yeniden başlatın.

🛠️ Kullanılabilir Araçlar (MCP Tools)

Bu FastMCP sunucusu LLM modelleri için aşağıdaki araçları sunar:

  • search_yok_tez_detailed: YÖK Ulusal Tez Merkezi'nde çeşitli detaylı kriterleri kullanarak tez araması yapar.

    • Parametreler: thesis_title, author_name, advisor_name, university_name, institute_name, department_name, discipline_name, thesis_number, subject_headings, index_terms, abstract_text, thesis_type, permission_status, thesis_status, language, institute_group, year_start, year_end, page, results_per_page.
    • Döndürdüğü Değer: YokTezSearchResult (sayfalanmış tez özeti listesi, toplam sonuç sayısı vb. içerir)
  • get_yok_tez_document_markdown: Belirli bir YÖK tezinin PDF içeriğini, istenen PDF sayfasına göre Markdown formatında getirir.

    • Parametreler: detail_page_url (tez detay sayfası URL'si), page_number (istenen PDF sayfa numarası).
    • Döndürdüğü Değer: YokTezDocumentMarkdown (sayfanın Markdown içeriği, toplam sayfa sayısı, metadata vb. içerir)

📜 Lisans

Bu proje MIT Lisansı altında lisanslanmıştır. Detaylar için LICENSE dosyasına bakınız.