Skip to main content

AI-based vehicle gallery assistant using Model Context Protocol (MCP)

Project description

🚗 MCP Araç Arama Sistemi - AI Tabanlı Araç Galeri Asistanı

MCP Logo

Bu proje, Model Context Protocol (MCP) kullanarak AI asistanlarına gerçek zamanlı araç veritabanı erişimi sağlayan kapsamlı bir örnek uygulamadır. Claude, ChatGPT gibi büyük dil modellerinin veritabanlarıyla nasıl etkileşim kurabileceğini gösterir.

🎯 Proje Özeti

MCP (Model Context Protocol), AI modellerinin dış veri kaynaklarına standartlaştırılmış şekilde erişmesini sağlayan devrimsel bir protokoldür. Bu proje, araç galeri senaryosu üzerinden MCP'nin gücünü pratik olarak göstermektedir.

🔥 Temel Özellikler

  • 🤖 AI Asistanı: Claude ile doğal dil kullanarak araç arama
  • 🗄️ MCP Server: MySQL veritabanına güvenli erişim
  • 📊 Gelişmiş Filtreleme: 15+ farklı arama kriteri
  • 🌐 Web Entegrasyonu: Tavily API ile güncel araç bilgileri
  • 📱 Çoklu Arayüz: Terminal, Streamlit ve web tabanlı
  • 🔒 Güvenlik: Parametrized queries ile SQL injection koruması

🏗️ Proje Mimarisi

MCP Akış Diyagramı

📦 Dosya Yapısı

mcp-anlatim/
├── 📱 Uygulamalar
│   ├── app.py              # Ana terminal uygulaması (Claude + MCP)
│   ├── appst.py            # Streamlit web uygulaması-mcpsiz (OpenAI + LangChain)
│   └── mcpanlatim.py       # Kapsamlı eğitim ve demo uygulaması
├── 🔧 MCP Server
│   └── dataturkmcp.py      # FastMCP tabanlı araç arama server'ı
├── 🗄️ Veri
│   └── veri.xlsx           # Excel format araç verileri
├── 📋 Yapılandırma
│   ├── requirements.txt    # Python bağımlılıkları
│   └── .env               # Ortam değişkenleri (API anahtarları)
├── 📚 Dokümantasyon
│   ├── README.md          # Bu dosya
│   ├── kaynak.txt         # Kaynaklar ve bağlantılar
│   └── *.png, *.jpeg      # Görsel materyaller
└── 📄 LICENSE             # MIT lisansı

🚀 Hızlı Başlangıç

1️⃣ Kurulum

# Projeyi klonla
git clone https://github.com/halilkkaya/mcp-anlatim.git
cd mcp-anlatim

# Sanal ortam oluştur (önerilen)
python -m venv venv
source venv/bin/activate  # Linux/Mac
# veya
venv\Scripts\activate     # Windows

# Bağımlılıkları yükle
pip install -r requirements.txt

2️⃣ Ortam Değişkenlerini Ayarla

.env dosyası oluşturun:

# AI API Anahtarları
ANTHROPIC_API_KEY=your_claude_api_key_here
OPENAI_API_KEY=your_openai_api_key_here

# Veritabanı Ayarları
MYSQL_HOST=localhost
MYSQL_USER=root
MYSQL_PASSWORD=your_mysql_password
MYSQL_DATABASE=mcp_deneme

# Web Arama API'si
TAVILY_API_KEY=your_tavily_api_key

# MCP Server URL'i
MCP_URL=http://localhost:8000/mcp

3️⃣ Veritabanını Hazırla

# MySQL'de veritabanı oluştur
mysql -u root -p
CREATE DATABASE mcp_deneme;
USE mcp_deneme;

# Araç verilerini import et (varsa)
# Veya SQLite dosyasını kullan: arabalar.db

4️⃣ Uygulamaları Çalıştır

🎓 Eğitim ve Demo (Önerilen)

streamlit run mcpanlatim.py

Kapsamlı MCP anlatımı, tool tanıtımları ve canlı test ortamı

🖥️ Terminal Uygulaması

python app.py

Claude ile terminal tabanlı araç asistanı

🌐 Web Uygulaması

streamlit run appst.py

OpenAI tabanlı web araç danışmanı

⚙️ MCP Server

python dataturkmcp.py

8000 portunda MCP server başlatır

🛠️ MCP Tools (Araçlar)

🔍 araba_ara - Ana Arama Tool'u

Gelişmiş filtreleme seçenekleri ile araç arama:

# Temel filtreleme
araba_ara(
    marka="toyota",           # Araç markası
    model="corolla",          # Model adı  
    min_fiyat=100000,         # Minimum fiyat
    max_fiyat=500000,         # Maksimum fiyat
    il="istanbul"             # Şehir
)

# Gelişmiş özellikler
araba_ara(
    ozel_arama="ekonomik",    # Önceden tanımlı kategoriler
    siralama="fiyat_artan",   # Sıralama tipi
    limit=10,                 # Sonuç sayısı
    detayli=True,             # Detaylı bilgiler
    istatistik=True           # İstatistiksel veriler
)

📋 Tam Parametre Listesi

Parametre Tip Açıklama Örnek
marka str/list Araç markası "toyota" veya ["ford", "bmw"]
model str Model adı "focus", "corolla"
min_fiyat/max_fiyat int Fiyat aralığı 50000, 200000
min_yil/max_yil int Model yılı 2015, 2023
min_km/max_km int Kilometre aralığı 0, 100000
il str Şehir "istanbul", "ankara"
yakit str Yakıt türü "benzin", "dizel", "hibrit"
vites str Vites türü "manuel", "otomatik"
durum str Araç durumu "yeni", "mükemmel", "iyi"
tip str Araç tipi "sedan", "suv", "hatchback"
renk str Araç rengi "beyaz", "siyah", "gri"
ozel_arama str Özel kategoriler "ekonomik", "lüks", "aile", "spor"
siralama str Sıralama "fiyat_artan", "yil_yeni", "km_az"
limit int Sonuç sayısı 5 (varsayılan)
detayli bool Detaylı bilgi True/False
benzer_araclar bool Benzer öneriler True/False
istatistik bool İstatistiksel veri True/False

🔧 Diğer Tools

Tool Açıklama Kullanım
sql_sorgusu_calistir Özel SQL sorguları Gelişmiş analiz
tablolari_listele Veritabanı tabloları Yapı keşfi
tablo_yapisi_goster Tablo şeması Sütun bilgileri
web_arama Tavily API araması Güncel bilgiler

💡 Örnek Kullanım Senaryoları

🏠 Aile Aracı Arama

araba_ara(
    ozel_arama="aile",
    min_fiyat=100000,
    max_fiyat=300000,
    yakit="dizel",
    siralama="fiyat_artan"
)

⚡ Ekonomik Araç Bulma

araba_ara(
    ozel_arama="ekonomik",
    max_fiyat=150000,
    yakit=["hibrit", "dizel"],
    limit=10
)

🏎️ Lüks Spor Araç

araba_ara(
    marka=["bmw", "mercedes", "audi"],
    tip="coupe",
    ozel_arama="lüks",
    min_yil=2020,
    detayli=True
)

📊 Pazar Analizi

araba_ara(
    marka="toyota",
    istatistik=True,
    benzer_araclar=True,
    limit=20
)

🤖 AI Asistan Örnekleri

💬 Doğal Dil Sorguları

Kullanıcı: "Aileme uygun, ekonomik bir araç arıyorum"
AI: araba_ara(ozel_arama="aile", yakit="dizel", siralama="fiyat_artan")

Kullanıcı: "BMW veya Mercedes, 2020 sonrası, coupe"  
AI: araba_ara(marka=["bmw", "mercedes"], tip="coupe", min_yil=2020)

Kullanıcı: "İstanbul'da 200 bin TL altı Toyota araçlar"
AI: araba_ara(marka="toyota", il="istanbul", max_fiyat=200000)

🔒 Güvenlik Özellikleri

  • 🛡️ SQL Injection Koruması: Parametrized queries
  • 🔐 API Anahtarı Güvenliği: Ortam değişkenleri
  • 🚫 Erişim Kontrolü: Aktif kayıt filtreleme
  • ⚠️ Hata Yönetimi: Güvenli hata mesajları
  • 🔍 Input Validation: Parametre doğrulama

📈 Performans Optimizasyonları

  • 📊 Veritabanı İndeksleri: Hızlı sorgular
  • 🔗 Connection Pooling: Kaynak yönetimi
  • 📝 Query Logging: Performans takibi
  • ⚡ Caching: Yanıt hızlandırma

🎓 MCP Öğrenme Kaynakları

🛠️ Teknik Detaylar

🔧 Kullanılan Teknolojiler

Kategori Teknoloji Versiyon
AI Models Anthropic Claude 3.5 Haiku
OpenAI GPT 3.5 Turbo
MCP Framework FastMCP Latest
Database MySQL 8.0+
Web Framework Streamlit Latest
ML Framework LangChain Latest
Search API Tavily v1

⚙️ Sistem Gereksinimleri

  • Python: 3.8+
  • RAM: 2GB+ (önerilen 4GB)
  • Disk: 1GB boş alan
  • Network: İnternet bağlantısı (API'lar için)

🔧 API Anahtarları

Servis Neden Gerekli Ücretsiz Limitler
Anthropic Claude AI model $5 kredi
OpenAI GPT model $5 kredi
Tavily Web araması 1000 arama/ay

📋 Kurulum Sorun Giderme

❌ Yaygın Sorunlar

1. ModuleNotFoundError

pip install -r requirements.txt

2. Database Connection Error

# MySQL servisinin çalıştığından emin olun
# .env dosyasındaki credentials'ları kontrol edin

3. API Key Errors

# .env dosyasındaki API anahtarlarını kontrol edin
# Anahtarların geçerli olduğundan emin olun

4. Port Already in Use

# MCP server için farklı port kullanın
python dataturkmcp.py --port 8001

🤝 Katkıda Bulunma

  1. Fork yapın
  2. Feature branch oluşturun (git checkout -b feature/amazing-feature)
  3. Commit yapın (git commit -m 'Add amazing feature')
  4. Push yapın (git push origin feature/amazing-feature)
  5. Pull Request açın

📄 Lisans

Bu proje MIT lisansı altında yayınlanmıştır. Detaylar için LICENSE dosyasına bakın.

👨‍💻 Geliştirici

Halil Kaya

🙏 Teşekkürler

  • Anthropic - Claude AI modeli
  • OpenAI - GPT modelleri
  • FastMCP - MCP framework
  • Tavily - Web arama API'si
  • Streamlit - Web arayüzü

Bu projeyi beğendiyseniz yıldız vermeyi unutmayın!

📧 Sorularınız için: Issues bölümünü kullanın

🔄 Güncellemeler için: Repository'yi watch edin

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

iflow_mcp_halilkkaya_mcp_anlatim-0.1.0.tar.gz (14.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file iflow_mcp_halilkkaya_mcp_anlatim-0.1.0.tar.gz.

File metadata

File hashes

Hashes for iflow_mcp_halilkkaya_mcp_anlatim-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1dc15a60763862bb735f94be399c2421675bee98a84f831555c2857effe2e236
MD5 4cc6f58e0119375853bb64ef64c63763
BLAKE2b-256 75f6ba19c473054593ebb1448796c5c5bc19d18875a6fe56943e5f9e0855ed2b

See more details on using hashes here.

File details

Details for the file iflow_mcp_halilkkaya_mcp_anlatim-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for iflow_mcp_halilkkaya_mcp_anlatim-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0972791452f3b75ed1886738d687b8fb26fe875558d9f753db2dae43a7979699
MD5 03856ff12247ac435676dad9c1c9bd00
BLAKE2b-256 96358a9b81778f5d2afb5f7e7cea5041713c855daa92f4bb5ba1594af12431ff

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page