Commit bd6f84e5 authored by Yusuke Iwaki's avatar Yusuke Iwaki

set connect timeout.

parent 2545749d
...@@ -36,6 +36,12 @@ public class DDPClientCallback { ...@@ -36,6 +36,12 @@ public class DDPClientCallback {
this.version = version; this.version = version;
} }
} }
public static class Timeout extends BaseException {
public Timeout(DDPClient client) {
super(client);
}
}
} }
public static class Ping extends Base { public static class Ping extends Base {
......
...@@ -67,6 +67,7 @@ public class DDPClientImpl { ...@@ -67,6 +67,7 @@ public class DDPClientImpl {
observable.filter(callback -> callback instanceof RxWebSocketCallback.Message) observable.filter(callback -> callback instanceof RxWebSocketCallback.Message)
.map(callback -> ((RxWebSocketCallback.Message) callback).responseBodyString) .map(callback -> ((RxWebSocketCallback.Message) callback).responseBodyString)
.map(DDPClientImpl::toJson) .map(DDPClientImpl::toJson)
.timeout(7, TimeUnit.SECONDS)
.subscribe(response -> { .subscribe(response -> {
String msg = extractMsg(response); String msg = extractMsg(response);
if ("connected".equals(msg) && !response.isNull("session")) { if ("connected".equals(msg) && !response.isNull("session")) {
...@@ -83,6 +84,7 @@ public class DDPClientImpl { ...@@ -83,6 +84,7 @@ public class DDPClientImpl {
subscriptions.unsubscribe(); subscriptions.unsubscribe();
} }
}, err -> { }, err -> {
task.setError(new DDPClientCallback.Connect.Timeout(client));
})); }));
addErrorCallback(subscriptions, task); addErrorCallback(subscriptions, task);
...@@ -336,7 +338,7 @@ public class DDPClientImpl { ...@@ -336,7 +338,7 @@ public class DDPClientImpl {
private void addErrorCallback(CompositeSubscription subscriptions, TaskCompletionSource<?> task) { private void addErrorCallback(CompositeSubscription subscriptions, TaskCompletionSource<?> task) {
subscriptions.add(observable.subscribe(base -> { subscriptions.add(observable.subscribe(base -> {
}, err -> { }, err -> {
task.setError(new Exception(err)); task.trySetError(new Exception(err));
subscriptions.unsubscribe(); subscriptions.unsubscribe();
})); }));
} }
......
...@@ -205,8 +205,13 @@ public class RocketChatWebSocketThread extends HandlerThread { ...@@ -205,8 +205,13 @@ public class RocketChatWebSocketThread extends HandlerThread {
} }
}).continueWithTask(task -> { }).continueWithTask(task -> {
if (task.isFaulted()) { if (task.isFaulted()) {
Exception error = task.getError();
if (error instanceof DDPClientCallback.Connect.Timeout) {
ServerConfig.logConnectionError(serverConfigId, new Exception("Connection Timeout"));
} else {
ServerConfig.logConnectionError(serverConfigId, task.getError()); ServerConfig.logConnectionError(serverConfigId, task.getError());
} }
}
return task; return task;
}); });
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment