commit ff8bf0bddf92cbb1fac9143dc118112ab944ce09
Author: amoghbl1 <amoghbl1(a)gmail.com>
Date: Fri Jun 20 02:15:13 2014 +0530
moved ip lookup into asynctask and also added some extra checking before the external ip is updated
---
src/org/torproject/android/service/TorService.java | 67 +++++++++++++-------
1 file changed, 45 insertions(+), 22 deletions(-)
diff --git a/src/org/torproject/android/service/TorService.java b/src/org/torproject/android/service/TorService.java
index c2c86c0..5240f28 100644
--- a/src/org/torproject/android/service/TorService.java
+++ b/src/org/torproject/android/service/TorService.java
@@ -87,8 +87,9 @@ public class TorService extends Service implements TorServiceConstants, TorConst
private static final int HS_NOTIFY_ID = 4;
private boolean prefPersistNotifications = true;
- String IPADDRESS_PATTERN =
+ private String IPADDRESS_PATTERN =
"(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)";
+ private long exitIPTime = 0;
private static final int MAX_START_TRIES = 3;
@@ -1378,27 +1379,7 @@ public class TorService extends Service implements TorServiceConstants, TorConst
sb.append(nodeName);
if(status.equals("BUILT") && currentStatus==STATUS_ON){
- Thread thread = new Thread()
- {
- @Override
- public void run() {
- try {
- String nodeDetails = conn.getInfo("ns/name/"+nodeName);
- Pattern pattern = Pattern.compile(IPADDRESS_PATTERN);
- Matcher matcher = pattern.matcher(nodeDetails);
- if (matcher.find()) {
- Log.d(TAG, "ip: "+matcher.group());
- exitIP = matcher.group();
- }
- } catch (Exception e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- }
- };
- thread.start();
-
- Log.d(TAG ,"Node name: "+nodeName+"IP: "+exitIP);
+ new getExternalIP().execute(nodeName);
}
if (st.hasMoreTokens())
@@ -1428,6 +1409,48 @@ public class TorService extends Service implements TorServiceConstants, TorConst
}
+ private class getExternalIP extends AsyncTask<String, Void, Void>{
+
+ private long time;
+ private String nodeDetails;
+
+ @Override
+ protected Void doInBackground(String... params) {
+ time = System.nanoTime();
+ try {
+ nodeDetails = conn.getInfo("ns/name/"+params[0]);
+ if (ENABLE_DEBUG_LOG)
+ {
+ Log.d(TAG,"Node Details: "+nodeDetails);
+ sendCallbackLogMessage("Node Details: "+nodeDetails);
+
+ }
+ } catch (Exception e) {
+ // TODO Auto-generated catch block
+ e.printStackTrace();
+ }
+ return null;
+ }
+
+ @Override
+ protected void onPostExecute(Void result) {
+ // check if we need to update the exit IP
+ if(time > exitIPTime) {
+ exitIPTime = time;
+
+ Pattern pattern = Pattern.compile(IPADDRESS_PATTERN);
+ Matcher matcher = null;
+ if(nodeDetails!=null)
+ matcher = pattern.matcher(nodeDetails);
+ if (matcher!=null && matcher.find()) {
+ Log.d(TAG, "ip: "+matcher.group());
+ exitIP = matcher.group();
+ }
+ }
+ }
+
+ }
+
private String parseNodeName(String node)
{
if (node.indexOf('=')!=-1)