sdk/index.js:
- accepted/pair sinyali → mwse.pairs.set(from, peer)
- end/pair sinyali → mwse.pairs.delete(from)
(İstek gönderen taraf pairs haritasına eklendi)
sdk/Peer.js:
- acceptPair() başarısında → mwse.pairs.set(socketId, this)
- rejectPair() → mwse.pairs.delete(socketId)
- endPair() → mwse.pairs.delete(socketId)
(Kabul eden taraf da pairs haritasına eklendi)
public/studio/Studio.js — tamamen yeniden yazıldı:
Gelen eşleme isteği → bildirim banner'ı:
- Yeşil arka plan, socket ID kodu olarak gösterilir
- [Reddet] → rejectPair() → banner kapanır
- [Kabul Et] → acceptPair() → banner kapanır, eşler yenilenir
Eşler kolonu: artık mwse.pairs'tan doğru veriler geliyor
Oda oluşturma: description alanı eklendi (sunucu zorunlu tutuyordu)
Oda oluştur → "Oda adı / Açıklama / Şifre" modal
ID ile ara → prompt() yerine modal
Araç çubuğu: "Kimliğim" kartı, kopyala butonu (⎘→✓ flash)
public/studio/style.css:
.mwse-notif-area / .mwse-notif-bar / __msg / __dot / __actions
go test -race ./... — yeşil
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
sdk/index.js — bağlantı hatası düzeltildi:
- new MWSE() options=undefined → TypeError patlaması
- constructor(options) → opts = { endpoint:'auto', ...options }
- Artık new MWSE() / new MWSE('ws://host') / new MWSE({…}) hepsi çalışıyor
public/studio/Studio.js — tamamen yeniden yazıldı:
Eşler kolonu:
- mwse.pairs'ten gerçek eşleri gösteriyor
- Her eş için: Video+Ses / Sesli Ara / Ekran Paylaş / Kamera Seç /
Mikrofon Seç / Dosya Gönder / Aktif Akışlar / Eşleşmeyi Bitir
- "ID ile ara" → prompt ile direkt peer ID girerek requestPair()
Odalar kolonu: mwse.rooms'tan oda + üye listesi
Cihazlar kolonu:
- MediaSources.devices() ile kamera ve mikrofon listesi
- Her cihaza tıkla → seçili eşe akış başlat veya önizle (floating video)
- İzin İste butonu → izin alındıktan sonra listeyi yenile
Akışlar kolonu: peer.rtc._streams.list() canlı gösterimi
Kalite kolonu: Yüksek/Orta/Düşük preset + mute/stop
Araç çubuğu: socket ID, durum mesajı, Ana butonu (popTo(0))
Gelen track'ler: audio otomatik çalınır, status bar bildirir
Cihaz önizleme: floating video element (✕ ile kapatılır)
public/studio/app.js: studio.mount() await ile çağrılıyor
go test -race ./... — yeşil
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
sdk/webrtc/CanvasCompositor.js (#38):
- Gelen video track'lerini tek canvas'ta birleştirme (grid/pip/side-by-side/focus)
- OffscreenCanvas öncelikli (DOM gerektirmiyor), yoksa <canvas> kullanır
- setFPS(), setLayout(), setFocus() ile runtime kontrol
- stream() → MediaStream; StreamManager.addStream('composite', ...) ile gönderilir
- setEncodings() ile bitrate/fps zaten StreamManager üzerinden destekleniyor
sdk/webrtc/index.js: CanvasCompositor re-export eklendi
public/demos/ (#34): Tüm demo'lar yeni SDK API'sine güncellendi:
- <script src="/script"> → <script type="module"> import MWSE from '/sdk/index.js'
- new MWSE() (endpoint otomatik import.meta.url'den alınıyor)
- rtc.connect({ polite }) ile perfect negotiation polite/impolite tayini
- rtc.addStream() / rtc.on('track') yeni API
- rtc.on('failed') durumu gösteriliyor
- window.send() module scope sorununu çözüyor (onclick handler)
go test -race ./... — tüm testler yeşil
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
sdk/webrtc/ — kapsamlı RTCEngine kütüphanesi:
- PeerConnection.js: RTCPeerConnection wrapper; connectionstatechange +
iceconnectionstatechange her ikisi de izleniyor (eski 'bağlantı kopsa
fark etmez' hatası bu şekilde önleniyor)
- Negotiator.js: perfect negotiation (RFC 8829); polite/impolite roller,
teklif çakışması rollback, ICE adayları sıraya alınıyor
- StreamManager.js: addStream/replaceTrack/removeStream/setEncodings —
runtime'da track ekle/çıkar/değiştir, yeniden müzakere gerekmiyor
- DataChannel.js: birincil veri kanalı, bağlantı canlıyken kapanırsa
otomatik yeniden oluşturulur, açılana kadar mesaj kuyruğu
- MediaSources.js: camera/microphone/screen/cameraAndMic fabrika metodları,
AudioBuffer→MediaStream, canvas.captureStream, AudioContext mix bus
- FileSender.js: en fazla 5 paralel DataChannel üzerinden dosya transferi,
progress olayı, 16 KB chunk + bufferedAmountLow akış kontrolü
- index.js (RTCEngine): tüm alt sistemleri koordine eder; ICE restart
exponential backoff (1s→2s→4s); Peer.js ile geriye dönük uyumlu
sdk/WebRTC.js → ./webrtc/index.js'e ince re-export (Peer.js değişmedi)
sdk/studio/ — masaüstü-first Miller-kolon UI (#47):
- Column.js: başlık + arama filtresi + öğe listesi
- ColumnView.js: yatay kayan kolon yöneticisi, popTo() ile derine git
- index.js (Studio): Server→Groups→Peers→Devices→Streams→Quality hiyerarşisi;
WebRTC bağlantısını otomatik başlatır (polite = küçük socketId)
- style.css: koyu masaüstü teması, aktif öğe vurgusu, ilerleme çubuğu
internal/services/ippressure.go — rastgele atama + sub-network (#40/#41):
- lockIP/lockNumber/lockCode: önce 256 rastgele deneme, sonra sıralı yedek;
yüksek bağlantı sayısında O(1) ortalama atama
- SubNet: /24 sanal alt ağ (10.A.B.0/24); Alloc/Release/Whois metodları
- alloc|release|whois APSubNet + APSubNetIP HTTP handler'ları eklendi
- Bağlantı kesildiğinde subnet IP'leri ve prefix otomatik serbest bırakılıyor
sdk/IPPressure.js: allocSubNet/releaseSubNet/allocSubNetIP/releaseSubNetIP/
querySubNetIP metodları eklendi
go test -race ./... — tüm testler yeşil
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>