Izmir Open Data API Client and MCP Server
Project description
İ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.
🚀 Özellikler
- Tam Asenkron Destek:
httpxaltyapı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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
aa3c655fcb66a4e797460778e233210f17ca77c253d2f2784fda00d21b4f3f85
|
|
| MD5 |
dc12cb27733bc6953d5d5572ecac7e65
|
|
| BLAKE2b-256 |
9d90deec1361b0d8c051b2543aaa423aecea921685bc84a57792d429237a0fd5
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
izmir_open_data_py-0.1.0.tar.gz -
Subject digest:
aa3c655fcb66a4e797460778e233210f17ca77c253d2f2784fda00d21b4f3f85 - Sigstore transparency entry: 1842843635
- Sigstore integration time:
-
Permalink:
AtaCanYmc/izmir-open-data-py@421cc30c586d03033bccc0842399bac2856abc74 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/AtaCanYmc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@421cc30c586d03033bccc0842399bac2856abc74 -
Trigger Event:
release
-
Statement type:
File details
Details for the file izmir_open_data_py-0.1.0-py3-none-any.whl.
File metadata
- Download URL: izmir_open_data_py-0.1.0-py3-none-any.whl
- Upload date:
- Size: 35.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
33512cd414467078cb9640c49011e8d18075d067882b8f209552faa71b83f731
|
|
| MD5 |
f76b2025e472bff2e555869e354b89ad
|
|
| BLAKE2b-256 |
f88ba18a65ab441ce2564edf8f1c10126aa50790ddb2148ded06fa3b99e12270
|
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
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
izmir_open_data_py-0.1.0-py3-none-any.whl -
Subject digest:
33512cd414467078cb9640c49011e8d18075d067882b8f209552faa71b83f731 - Sigstore transparency entry: 1842843760
- Sigstore integration time:
-
Permalink:
AtaCanYmc/izmir-open-data-py@421cc30c586d03033bccc0842399bac2856abc74 -
Branch / Tag:
refs/tags/v0.1.0 - Owner: https://github.com/AtaCanYmc
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@421cc30c586d03033bccc0842399bac2856abc74 -
Trigger Event:
release
-
Statement type: