mirror of
https://github.com/Divested-Mobile/DivestOS-Build.git
synced 2025-01-22 05:11:24 -05:00
125 lines
5.3 KiB
Diff
125 lines
5.3 KiB
Diff
|
From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
|
||
|
From: Pratyush <codelab@pratyush.dev>
|
||
|
Date: Tue, 6 Jul 2021 18:18:06 +0530
|
||
|
Subject: [PATCH] Wi-Fi auto turn off
|
||
|
|
||
|
---
|
||
|
core/java/android/provider/Settings.java | 6 ++
|
||
|
.../server/net/NetworkStatsService.java | 70 +++++++++++++++++++
|
||
|
2 files changed, 76 insertions(+)
|
||
|
|
||
|
diff --git a/core/java/android/provider/Settings.java b/core/java/android/provider/Settings.java
|
||
|
index d7e3e8f13acd..367c57526fe5 100755
|
||
|
--- a/core/java/android/provider/Settings.java
|
||
|
+++ b/core/java/android/provider/Settings.java
|
||
|
@@ -14480,6 +14480,12 @@ public final class Settings {
|
||
|
*/
|
||
|
public static final String BLUETOOTH_OFF_TIMEOUT = "bluetooth_off_timeout";
|
||
|
|
||
|
+ /**
|
||
|
+ * The amount of time in milliseconds before Wi-Fi is turned off
|
||
|
+ * @hide
|
||
|
+ */
|
||
|
+ public static final String WIFI_OFF_TIMEOUT = "wifi_off_timeout";
|
||
|
+
|
||
|
/**
|
||
|
* Whether to automatically reboot the device after a user defined timeout
|
||
|
*
|
||
|
diff --git a/services/core/java/com/android/server/net/NetworkStatsService.java b/services/core/java/com/android/server/net/NetworkStatsService.java
|
||
|
index ba9f486092f7..24cba592a59d 100644
|
||
|
--- a/services/core/java/com/android/server/net/NetworkStatsService.java
|
||
|
+++ b/services/core/java/com/android/server/net/NetworkStatsService.java
|
||
|
@@ -87,6 +87,7 @@ import android.content.Intent;
|
||
|
import android.content.IntentFilter;
|
||
|
import android.content.pm.ApplicationInfo;
|
||
|
import android.content.pm.PackageManager;
|
||
|
+import android.database.ContentObserver;
|
||
|
import android.net.DataUsageRequest;
|
||
|
import android.net.INetworkManagementEventObserver;
|
||
|
import android.net.INetworkStatsService;
|
||
|
@@ -106,8 +107,10 @@ import android.net.TrafficStats;
|
||
|
import android.net.netstats.provider.INetworkStatsProvider;
|
||
|
import android.net.netstats.provider.INetworkStatsProviderCallback;
|
||
|
import android.net.netstats.provider.NetworkStatsProvider;
|
||
|
+import android.net.wifi.WifiManager;
|
||
|
import android.os.BestClock;
|
||
|
import android.os.Binder;
|
||
|
+import android.os.Bundle;
|
||
|
import android.os.DropBoxManager;
|
||
|
import android.os.Environment;
|
||
|
import android.os.Handler;
|
||
|
@@ -438,6 +441,73 @@ public class NetworkStatsService extends INetworkStatsService.Stub {
|
||
|
mHandler = new NetworkStatsHandler(handlerThread.getLooper());
|
||
|
mNetworkStatsSubscriptionsMonitor = deps.makeSubscriptionsMonitor(mContext,
|
||
|
new HandlerExecutor(mHandler), this);
|
||
|
+
|
||
|
+ IntentFilter wifiFilter = new IntentFilter();
|
||
|
+ wifiFilter.addAction(WifiManager.NETWORK_STATE_CHANGED_ACTION);
|
||
|
+ wifiFilter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION);
|
||
|
+
|
||
|
+ context.registerReceiver(
|
||
|
+ new BroadcastReceiver() {
|
||
|
+ @Override
|
||
|
+ public void onReceive(Context context, Intent intent) {
|
||
|
+ if (WifiManager.NETWORK_STATE_CHANGED_ACTION.equals(intent.getAction())) {
|
||
|
+ Bundle bundle = intent.getExtras();
|
||
|
+ NetworkInfo networkInfo = bundle.getParcelable(WifiManager.EXTRA_NETWORK_INFO);
|
||
|
+ isWifiConnected = networkInfo != null && networkInfo.isConnected();
|
||
|
+ }
|
||
|
+ reconfigureWiFiTimeoutListener();
|
||
|
+ }
|
||
|
+ }, wifiFilter
|
||
|
+ );
|
||
|
+
|
||
|
+ context.getContentResolver().registerContentObserver(
|
||
|
+ Global.getUriFor(Global.WIFI_OFF_TIMEOUT),
|
||
|
+ false,
|
||
|
+ new ContentObserver(new Handler(context.getMainLooper())) {
|
||
|
+ @Override
|
||
|
+ public void onChange(boolean selfChange) {
|
||
|
+ super.onChange(selfChange);
|
||
|
+ reconfigureWiFiTimeoutListener();
|
||
|
+ }
|
||
|
+ });
|
||
|
+ }
|
||
|
+
|
||
|
+ private static boolean isWifiConnected = false;
|
||
|
+ private final AlarmManager.OnAlarmListener listener = this::turnOffWifi;
|
||
|
+
|
||
|
+ private void turnOffWifi() {
|
||
|
+ WifiManager wifiManager = (WifiManager) mContext.getSystemService(Context.WIFI_SERVICE);
|
||
|
+ if (isWifiTimeoutEnabled(mContext) && wifiManager.isWifiEnabled()) {
|
||
|
+ // setWifiEnabled(enabled) is deprecated, though AOSP still uses
|
||
|
+ // it internally and system apps/services are exempted
|
||
|
+ wifiManager.setWifiEnabled(false);
|
||
|
+ }
|
||
|
+ }
|
||
|
+
|
||
|
+ private void reconfigureWiFiTimeoutListener() {
|
||
|
+ if (isWifiTimeoutEnabled(mContext) && !isWifiConnected) {
|
||
|
+ final long timeout = SystemClock.elapsedRealtime() + wifiTimeoutDurationInMilli(mContext);
|
||
|
+ mAlarmManager.cancel(listener);
|
||
|
+ mAlarmManager.setExact(
|
||
|
+ AlarmManager.ELAPSED_REALTIME_WAKEUP,
|
||
|
+ timeout,
|
||
|
+ "Wi-Fi Idle Timeout",
|
||
|
+ listener,
|
||
|
+ new Handler(mContext.getMainLooper())
|
||
|
+ );
|
||
|
+ } else {
|
||
|
+ mAlarmManager.cancel(listener);
|
||
|
+ }
|
||
|
+ }
|
||
|
+
|
||
|
+ private static long wifiTimeoutDurationInMilli(Context mContext) {
|
||
|
+ return Settings.Global.getLong(mContext.getContentResolver(),
|
||
|
+ Global.WIFI_OFF_TIMEOUT, 0);
|
||
|
+ }
|
||
|
+
|
||
|
+ /** Zero is default and means disabled */
|
||
|
+ private static boolean isWifiTimeoutEnabled(Context mContext) {
|
||
|
+ return 0 != wifiTimeoutDurationInMilli(mContext);
|
||
|
}
|
||
|
|
||
|
/**
|