add the ability for briar-android to get the current country.

- this will be useful later for e.g. auto-disabling Tor
This commit is contained in:
Ximin Luo
2014-02-06 19:16:04 +00:00
parent 39b7a97267
commit 9697b351e9
4 changed files with 58 additions and 0 deletions

View File

@@ -44,6 +44,7 @@ import org.briarproject.util.StringUtils;
import socks.Socks5Proxy;
import socks.SocksSocket;
import android.annotation.SuppressLint;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
@@ -275,6 +276,7 @@ class TorPlugin implements DuplexPlugin, EventHandler {
out.close();
}
@SuppressLint("NewApi")
private boolean setExecutable(File f) {
if(Build.VERSION.SDK_INT >= 9) {
return f.setExecutable(true, true);

View File

@@ -0,0 +1,46 @@
package org.briarproject.system;
import java.util.Locale;
import java.util.logging.Logger;
import org.briarproject.api.system.LocationUtils;
import roboguice.inject.ContextSingleton;
import android.annotation.SuppressLint;
import android.content.Context;
import android.telephony.TelephonyManager;
import android.text.TextUtils;
import com.google.inject.Inject;
@ContextSingleton
class AndroidLocationUtils implements LocationUtils {
private static final Logger LOG =
Logger.getLogger(AndroidLocationUtils.class.getName());
final Context context;
@Inject
public AndroidLocationUtils(Context context) {
this.context = context;
}
@SuppressLint("DefaultLocale")
@Override
public String getCurrentCountry() {
String countryCode;
countryCode = getCountryFromPhoneNetwork();
if (!TextUtils.isEmpty(countryCode)) {
return countryCode.toUpperCase(); // android api gives lowercase for some reason
}
LOG.warning("Could not determine current country; fall back to user-defined locale");
return Locale.getDefault().getCountry();
}
String getCountryFromPhoneNetwork() {
TelephonyManager tm = (TelephonyManager)context.getSystemService(Context.TELEPHONY_SERVICE);
return tm.getNetworkCountryIso();
}
}

View File

@@ -2,6 +2,7 @@ package org.briarproject.system;
import org.briarproject.api.system.Clock;
import org.briarproject.api.system.FileUtils;
import org.briarproject.api.system.LocationUtils;
import org.briarproject.api.system.SeedProvider;
import org.briarproject.api.system.Timer;
@@ -14,5 +15,6 @@ public class AndroidSystemModule extends AbstractModule {
bind(Timer.class).to(SystemTimer.class);
bind(SeedProvider.class).to(AndroidSeedProvider.class);
bind(FileUtils.class).to(AndroidFileUtils.class);
bind(LocationUtils.class).to(AndroidLocationUtils.class);
}
}

View File

@@ -0,0 +1,8 @@
package org.briarproject.api.system;
public interface LocationUtils {
/** Get the country the device is currently-located in. */
String getCurrentCountry();
}