Problème : Le serveur retournait ws://localhost:7880 aux clients, empêchant les connexions depuis d'autres appareils sur le réseau. Solution : - Ajout détection automatique IP réseau (WiFi/Ethernet) - Variable LIVEKIT_URL=AUTO pour mode auto-détection - Fonction getNetworkIP() avec priorité interfaces (en0, en1, eth0, wlan0) - Affichage IP détectée au démarrage du serveur - Fallback vers localhost si IP non détectée Modifications : - server/index.js : ajout getNetworkIP() et détection AUTO - server/.env : LIVEKIT_URL=AUTO par défaut - server/.env.example : documentation modes configuration - NETWORK_SETUP.md : guide complet configuration réseau et dépannage Les clients reçoivent maintenant ws://IP_RESEAU:7880 et peuvent se connecter depuis n'importe quel appareil sur le même réseau WiFi. Ports utilisés : - 3000 : API REST - 7880 : LiveKit WebSocket - 7882 : LiveKit UDP (RTP) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
3.3 KiB
Configuration Réseau - Connexion Multi-Appareils
Problème résolu
Le serveur retournait précédemment ws://localhost:7880 aux clients, ce qui empêchait les connexions depuis d'autres appareils sur le réseau.
Solution
Le serveur détecte maintenant automatiquement l'IP réseau locale et retourne l'URL LiveKit correcte aux clients.
Configuration
Fichier .env
# AUTO = détection automatique de l'IP réseau
LIVEKIT_URL=AUTO
# OU spécifier manuellement l'IP du serveur
# LIVEKIT_URL=ws://192.168.1.100:7880
Mode AUTO (recommandé)
Le mode AUTO détecte automatiquement l'IP réseau :
- macOS : WiFi (en0) ou Ethernet (en1)
- Linux : eth0, wlan0, ou première interface réseau
L'IP détectée est affichée au démarrage :
📡 IP réseau détectée : 10.1.1.111
🔗 URL LiveKit clients : ws://10.1.1.111:7880
Mode manuel
Si la détection automatique ne fonctionne pas, spécifiez l'IP manuellement :
-
Trouvez l'IP du serveur :
# macOS ifconfig | grep "inet " | grep -v 127.0.0.1 # Linux ip addr show | grep "inet " | grep -v 127.0.0.1 -
Modifiez
.env:LIVEKIT_URL=ws://VOTRE_IP:7880
Test connexion multi-appareils
1. Démarrer le serveur
cd server
npm run dev
Notez l'IP affichée (ex: 10.1.1.111)
2. Accéder depuis un autre appareil
Sur smartphone (même WiFi)
- Ouvrir navigateur
- Aller sur :
http://10.1.1.111:3000(remplacer par l'IP serveur) - Le client PWA va automatiquement recevoir l'URL LiveKit correcte
Depuis un autre ordinateur
Même procédure : http://IP_SERVEUR:3000
Ports utilisés
- 3000 : API REST (serveur Express)
- 7880 : LiveKit WebSocket (connexions WebRTC)
- 7882 : LiveKit UDP (trafic RTP audio/vidéo)
Firewall et réseau
macOS
Autorisez Node.js et LiveKit dans les préférences réseau si demandé.
Configuration WiFi recommandée
- QoS activée : Priorisation trafic audio/vidéo
- Isolation client désactivée : Permet communication entre appareils
- Band 5GHz : Meilleure latence que 2.4GHz
Dépannage
Erreur "bind: address already in use"
Un autre processus utilise le port 7880 ou 7882 :
# Trouver le processus
lsof -i :7880
lsof -i :7882
# Tuer le processus si nécessaire
kill -9 PID
Client ne peut pas se connecter
-
Vérifiez que le serveur tourne :
curl http://IP_SERVEUR:3000/health -
Vérifiez l'URL LiveKit retournée :
curl http://IP_SERVEUR:3000/config -
Testez la connexion LiveKit :
# Depuis un navigateur sur le client # Console DevTools : const ws = new WebSocket('ws://IP_SERVEUR:7880'); ws.onopen = () => console.log('LiveKit accessible !'); ws.onerror = (e) => console.error('Erreur:', e);
IP détectée incorrecte
Si le serveur détecte la mauvaise IP (ex: VPN, Docker, etc.) :
- Utilisez le mode manuel dans
.env - Ou modifiez la priorité des interfaces dans
server/index.js(ligne 28)
Sécurité
⚠️ En production, utilisez HTTPS/WSS :
# .env
LIVEKIT_URL=wss://votre-domaine.com:7880
Et configurez des certificats SSL pour LiveKit et Express.
Dernière mise à jour : 2026-05-22