Skip to main content

Izmir Open Data API Client and MCP Server

Project description

Izmir Open Data Logo

İzmir Open Data · Python İstemcisi

İzmir Büyükşehir Belediyesi Açık Veri Portalı ve Open API servisleri için modern, asenkron ve tip güvenli (Pydantic) Python istemcisi.

Python 3.10+ Pydantic v2 Ruff Mypy checked MCP Ready


🚀 Özellikler

  • Tam Asenkron Destek: httpx altyapısı ile non-blocking, yüksek performanslı istekler.
  • %100 Tip Güvenliği: API yanıtları Pydantic V2 modellerine dönüştürülür, IDE'lerde otomatik tamamlama (autocompletion) desteği sunar.
  • Kapsamlı Kapsama Alanı: ESHOT, İZBAN, Metro, Vapur, BİSİM, İZSU, Otopark, Etkinlikler, Hal Fiyatları ve daha birçok servisi kapsayan ~150 endpoint desteği.
  • CLI (Komut Satırı) Aracı: Terminal üzerinden doğrudan açık veriye erişebilme imkanı.
  • Model Context Protocol (MCP): AI ajanlarının (Claude, vb.) doğrudan açık veriyi sorgulayabilmesi için hazır bir MCP sunucusu.

📦 Kurulum

Şu anda paket kaynak koddan yüklenebilmektedir (ileride PyPI'a eklenebilir):

# Repoyu klonlayın
git clone https://github.com/AtaCanYmc/izmir-open-data-py.git
cd izmir-open-data-py

# pip ile (tercihen sanal ortamda) kurun
pip install -e .

📖 Temel Kullanım

import asyncio
from izmir_open_data import IzmirClient

async def main():
    async with IzmirClient() as client:
        # BİSİM İstasyonları ve Boş Bisiklet Durumları
        istasyonlar = await client.bisim.get_istasyon_list()
        for ist = istasyonlar.kayitlar[:3]:
            print(f"İstasyon: {ist.adi} | Boş Bisiklet: {ist.bos_bisiklet_sayisi}")

        # Otopark Doluluk Oranları
        otoparklar = await client.otopark.get_list()
        for oto in otoparklar[:3]:
            print(f"Otopark: {oto.name} | Boş Yer: {oto.occupancy.total.free}")

if __name__ == "__main__":
    asyncio.run(main())

Daha detaylı istemci mimarisi ve namespace yapıları için İstemci (Client) Dokümantasyonuna (docs/CLIENT.md) göz atın.

💻 CLI (Komut Satırı) Aracı

Terminal üzerinden herhangi bir script yazmadan İzmir verilerine ulaşabilirsiniz.

# Yardım menüsü
izmir-data --help

# İstediğiniz veri setini çekmek (örn: afet toplanma alanları)
izmir-data get cbs/afetaciltoplanmaalani

🤖 MCP (Model Context Protocol) Sunucusu

Proje entegre bir MCP sunucusuyla gelmektedir. Yapay zeka ajanlarına izmir verilerini öğretmek isterseniz:

# FastMCP sunucusunu başlatın
izmir-mcp dev

Yapay zeka asistanları (Örn. Claude), bu sunucuya bağlandıklarında sistemdeki tüm API'leri kendi başlarına tarayabilir ve sorularınızı gerçek zamanlı verilerle cevaplayabilir.

MCP sunucusunun yetenekleri, LLM araçları ve Claude Desktop entegrasyonu için detaylı MCP Dokümantasyonuna (docs/MCP.md) göz atın.

🧪 Testler ve Geliştirme

Proje kod kalitesini sağlamak için ruff, mypy ve pre-commit kullanmaktadır. Canlı endpoint testleri pytest ile yazılmıştır:

# Canlı veritabanına bağlanıp 150 endpointin anlık durumunu test edin
pytest tests/test_live_endpoints.py -v

📄 Lisans

Bu proje MIT Lisansı ile lisanslanmıştır. Kullanılan veriler İzmir Büyükşehir Belediyesi Açık Veri Portalı ve Açık Kaynak Kodlu API üzerinden sağlanmaktadır.

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

izmir_open_data_py-0.1.0.tar.gz (25.1 kB view details)

Uploaded Source

Built Distribution

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

izmir_open_data_py-0.1.0-py3-none-any.whl (35.2 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: izmir_open_data_py-0.1.0.tar.gz
  • Upload date:
  • Size: 25.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for izmir_open_data_py-0.1.0.tar.gz
Algorithm Hash digest
SHA256 aa3c655fcb66a4e797460778e233210f17ca77c253d2f2784fda00d21b4f3f85
MD5 dc12cb27733bc6953d5d5572ecac7e65
BLAKE2b-256 9d90deec1361b0d8c051b2543aaa423aecea921685bc84a57792d429237a0fd5

See more details on using hashes here.

Provenance

The following attestation bundles were made for izmir_open_data_py-0.1.0.tar.gz:

Publisher: publish.yml on AtaCanYmc/izmir-open-data-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

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

File metadata

File hashes

Hashes for izmir_open_data_py-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 33512cd414467078cb9640c49011e8d18075d067882b8f209552faa71b83f731
MD5 f76b2025e472bff2e555869e354b89ad
BLAKE2b-256 f88ba18a65ab441ce2564edf8f1c10126aa50790ddb2148ded06fa3b99e12270

See more details on using hashes here.

Provenance

The following attestation bundles were made for izmir_open_data_py-0.1.0-py3-none-any.whl:

Publisher: publish.yml on AtaCanYmc/izmir-open-data-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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