From 11f3fe7fc3c369cd7ebc41a44165a07b23b92d28 Mon Sep 17 00:00:00 2001 From: Nathan Freitas Date: Thu, 29 Jul 2010 17:03:34 +0000 Subject: [PATCH] fix for root perms bug svn:r22707 --- .../android/SettingsPreferences.java | 18 ++- .../android/service/TorService.java | 148 ++++++++++++++---- 2 files changed, 131 insertions(+), 35 deletions(-) diff --git a/src/org/torproject/android/SettingsPreferences.java b/src/org/torproject/android/SettingsPreferences.java index 45db4405..13fcd4f1 100644 --- a/src/org/torproject/android/SettingsPreferences.java +++ b/src/org/torproject/android/SettingsPreferences.java @@ -21,6 +21,9 @@ public class SettingsPreferences private CheckBoxPreference prefCBTransProxy = null; private CheckBoxPreference prefcBTransProxyAll = null; private Preference prefTransProxyApps = null; + private Preference prefWebProxy = null; + + private boolean hasRoot = false; @@ -60,7 +63,9 @@ public class SettingsPreferences } - + //disabled for now 28/07 nf + //prefWebProxy = ((PreferenceCategory)this.getPreferenceScreen().getPreference(1)).getPreference(0); + //prefWebProxy.setOnPreferenceClickListener(this); } @@ -83,6 +88,17 @@ public class SettingsPreferences if (preference == prefTransProxyApps) { startActivity(new Intent(this, AppManager.class)); + } + else if (preference == prefWebProxy) + { + Intent intent = new Intent(); + intent.setClassName(this,"com.android.settings.ProxySelector"); + intent.putExtra("title", "Set host=127.0.0.1 and port=8118"); + intent.putExtra("button-label", "Save"); + + startActivity(intent); + + } else { diff --git a/src/org/torproject/android/service/TorService.java b/src/org/torproject/android/service/TorService.java index cd7a8ab9..f1f6a577 100644 --- a/src/org/torproject/android/service/TorService.java +++ b/src/org/torproject/android/service/TorService.java @@ -10,6 +10,7 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.Iterator; import java.util.List; +import java.util.StringTokenizer; import net.freehaven.tor.control.ConfigEntry; import net.freehaven.tor.control.EventHandler; @@ -18,6 +19,7 @@ import net.freehaven.tor.control.TorControlConnection; import org.torproject.android.AppManager; import org.torproject.android.Orbot; import org.torproject.android.R; +import org.torproject.android.TorConstants; import android.app.AlertDialog; import android.app.Notification; @@ -652,12 +654,8 @@ public class TorService extends Service implements TorServiceConstants, Runnable addEventHandler(); - if (configBuffer != null) - { - conn.setConf(configBuffer); - //conn.saveConf(); - configBuffer = null; - } + applyPreferences(); + break; //don't need to retry } @@ -978,34 +976,11 @@ public class TorService extends Service implements TorServiceConstants, Runnable **/ public boolean updateConfiguration (String name, String value, boolean saveToDisk) { - try - { - if (conn != null) - { - conn.setConf(name, value); - - if (saveToDisk) - { - // Flush the configuration to disk. - //conn.saveConf(); //NF 22/07/10 this is crashing right now - } + if (configBuffer == null) + configBuffer = new ArrayList(); - return true; - } - else - { - if (configBuffer == null) - configBuffer = new ArrayList(); - - configBuffer.add(name + ' ' + value); - } - } - catch (IOException ioe) - { - Log.e(TAG, "Unable to update Tor configuration", ioe); - logNotice("Unable to update Tor configuration: " + ioe.getMessage()); - } - + configBuffer.add(name + ' ' + value); + return false; } @@ -1015,7 +990,12 @@ public class TorService extends Service implements TorServiceConstants, Runnable { if (conn != null) { - + if (configBuffer != null) + { + conn.setConf(configBuffer); + //conn.saveConf(); + configBuffer = null; + } // Flush the configuration to disk. //this is doing bad things right now NF 22/07/10 @@ -1074,6 +1054,106 @@ public class TorService extends Service implements TorServiceConstants, Runnable mCallbacks.finishBroadcast(); } + private void applyPreferences () throws RemoteException + { + + + + SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this); + + boolean useBridges = prefs.getBoolean(TorConstants.PREF_BRIDGES_ENABLED, false); + + boolean autoUpdateBridges = prefs.getBoolean(TorConstants.PREF_BRIDGES_UPDATED, false); + + boolean becomeRelay = prefs.getBoolean(TorConstants.PREF_OR, false); + + boolean ReachableAddresses = prefs.getBoolean(TorConstants.PREF_REACHABLE_ADDRESSES,false); + + boolean enableTransparentProxy = prefs.getBoolean(TorConstants.PREF_TRANSPARENT, false); + + + String bridgeList = prefs.getString(TorConstants.PREF_BRIDGES_LIST,""); + + if (useBridges) + { + if (bridgeList == null || bridgeList.length() == 0) + { + + showAlert("Bridge Error","In order to use the bridge feature, you must enter at least one bridge IP address." + + "Send an email to bridges@torproject.org with the line \"get bridges\" by itself in the body of the mail from a gmail account."); + + + return; + } + + + mBinder.updateConfiguration("UseBridges", "1", false); + + String bridgeDelim = "\n"; + + if (bridgeList.indexOf(",") != -1) + { + bridgeDelim = ","; + } + + StringTokenizer st = new StringTokenizer(bridgeList,bridgeDelim); + while (st.hasMoreTokens()) + { + + mBinder.updateConfiguration("bridge", st.nextToken(), false); + + } + + mBinder.updateConfiguration("UpdateBridgesFromAuthority", "0", false); + + } + else + { + mBinder.updateConfiguration("UseBridges", "0", false); + + } + + try + { + if (ReachableAddresses) + { + String ReachableAddressesPorts = + prefs.getString(TorConstants.PREF_REACHABLE_ADDRESSES_PORTS, "*:80,*:443"); + + mBinder.updateConfiguration("ReachableAddresses", ReachableAddressesPorts, false); + + } + } + catch (Exception e) + { + showAlert("Config Error","Your ReachableAddresses settings caused an exception!"); + } + + try + { + if (becomeRelay && (!useBridges) && (!ReachableAddresses)) + { + int ORPort = Integer.parseInt(prefs.getString(TorConstants.PREF_OR_PORT, "9001")); + String nickname = prefs.getString(TorConstants.PREF_OR_NICKNAME, "Orbot"); + + mBinder.updateConfiguration("ORPort", ORPort + "", false); + mBinder.updateConfiguration("Nickname", nickname, false); + mBinder.updateConfiguration("ExitPolicy", "reject *:*", false); + + } + } + catch (Exception e) + { + showAlert("Uh-oh!","Your relay settings caused an exception!"); + + return; + } + + mBinder.saveConfiguration(); + + } + + private void setupTransProxy (boolean enabled) {