Commit d13702d9 authored by Yusuke Iwaki's avatar Yusuke Iwaki

Merge branch 'origin/okhttp3.5.0' into develop

parents aa7eb67a 8e235f66
......@@ -37,7 +37,7 @@ android {
dependencies {
compile project(':log-wrapper')
compile rootProject.ext.supportAnnotations
compile 'com.squareup.okhttp3:okhttp-ws:3.4.1'
compile rootProject.ext.okhttp3
compile rootProject.ext.rxJava
compile rootProject.ext.boltsTask
}
......@@ -15,7 +15,8 @@ public class DDPClientCallback {
public static abstract class BaseException extends Exception {
public DDPClient client;
public BaseException(DDPClient client) {
public BaseException(Class<? extends BaseException> clazz, DDPClient client) {
super(clazz.getName());
this.client = client;
}
}
......@@ -32,14 +33,14 @@ public class DDPClientCallback {
public String version;
public Failed(DDPClient client, String version) {
super(client);
super(Failed.class, client);
this.version = version;
}
}
public static class Timeout extends BaseException {
public Timeout(DDPClient client) {
super(client);
super(Timeout.class, client);
}
}
}
......@@ -54,7 +55,7 @@ public class DDPClientCallback {
public static class Timeout extends BaseException {
public Timeout(DDPClient client) {
super(client);
super(Timeout.class, client);
}
}
}
......@@ -74,7 +75,7 @@ public class DDPClientCallback {
public JSONObject error;
public Error(DDPClient client, String id, JSONObject error) {
super(client);
super(Error.class, client);
this.id = id;
this.error = error;
}
......@@ -82,8 +83,14 @@ public class DDPClientCallback {
public static class Timeout extends BaseException {
public Timeout(DDPClient client) {
super(client);
super(Timeout.class, client);
}
}
}
public static class Closed extends BaseException {
public Closed(DDPClient client) {
super(Closed.class, client);
}
}
}
......@@ -4,13 +4,9 @@ import java.io.IOException;
import chat.rocket.android.log.RCLog;
import okhttp3.OkHttpClient;
import okhttp3.Request;
import okhttp3.RequestBody;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okhttp3.ws.WebSocket;
import okhttp3.ws.WebSocketCall;
import okhttp3.ws.WebSocketListener;
import okio.Buffer;
import okhttp3.WebSocket;
import okhttp3.WebSocketListener;
import rx.Observable;
import rx.Subscriber;
import rx.exceptions.OnErrorNotImplementedException;
......@@ -28,12 +24,11 @@ public class RxWebSocket {
public ConnectableObservable<RxWebSocketCallback.Base> connect(String url) {
final Request request = new Request.Builder().url(url).build();
WebSocketCall call = WebSocketCall.create(httpClient, request);
return Observable.create(new Observable.OnSubscribe<RxWebSocketCallback.Base>() {
@Override
public void call(Subscriber<? super RxWebSocketCallback.Base> subscriber) {
call.enqueue(new WebSocketListener() {
httpClient.newWebSocket(request, new WebSocketListener() {
@Override
public void onOpen(WebSocket webSocket, Response response) {
isConnected = true;
......@@ -42,29 +37,23 @@ public class RxWebSocket {
}
@Override
public void onFailure(IOException e, Response response) {
public void onFailure(WebSocket webSocket, Throwable err, Response response) {
try {
isConnected = false;
subscriber.onError(new RxWebSocketCallback.Failure(webSocket, e, response));
subscriber.onError(new RxWebSocketCallback.Failure(webSocket, err, response));
} catch (OnErrorNotImplementedException ex) {
RCLog.w(ex, "OnErrorNotImplementedException ignored");
}
}
@Override
public void onMessage(ResponseBody responseBody) throws IOException {
public void onMessage(WebSocket webSocket, String text) {
isConnected = true;
subscriber.onNext(new RxWebSocketCallback.Message(webSocket, responseBody));
subscriber.onNext(new RxWebSocketCallback.Message(webSocket, text));
}
@Override
public void onPong(Buffer payload) {
isConnected = true;
subscriber.onNext(new RxWebSocketCallback.Pong(webSocket, payload));
}
@Override
public void onClose(int code, String reason) {
public void onClosed(WebSocket webSocket, int code, String reason) {
isConnected = false;
subscriber.onNext(new RxWebSocketCallback.Close(webSocket, code, reason));
subscriber.onCompleted();
......@@ -74,15 +63,15 @@ public class RxWebSocket {
}).publish();
}
public void sendText(String message) throws IOException {
webSocket.sendMessage(RequestBody.create(WebSocket.TEXT, message));
public boolean sendText(String message) throws IOException {
return webSocket.send(message);
}
public boolean isConnected() {
return isConnected;
}
public void close(int code, String reason) throws IOException {
webSocket.close(code, reason);
public boolean close(int code, String reason) throws IOException {
return webSocket.close(code, reason);
}
}
......@@ -2,12 +2,9 @@ package chat.rocket.android_ddp.rx;
import static android.R.attr.type;
import java.io.IOException;
import chat.rocket.android.log.RCLog;
import okhttp3.Response;
import okhttp3.ResponseBody;
import okhttp3.ws.WebSocket;
import okio.Buffer;
import okhttp3.WebSocket;
public class RxWebSocketCallback {
public static abstract class Base {
......@@ -38,8 +35,8 @@ public class RxWebSocketCallback {
public WebSocket ws;
public Response response;
public Failure(WebSocket websocket, IOException e, Response response) {
super(e);
public Failure(WebSocket websocket, Throwable err, Response response) {
super(err);
this.ws = websocket;
this.response = response;
}
......@@ -57,10 +54,10 @@ public class RxWebSocketCallback {
public static class Message extends Base {
public String responseBodyString;
public Message(WebSocket websocket, ResponseBody responseBody) {
public Message(WebSocket websocket, String responseBody) {
super("Message", websocket);
try {
this.responseBodyString = responseBody.string();
this.responseBodyString = responseBody;
} catch (Exception e) {
RCLog.e(e, "error in reading response(Message)");
}
......@@ -72,15 +69,6 @@ public class RxWebSocketCallback {
}
}
public static class Pong extends Base {
public Buffer payload;
public Pong(WebSocket websocket, Buffer payload) {
super("Pong", websocket);
this.payload = payload;
}
}
public static class Close extends Base {
public int code;
public String reason;
......
......@@ -15,7 +15,7 @@ ext {
rxJava = 'io.reactivex:rxjava:1.2.2'
boltsTask = 'com.parse.bolts:bolts-tasks:1.4.0'
okhttp3 = 'com.squareup.okhttp3:okhttp:3.4.1'
okhttp3 = 'com.squareup.okhttp3:okhttp:3.5.0'
picasso = 'com.squareup.picasso:picasso:2.5.2'
picasso2Okhttp3Downloader = 'com.jakewharton.picasso:picasso2-okhttp3-downloader:1.1.0'
textDrawable = 'com.amulyakhare:com.amulyakhare.textdrawable:1.0.1'
......
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