2025-11-08 · Hub: Merkezi Router
Bütün sistemlerimi MCP'ye uyumlu hale getirip her birinin etkileşim halinde olmasını ve hepsinin loglarını görebilmeyi istiyorum.
Niye böyle bir şey kuruyorum? Çünkü çok sıkıntılı. Kimin neyle haberleştiğini göremiyorum. macOS-helper'da çalışırken debug yapmamız gerekiyor. Her seferinde custom, farklı yapılara bakmam gerekiyor. Bütün sistemlerin birbirine etkileşim halinde olmasını istiyorum. Bana haz veriyor. Mesela macOS'i backend'de kullanabiliyoruz ama hotkey yapıları çok sıkıntılı oluyor. Tekerleği yeniden icat etmek yerine Hammerspoon'un hotkeyini kullanıyorum. macOS uygulamam var, Telegram uygulamam var, Whisper uygulaması var. Bir sürü farklı application'lar var. Hepsi birbirleriyle etkileşim halinde olsun. Ben onların communication'ını dizayn edeyim. Orchestrate edeyim. Ne oluyor, ne bitiyor göreyim. Agent de görsün. Agent'lar çalışsın. Böyle bir medeniyet olsun. Katman katman. Böyle bir arzım var. Bu yüzden bu sistemlerle uğraşıyorum.
Architecture Flow
FINAL ARCHITECTURE
┌──────────────────────────────────────────────────────────┐
│ CLIENTS (Send requests to Hub) │
├──────────────────────────────────────────────────────────┤
│ clients/telegram/yemreak/ → Voice, text, commands │
│ clients/hammerspoon/ → macOS automation │
│ clients/cli/ → gitc, stt, fetch │
│ clients/vscode/ → Extensions │
└──────────────────────────────────────────────────────────┘
↓ HTTP :8772 (JSON-RPC)
┌──────────────────────────────────────────────────────────┐
│ HUB (Central Router) │
├──────────────────────────────────────────────────────────┤
│ hub/server.ts → Request router │
│ hub/ports/registry.ts → Port discovery │
└──────────────────────────────────────────────────────────┘
↓ registry.call()
┌──────────────────────────────────────────────────────────┐
│ LAYERS (Receive from Hub, proxy to external services) │
├──────────────────────────────────────────────────────────┤
│ layers/api/ → Raw API clients │
│ ├─ whisper.ts → :8770 WebSocket │
│ ├─ macos.ts → :8766 HTTP │
│ ├─ chrome.ts → Chrome DevTools WebSocket │
│ └─ yemreak.ts → Telegram bot API │
│ │
│ layers/protocol/ → JSON-RPC wrappers │
│ ├─ whisper.ts │
│ ├─ macos.ts │
│ ├─ chrome.ts │
│ └─ yemreak.ts │
│ │
│ layers/hub/ → Hub adapters (PortAdapter) │
│ ├─ whisper.ts │
│ ├─ macos.ts │
│ ├─ chrome.ts │
│ └─ yemreak.ts │
└──────────────────────────────────────────────────────────┘
↓ import
┌──────────────────────────────────────────────────────────┐
│ FLOWS (Orchestration) │
├──────────────────────────────────────────────────────────┤
│ flows/transcribe.ts → whisper + DB save │
│ flows/media-extract.ts → download + compress │
└──────────────────────────────────────────────────────────┘
↓ import
┌──────────────────────────────────────────────────────────┐
│ CORE (Pure business logic) │
├──────────────────────────────────────────────────────────┤
│ core/trading/price.ts → Price calculations │
│ core/llm/compress.ts → Text processing │
│ core/analytics/infer-tags.ts → Tag inference │
└──────────────────────────────────────────────────────────┘
↓ import
┌──────────────────────────────────────────────────────────┐
│ INFRA (Database, cache, credentials) │
├──────────────────────────────────────────────────────────┤
│ infra/database/ → Supabase clients │
│ infra/cache.ts → Redis wrapper │
│ infra/credentials.ts → Env management │
└──────────────────────────────────────────────────────────┘
PROJECT STRUCTURE
src/
├─ clients/
│ ├─ telegram/
│ │ ├─ yemreak/
│ │ │ ├─ handlers/
│ │ │ │ ├─ message.text.ts
│ │ │ │ ├─ message.voice.ts
│ │ │ │ └─ command.agent.ts
│ │ │ ├─ client.ts # Hub client instance
│ │ │ ├─ bot.ts # PM2 entry
│ │ │ └─ config.ts
│ │ └─ (ytrader separate if needed)
│ │
│ ├─ hammerspoon/
│ │ ├─ modules/
│ │ │ ├─ dictation.lua
│ │ │ └─ activity-tracker.lua
│ │ ├─ client.lua # jsonrpc.lua
│ │ └─ init.lua
│ │
│ ├─ cli/
│ │ ├─ commands/
│ │ │ ├─ gitc.ts
│ │ │ ├─ stt.ts
│ │ │ └─ fetch.ts
│ │ └─ client.ts
│ │
│ └─ vscode/
│ ├─ bridge/
│ ├─ commands/
│ └─ theme/
│
├─ hub/
│ ├─ server.ts # HTTP :8772
│ ├─ types.ts # JSON-RPC types
│ ├─ ports/
│ │ └─ registry.ts
│ └─ tests/
│ ├─ health.sh
│ └─ whisper.sh
│
├─ layers/
│ ├─ api/
│ │ ├─ whisper.ts # :8770 WebSocket
│ │ ├─ macos.ts # :8766 HTTP
│ │ ├─ chrome.ts # Chrome CDP
│ │ ├─ vscode.ts # Extension API
│ │ └─ yemreak.ts # Telegram API
│ │
│ ├─ protocol/
│ │ ├─ whisper.ts
│ │ ├─ macos.ts
│ │ ├─ chrome.ts
│ │ ├─ vscode.ts
│ │ └─ yemreak.ts
│ │
│ └─ hub/
│ ├─ whisper.ts
│ ├─ macos.ts
│ ├─ chrome.ts
│ ├─ vscode.ts
│ └─ yemreak.ts
│
├─ flows/
│ ├─ transcribe.ts
│ ├─ media-extract.ts
│ └─ text-transform.ts
│
├─ core/
│ ├─ trading/
│ │ └─ price.ts # Price calculations
│ ├─ llm/
│ │ ├─ compress.ts
│ │ └─ translate.ts
│ └─ analytics/
│ └─ infer-tags.ts
│
└─ infra/
├─ database/
│ ├─ personal/
│ └─ private/
├─ cache.ts
└─ credentials.ts
FLOW EXAMPLES
1. Telegram voice → transcribe:
User → Telegram voice
clients/telegram/yemreak/handlers/message.voice.ts
→ hub.call("whisper.transcribe", {audio_path})
→ hub/server.ts
→ registry.call("whisper.transcribe")
→ layers/hub/whisper.ts
→ layers/protocol/whisper.ts
→ layers/api/whisper.ts
→ WebSocket :8770
→ result
→ hub.call("yemreak.sendMessage", {text})
→ layers/hub/yemreak.ts
→ Telegram API
TSCONFIG PATHS
{
"@clients/*": ["src/clients/*"],
"@hub/*": ["src/hub/*"],
"@layers/*": ["src/layers/*"],
"@flows/*": ["src/flows/*"],
"@core/*": ["src/core/*"],
"@infra/*": ["src/infra/*"]
}Last updated
Was this helpful?