|
@@ -6,65 +6,90 @@ import android.content.Context;
|
|
|
import android.content.Intent;
|
|
|
import android.content.pm.PackageManager;
|
|
|
import android.net.ConnectivityManager;
|
|
|
+import android.net.NetworkInfo;
|
|
|
+import android.net.NetworkInfo.State;
|
|
|
+import android.net.wifi.WifiManager;
|
|
|
import android.os.Bundle;
|
|
|
import android.util.Log;
|
|
|
|
|
|
import com.owncloud.android.files.InstantUploadBroadcastReceiver;
|
|
|
+import com.owncloud.android.lib.common.utils.Log_OC;
|
|
|
|
|
|
/**
|
|
|
- * Receives all connectivity action from Android OS at all times and performs required OC actions.
|
|
|
- * For now that are:
|
|
|
- * - Signal connectivity to {@link FileUploadService}.
|
|
|
- *
|
|
|
- * Later can be added:
|
|
|
- * - Signal connectivity to download service, deletion service, ...
|
|
|
- * - Handle offline mode (cf. https://github.com/owncloud/android/issues/162)
|
|
|
- *
|
|
|
+ * Receives all connectivity action from Android OS at all times and performs
|
|
|
+ * required OC actions. For now that are: - Signal connectivity to
|
|
|
+ * {@link FileUploadService}.
|
|
|
+ *
|
|
|
+ * Later can be added: - Signal connectivity to download service, deletion
|
|
|
+ * service, ... - Handle offline mode (cf.
|
|
|
+ * https://github.com/owncloud/android/issues/162)
|
|
|
+ *
|
|
|
* @author LukeOwncloud
|
|
|
- *
|
|
|
+ *
|
|
|
*/
|
|
|
public class ConnectivityActionReceiver extends BroadcastReceiver {
|
|
|
private static final String TAG = "ConnectivityActionReceiver";
|
|
|
|
|
|
@Override
|
|
|
public void onReceive(final Context context, Intent intent) {
|
|
|
-// if (intent.getAction().equals(ConnectivityManager.CONNECTIVITY_ACTION)) {
|
|
|
- Log.v(TAG, "action: " + intent.getAction());
|
|
|
- Log.v(TAG, "component: " + intent.getComponent());
|
|
|
- Bundle extras = intent.getExtras();
|
|
|
- if (extras != null) {
|
|
|
- for (String key : extras.keySet()) {
|
|
|
- Log.v(TAG, "key [" + key + "]: " + extras.get(key));
|
|
|
- }
|
|
|
- } else {
|
|
|
- Log.v(TAG, "no extras");
|
|
|
+ // LOG ALL EVENTS:
|
|
|
+ Log.v(TAG, "action: " + intent.getAction());
|
|
|
+ Log.v(TAG, "component: " + intent.getComponent());
|
|
|
+ Bundle extras = intent.getExtras();
|
|
|
+ if (extras != null) {
|
|
|
+ for (String key : extras.keySet()) {
|
|
|
+ Log.v(TAG, "key [" + key + "]: " + extras.get(key));
|
|
|
}
|
|
|
+ } else {
|
|
|
+ Log.v(TAG, "no extras");
|
|
|
+ }
|
|
|
|
|
|
- if (InstantUploadBroadcastReceiver.isOnline(context)) {
|
|
|
- FileUploadService.retry(context);
|
|
|
+
|
|
|
+ /**
|
|
|
+ * Just checking for State.CONNECTED will is not good enough, as it ends here multiple times.
|
|
|
+ * Work around from:
|
|
|
+ * http://stackoverflow.com/questions/17287178/connectivitymanager-getactivenetworkinfo-returning-true-when-internet-is-off
|
|
|
+ */
|
|
|
+ if(intent.getAction().equals(WifiManager.NETWORK_STATE_CHANGED_ACTION)) {
|
|
|
+ NetworkInfo networkInfo =
|
|
|
+ intent.getParcelableExtra(WifiManager.EXTRA_NETWORK_INFO);
|
|
|
+ if(networkInfo.isConnected()) {
|
|
|
+ Log.d(TAG, "Wifi is connected: " + String.valueOf(networkInfo));
|
|
|
+ wifiConnected(context);
|
|
|
}
|
|
|
-// }
|
|
|
+ } else if(intent.getAction().equals(ConnectivityManager.CONNECTIVITY_ACTION)) {
|
|
|
+ ConnectivityManager cm =
|
|
|
+ (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
|
|
|
+ NetworkInfo networkInfo = cm.getActiveNetworkInfo();
|
|
|
+ if(networkInfo.getType() == ConnectivityManager.TYPE_WIFI &&
|
|
|
+ ! networkInfo.isConnected()) {
|
|
|
+ Log.d(TAG, "Wifi is disconnected: " + String.valueOf(networkInfo));
|
|
|
+ wifiDisconnected(context);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ private void wifiConnected(Context context) {
|
|
|
+ Log_OC.d(TAG, "FileUploadService.retry() called by onReceive()");
|
|
|
+ FileUploadService.retry(context);
|
|
|
}
|
|
|
-
|
|
|
- static public void enable(Context context) {
|
|
|
+
|
|
|
+ private void wifiDisconnected(Context context) {
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ static public void enableActionReceiver(Context context) {
|
|
|
PackageManager pm = context.getPackageManager();
|
|
|
- ComponentName compName =
|
|
|
- new ComponentName(context.getApplicationContext(),
|
|
|
- ConnectivityActionReceiver.class);
|
|
|
- pm.setComponentEnabledSetting(
|
|
|
- compName,
|
|
|
- PackageManager.COMPONENT_ENABLED_STATE_ENABLED,
|
|
|
- PackageManager.DONT_KILL_APP);
|
|
|
+ ComponentName compName = new ComponentName(context.getApplicationContext(), ConnectivityActionReceiver.class);
|
|
|
+ pm.setComponentEnabledSetting(compName, PackageManager.COMPONENT_ENABLED_STATE_ENABLED,
|
|
|
+ PackageManager.DONT_KILL_APP);
|
|
|
}
|
|
|
-
|
|
|
- static public void disable(Context context) {
|
|
|
+
|
|
|
+ static public void disableActionReceiver(Context context) {
|
|
|
PackageManager pm = context.getPackageManager();
|
|
|
- ComponentName compName =
|
|
|
- new ComponentName(context.getApplicationContext(),
|
|
|
- ConnectivityActionReceiver.class);
|
|
|
- pm.setComponentEnabledSetting(
|
|
|
- compName,
|
|
|
- PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
|
|
- PackageManager.DONT_KILL_APP);
|
|
|
+ ComponentName compName = new ComponentName(context.getApplicationContext(), ConnectivityActionReceiver.class);
|
|
|
+ pm.setComponentEnabledSetting(compName, PackageManager.COMPONENT_ENABLED_STATE_DISABLED,
|
|
|
+ PackageManager.DONT_KILL_APP);
|
|
|
}
|
|
|
}
|