commit ff47ccd340c6999c31549cee039ff8a1ceb03180
Author: Juan Ezquerro LLanes <juan(a)paynopain.com>
Date: Thu Nov 17 13:42:50 2016 +0100
setup config file
---
.../org/torproject/android/OrbotMainActivity.java | 4 +-
.../org/torproject/android/service/TorService.java | 81 ++++++++++++----------
2 files changed, 45 insertions(+), 40 deletions(-)
diff --git a/app/src/main/java/org/torproject/android/OrbotMainActivity.java b/app/src/main/java/org/torproject/android/OrbotMainActivity.java
index 8541831..2e17f39 100644
--- a/app/src/main/java/org/torproject/android/OrbotMainActivity.java
+++ b/app/src/main/java/org/torproject/android/OrbotMainActivity.java
@@ -595,12 +595,12 @@ public class OrbotMainActivity extends AppCompatActivity
if(row == null) {
cr.insert(HSContentProvider.CONTENT_URI, fields);
} else {
- onionHostname = row.getString(row.getColumnIndex(HSContentProvider.HiddenService.NAME));
+ onionHostname = row.getString(row.getColumnIndex(HSContentProvider.HiddenService.DOMAIN));
cr.update(HSContentProvider.CONTENT_URI, fields, "port=" + mHsPort, null);
row.close();
}
- if(onionHostname == null) {
+ if(onionHostname == null || onionHostname.length() < 1) {
requestTorRereadConfig();
diff --git a/orbotservice/src/main/java/org/torproject/android/service/TorService.java b/orbotservice/src/main/java/org/torproject/android/service/TorService.java
index d55e1cf..9942abb 100644
--- a/orbotservice/src/main/java/org/torproject/android/service/TorService.java
+++ b/orbotservice/src/main/java/org/torproject/android/service/TorService.java
@@ -16,6 +16,7 @@ import android.app.NotificationManager;
import android.app.PendingIntent;
import android.app.Service;
import android.content.BroadcastReceiver;
+import android.content.ContentResolver;
import android.content.Context;
import android.content.ContextWrapper;
import android.content.Intent;
@@ -23,12 +24,15 @@ import android.content.IntentFilter;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.content.pm.PackageManager;
+import android.database.Cursor;
import android.net.ConnectivityManager;
import android.net.NetworkInfo;
+import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.os.IBinder;
import android.os.RemoteException;
+import android.provider.BaseColumns;
import android.support.v4.app.NotificationCompat;
import android.support.v4.content.LocalBroadcastManager;
import android.text.TextUtils;
@@ -128,6 +132,26 @@ public class TorService extends Service implements TorServiceConstants, OrbotCon
private Shell mShell;
private Shell mShellPolipo;
+ private static final Uri CONTENT_URI = Uri.parse("content://org.torproject.android.ui.hs.providers/hs");
+
+ public static final class HiddenService implements BaseColumns {
+ //Nombres de columnas
+ public static final String NAME = "name";
+ public static final String PORT = "port";
+ public static final String ONION_PORT = "onion_port";
+ public static final String DOMAIN = "domain";
+
+ private HiddenService() {
+ }
+ }
+
+ private String[] mProjection = new String[]{
+ HiddenService._ID,
+ HiddenService.NAME,
+ HiddenService.DOMAIN,
+ HiddenService.PORT,
+ HiddenService.ONION_PORT};
+
public void debug(String msg)
{
if (Prefs.useDebugLogging())
@@ -1778,49 +1802,30 @@ public class TorService extends Service implements TorServiceConstants, OrbotCon
return false;
}
- if (enableHiddenServices)
- {
- logNotice("hidden services are enabled");
-
- //updateConfiguration("RendPostPeriod", "600 seconds", false); //possible feature to investigate
-
- String hsPorts = prefs.getString("pref_hs_ports","");
-
- StringTokenizer st = new StringTokenizer (hsPorts,",");
- String hsPortConfig = null;
- int hsPort = -1;
-
- while (st.hasMoreTokens())
- {
- try
- {
- hsPortConfig = st.nextToken().trim();
-
- if (hsPortConfig.indexOf(":")==-1) //setup the port to localhost if not specifed
- {
- hsPortConfig = hsPortConfig + " 127.0.0.1:" + hsPortConfig;
- }
-
- hsPort = Integer.parseInt(hsPortConfig.split(" ")[0]);
+ /* ---- Hidden Services ---- */
+ ContentResolver mCR = getApplicationContext().getContentResolver();
+ Cursor hidden_services = mCR.query(CONTENT_URI, mProjection, null, null, null);
+ if(hidden_services != null) {
+ try {
+ while (hidden_services.moveToNext()) {
+ Integer HSLocalPort = hidden_services.getInt(hidden_services.getColumnIndex(HiddenService.PORT));
+ Integer HSOnionPort = hidden_services.getInt(hidden_services.getColumnIndex(HiddenService.ONION_PORT));
+ String hsDirPath = new File(appCacheHome,"hs" + HSLocalPort).getCanonicalPath();
- String hsDirPath = new File(appCacheHome,"hs" + hsPort).getCanonicalPath();
-
- debug("Adding hidden service on port: " + hsPortConfig);
-
- extraLines.append("HiddenServiceDir" + ' ' + hsDirPath).append('\n');
- extraLines.append("HiddenServicePort" + ' ' + hsPortConfig).append('\n');
-
+ debug("Adding hidden service on port: " + HSLocalPort);
- } catch (NumberFormatException e) {
+ extraLines.append("HiddenServiceDir" + ' ' + hsDirPath).append('\n');
+ extraLines.append("HiddenServicePort" + ' ' + HSOnionPort + " 127.0.0.1:" + HSLocalPort).append('\n');
+ }
+ } catch (NumberFormatException e) {
Log.e(OrbotConstants.TAG,"error parsing hsport",e);
- } catch (Exception e) {
+ } catch (Exception e) {
Log.e(OrbotConstants.TAG,"error starting share server",e);
- }
}
-
-
- }
-
+
+ hidden_services.close();
+ }
+
return true;
}