parent
7488525641
commit
ae40715526
@ -1,50 +1,24 @@
|
|||||||
package org.thoughtcrime.securesms.push;
|
package org.thoughtcrime.securesms.push;
|
||||||
|
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.support.annotation.NonNull;
|
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.BuildConfig;
|
import org.thoughtcrime.securesms.BuildConfig;
|
||||||
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
||||||
import org.whispersystems.signalservice.api.SignalServiceAccountManager;
|
import org.whispersystems.signalservice.api.SignalServiceAccountManager;
|
||||||
import org.whispersystems.signalservice.api.push.TrustStore;
|
|
||||||
import org.whispersystems.signalservice.internal.push.SignalServiceUrl;
|
import org.whispersystems.signalservice.internal.push.SignalServiceUrl;
|
||||||
|
|
||||||
public class AccountManagerFactory {
|
public class AccountManagerFactory {
|
||||||
|
|
||||||
public static SignalServiceAccountManager createManager(Context context) {
|
public static SignalServiceAccountManager createManager(Context context) {
|
||||||
return new SignalServiceAccountManager(getUrl(context), getTrustStore(context),
|
return new SignalServiceAccountManager(new SignalServiceNetworkAccess(context).getConfiguration(context),
|
||||||
TextSecurePreferences.getLocalNumber(context),
|
TextSecurePreferences.getLocalNumber(context),
|
||||||
TextSecurePreferences.getPushServerPassword(context),
|
TextSecurePreferences.getPushServerPassword(context),
|
||||||
BuildConfig.USER_AGENT);
|
BuildConfig.USER_AGENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static SignalServiceAccountManager createManager(Context context, String number, String password) {
|
public static SignalServiceAccountManager createManager(Context context, String number, String password) {
|
||||||
return new SignalServiceAccountManager(getUrl(number), getTrustStore(context, number),
|
return new SignalServiceAccountManager(new SignalServiceNetworkAccess(context).getConfiguration(number),
|
||||||
number, password, BuildConfig.USER_AGENT);
|
number, password, BuildConfig.USER_AGENT);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SignalServiceUrl getUrl(@NonNull Context context) {
|
|
||||||
return getUrl(TextSecurePreferences.getLocalNumber(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TrustStore getTrustStore(@NonNull Context context) {
|
|
||||||
return getTrustStore(context, TextSecurePreferences.getLocalNumber(context));
|
|
||||||
}
|
|
||||||
|
|
||||||
private static SignalServiceUrl getUrl(@NonNull String number) {
|
|
||||||
if (Censorship.isCensored(number)) {
|
|
||||||
return new SignalServiceUrl(BuildConfig.UNCENSORED_FRONTING_HOST, BuildConfig.CENSORED_REFLECTOR);
|
|
||||||
} else {
|
|
||||||
return new SignalServiceUrl(BuildConfig.TEXTSECURE_URL, null);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private static TrustStore getTrustStore(@NonNull Context context, @NonNull String number) {
|
|
||||||
if (Censorship.isCensored(number)) {
|
|
||||||
return new CensorshipFrontingTrustStore(context);
|
|
||||||
} else {
|
|
||||||
return new SignalServiceTrustStore(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -1,26 +0,0 @@
|
|||||||
package org.thoughtcrime.securesms.push;
|
|
||||||
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
|
|
||||||
import org.thoughtcrime.securesms.BuildConfig;
|
|
||||||
import org.thoughtcrime.securesms.util.TextSecurePreferences;
|
|
||||||
|
|
||||||
public class Censorship {
|
|
||||||
|
|
||||||
public static boolean isCensored(Context context) {
|
|
||||||
String localNumber = TextSecurePreferences.getLocalNumber(context);
|
|
||||||
return isCensored(localNumber);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static boolean isCensored(String localNumber) {
|
|
||||||
for (String censoredRegion : BuildConfig.CENSORED_COUNTRIES) {
|
|
||||||
if (localNumber.startsWith(censoredRegion)) {
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@ -0,0 +1,77 @@
|
|||||||
|
package org.thoughtcrime.securesms.push;
|
||||||
|
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
|
||||||
|
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;
|
||||||
|
|
||||||
|
public class SignalServiceNetworkAccess {
|
||||||
|
|
||||||
|
private static final String TAG = SignalServiceNetworkAccess.class.getName();
|
||||||
|
|
||||||
|
private static final String APPSPOT_REFLECTOR_HOST = "signal-reflector-meek.appspot.com";
|
||||||
|
|
||||||
|
private final Map<String, SignalServiceUrl[]> censorshipConfiguration;
|
||||||
|
private final String[] censoredCountries;
|
||||||
|
private final SignalServiceUrl[] uncensoredConfiguration;
|
||||||
|
|
||||||
|
public SignalServiceNetworkAccess(Context context) {
|
||||||
|
final TrustStore googleTrustStore = new GoogleFrontingTrustStore(context);
|
||||||
|
final SignalServiceUrl baseGoogle = new SignalServiceUrl("https://www.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore);
|
||||||
|
final SignalServiceUrl baseAndroid = new SignalServiceUrl("https://android.clients.google.com", APPSPOT_REFLECTOR_HOST, googleTrustStore);
|
||||||
|
|
||||||
|
this.censorshipConfiguration = new HashMap<String, SignalServiceUrl[]>() {{
|
||||||
|
put("+20", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.eg",
|
||||||
|
APPSPOT_REFLECTOR_HOST,
|
||||||
|
googleTrustStore),
|
||||||
|
baseAndroid});
|
||||||
|
|
||||||
|
put("+971", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.ae",
|
||||||
|
APPSPOT_REFLECTOR_HOST,
|
||||||
|
googleTrustStore),
|
||||||
|
baseAndroid, baseGoogle});
|
||||||
|
|
||||||
|
put("+53", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.om",
|
||||||
|
APPSPOT_REFLECTOR_HOST,
|
||||||
|
googleTrustStore),
|
||||||
|
baseAndroid, baseGoogle});
|
||||||
|
|
||||||
|
put("+968", new SignalServiceUrl[] {new SignalServiceUrl("https://www.google.com.cu",
|
||||||
|
APPSPOT_REFLECTOR_HOST,
|
||||||
|
googleTrustStore),
|
||||||
|
baseAndroid, baseGoogle});
|
||||||
|
}};
|
||||||
|
|
||||||
|
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);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SignalServiceUrl[] getConfiguration(String localNumber) {
|
||||||
|
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;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue