Updated UI for start/stop notifications and systems preferences
svn:r24646
This commit is contained in:
		
							parent
							
								
									28379e1d57
								
							
						
					
					
						commit
						24108e1206
					
				|  | @ -69,6 +69,7 @@ public class AppManager extends Activity implements OnCheckedChangeListener, OnC | ||||||
| 
 | 
 | ||||||
| 	private void loadApps () | 	private void loadApps () | ||||||
| 	{ | 	{ | ||||||
|  | 		resetApps(this); | ||||||
|         final TorifiedApp[] apps = getApps(this); |         final TorifiedApp[] apps = getApps(this); | ||||||
|          |          | ||||||
|         Arrays.sort(apps, new Comparator<TorifiedApp>() { |         Arrays.sort(apps, new Comparator<TorifiedApp>() { | ||||||
|  | @ -140,11 +141,17 @@ public class AppManager extends Activity implements OnCheckedChangeListener, OnC | ||||||
| 	protected void onStop() { | 	protected void onStop() { | ||||||
| 		super.onStop(); | 		super.onStop(); | ||||||
| 		 | 		 | ||||||
| 		//Log.d(getClass().getName(),"Exiting Preferences"); |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 
 |  | ||||||
| 	public static TorifiedApp[] getApps (Context context) | 	public static TorifiedApp[] getApps (Context context) | ||||||
|  | 	{ | ||||||
|  | 		if (apps == null) | ||||||
|  | 			resetApps(context); | ||||||
|  | 		 | ||||||
|  | 		return apps; | ||||||
|  | 	} | ||||||
|  | 	 | ||||||
|  | 	public static TorifiedApp[] resetApps (Context context) | ||||||
| 	{ | 	{ | ||||||
| 
 | 
 | ||||||
| 		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); | 		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); | ||||||
|  | @ -200,6 +207,7 @@ public class AppManager extends Activity implements OnCheckedChangeListener, OnC | ||||||
| 			appIdx++; | 			appIdx++; | ||||||
| 		} | 		} | ||||||
| 	 | 	 | ||||||
|  | 		 | ||||||
| 		return apps; | 		return apps; | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
|  |  | ||||||
|  | @ -33,19 +33,20 @@ import android.os.RemoteException; | ||||||
| import android.preference.PreferenceManager; | import android.preference.PreferenceManager; | ||||||
| import android.util.Log; | import android.util.Log; | ||||||
| import android.view.KeyEvent; | import android.view.KeyEvent; | ||||||
|  | import android.view.LayoutInflater; | ||||||
| import android.view.Menu; | import android.view.Menu; | ||||||
| import android.view.MenuItem; | import android.view.MenuItem; | ||||||
| import android.view.MotionEvent; | import android.view.MotionEvent; | ||||||
| import android.view.View; | import android.view.View; | ||||||
| import android.view.View.OnClickListener; | import android.view.View.OnClickListener; | ||||||
|  | import android.view.View.OnLongClickListener; | ||||||
| import android.widget.ImageView; | import android.widget.ImageView; | ||||||
| import android.widget.TextView; | import android.widget.TextView; | ||||||
| 
 | 
 | ||||||
| public class Orbot extends Activity implements OnClickListener, TorConstants | public class Orbot extends Activity implements OnLongClickListener, TorConstants | ||||||
| { | { | ||||||
| 	 | 	 | ||||||
| 	/* Useful UI bits */ | 	/* Useful UI bits */ | ||||||
| 	//private TextView txtMessageLog = null; //the full screen log view of Tor control messages |  | ||||||
| 	private TextView lblStatus = null; //the main text display widget | 	private TextView lblStatus = null; //the main text display widget | ||||||
| 	private ImageView imgStatus = null; //the main touchable image for activating Orbot | 	private ImageView imgStatus = null; //the main touchable image for activating Orbot | ||||||
| 	private ProgressDialog progressDialog; | 	private ProgressDialog progressDialog; | ||||||
|  | @ -53,8 +54,6 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	 | 	 | ||||||
| 	/* Some tracking bits */ | 	/* Some tracking bits */ | ||||||
| 	private int torStatus = STATUS_READY; //latest status reported from the tor service | 	private int torStatus = STATUS_READY; //latest status reported from the tor service | ||||||
| 	private int currentView = 0; //the currently displayed UI view |  | ||||||
| 	private StringBuffer logBuffer = new StringBuffer(); //the output of the service log messages |  | ||||||
| 	 | 	 | ||||||
| 	/* Tor Service interaction */ | 	/* Tor Service interaction */ | ||||||
| 		/* The primary interface we will be calling on the service. */ | 		/* The primary interface we will be calling on the service. */ | ||||||
|  | @ -63,13 +62,14 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 
 | 
 | ||||||
| 	SharedPreferences prefs; | 	SharedPreferences prefs; | ||||||
| 	 | 	 | ||||||
|     Orbot mOrbot = null; |  | ||||||
|      |  | ||||||
|     /** Called when the activity is first created. */ |     /** Called when the activity is first created. */ | ||||||
|     public void onCreate(Bundle savedInstanceState) { |     public void onCreate(Bundle savedInstanceState) { | ||||||
|         super.onCreate(savedInstanceState); |         super.onCreate(savedInstanceState); | ||||||
|          |          | ||||||
|         mOrbot = this; |       //if Tor binary is not running, then start the service up | ||||||
|  | 		startService(new Intent(INTENT_TOR_SERVICE)); | ||||||
|  | 		bindService (); | ||||||
|  | 		 | ||||||
| 
 | 
 | ||||||
|     	setTheme(android.R.style.Theme_Black_NoTitleBar); |     	setTheme(android.R.style.Theme_Black_NoTitleBar); | ||||||
|     	 |     	 | ||||||
|  | @ -96,18 +96,35 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|         mItem = menu.add(0, 7, Menu.NONE, getString(R.string.menu_verify)); |         mItem = menu.add(0, 7, Menu.NONE, getString(R.string.menu_verify)); | ||||||
|         mItem.setIcon(R.drawable.ic_menu_check); |         mItem.setIcon(R.drawable.ic_menu_check); | ||||||
|        |        | ||||||
|        // mItem =  menu.add(0,6, Menu.NONE, getString(R.string.menu_log)); |         mItem =  menu.add(0,6, Menu.NONE, getString(R.string.menu_about)); | ||||||
|        // mItem.setIcon(R.drawable.ic_menu_reports); |  | ||||||
|          |  | ||||||
|         mItem = menu.add(0, 3, Menu.NONE, getString(R.string.menu_info)); |  | ||||||
|         mItem.setIcon(R.drawable.ic_menu_about); |         mItem.setIcon(R.drawable.ic_menu_about); | ||||||
|          |          | ||||||
|  |         mItem = menu.add(0, 3, Menu.NONE, getString(R.string.menu_wizard)); | ||||||
|  |         mItem.setIcon(R.drawable.ic_menu_goto); | ||||||
|  |         | ||||||
|         mItem = menu.add(0, 8, Menu.NONE, getString(R.string.menu_exit)); |         mItem = menu.add(0, 8, Menu.NONE, getString(R.string.menu_exit)); | ||||||
|         mItem.setIcon(R.drawable.ic_menu_exit); |         mItem.setIcon(R.drawable.ic_menu_exit); | ||||||
|         |         | ||||||
|  |          | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|      |      | ||||||
|  | 
 | ||||||
|  |     private void showAbout () | ||||||
|  | 	{ | ||||||
|  | 		 | ||||||
|  | 		LayoutInflater li = LayoutInflater.from(this); | ||||||
|  |         View view = li.inflate(R.layout.layout_about, null);  | ||||||
|  |          | ||||||
|  |         TextView versionName = (TextView)view.findViewById(R.id.versionName); | ||||||
|  |         versionName.setText(R.string.app_version);     | ||||||
|  |          | ||||||
|  | 		new AlertDialog.Builder(this) | ||||||
|  |         .setTitle(getString(R.string.button_about)) | ||||||
|  |         .setView(view) | ||||||
|  |         .show(); | ||||||
|  | 	} | ||||||
|  |      | ||||||
|     /* When a menu item is selected launch the appropriate view or activity |     /* When a menu item is selected launch the appropriate view or activity | ||||||
|      * (non-Javadoc) |      * (non-Javadoc) | ||||||
| 	 * @see android.app.Activity#onMenuItemSelected(int, android.view.MenuItem) | 	 * @see android.app.Activity#onMenuItemSelected(int, android.view.MenuItem) | ||||||
|  | @ -128,12 +145,14 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 				} | 				} | ||||||
| 				else if (mService.getStatus() == STATUS_READY) | 				else if (mService.getStatus() == STATUS_READY) | ||||||
| 				{ | 				{ | ||||||
|  | 		    		if (mItemOnOff != null) | ||||||
| 		    			mItemOnOff.setTitle(R.string.menu_stop); | 		    			mItemOnOff.setTitle(R.string.menu_stop); | ||||||
| 					startTor(); | 					startTor(); | ||||||
| 					 | 					 | ||||||
| 				} | 				} | ||||||
| 				else | 				else | ||||||
| 				{ | 				{ | ||||||
|  | 		    		if (mItemOnOff != null) | ||||||
| 		    			mItemOnOff.setTitle(R.string.menu_start); | 		    			mItemOnOff.setTitle(R.string.menu_start); | ||||||
| 					stopTor(); | 					stopTor(); | ||||||
| 					 | 					 | ||||||
|  | @ -163,6 +182,12 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 			doExit(); | 			doExit(); | ||||||
| 			 | 			 | ||||||
| 			 | 			 | ||||||
|  | 		} | ||||||
|  | 		else if (item.getItemId() == 6) | ||||||
|  | 		{ | ||||||
|  | 			showAbout(); | ||||||
|  | 			 | ||||||
|  | 			 | ||||||
| 		} | 		} | ||||||
| 		 | 		 | ||||||
|         return true; |         return true; | ||||||
|  | @ -224,7 +249,6 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		  // Save UI state changes to the savedInstanceState. | 		  // Save UI state changes to the savedInstanceState. | ||||||
| 		  // This bundle will be passed to onCreate if the process is | 		  // This bundle will be passed to onCreate if the process is | ||||||
| 		  // killed and restarted. | 		  // killed and restarted. | ||||||
| 		  savedInstanceState.putString("log", logBuffer.toString()); |  | ||||||
| 		  // etc. | 		  // etc. | ||||||
| 		  super.onSaveInstanceState(savedInstanceState); | 		  super.onSaveInstanceState(savedInstanceState); | ||||||
| 		} | 		} | ||||||
|  | @ -234,14 +258,13 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	  // Restore UI state from the savedInstanceState. | 	  // Restore UI state from the savedInstanceState. | ||||||
| 	  // This bundle has also been passed to onCreate. | 	  // This bundle has also been passed to onCreate. | ||||||
| 	  | 	  | ||||||
| 	  String logText = savedInstanceState.getString("log"); |  | ||||||
| 	  logBuffer.append(logText); |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	private void doTorCheck () | 	private void doTorCheck () | ||||||
| 	{ | 	{ | ||||||
| 		 | 		 | ||||||
| 		DialogInterface.OnClickListener dialogClickListener = new DialogInterface.OnClickListener() { | 		DialogInterface.OnClickListener dialogClickListener = new DialogInterface.OnClickListener() { | ||||||
|  | 			 | ||||||
| 		    @Override | 		    @Override | ||||||
| 		    public void onClick(DialogInterface dialog, int which) { | 		    public void onClick(DialogInterface dialog, int which) { | ||||||
| 		        switch (which){ | 		        switch (which){ | ||||||
|  | @ -269,7 +292,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	 | 	 | ||||||
| 	private void enableHiddenServicePort (int hsPort) | 	private void enableHiddenServicePort (int hsPort) | ||||||
| 	{ | 	{ | ||||||
| 		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(mOrbot); | 		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this); | ||||||
| 		Editor pEdit = prefs.edit(); | 		Editor pEdit = prefs.edit(); | ||||||
| 		 | 		 | ||||||
| 		String hsPortString = prefs.getString("pref_hs_ports", ""); | 		String hsPortString = prefs.getString("pref_hs_ports", ""); | ||||||
|  | @ -284,20 +307,12 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		 | 		 | ||||||
| 		pEdit.commit(); | 		pEdit.commit(); | ||||||
| 		 | 		 | ||||||
| 		try { | 		String onionHostname = prefs.getString("pref_hs_hostname",""); | ||||||
| 			processSettings(); |  | ||||||
| 		 |  | ||||||
| 			String onionHostname = getHiddenServiceHostname(); |  | ||||||
| 
 | 
 | ||||||
| 		Intent nResult = new Intent(); | 		Intent nResult = new Intent(); | ||||||
| 		nResult.putExtra("hs_host", onionHostname); | 		nResult.putExtra("hs_host", onionHostname); | ||||||
| 		setResult(RESULT_OK, nResult); | 		setResult(RESULT_OK, nResult); | ||||||
| 	 | 	 | ||||||
| 		} catch (RemoteException e) { |  | ||||||
| 			Log.e(TAG, "error accessing hidden service", e); |  | ||||||
| 		} |  | ||||||
| 		 |  | ||||||
| 		 |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	/* (non-Javadoc) | 	/* (non-Javadoc) | ||||||
|  | @ -307,6 +322,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		super.onResume(); | 		super.onResume(); | ||||||
| 		 | 		 | ||||||
| 		 showMain(); | 		 showMain(); | ||||||
|  | 		 updateStatus(""); | ||||||
| 		  | 		  | ||||||
| 		if (getIntent() == null) | 		if (getIntent() == null) | ||||||
| 			return; | 			return; | ||||||
|  | @ -367,8 +383,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 			NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); | 			NotificationManager mNotificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE); | ||||||
| 			mNotificationManager.cancelAll(); | 			mNotificationManager.cancelAll(); | ||||||
| 			 | 			 | ||||||
| 			 | 			SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this); | ||||||
| 			SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(mOrbot); |  | ||||||
| 	 | 	 | ||||||
| 			boolean showWizard = prefs.getBoolean("show_wizard",true); | 			boolean showWizard = prefs.getBoolean("show_wizard",true); | ||||||
| 			 | 			 | ||||||
|  | @ -394,9 +409,6 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	protected void onStart() { | 	protected void onStart() { | ||||||
| 		super.onStart(); | 		super.onStart(); | ||||||
| 		 | 		 | ||||||
| 		//if Tor binary is not running, then start the service up |  | ||||||
| 		startService(new Intent(INTENT_TOR_SERVICE)); |  | ||||||
| 		bindService (); |  | ||||||
| 		 | 		 | ||||||
| 		updateStatus (""); | 		updateStatus (""); | ||||||
| 		 | 		 | ||||||
|  | @ -419,19 +431,14 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	 */ | 	 */ | ||||||
| 	private void showMain () | 	private void showMain () | ||||||
|     { |     { | ||||||
| 	//	bindService(); //connect the UI activity to the remote service |  | ||||||
| 		 | 		 | ||||||
| 		currentView = R.layout.layout_main; | 		setContentView(R.layout.layout_main); | ||||||
| 		setContentView(currentView); |  | ||||||
| 		 |  | ||||||
| 		//add touch listeners for the image and the text label |  | ||||||
|     	findViewById(R.id.imgStatus).setOnClickListener(this);  |  | ||||||
|     	findViewById(R.id.lblStatus).setOnClickListener(this); |  | ||||||
| 		 | 		 | ||||||
|     	lblStatus = (TextView)findViewById(R.id.lblStatus); |     	lblStatus = (TextView)findViewById(R.id.lblStatus); | ||||||
|  | 		lblStatus.setOnLongClickListener(this); | ||||||
|     	imgStatus = (ImageView)findViewById(R.id.imgStatus); |     	imgStatus = (ImageView)findViewById(R.id.imgStatus); | ||||||
|  |     	imgStatus.setOnLongClickListener(this); | ||||||
|     	 |     	 | ||||||
|     	updateStatus(""); |  | ||||||
|     } |     } | ||||||
| 	 | 	 | ||||||
| 	/* | 	/* | ||||||
|  | @ -455,232 +462,30 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	 | 	 | ||||||
| 	/* |  | ||||||
| 	 * Show the message log UI |  | ||||||
| 	 */ |  | ||||||
| 	/* |  | ||||||
| 	private void showMessageLog () |  | ||||||
| 	{ |  | ||||||
| 		currentView = R.layout.layout_log; |  | ||||||
| 		setContentView(currentView); |  | ||||||
| 		 |  | ||||||
| 		txtMessageLog = (TextView)findViewById(R.id.messageLog); |  | ||||||
| 		 |  | ||||||
| 		txtMessageLog.setClickable(true); |  | ||||||
|     	txtMessageLog.setText(logBuffer.toString()); |  | ||||||
|     	 |  | ||||||
| 		 |  | ||||||
| 	}*/ |  | ||||||
| 	 |  | ||||||
| 	 |  | ||||||
|     /* |     /* | ||||||
|      * Load the basic settings application to display torrc |      * Load the basic settings application to display torrc | ||||||
|      */ |      */ | ||||||
| 	private void showSettings () | 	private void showSettings () | ||||||
| 	{ | 	{ | ||||||
| 		 | 		 | ||||||
| 	 |  | ||||||
| 		startActivityForResult(new Intent(this, SettingsPreferences.class), 1); | 		startActivityForResult(new Intent(this, SettingsPreferences.class), 1); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	 | 	 | ||||||
| 	 |  | ||||||
| 	@Override | 	@Override | ||||||
| 	protected void onActivityResult(int requestCode, int resultCode, Intent data) { | 	protected void onActivityResult(int requestCode, int resultCode, Intent data) { | ||||||
| 		super.onActivityResult(requestCode, resultCode, data); | 		super.onActivityResult(requestCode, resultCode, data); | ||||||
| 		 | 		 | ||||||
| 		if (requestCode == 1) | 		if (requestCode == 1 && resultCode == 1010 && mService != null) | ||||||
| 		{ | 		{ | ||||||
| 			try { | 			new ProcessSettingsAsyncTask().execute(mService);	 | ||||||
| 				processSettings(); |  | ||||||
| 			} catch (RemoteException e) { |  | ||||||
| 				e.printStackTrace(); |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	private void processSettings () throws RemoteException | 	private void showAlert(String title, String msg, boolean button) | ||||||
| 	{ | 	{ | ||||||
| 		try | 		 if (button) | ||||||
| 		 { | 		 { | ||||||
| 			if (mService == null) |  | ||||||
| 				return; //nothing to do if the service isn't connected yet |  | ||||||
| 			 |  | ||||||
| 			boolean useBridges = prefs.getBoolean(PREF_BRIDGES_ENABLED, false); |  | ||||||
| 			 |  | ||||||
| 			//boolean autoUpdateBridges = prefs.getBoolean(PREF_BRIDGES_UPDATED, false); |  | ||||||
| 	 |  | ||||||
| 	        boolean becomeRelay = prefs.getBoolean(PREF_OR, false); |  | ||||||
| 	 |  | ||||||
| 	        boolean ReachableAddresses = prefs.getBoolean(PREF_REACHABLE_ADDRESSES,false); |  | ||||||
| 	 |  | ||||||
| 	        boolean enableHiddenServices = prefs.getBoolean("pref_hs_enable", false); |  | ||||||
| 			 |  | ||||||
| 			boolean enableTransparentProxy = prefs.getBoolean(PREF_TRANSPARENT, false);		 |  | ||||||
| 			mService.updateTransProxy(); |  | ||||||
| 			 |  | ||||||
| 	         |  | ||||||
| 			String bridgeList = prefs.getString(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; |  | ||||||
| 				} |  | ||||||
| 				 |  | ||||||
| 				 |  | ||||||
| 				mService.updateConfiguration("UseBridges", "1", false); |  | ||||||
| 					 |  | ||||||
| 				String bridgeDelim = "\n"; |  | ||||||
| 				 |  | ||||||
| 				if (bridgeList.indexOf(",") != -1) |  | ||||||
| 				{ |  | ||||||
| 					bridgeDelim = ","; |  | ||||||
| 				} |  | ||||||
| 				 |  | ||||||
| 				StringTokenizer st = new StringTokenizer(bridgeList,bridgeDelim); |  | ||||||
| 				while (st.hasMoreTokens()) |  | ||||||
| 				{ |  | ||||||
| 	 |  | ||||||
| 					mService.updateConfiguration("bridge", st.nextToken(), false); |  | ||||||
| 	 |  | ||||||
| 				} |  | ||||||
| 				 |  | ||||||
| 				mService.updateConfiguration("UpdateBridgesFromAuthority", "0", false); |  | ||||||
| 				 |  | ||||||
| 			} |  | ||||||
| 			else |  | ||||||
| 			{ |  | ||||||
| 				mService.updateConfiguration("UseBridges", "0", false); |  | ||||||
| 	 |  | ||||||
| 			} |  | ||||||
| 	 |  | ||||||
| 	        try |  | ||||||
| 	        { |  | ||||||
| 	            if (ReachableAddresses) |  | ||||||
| 	            { |  | ||||||
| 	                String ReachableAddressesPorts = |  | ||||||
| 	                    prefs.getString(PREF_REACHABLE_ADDRESSES_PORTS, "*:80,*:443"); |  | ||||||
| 	                 |  | ||||||
| 	    			mService.updateConfiguration("ReachableAddresses", ReachableAddressesPorts, false); |  | ||||||
| 	 |  | ||||||
| 	            } |  | ||||||
| 	            else |  | ||||||
| 	            { |  | ||||||
| 	            	mService.updateConfiguration("ReachableAddresses", "", false); |  | ||||||
| 	            } |  | ||||||
| 	        } |  | ||||||
| 	        catch (Exception e) |  | ||||||
| 	        { |  | ||||||
| 	           showAlert("Config Error","Your ReachableAddresses settings caused an exception!"); |  | ||||||
| 	        } |  | ||||||
| 	 |  | ||||||
| 	        try |  | ||||||
| 	        { |  | ||||||
| 	            if (becomeRelay && (!useBridges) && (!ReachableAddresses)) |  | ||||||
| 	            { |  | ||||||
| 	                int ORPort =  Integer.parseInt(prefs.getString(PREF_OR_PORT, "9001")); |  | ||||||
| 	                String nickname = prefs.getString(PREF_OR_NICKNAME, "Orbot"); |  | ||||||
| 	 |  | ||||||
| 	    			mService.updateConfiguration("ORPort", ORPort + "", false); |  | ||||||
| 	    			mService.updateConfiguration("Nickname", nickname, false); |  | ||||||
| 	    			mService.updateConfiguration("ExitPolicy", "reject *:*", false); |  | ||||||
| 	 |  | ||||||
| 	            } |  | ||||||
| 	            else |  | ||||||
| 	            { |  | ||||||
| 	            	mService.updateConfiguration("ORPort", "", false); |  | ||||||
| 	    			mService.updateConfiguration("Nickname", "", false); |  | ||||||
| 	    			mService.updateConfiguration("ExitPolicy", "", false); |  | ||||||
| 	            } |  | ||||||
| 	        } |  | ||||||
| 	        catch (Exception e) |  | ||||||
| 	        { |  | ||||||
| 	            showAlert("Uh-oh!","Your relay settings caused an exception!"); |  | ||||||
| 	           |  | ||||||
| 	            return; |  | ||||||
| 	        } |  | ||||||
| 	 |  | ||||||
| 	        if (enableHiddenServices) |  | ||||||
| 	        { |  | ||||||
| 	        	mService.updateConfiguration("HiddenServiceDir","/data/data/org.torproject.android/", false); |  | ||||||
| 	        	 |  | ||||||
| 	        	String hsPorts = prefs.getString("pref_hs_ports",""); |  | ||||||
| 	        	 |  | ||||||
| 	        	StringTokenizer st = new StringTokenizer (hsPorts,","); |  | ||||||
| 	        	String hsPortConfig = null; |  | ||||||
| 	        	 |  | ||||||
| 	        	while (st.hasMoreTokens()) |  | ||||||
| 	        	{ |  | ||||||
| 	        		hsPortConfig = st.nextToken(); |  | ||||||
| 	        		 |  | ||||||
| 	        		if (hsPortConfig.indexOf(":")==-1) //setup the port to localhost if not specifed |  | ||||||
| 	        		{ |  | ||||||
| 	        			hsPortConfig = hsPortConfig + " 127.0.0.1:" + hsPortConfig; |  | ||||||
| 	        		} |  | ||||||
| 	        		 |  | ||||||
| 	        		mService.updateConfiguration("HiddenServicePort",hsPortConfig, false); |  | ||||||
| 	        	} |  | ||||||
| 	        	 |  | ||||||
| 	        	//force save now so the hostname file gets generated |  | ||||||
| 	        	 mService.saveConfiguration(); |  | ||||||
| 	        	  |  | ||||||
| 	        	String onionHostname = getHiddenServiceHostname(); |  | ||||||
| 	        	 |  | ||||||
| 	        	if (onionHostname != null) |  | ||||||
| 	        	{ |  | ||||||
| 	        		 |  | ||||||
| 	        		Editor pEdit = prefs.edit(); |  | ||||||
| 	    			pEdit.putString("pref_hs_hostname",onionHostname); |  | ||||||
| 	    			pEdit.commit(); |  | ||||||
| 	        		 |  | ||||||
| 	        	} |  | ||||||
| 	        } |  | ||||||
| 	        else |  | ||||||
| 	        { |  | ||||||
| 	        	mService.updateConfiguration("HiddenServiceDir","", false);	        |  | ||||||
| 	        } |  | ||||||
| 	         |  | ||||||
| 	        mService.saveConfiguration(); |  | ||||||
| 	         |  | ||||||
| 		 } |  | ||||||
|         catch (Exception e) |  | ||||||
|         { |  | ||||||
|             showAlert("Uh-oh!","There was an error updating your settings"); |  | ||||||
|            |  | ||||||
|             Log.w(TAG, "processSettings()", e); |  | ||||||
|              |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	 |  | ||||||
| 	private String getHiddenServiceHostname () |  | ||||||
| 	{ |  | ||||||
|     	String appHome = "/data/data/" + TorServiceConstants.TOR_APP_USERNAME + "/"; |  | ||||||
| 
 |  | ||||||
|     	File file = new File(appHome, "hostname"); |  | ||||||
|     	try { |  | ||||||
| 			String onionHostname = Utils.readString(new FileInputStream(file)); |  | ||||||
| 			return onionHostname.trim(); |  | ||||||
| 		} catch (FileNotFoundException e) { |  | ||||||
| 			Log.d(TAG, "unable to read onion hostname file",e); |  | ||||||
| 			return null; |  | ||||||
| 		} |  | ||||||
| 	} |  | ||||||
| 	 |  | ||||||
| 	 |  | ||||||
| 	private void showAlert(String title, String msg) |  | ||||||
| 	{ |  | ||||||
| 		  |  | ||||||
| 		 new AlertDialog.Builder(this) | 		 new AlertDialog.Builder(this) | ||||||
| 		 .setIcon(R.drawable.icon) | 		 .setIcon(R.drawable.icon) | ||||||
|          .setTitle(title) |          .setTitle(title) | ||||||
|  | @ -688,6 +493,15 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|          .setPositiveButton(android.R.string.ok, null) |          .setPositiveButton(android.R.string.ok, null) | ||||||
|          .show(); |          .show(); | ||||||
| 		 } | 		 } | ||||||
|  | 		 else | ||||||
|  | 		 { | ||||||
|  | 			 new AlertDialog.Builder(this) | ||||||
|  | 			 .setIcon(R.drawable.icon) | ||||||
|  | 	         .setTitle(title) | ||||||
|  | 	         .setMessage(msg) | ||||||
|  | 	         .show(); | ||||||
|  | 		 } | ||||||
|  | 	} | ||||||
|     /* |     /* | ||||||
|      * Set the state of the running/not running graphic and label |      * Set the state of the running/not running graphic and label | ||||||
|      */ |      */ | ||||||
|  | @ -699,7 +513,6 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|     		if (mService != null) |     		if (mService != null) | ||||||
|     			torStatus = mService.getStatus(); |     			torStatus = mService.getStatus(); | ||||||
|     		 |     		 | ||||||
| 
 |  | ||||||
| 	    	if (imgStatus != null) | 	    	if (imgStatus != null) | ||||||
| 	    	{ | 	    	{ | ||||||
| 	    		 | 	    		 | ||||||
|  | @ -714,11 +527,15 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		    		} | 		    		} | ||||||
| 		    		 | 		    		 | ||||||
| 		    		 | 		    		 | ||||||
| 		    		String lblMsg = getString(R.string.status_activated) + "\n" + torServiceMsg; | 		    		String lblMsg = getString(R.string.status_activated); | ||||||
|  | 		    		//+ "\n" + torServiceMsg; | ||||||
| 		    		 | 		    		 | ||||||
| 		    		lblStatus.setText(lblMsg); | 		    		lblStatus.setText(lblMsg); | ||||||
| 		    		 | 		    		 | ||||||
| 		    		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(mOrbot); | 		    		if (torServiceMsg.length() > 0) | ||||||
|  | 		    			showAlert("Update", torServiceMsg, false); | ||||||
|  | 		    		 | ||||||
|  | 		    		SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(this); | ||||||
| 
 | 
 | ||||||
| 		    		boolean showFirstTime = prefs.getBoolean("connect_first_time",true); | 		    		boolean showFirstTime = prefs.getBoolean("connect_first_time",true); | ||||||
| 		    		 | 		    		 | ||||||
|  | @ -731,26 +548,11 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		    			 | 		    			 | ||||||
| 		    			pEdit.commit(); | 		    			pEdit.commit(); | ||||||
| 		    			 | 		    			 | ||||||
| 		    			showAlert(getString(R.string.status_activated),getString(R.string.connect_first_time)); | 		    			showAlert(getString(R.string.status_activated),getString(R.string.connect_first_time),true); | ||||||
| 		    			 | 		    			 | ||||||
| 		    		} | 		    		} | ||||||
| 		    		 | 		    		if (mItemOnOff != null) | ||||||
| 			        boolean enableHiddenServices = prefs.getBoolean("pref_hs_enable", false); | 		    			mItemOnOff.setTitle(R.string.menu_stop); | ||||||
| 
 |  | ||||||
| 			        if (enableHiddenServices) |  | ||||||
| 			        { |  | ||||||
| 			    		String onionHostname = getHiddenServiceHostname(); |  | ||||||
| 			    		 |  | ||||||
| 			    		if (onionHostname != null) |  | ||||||
| 			    		{ |  | ||||||
| 			    			Editor pEdit = prefs.edit(); |  | ||||||
| 			    			pEdit.putString("pref_hs_hostname",onionHostname); |  | ||||||
| 			    			pEdit.commit(); |  | ||||||
| 			    			 |  | ||||||
| 			    		} |  | ||||||
| 		    		 |  | ||||||
| 			        } |  | ||||||
| 	    		 |  | ||||||
| 
 | 
 | ||||||
| 		    	} | 		    	} | ||||||
| 		    	else if (torStatus == STATUS_CONNECTING) | 		    	else if (torStatus == STATUS_CONNECTING) | ||||||
|  | @ -763,25 +565,14 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		    		} | 		    		} | ||||||
| 		    		else | 		    		else | ||||||
| 		    			progressDialog.setMessage(torServiceMsg); | 		    			progressDialog.setMessage(torServiceMsg); | ||||||
| 		    		//lblStatus.setText(torServiceMsg); |  | ||||||
| 		    		 | 		    		 | ||||||
| 		    		 | 		    		if (mItemOnOff != null) | ||||||
| 		    		/* | 		    			mItemOnOff.setTitle(R.string.menu_stop); | ||||||
| 	    			int idx = torServiceMsg.indexOf("%"); |  | ||||||
| 	    			 |  | ||||||
| 	    			if (idx != -1) |  | ||||||
| 	    			{	 |  | ||||||
| 	    				String pComp = torServiceMsg.substring(idx-2,idx).trim(); |  | ||||||
| 	    				int ipComp = Integer.parseInt(pComp); |  | ||||||
| 	    			//	progressDialog.setProgress(ipComp); |  | ||||||
| 	    				 |  | ||||||
| 	    			}*/ |  | ||||||
| 		    			 | 		    			 | ||||||
| 		    	} | 		    	} | ||||||
| 		    	else if (torStatus == STATUS_OFF) | 		    	else if (torStatus == STATUS_OFF) | ||||||
| 		    	{ | 		    	{ | ||||||
| 		    		imgStatus.setImageResource(R.drawable.torstopping); | 		    		imgStatus.setImageResource(R.drawable.torstopping); | ||||||
| 		    	//	imgStatus.clearAnimation(); |  | ||||||
| 		    		 | 		    		 | ||||||
| 		    		if (progressDialog != null) | 		    		if (progressDialog != null) | ||||||
| 		    		{ | 		    		{ | ||||||
|  | @ -791,6 +582,8 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		    		 | 		    		 | ||||||
| 		    		lblStatus.setText(getString(R.string.status_shutting_down)); | 		    		lblStatus.setText(getString(R.string.status_shutting_down)); | ||||||
| 		    			 | 		    			 | ||||||
|  | 		    		if (mItemOnOff != null) | ||||||
|  | 		    			mItemOnOff.setTitle(R.string.menu_start); | ||||||
| 		    	} | 		    	} | ||||||
| 		    	else | 		    	else | ||||||
| 		    	{ | 		    	{ | ||||||
|  | @ -801,12 +594,12 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		    			progressDialog = null; | 		    			progressDialog = null; | ||||||
| 		    		} | 		    		} | ||||||
| 		    		 | 		    		 | ||||||
| 		    	//	imgStatus.clearAnimation(); |  | ||||||
| 		    		 | 		    		 | ||||||
| 		    		imgStatus.setImageResource(R.drawable.toroff); | 		    		imgStatus.setImageResource(R.drawable.toroff); | ||||||
| 		    		lblStatus.setText(getString(R.string.status_disabled) + "\n" + getString(R.string.press_to_start)); | 		    		lblStatus.setText(getString(R.string.status_disabled) + "\n" + getString(R.string.press_to_start)); | ||||||
| 		    		 | 		    		 | ||||||
| 		    		 | 		    		if (mItemOnOff != null) | ||||||
|  | 		    			mItemOnOff.setTitle(R.string.menu_start); | ||||||
| 		    		 | 		    		 | ||||||
| 		    	} | 		    	} | ||||||
| 	    	} | 	    	} | ||||||
|  | @ -814,7 +607,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|     	} |     	} | ||||||
|     	catch (RemoteException e) |     	catch (RemoteException e) | ||||||
|     	{ |     	{ | ||||||
|     		e.printStackTrace(); |     		Log.e(TAG,"remote exception updating status",e); | ||||||
|     	} |     	} | ||||||
|     	 |     	 | ||||||
|          |          | ||||||
|  | @ -822,75 +615,44 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|    |    | ||||||
|     private void startTor () throws RemoteException |     private void startTor () throws RemoteException | ||||||
|     { |     { | ||||||
|     	mService.setProfile(PROFILE_ON); //this means turn on |     	if (progressDialog == null) | ||||||
|  | 		{ | ||||||
|  | 			progressDialog =ProgressDialog.show(this, "", getString(R.string.status_starting_up)); | ||||||
|  | 		} | ||||||
|  |     	 | ||||||
|  |     	mService.setProfile(TorServiceConstants.PROFILE_ON); //this means turn on | ||||||
| 		 | 		 | ||||||
| 		imgStatus.setImageResource(R.drawable.torstarting); | 		imgStatus.setImageResource(R.drawable.torstarting); | ||||||
| 		lblStatus.setText(getString(R.string.status_starting_up)); | 		lblStatus.setText(getString(R.string.status_starting_up)); | ||||||
| 		 | 		 | ||||||
| 		Message msg = mHandler.obtainMessage(ENABLE_TOR_MSG); | 		Message msg = mHandler.obtainMessage(TorServiceConstants.ENABLE_TOR_MSG); | ||||||
|     	mHandler.sendMessage(msg); |     	mHandler.sendMessage(msg); | ||||||
|     	 |     	 | ||||||
|     	logBuffer = new StringBuffer(); |     	 | ||||||
|  |     	 | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     private void stopTor () throws RemoteException |     private void stopTor () throws RemoteException | ||||||
|     { |     { | ||||||
|     	if (mService != null) |     	if (mService != null) | ||||||
|     	{ |     	{ | ||||||
|     		mService.setProfile(PROFILE_ONDEMAND);	//these means turn off |     		mService.setProfile(TorServiceConstants.PROFILE_OFF); | ||||||
| 		 |     		Message msg = mHandler.obtainMessage(TorServiceConstants.DISABLE_TOR_MSG); | ||||||
|     		Message msg = mHandler.obtainMessage(DISABLE_TOR_MSG); |  | ||||||
|     		mHandler.sendMessage(msg); |     		mHandler.sendMessage(msg); | ||||||
|     	} |     	} | ||||||
|     	 |     	 | ||||||
|     	//unbindService(); |  | ||||||
| 		 |  | ||||||
|         stopService(new Intent(ITorService.class.getName())); |         stopService(new Intent(ITorService.class.getName())); | ||||||
| 	 | 	 | ||||||
|     	 |     	 | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     /* |  | ||||||
|     @Override |  | ||||||
| 	public boolean onTouchEvent(MotionEvent event) { |  | ||||||
|     	 |  | ||||||
|     	if (currentView == R.layout.layout_main) |  | ||||||
|     	{ |  | ||||||
| 	    	try |  | ||||||
| 			{ |  | ||||||
| 				if (mService == null) |  | ||||||
| 				{ |  | ||||||
| 				 |  | ||||||
| 				} |  | ||||||
| 				else if (mService.getStatus() == STATUS_READY) |  | ||||||
| 				{ |  | ||||||
| 					startTor(); |  | ||||||
| 					 |  | ||||||
| 				} |  | ||||||
| 				else |  | ||||||
| 				{ |  | ||||||
| 					stopTor(); |  | ||||||
| 					 |  | ||||||
| 				} |  | ||||||
| 				 |  | ||||||
| 			} |  | ||||||
| 			catch (Exception e) |  | ||||||
| 			{ |  | ||||||
| 				Log.d(TAG,"error onclick",e); |  | ||||||
| 			} |  | ||||||
|     	} |  | ||||||
|     	 |  | ||||||
| 		return super.onTouchEvent(event); |  | ||||||
| 	}*/ |  | ||||||
| 
 |  | ||||||
| 	/* | 	/* | ||||||
|      * (non-Javadoc) |      * (non-Javadoc) | ||||||
|      * @see android.view.View.OnClickListener#onClick(android.view.View) |      * @see android.view.View.OnClickListener#onClick(android.view.View) | ||||||
|      */ |      */ | ||||||
| 	public void onClick(View view) { | 	public boolean onLongClick(View view) { | ||||||
|  | 		 | ||||||
| 		 | 		 | ||||||
| 		if (currentView == R.layout.layout_main) |  | ||||||
|     	{ |  | ||||||
| 		try | 		try | ||||||
| 		{ | 		{ | ||||||
| 			 | 			 | ||||||
|  | @ -917,9 +679,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 			Log.d(TAG,"error onclick",e); | 			Log.d(TAG,"error onclick",e); | ||||||
| 		} | 		} | ||||||
| 			 | 			 | ||||||
| 		} | 		return true; | ||||||
| 		 |  | ||||||
| 		 |  | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 
 | 
 | ||||||
|  | @ -937,7 +697,7 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|          */ |          */ | ||||||
|         public void statusChanged(String value) { |         public void statusChanged(String value) { | ||||||
|             |             | ||||||
|         	Message msg = mHandler.obtainMessage(STATUS_MSG); |         	Message msg = mHandler.obtainMessage(TorServiceConstants.STATUS_MSG); | ||||||
|         	msg.getData().putString(HANDLER_TOR_MSG, value); |         	msg.getData().putString(HANDLER_TOR_MSG, value); | ||||||
|         	mHandler.sendMessage(msg); |         	mHandler.sendMessage(msg); | ||||||
|         } |         } | ||||||
|  | @ -945,43 +705,34 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
| 		@Override | 		@Override | ||||||
| 		public void logMessage(String value) throws RemoteException { | 		public void logMessage(String value) throws RemoteException { | ||||||
| 			 | 			 | ||||||
| 			Message msg = mHandler.obtainMessage(LOG_MSG); | 			Message msg = mHandler.obtainMessage(TorServiceConstants.LOG_MSG); | ||||||
|         	msg.getData().putString(HANDLER_TOR_MSG, value); |         	msg.getData().putString(HANDLER_TOR_MSG, value); | ||||||
|         	mHandler.sendMessage(msg); |         	mHandler.sendMessage(msg); | ||||||
| 			 | 			 | ||||||
| 		} | 		} | ||||||
|     }; |     }; | ||||||
|      |      | ||||||
|     private static final int STATUS_MSG = 1; |  | ||||||
|     private static final int ENABLE_TOR_MSG = 2; |  | ||||||
|     private static final int DISABLE_TOR_MSG = 3; |  | ||||||
|     private static final int LOG_MSG = 4; |  | ||||||
| 
 | 
 | ||||||
|     private Handler mHandler = new Handler() { |     private Handler mHandler = new Handler() { | ||||||
|         public void handleMessage(Message msg) { |         public void handleMessage(Message msg) { | ||||||
|             switch (msg.what) { |             switch (msg.what) { | ||||||
|                 case STATUS_MSG: |                 case TorServiceConstants.STATUS_MSG: | ||||||
| 
 | 
 | ||||||
|                 	String torServiceMsg = (String)msg.getData().getString(HANDLER_TOR_MSG); |                 	String torServiceMsg = (String)msg.getData().getString(HANDLER_TOR_MSG); | ||||||
|                 	 |                 	 | ||||||
|                 	logBuffer.append(torServiceMsg); |  | ||||||
|                 	logBuffer.append('\n'); |  | ||||||
|                 	 |  | ||||||
|                 	 |  | ||||||
|                 	if (torServiceMsg.length() > 0) |                 	if (torServiceMsg.length() > 0) | ||||||
|                 		updateStatus(torServiceMsg); |                 		updateStatus(torServiceMsg); | ||||||
|                 	 |                 	 | ||||||
|                     break; |                     break; | ||||||
|                 case LOG_MSG: |                 case TorServiceConstants.LOG_MSG: | ||||||
|                 	//do nothing |  | ||||||
|                 	 |                 	 | ||||||
|                 	 |                 	 | ||||||
|                     break; |                     break; | ||||||
|                 case ENABLE_TOR_MSG: |                 case TorServiceConstants.ENABLE_TOR_MSG: | ||||||
|                 	 |                 	 | ||||||
|                 	 |                 	 | ||||||
|                 	break; |                 	break; | ||||||
|                 case DISABLE_TOR_MSG: |                 case TorServiceConstants.DISABLE_TOR_MSG: | ||||||
|                 	 |                 	 | ||||||
|                 	break; |                 	break; | ||||||
|                 		 |                 		 | ||||||
|  | @ -1006,13 +757,12 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|             // representation of that from the raw service object. |             // representation of that from the raw service object. | ||||||
|             mService = ITorService.Stub.asInterface(service); |             mService = ITorService.Stub.asInterface(service); | ||||||
|         |         | ||||||
|             updateStatus (""); |  | ||||||
|         |  | ||||||
|             // We want to monitor the service for as long as we are |             // We want to monitor the service for as long as we are | ||||||
|             // connected to it. |             // connected to it. | ||||||
|             try { |             try { | ||||||
|                 mService.registerCallback(mCallback); |                 mService.registerCallback(mCallback); | ||||||
|             |             | ||||||
|  |                 updateStatus(""); | ||||||
|                  |                  | ||||||
|                 if (autoStartOnBind) |                 if (autoStartOnBind) | ||||||
|                 { |                 { | ||||||
|  | @ -1031,6 +781,10 @@ public class Orbot extends Activity implements OnClickListener, TorConstants | ||||||
|             } |             } | ||||||
|              |              | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
|  |             | ||||||
|  |         | ||||||
|  |            | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         public void onServiceDisconnected(ComponentName className) { |         public void onServiceDisconnected(ComponentName className) { | ||||||
|  |  | ||||||
|  | @ -37,7 +37,7 @@ public class SettingsPreferences | ||||||
| 		 | 		 | ||||||
| 		if (prefs.contains("has_root")) | 		if (prefs.contains("has_root")) | ||||||
| 		{ | 		{ | ||||||
| 			hasRoot = prefs.getBoolean("has_root",false);//TorServiceUtils.checkRootAccess(); | 			hasRoot = prefs.getBoolean("has_root",false); | ||||||
| 		} | 		} | ||||||
| 		else | 		else | ||||||
| 		{ | 		{ | ||||||
|  | @ -103,10 +103,12 @@ public class SettingsPreferences | ||||||
| 	@Override | 	@Override | ||||||
| 	public boolean onPreferenceClick(Preference preference) { | 	public boolean onPreferenceClick(Preference preference) { | ||||||
| 		 | 		 | ||||||
|  | 		setResult(1010); | ||||||
| 		 | 		 | ||||||
| 		if (preference == prefTransProxyApps) | 		if (preference == prefTransProxyApps) | ||||||
| 		{ | 		{ | ||||||
| 			startActivity(new Intent(this, AppManager.class)); | 			startActivity(new Intent(this, AppManager.class)); | ||||||
|  | 			 | ||||||
| 		} | 		} | ||||||
| 		else if (preference == prefHiddenServices) | 		else if (preference == prefHiddenServices) | ||||||
| 		{ | 		{ | ||||||
|  |  | ||||||
|  | @ -21,9 +21,6 @@ public interface TorConstants { | ||||||
|     public final static int STATUS_ON = 1; |     public final static int STATUS_ON = 1; | ||||||
|     public final static int STATUS_CONNECTING = 2; |     public final static int STATUS_CONNECTING = 2; | ||||||
|      |      | ||||||
|     public final static int PROFILE_OFF = -1; |  | ||||||
|     public final static int PROFILE_ONDEMAND = 0; |  | ||||||
|     public final static int PROFILE_ON = 1; |  | ||||||
|      |      | ||||||
|     public final static String NEWLINE = "\n"; |     public final static String NEWLINE = "\n"; | ||||||
|      |      | ||||||
|  |  | ||||||
|  | @ -41,7 +41,7 @@ public class WizardActivity extends Activity implements OnClickListener | ||||||
| 
 | 
 | ||||||
| 	public void showStep1() | 	public void showStep1() | ||||||
| 	{ | 	{ | ||||||
| 		showDialog("Test","this is nathan's test","foo","bar",this); | 		showDialog("Test","","foo","bar",this); | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	private void showDialog (String title, String msg, String button1, String button2, OnClickListener ocListener) | 	private void showDialog (String title, String msg, String button1, String button2, OnClickListener ocListener) | ||||||
|  |  | ||||||
|  | @ -48,7 +48,7 @@ public class WizardHelper implements TorConstants { | ||||||
|         View view = li.inflate(R.layout.layout_wizard_welcome, null);  |         View view = li.inflate(R.layout.layout_wizard_welcome, null);  | ||||||
|          |          | ||||||
|         |         | ||||||
| 		showCustomDialog(title, view,context.getString(R.string.btn_next),context.getString(R.string.wizard_btn_tell_me_more),new DialogInterface.OnClickListener() { | 		showCustomDialog(title, view,context.getString(R.string.btn_next),null,new DialogInterface.OnClickListener() { | ||||||
| 					 | 					 | ||||||
| 			@Override | 			@Override | ||||||
| 			public void onClick(DialogInterface dialog, int which) { | 			public void onClick(DialogInterface dialog, int which) { | ||||||
|  | @ -59,10 +59,11 @@ public class WizardHelper implements TorConstants { | ||||||
| 
 | 
 | ||||||
| 					showWizardStep2(); | 					showWizardStep2(); | ||||||
| 				} | 				} | ||||||
|  | 				/* | ||||||
| 				else if (which == DialogInterface.BUTTON_POSITIVE) | 				else if (which == DialogInterface.BUTTON_POSITIVE) | ||||||
| 				{ | 				{ | ||||||
| 					showAbout(); | 					showAbout(); | ||||||
| 				} | 				}*/ | ||||||
| 				 | 				 | ||||||
| 			} | 			} | ||||||
| 		}); | 		}); | ||||||
|  | @ -116,7 +117,11 @@ public class WizardHelper implements TorConstants { | ||||||
| 			 | 			 | ||||||
| 				currentDialog.getButton(AlertDialog.BUTTON_NEUTRAL).setEnabled(isChecked); | 				currentDialog.getButton(AlertDialog.BUTTON_NEUTRAL).setEnabled(isChecked); | ||||||
| 				 | 				 | ||||||
|  | 				SharedPreferences prefs = PreferenceManager.getDefaultSharedPreferences(context); | ||||||
| 
 | 
 | ||||||
|  | 				Editor pEdit = prefs.edit(); | ||||||
|  | 				pEdit.putBoolean("has_root",false); | ||||||
|  | 				pEdit.commit(); | ||||||
| 				 | 				 | ||||||
| 			} | 			} | ||||||
|         	 |         	 | ||||||
|  | @ -380,25 +385,7 @@ public class WizardHelper implements TorConstants { | ||||||
| 	 | 	 | ||||||
| 	} | 	} | ||||||
| 	 | 	 | ||||||
| 	private void showAbout () |  | ||||||
| 	{ |  | ||||||
| 	 | 	 | ||||||
| 		LayoutInflater li = LayoutInflater.from(context); |  | ||||||
|         View view = li.inflate(R.layout.layout_about, null);  |  | ||||||
|          |  | ||||||
|         TextView versionName = (TextView)view.findViewById(R.id.versionName); |  | ||||||
|         versionName.setText(R.string.app_version);     |  | ||||||
|          |  | ||||||
| 		new AlertDialog.Builder(context) |  | ||||||
|         .setTitle(context.getString(R.string.button_about)) |  | ||||||
|         .setView(view) |  | ||||||
|         .setNeutralButton(context.getString(R.string.btn_back), new DialogInterface.OnClickListener() { |  | ||||||
|                 public void onClick(DialogInterface dialog, int whichButton) { |  | ||||||
|                       showWizard(); |  | ||||||
|                 } |  | ||||||
|         }) |  | ||||||
|         .show(); |  | ||||||
| 	} |  | ||||||
| 	 | 	 | ||||||
| 	private void showProxyHelp () | 	private void showProxyHelp () | ||||||
| 	{ | 	{ | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue