commit 4a2e8b14c8f3a5419453389c947468a95b3d6fc3
Author: n8fr8 <nathan(a)guardianproject.info>
Date: Fri Dec 11 18:09:38 2020 -0500
more improvements to bridge PT init logic
---
.../torproject/android/service/OrbotService.java | 41 ++++++++++------------
1 file changed, 18 insertions(+), 23 deletions(-)
diff --git a/orbotservice/src/main/java/org/torproject/android/service/OrbotService.java b/orbotservice/src/main/java/org/torproject/android/service/OrbotService.java
index d03fd989..227f503e 100644
--- a/orbotservice/src/main/java/org/torproject/android/service/OrbotService.java
+++ b/orbotservice/src/main/java/org/torproject/android/service/OrbotService.java
@@ -307,7 +307,7 @@ public class OrbotService extends VpnService implements TorServiceConstants, Orb
sendCallbackStatus(STATUS_STOPPING);
sendCallbackLogMessage(getString(R.string.status_shutting_down));
- if (useIPtObfs4Proxy())
+ if (useIPtObfsMeekProxy())
IPtProxy.stopObfs4Proxy();
if (useIPtSnowflakeProxy())
@@ -329,10 +329,10 @@ public class OrbotService extends VpnService implements TorServiceConstants, Orb
}
- private static boolean useIPtObfs4Proxy ()
+ private static boolean useIPtObfsMeekProxy ()
{
String bridgeList = Prefs.getBridgesList();
- return bridgeList.contains("obfs3")|| bridgeList.contains("obfs4")||bridgeList.contains("meek");
+ return bridgeList.contains("obfs")||bridgeList.contains("meek");
}
private static boolean useIPtSnowflakeProxy ()
@@ -1415,35 +1415,30 @@ public class OrbotService extends VpnService implements TorServiceConstants, Orb
// extraLines.append("UpdateBridgesFromAuthority 1").append('\n');
String bridgeList = Prefs.getBridgesList();
- boolean obfsBridges = bridgeList.contains("obfs");
- boolean meekBridges = bridgeList.contains("meek");
- boolean snowflakeBridges = bridgeList.contains("snowflake");
+
+ String builtInBridgeType = null;
//check if any PT bridges are needed
- if (obfsBridges) {
+ if (bridgeList.contains("obfs")) {
extraLines.append("ClientTransportPlugin obfs3 socks5 127.0.0.1:" + IPtProxy.Obfs3SocksPort).append('\n');
extraLines.append("ClientTransportPlugin obfs4 socks5 127.0.0.1:" + IPtProxy.Obfs4SocksPort).append('\n');
+
+ if (bridgeList.equals("obfs4"))
+ builtInBridgeType = "obfs4";
}
- if (meekBridges)
+ if (bridgeList.equals("meek")) {
extraLines.append("ClientTransportPlugin meek_lite socks5 127.0.0.1:" + IPtProxy.MeekSocksPort).append('\n');
+ builtInBridgeType = "meek_lite";
+ }
- if (snowflakeBridges)
+ if (bridgeList.equals("snowflake")) {
extraLines.append("ClientTransportPlugin snowflake socks5 127.0.0.1:" + IPtProxy.SnowflakeSocksPort).append('\n');
-
- if (obfsBridges||meekBridges||snowflakeBridges)
- {
-
- String type = "obfs4";
-
- if (meekBridges)
- type = "meek_lite";
- else if (snowflakeBridges)
- type = "snowflake";
-
- getBridges(type, extraLines);
-
+ builtInBridgeType = "snowflake";
}
+
+ if (!TextUtils.isEmpty(builtInBridgeType))
+ getBridges(builtInBridgeType, extraLines);
else
{
String[] bridgeListLines = parseBridgesFromSettings(bridgeList);
@@ -1781,7 +1776,7 @@ public class OrbotService extends VpnService implements TorServiceConstants, Orb
if (!TextUtils.isEmpty(action)) {
if (action.equals(ACTION_START) || action.equals(ACTION_START_ON_BOOT)) {
- if (useIPtObfs4Proxy())
+ if (useIPtObfsMeekProxy())
IPtProxy.startObfs4Proxy("DEBUG", false, false);
if (useIPtSnowflakeProxy())