Does not support local insecure connections on 'newer Android phones'
DanMakingWithAI opened this issue · 2 comments
Crosspost from Discord
A bit of digging suggests that on newer Android phones, the 01 mobile app will refuse to connect to a local livekit server (such as the one exposed by the 01 python code) that is served over http rather than https. I had suspected this to be the cause of my app not connecting, and a logcat over adb confirms it - the app produces this in the log trace (after the token check passes)
09-20 23:38:40.653 5218 5273 W ReactNativeJS: 'websocket closed', { room: undefined,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: roomID: undefined,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: participant: undefined,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: pID: undefined,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: reason: 'CLEARTEXT communication to 192.168.1.159 not permitted by network security policy',
09-20 23:38:40.653 5218 5273 W ReactNativeJS: code: 1006,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: wasClean: undefined,
09-20 23:38:40.653 5218 5273 W ReactNativeJS: state: 4 }
Of course, using ngrok you get an https endpoint, so folks doing the --expose
flag when starting the 01 server should not experience this.
I only say 'newer Android phones' because I searched the error line in Perplexity
: https://www.perplexity.ai/search/reactnaivejs-livekit-error-cle-WPS1IVDRQ56eacKjW0o8lg
That (re)search thread proposes fixes, if desired - enabling cleartext communication only for local networks and with a clear warning to users could be a reasonable idea. Or denying it and alerting on 'http' rather than 'https'. Or catching and relaying the warning etc. etc.
Alternatively, updating the documentation to say this won't work is fine, too. I have no particular opinion either way. 😊
A bit more Perplexity searching suggests the reasonable fix might be to use the expo-network
plugin and update the plugin section of the app.config.ts
file to include the relevant section of this:
import { ExpoConfig } from 'expo/config';
const config: ExpoConfig = {
// ... other configurations
android: {
// ... other Android-specific configurations
},
plugins: [
[
'expo-network',
{
'android': {
'networkSecurityConfig': {
'cleartextTrafficPermitted': false,
'domains': [
{
'domain': '10.0.0.0/8',
'cleartextTrafficPermitted': true
},
{
'domain': '172.16.0.0/12',
'cleartextTrafficPermitted': true
},
{
'domain': '192.168.0.0/16',
'cleartextTrafficPermitted': true
}
]
}
}
}
]
],
// ... rest of your configuration
};
export default config;
Means little to me as I don't know Expo/React Native, but I get the IP address reasoning so hopefully this isn't too far off hte mark 😄
This is so helpful, thank you so much @DanMakingWithAI!