2016-12-30 04:54:05 +00:00
|
|
|
package org.thoughtcrime.securesms.push;
|
|
|
|
|
|
|
|
|
|
|
|
import android.content.Context;
|
2017-01-11 23:37:51 +00:00
|
|
|
import android.support.annotation.NonNull;
|
|
|
|
import android.support.annotation.Nullable;
|
2016-12-30 04:54:05 +00:00
|
|
|
|
|
|
|
import org.thoughtcrime.securesms.BuildConfig;
|
|
|
|
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
|
|
|
import org.whispersystems.signalservice.api.push.TrustStore;
|
|
|
|
import org.whispersystems.signalservice.internal.push.SignalServiceUrl;
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
|
|
|
|
2017-01-11 23:37:51 +00:00
|
|
|
import okhttp3.CipherSuite;
|
|
|
|
import okhttp3.ConnectionSpec;
|
|
|
|
import okhttp3.TlsVersion;
|
|
|
|
|
2016-12-30 04:54:05 +00:00
|
|
|
public class SignalServiceNetworkAccess {
|
|
|
|
|
|
|
|
private static final String TAG = SignalServiceNetworkAccess.class.getName();
|
|
|
|
|
|
|
|
private static final String APPSPOT_REFLECTOR_HOST = "signal-reflector-meek.appspot.com";
|
|
|
|
|
2017-01-11 23:37:51 +00:00
|
|
|
private static final ConnectionSpec GMAPS_CONNECTION_SPEC = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
|
|
|
|
.tlsVersions(TlsVersion.TLS_1_2)
|
|
|
|
.cipherSuites(CipherSuite.TLS_ECDHE_ECDSA_WITH_CHACHA20_POLY1305_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_CHACHA20_POLY1305_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_256_CBC_SHA)
|
|
|
|
.supportsTlsExtensions(true)
|
|
|
|
.build();
|
|
|
|
|
|
|
|
private static final ConnectionSpec GMAIL_CONNECTION_SPEC = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
|
|
|
|
.tlsVersions(TlsVersion.TLS_1_2)
|
|
|
|
.cipherSuites(CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_256_GCM_SHA384,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV)
|
|
|
|
.supportsTlsExtensions(true)
|
|
|
|
.build();
|
|
|
|
|
|
|
|
private static final ConnectionSpec PLAY_CONNECTION_SPEC = new ConnectionSpec.Builder(ConnectionSpec.MODERN_TLS)
|
|
|
|
.tlsVersions(TlsVersion.TLS_1_2)
|
|
|
|
.cipherSuites(CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_ECDSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_ECDHE_RSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_DHE_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_GCM_SHA256,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_128_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_AES_256_CBC_SHA,
|
|
|
|
CipherSuite.TLS_RSA_WITH_RC4_128_SHA,
|
|
|
|
CipherSuite.TLS_EMPTY_RENEGOTIATION_INFO_SCSV)
|
|
|
|
.supportsTlsExtensions(true)
|
|
|
|
.build();
|
|
|
|
|
|
|
|
|
2016-12-30 04:54:05 +00:00
|
|
|
private final Map<String, SignalServiceUrl[]> censorshipConfiguration;
|
|
|
|
private final String[] censoredCountries;
|
|
|
|
private final SignalServiceUrl[] uncensoredConfiguration;
|
|
|
|
|
|
|
|
public SignalServiceNetworkAccess(Context context) {
|
|
|
|
final TrustStore googleTrustStore = new GoogleFrontingTrustStore(context);
|
2017-01-11 23:37:51 +00:00
|
|
|
final SignalServiceUrl baseGoogle = new SignalServiceUrl("https://www.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore, GMAIL_CONNECTION_SPEC);
|
|
|
|
final SignalServiceUrl baseAndroid = new SignalServiceUrl("https://android.clients.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore, PLAY_CONNECTION_SPEC);
|
|
|
|
final SignalServiceUrl mapsOneAndroid = new SignalServiceUrl("https://clients3.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore, GMAPS_CONNECTION_SPEC);
|
|
|
|
final SignalServiceUrl mapsTwoAndroid = new SignalServiceUrl("https://clients4.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore, GMAPS_CONNECTION_SPEC);
|
|
|
|
final SignalServiceUrl mailAndroid = new SignalServiceUrl("https://mail.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore, GMAIL_CONNECTION_SPEC);
|
2016-12-30 04:54:05 +00:00
|
|
|
|
|
|
|
this.censorshipConfiguration = new HashMap<String, SignalServiceUrl[]>() {{
|
|
|
|
put("+20", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.eg",
|
|
|
|
APPSPOT_REFLECTOR_HOST,
|
2017-01-11 23:37:51 +00:00
|
|
|
googleTrustStore, GMAIL_CONNECTION_SPEC),
|
|
|
|
baseAndroid, mapsOneAndroid, mapsTwoAndroid, mailAndroid});
|
2016-12-30 04:54:05 +00:00
|
|
|
|
|
|
|
put("+971", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.ae",
|
|
|
|
APPSPOT_REFLECTOR_HOST,
|
2017-01-11 23:37:51 +00:00
|
|
|
googleTrustStore, GMAIL_CONNECTION_SPEC),
|
|
|
|
baseAndroid, baseGoogle, mapsOneAndroid, mapsTwoAndroid, mailAndroid});
|
2016-12-30 04:54:05 +00:00
|
|
|
|
2017-01-23 18:46:57 +00:00
|
|
|
// put("+53", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.cu",
|
|
|
|
// APPSPOT_REFLECTOR_HOST,
|
|
|
|
// googleTrustStore, GMAIL_CONNECTION_SPEC),
|
|
|
|
// baseAndroid, baseGoogle, mapsOneAndroid, mapsTwoAndroid, mailAndroid});
|
2016-12-30 04:54:05 +00:00
|
|
|
|
2016-12-31 16:02:52 +00:00
|
|
|
put("+968", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.om",
|
2016-12-30 04:54:05 +00:00
|
|
|
APPSPOT_REFLECTOR_HOST,
|
2017-01-11 23:37:51 +00:00
|
|
|
googleTrustStore, GMAIL_CONNECTION_SPEC),
|
|
|
|
baseAndroid, baseGoogle, mapsOneAndroid, mapsTwoAndroid, mailAndroid});
|
2016-12-30 04:54:05 +00:00
|
|
|
}};
|
|
|
|
|
|
|
|
this.uncensoredConfiguration = new SignalServiceUrl[] {
|
|
|
|
new SignalServiceUrl(BuildConfig.SIGNAL_URL, new SignalServiceTrustStore(context))
|
|
|
|
};
|
|
|
|
|
|
|
|
this.censoredCountries = this.censorshipConfiguration.keySet().toArray(new String[0]);
|
|
|
|
}
|
|
|
|
|
|
|
|
public SignalServiceUrl[] getConfiguration(Context context) {
|
|
|
|
String localNumber = TextSecurePreferences.getLocalNumber(context);
|
|
|
|
return getConfiguration(localNumber);
|
|
|
|
}
|
|
|
|
|
2017-01-11 23:37:51 +00:00
|
|
|
public SignalServiceUrl[] getConfiguration(@Nullable String localNumber) {
|
|
|
|
if (localNumber == null) return this.uncensoredConfiguration;
|
|
|
|
|
2016-12-30 04:54:05 +00:00
|
|
|
for (String censoredRegion : this.censoredCountries) {
|
|
|
|
if (localNumber.startsWith(censoredRegion)) {
|
|
|
|
return this.censorshipConfiguration.get(censoredRegion);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return this.uncensoredConfiguration;
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isCensored(Context context) {
|
|
|
|
return getConfiguration(context) != this.uncensoredConfiguration;
|
|
|
|
}
|
|
|
|
|
2017-01-11 23:37:51 +00:00
|
|
|
public boolean isCensored(String number) {
|
|
|
|
return getConfiguration(number) != this.uncensoredConfiguration;
|
|
|
|
}
|
|
|
|
|
2016-12-30 04:54:05 +00:00
|
|
|
}
|