Prevent double reload

pull/184/head
M66B 5 years ago
parent 4bd9247073
commit f7a0f29738

@ -1718,6 +1718,7 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
} }
private ConnectivityManager.NetworkCallback networkCallback = new ConnectivityManager.NetworkCallback() { private ConnectivityManager.NetworkCallback networkCallback = new ConnectivityManager.NetworkCallback() {
private Network reloaded = null;
private NetworkCapabilities lastActiveCaps = null; private NetworkCapabilities lastActiveCaps = null;
private LinkProperties lastActiveProps = null; private LinkProperties lastActiveProps = null;
@ -1744,7 +1745,7 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE); ConnectivityManager cm = (ConnectivityManager) getSystemService(Context.CONNECTIVITY_SERVICE);
Network active = cm.getActiveNetwork(); Network active = cm.getActiveNetwork();
if (active != null && active.equals(network)) { if (active != null && active.equals(network)) {
boolean reload = (lastActiveCaps != null && boolean reload = (!active.equals(reloaded) && lastActiveCaps != null &&
caps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VPN) && caps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VPN) &&
caps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED) && caps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_METERED) &&
lastActiveCaps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VPN) && lastActiveCaps.hasCapability(NetworkCapabilities.NET_CAPABILITY_NOT_VPN) &&
@ -1754,8 +1755,10 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
EntityLog.log(ServiceSynchronize.this, "Connectivity changed " + network + EntityLog.log(ServiceSynchronize.this, "Connectivity changed " + network +
" caps=" + caps + " reload=" + reload); " caps=" + caps + " reload=" + reload);
if (reload) if (reload) {
reloaded = active;
reload(ServiceSynchronize.this, -1L, false, "unmetered"); reload(ServiceSynchronize.this, -1L, false, "unmetered");
}
lastActiveCaps = caps; lastActiveCaps = caps;
} }
@ -1804,14 +1807,17 @@ public class ServiceSynchronize extends ServiceBase implements SharedPreferences
} }
} }
boolean reload = ((ahas4 && !lhas4) || (ahas6 && !lhas6)); boolean reload = (!active.equals(reloaded) &&
(ahas4 && !lhas4) || (ahas6 && !lhas6));
if (reload || BuildConfig.DEBUG) if (reload || BuildConfig.DEBUG)
EntityLog.log(ServiceSynchronize.this, "Connectivity changed " + network + EntityLog.log(ServiceSynchronize.this, "Connectivity changed " + network +
" props=" + props + " reload=" + reload); " props=" + props + " reload=" + reload);
if (reload) if (reload) {
reloaded = active;
reload(ServiceSynchronize.this, -1L, false, "connectivity"); reload(ServiceSynchronize.this, -1L, false, "connectivity");
}
lastActiveProps = props; lastActiveProps = props;
} }

Loading…
Cancel
Save