mirror of
https://github.com/TeamVanced/VancedMicroG
synced 2025-01-18 15:17:31 +01:00
Don't teardown things after sockets have been closed
Before, the call to closeAll() in McsService#connect() would trigger a SocketException (Socket closed) in McsOutputStream and/or McsInputStream. This would send a teardown message causing McsService to take the new connection down right away. In unlucky situations, this could cause small connect/teardown loops. This commit hopes to prevent those. Change-Id: Id347d598e028bdd1ba2622cd6a5c6b07874335d6
This commit is contained in:
parent
b9b1ef6246
commit
f3c20333b0
@ -20,7 +20,6 @@ import android.os.Handler;
|
|||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
|
|
||||||
import com.squareup.wire.Message;
|
import com.squareup.wire.Message;
|
||||||
import com.squareup.wire.Wire;
|
|
||||||
|
|
||||||
import org.microg.gms.gcm.mcs.Close;
|
import org.microg.gms.gcm.mcs.Close;
|
||||||
import org.microg.gms.gcm.mcs.DataMessageStanza;
|
import org.microg.gms.gcm.mcs.DataMessageStanza;
|
||||||
@ -57,7 +56,7 @@ public class McsInputStream extends Thread implements Closeable {
|
|||||||
private int streamId = 0;
|
private int streamId = 0;
|
||||||
private long lastMsgTime = 0;
|
private long lastMsgTime = 0;
|
||||||
|
|
||||||
private boolean closed = false;
|
private volatile boolean closed = false;
|
||||||
|
|
||||||
public McsInputStream(InputStream is, Handler mainHandler) {
|
public McsInputStream(InputStream is, Handler mainHandler) {
|
||||||
this(is, mainHandler, false);
|
this(is, mainHandler, false);
|
||||||
@ -83,8 +82,12 @@ public class McsInputStream extends Thread implements Closeable {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
|
if (closed) {
|
||||||
|
Log.d(TAG, "We were closed already. Ignoring IOException");
|
||||||
|
} else {
|
||||||
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_INPUT_ERROR, e));
|
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_INPUT_ERROR, e));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
is.close();
|
is.close();
|
||||||
} catch (IOException ignored) {
|
} catch (IOException ignored) {
|
||||||
@ -120,7 +123,7 @@ public class McsInputStream extends Thread implements Closeable {
|
|||||||
Log.d(TAG, "Reading from MCS version: " + version);
|
Log.d(TAG, "Reading from MCS version: " + version);
|
||||||
initialized = true;
|
initialized = true;
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
Log.w(TAG, e);
|
Log.w(TAG, "Error reading version", e);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -41,10 +41,10 @@ public class McsOutputStream extends Thread implements Handler.Callback, Closeab
|
|||||||
private int version = MCS_VERSION_CODE;
|
private int version = MCS_VERSION_CODE;
|
||||||
private int streamId = 0;
|
private int streamId = 0;
|
||||||
|
|
||||||
private Handler mainHandler;
|
private final Handler mainHandler;
|
||||||
private Handler myHandler;
|
private Handler myHandler;
|
||||||
|
|
||||||
private boolean closed = false;
|
private volatile boolean closed = false;
|
||||||
|
|
||||||
public McsOutputStream(OutputStream os, Handler mainHandler) {
|
public McsOutputStream(OutputStream os, Handler mainHandler) {
|
||||||
this(os, mainHandler, false);
|
this(os, mainHandler, false);
|
||||||
@ -78,8 +78,12 @@ public class McsOutputStream extends Thread implements Handler.Callback, Closeab
|
|||||||
writeInternal((Message) msg.obj, msg.arg1);
|
writeInternal((Message) msg.obj, msg.arg1);
|
||||||
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_OUTPUT_DONE, msg.arg1, msg.arg2, msg.obj));
|
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_OUTPUT_DONE, msg.arg1, msg.arg2, msg.obj));
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
|
if (closed) {
|
||||||
|
Log.d(TAG, "We were closed already. Ignoring IOException");
|
||||||
|
} else {
|
||||||
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_OUTPUT_ERROR, e));
|
mainHandler.dispatchMessage(mainHandler.obtainMessage(MSG_OUTPUT_ERROR, e));
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
case MSG_TEARDOWN:
|
case MSG_TEARDOWN:
|
||||||
try {
|
try {
|
||||||
|
@ -441,7 +441,6 @@ public class McsService extends Service implements Handler.Callback {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private synchronized void connect() {
|
private synchronized void connect() {
|
||||||
wasTornDown = false;
|
|
||||||
try {
|
try {
|
||||||
closeAll();
|
closeAll();
|
||||||
ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
|
||||||
@ -452,6 +451,7 @@ public class McsService extends Service implements Handler.Callback {
|
|||||||
scheduleReconnect(this);
|
scheduleReconnect(this);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
wasTornDown = false;
|
||||||
|
|
||||||
logd(this, "Starting MCS connection...");
|
logd(this, "Starting MCS connection...");
|
||||||
Socket socket = new Socket(SERVICE_HOST, SERVICE_PORT);
|
Socket socket = new Socket(SERVICE_HOST, SERVICE_PORT);
|
||||||
@ -744,6 +744,7 @@ public class McsService extends Service implements Handler.Callback {
|
|||||||
resetCurrentDelay();
|
resetCurrentDelay();
|
||||||
lastIncomingNetworkRealtime = SystemClock.elapsedRealtime();
|
lastIncomingNetworkRealtime = SystemClock.elapsedRealtime();
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
|
Log.w(TAG, "Exception when handling input: " + message, e);
|
||||||
rootHandler.sendMessage(rootHandler.obtainMessage(MSG_TEARDOWN, e));
|
rootHandler.sendMessage(rootHandler.obtainMessage(MSG_TEARDOWN, e));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -758,6 +759,7 @@ public class McsService extends Service implements Handler.Callback {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static void closeAll() {
|
private static void closeAll() {
|
||||||
|
logd(null, "Closing all sockets...");
|
||||||
tryClose(inputStream);
|
tryClose(inputStream);
|
||||||
tryClose(outputStream);
|
tryClose(outputStream);
|
||||||
if (sslSocket != null) {
|
if (sslSocket != null) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user