aboutsummaryrefslogtreecommitdiffstats
path: root/src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java
diff options
context:
space:
mode:
authorChristian Schneppe <christian@pix-art.de>2019-04-28 14:45:36 +0200
committerChristian Schneppe <christian@pix-art.de>2019-04-28 14:45:36 +0200
commitb563d5a8118006f967b153a0aafca81b54b88f2f (patch)
tree134962d1ea74311ae999cafeb189815124b6caa3 /src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java
parentda896e202d1d286b60fa1f950d76dfdb403b0176 (diff)
added Tor support to channel search
Diffstat (limited to 'src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java')
-rw-r--r--src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java26
1 files changed, 22 insertions, 4 deletions
diff --git a/src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java b/src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java
index 21711c647..ac790b10f 100644
--- a/src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java
+++ b/src/main/java/de/pixart/messenger/services/ChannelDiscoveryService.java
@@ -5,12 +5,16 @@ import android.util.Log;
import com.google.common.cache.Cache;
import com.google.common.cache.CacheBuilder;
+import java.io.IOException;
+import java.util.Collections;
import java.util.List;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
import de.pixart.messenger.Config;
+import de.pixart.messenger.http.HttpConnectionManager;
import de.pixart.messenger.http.services.MuclumbusService;
+import okhttp3.OkHttpClient;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;
@@ -21,19 +25,31 @@ public class ChannelDiscoveryService {
private final XmppConnectionService service;
- private final MuclumbusService muclumbusService;
+ private MuclumbusService muclumbusService;
private final Cache<String, List<MuclumbusService.Room>> cache;
public ChannelDiscoveryService(XmppConnectionService service) {
this.service = service;
+ this.cache = CacheBuilder.newBuilder().expireAfterWrite(5, TimeUnit.MINUTES).build();
+ }
+
+ public void initializeMuclumbusService() {
+ OkHttpClient.Builder builder = new OkHttpClient.Builder();
+ if (service.useTorToConnect()) {
+ try {
+ builder.proxy(HttpConnectionManager.getProxy());
+ } catch (IOException e) {
+ throw new RuntimeException("Unable to use Tor proxy", e);
+ }
+ }
Retrofit retrofit = new Retrofit.Builder()
+ .client(builder.build())
.baseUrl(Config.CHANNEL_DISCOVERY)
.addConverterFactory(GsonConverterFactory.create())
.callbackExecutor(Executors.newSingleThreadExecutor())
.build();
this.muclumbusService = retrofit.create(MuclumbusService.class);
- this.cache = CacheBuilder.newBuilder().expireAfterWrite(5, TimeUnit.MINUTES).build();
}
public void discover(String query, OnChannelSearchResultsFound onChannelSearchResultsFound) {
@@ -67,7 +83,8 @@ public class ChannelDiscoveryService {
@Override
public void onFailure(Call<MuclumbusService.Rooms> call, Throwable throwable) {
-
+ Log.d(Config.LOGTAG, "Unable to query muclumbus on " + Config.CHANNEL_DISCOVERY, throwable);
+ listener.onChannelSearchResultsFound(Collections.emptyList());
}
});
} catch (Exception e) {
@@ -92,7 +109,8 @@ public class ChannelDiscoveryService {
@Override
public void onFailure(Call<MuclumbusService.SearchResult> call, Throwable throwable) {
- throwable.printStackTrace();
+ Log.d(Config.LOGTAG, "Unable to query muclumbus on " + Config.CHANNEL_DISCOVERY, throwable);
+ listener.onChannelSearchResultsFound(Collections.emptyList());
}
});
}