diff --git a/TMessagesProj/build.gradle b/TMessagesProj/build.gradle index daf2e0c4..c49d61bb 100644 --- a/TMessagesProj/build.gradle +++ b/TMessagesProj/build.gradle @@ -83,7 +83,7 @@ android { defaultConfig { minSdkVersion 8 targetSdkVersion 19 - versionCode 280 + versionCode 281 versionName "1.6.0" } } diff --git a/TMessagesProj/src/main/java/org/telegram/messenger/ConnectionsManager.java b/TMessagesProj/src/main/java/org/telegram/messenger/ConnectionsManager.java index 5e93263a..19bd2c1b 100644 --- a/TMessagesProj/src/main/java/org/telegram/messenger/ConnectionsManager.java +++ b/TMessagesProj/src/main/java/org/telegram/messenger/ConnectionsManager.java @@ -781,7 +781,7 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. } updatingDcSettings = false; } - }, null, true, RPCRequest.RPCRequestClassEnableUnauthorized | RPCRequest.RPCRequestClassGeneric | RPCRequest.RPCRequestClassWithoutLogin, dcNum == 0 ? currentDatacenterId : dcNum); + }, null, true, RPCRequest.RPCRequestClassEnableUnauthorized | RPCRequest.RPCRequestClassGeneric | RPCRequest.RPCRequestClassWithoutLogin | RPCRequest.RPCRequestClassTryDifferentDc, dcNum == 0 ? currentDatacenterId : dcNum); } private TLObject wrapInLayer(TLObject object, int datacenterId, RPCRequest request) { @@ -996,20 +996,6 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. for (int i = 0; i < runningRequests.size(); i++) { RPCRequest request = runningRequests.get(i); - if (datacenters.size() > 1) { - if (updatingDcSettings && request.rawRequest instanceof TLRPC.TL_help_getConfig) { - if (updatingDcStartTime < currentTime - 60) { - FileLog.e("tmessages", "move TL_help_getConfig to requestQueue"); - requestQueue.add(request); - runningRequests.remove(i); - i--; - continue; - } - } else if (request.rawRequest instanceof TLRPC.TL_auth_sendCode || request.rawRequest instanceof TLRPC.TL_auth_signIn || request.rawRequest instanceof TLRPC.TL_auth_signUp) { - - } - } - int datacenterId = request.runningDatacenterId; if (datacenterId == DEFAULT_DATACENTER_ID) { if (movingToDatacenterId != DEFAULT_DATACENTER_ID) { @@ -1018,6 +1004,22 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. datacenterId = currentDatacenterId; } + if (datacenters.size() > 1 && (request.flags & RPCRequest.RPCRequestClassTryDifferentDc) != 0) { + int requestStartTime = request.runningStartTime; + int timeout = 30; + if (updatingDcSettings && request.rawRequest instanceof TLRPC.TL_help_getConfig) { + requestStartTime = updatingDcStartTime; + timeout = 60; + } + if (requestStartTime != 0 && requestStartTime < currentTime - timeout) { + FileLog.e("tmessages", "move " + request.rawRequest + " to requestQueue"); + requestQueue.add(request); + runningRequests.remove(i); + i--; + continue; + } + } + Datacenter requestDatacenter = datacenterWithId(datacenterId); if (!request.initRequest && requestDatacenter.lastInitVersion != currentAppVersion) { request.rpcRequest = wrapInLayer(request.rawRequest, requestDatacenter.datacenterId, request); @@ -1124,27 +1126,23 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. } } - boolean updatingState = MessagesController.getInstance().updatingState; - if (genericConnection != null && genericConnection.channelToken != 0) { - if (!updatingState) { - Datacenter currentDatacenter = datacenterWithId(currentDatacenterId); + Datacenter currentDatacenter = datacenterWithId(currentDatacenterId); - for (Long it : sessionsToDestroy) { - if (destroyingSessions.contains(it)) { - continue; - } - if (System.currentTimeMillis() / 1000 - lastDestroySessionRequestTime > 2.0) { - lastDestroySessionRequestTime = (int)(System.currentTimeMillis() / 1000); - TLRPC.TL_destroy_session destroySession = new TLRPC.TL_destroy_session(); - destroySession.session_id = it; - destroyingSessions.add(it); + for (Long it : sessionsToDestroy) { + if (destroyingSessions.contains(it)) { + continue; + } + if (System.currentTimeMillis() / 1000 - lastDestroySessionRequestTime > 2.0) { + lastDestroySessionRequestTime = (int)(System.currentTimeMillis() / 1000); + TLRPC.TL_destroy_session destroySession = new TLRPC.TL_destroy_session(); + destroySession.session_id = it; + destroyingSessions.add(it); - NetworkMessage networkMessage = new NetworkMessage(); - networkMessage.protoMessage = wrapMessage(destroySession, currentDatacenter.connection, false); - if (networkMessage.protoMessage != null) { - addMessageToDatacenter(currentDatacenter.datacenterId, networkMessage); - } + NetworkMessage networkMessage = new NetworkMessage(); + networkMessage.protoMessage = wrapMessage(destroySession, currentDatacenter.connection, false); + if (networkMessage.protoMessage != null) { + addMessageToDatacenter(currentDatacenter.datacenterId, networkMessage); } } } @@ -1172,22 +1170,6 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. continue; } - if (updatingDcSettings && datacenters.size() > 1 && request.rawRequest instanceof TLRPC.TL_help_getConfig) { - if (updatingDcStartTime < currentTime - 60) { - updatingDcStartTime = currentTime; - ArrayList allDc = new ArrayList(datacenters.values()); - for (int a = 0; a < allDc.size(); a++) { - Datacenter dc = allDc.get(a); - if (dc.datacenterId == request.runningDatacenterId) { - allDc.remove(a); - break; - } - } - Datacenter newDc = allDc.get(Math.abs(Utilities.random.nextInt() % allDc.size())); - request.runningDatacenterId = newDc.datacenterId; - } - } - int datacenterId = request.runningDatacenterId; if (datacenterId == DEFAULT_DATACENTER_ID) { if (movingToDatacenterId != DEFAULT_DATACENTER_ID && (request.flags & RPCRequest.RPCRequestClassEnableUnauthorized) == 0) { @@ -1196,6 +1178,28 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. datacenterId = currentDatacenterId; } + if (datacenters.size() > 1 && (request.flags & RPCRequest.RPCRequestClassTryDifferentDc) != 0) { + int requestStartTime = request.runningStartTime; + int timeout = 30; + if (updatingDcSettings && request.rawRequest instanceof TLRPC.TL_help_getConfig) { + requestStartTime = updatingDcStartTime; + updatingDcStartTime = currentTime; + timeout = 60; + } + if (requestStartTime != 0 && requestStartTime < currentTime - timeout) { + ArrayList allDc = new ArrayList(datacenters.values()); + for (int a = 0; a < allDc.size(); a++) { + Datacenter dc = allDc.get(a); + if (dc.datacenterId == datacenterId) { + allDc.remove(a); + break; + } + } + Datacenter newDc = allDc.get(Math.abs(Utilities.random.nextInt() % allDc.size())); + datacenterId = request.runningDatacenterId = newDc.datacenterId; + } + } + Datacenter requestDatacenter = datacenterWithId(datacenterId); if (!request.initRequest && requestDatacenter.lastInitVersion != currentAppVersion) { request.rpcRequest = wrapInLayer(request.rawRequest, requestDatacenter.datacenterId, request); @@ -1225,10 +1229,6 @@ public class ConnectionsManager implements Action.ActionDelegate, TcpConnection. continue; } - if (updatingState && (request.rawRequest instanceof TLRPC.TL_account_updateStatus || request.rawRequest instanceof TLRPC.TL_account_registerDevice)) { - continue; - } - if (request.requiresCompletion) { if ((request.flags & RPCRequest.RPCRequestClassGeneric) != 0) { if (genericRunningRequestCount >= 60) { diff --git a/TMessagesProj/src/main/java/org/telegram/messenger/RPCRequest.java b/TMessagesProj/src/main/java/org/telegram/messenger/RPCRequest.java index bd8b7898..aa40b7bd 100644 --- a/TMessagesProj/src/main/java/org/telegram/messenger/RPCRequest.java +++ b/TMessagesProj/src/main/java/org/telegram/messenger/RPCRequest.java @@ -26,6 +26,7 @@ public class RPCRequest { public static int RPCRequestClassCanCompress = 32; public static int RPCRequestClassPush = 64; public static int RPCRequestClassWithoutLogin = 128; + public static int RPCRequestClassTryDifferentDc = 256; static int RPCRequestClassTransportMask = (RPCRequestClassGeneric | RPCRequestClassDownloadMedia | RPCRequestClassUploadMedia); diff --git a/TMessagesProj/src/main/java/org/telegram/ui/LoginActivityPhoneView.java b/TMessagesProj/src/main/java/org/telegram/ui/LoginActivityPhoneView.java index ea07252e..4f37c7f7 100644 --- a/TMessagesProj/src/main/java/org/telegram/ui/LoginActivityPhoneView.java +++ b/TMessagesProj/src/main/java/org/telegram/ui/LoginActivityPhoneView.java @@ -390,7 +390,7 @@ public class LoginActivityPhoneView extends SlideView implements AdapterView.OnI } }); } - }, true, RPCRequest.RPCRequestClassGeneric | RPCRequest.RPCRequestClassFailOnServerErrors | RPCRequest.RPCRequestClassWithoutLogin); + }, true, RPCRequest.RPCRequestClassGeneric | RPCRequest.RPCRequestClassFailOnServerErrors | RPCRequest.RPCRequestClassWithoutLogin | RPCRequest.RPCRequestClassTryDifferentDc | RPCRequest.RPCRequestClassEnableUnauthorized); } @Override