mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-24 19:33:45 +02:00 
			
		
		
		
	Optional "when charging only" toggle for BG updates (#1914)
This commit is contained in:
		| @@ -419,6 +419,25 @@ class _SettingsPageState extends State<SettingsPage> { | ||||
|                                                           }) | ||||
|                                                     ], | ||||
|                                                   ), | ||||
|                                                   height16, | ||||
|                                                   Row( | ||||
|                                                     mainAxisAlignment: | ||||
|                                                         MainAxisAlignment | ||||
|                                                             .spaceBetween, | ||||
|                                                     children: [ | ||||
|                                                       Flexible( | ||||
|                                                           child: Text(tr( | ||||
|                                                               'bgUpdatesWhileChargingOnly'))), | ||||
|                                                       Switch( | ||||
|                                                           value: settingsProvider | ||||
|                                                               .bgUpdatesWhileChargingOnly, | ||||
|                                                           onChanged: (value) { | ||||
|                                                             settingsProvider | ||||
|                                                                     .bgUpdatesWhileChargingOnly = | ||||
|                                                                 value; | ||||
|                                                           }) | ||||
|                                                     ], | ||||
|                                                   ), | ||||
|                                                 ], | ||||
|                                               ), | ||||
|                                           ], | ||||
|   | ||||
| @@ -5,6 +5,7 @@ import 'dart:async'; | ||||
| import 'dart:convert'; | ||||
| import 'dart:io'; | ||||
| import 'dart:math'; | ||||
| import 'package:battery_plus/battery_plus.dart'; | ||||
| import 'package:fluttertoast/fluttertoast.dart'; | ||||
| import 'package:http/http.dart' as http; | ||||
| import 'package:crypto/crypto.dart'; | ||||
| @@ -1885,10 +1886,20 @@ Future<void> bgUpdateCheck(String taskId, Map<String, dynamic>? params) async { | ||||
|         (<List<MapEntry<String, int>>>[])) | ||||
|   ]; | ||||
|  | ||||
|   var networkRestricted = false; | ||||
|   if (appsProvider.settingsProvider.bgUpdatesOnWiFiOnly) { | ||||
|     networkRestricted = !netResult.contains(ConnectivityResult.wifi) && | ||||
|         !netResult.contains(ConnectivityResult.ethernet); | ||||
|   var networkRestricted = appsProvider.settingsProvider.bgUpdatesOnWiFiOnly && | ||||
|       !netResult.contains(ConnectivityResult.wifi) && | ||||
|       !netResult.contains(ConnectivityResult.ethernet); | ||||
|  | ||||
|   var chargingRestricted = | ||||
|       appsProvider.settingsProvider.bgUpdatesWhileChargingOnly && | ||||
|           (await Battery().batteryState) != BatteryState.charging; | ||||
|  | ||||
|   if (networkRestricted) { | ||||
|     logs.add('BG update task: Network restriction in effect.'); | ||||
|   } | ||||
|  | ||||
|   if (chargingRestricted) { | ||||
|     logs.add('BG update task: Charging restriction in effect.'); | ||||
|   } | ||||
|  | ||||
|   if (toCheck.isNotEmpty) { | ||||
| @@ -1928,14 +1939,6 @@ Future<void> bgUpdateCheck(String taskId, Map<String, dynamic>? params) async { | ||||
|     CheckingUpdatesNotification notif = CheckingUpdatesNotification( | ||||
|         plural('apps', toCheck.length)); // The notif. to show while checking | ||||
|  | ||||
|     // Set a bool for when we're no on wifi/wired and the user doesn't want to download apps in that state | ||||
|     var networkRestricted = false; | ||||
|     if (appsProvider.settingsProvider.bgUpdatesOnWiFiOnly) { | ||||
|       var netResult = await (Connectivity().checkConnectivity()); | ||||
|       networkRestricted = !netResult.contains(ConnectivityResult.wifi) && | ||||
|           !netResult.contains(ConnectivityResult.ethernet); | ||||
|     } | ||||
|  | ||||
|     try { | ||||
|       // Check for updates | ||||
|       notificationsProvider.notify(notif, cancelExisting: true); | ||||
| @@ -1983,6 +1986,7 @@ Future<void> bgUpdateCheck(String taskId, Map<String, dynamic>? params) async { | ||||
|     // Filter out updates that will be installed silently (the rest go into toNotify) | ||||
|     for (var i = 0; i < updates.length; i++) { | ||||
|       if (networkRestricted || | ||||
|           chargingRestricted || | ||||
|           !(await appsProvider.canInstallSilently(updates[i]))) { | ||||
|         if (updates[i].additionalSettings['skipUpdateNotifications'] != true) { | ||||
|           toNotify.add(updates[i]); | ||||
| @@ -2029,7 +2033,7 @@ Future<void> bgUpdateCheck(String taskId, Map<String, dynamic>? params) async { | ||||
|   } else { | ||||
|     // In install mode... | ||||
|     // If you haven't explicitly been given updates to install, grab all available silent updates | ||||
|     if (toInstall.isEmpty && !networkRestricted) { | ||||
|     if (toInstall.isEmpty && !networkRestricted && !chargingRestricted) { | ||||
|       var temp = appsProvider.findExistingUpdates(installedOnly: true); | ||||
|       for (var i = 0; i < temp.length; i++) { | ||||
|         if (await appsProvider | ||||
|   | ||||
| @@ -349,6 +349,15 @@ class SettingsProvider with ChangeNotifier { | ||||
|     notifyListeners(); | ||||
|   } | ||||
|  | ||||
|   bool get bgUpdatesWhileChargingOnly { | ||||
|     return prefs?.getBool('bgUpdatesWhileChargingOnly') ?? false; | ||||
|   } | ||||
|  | ||||
|   set bgUpdatesWhileChargingOnly(bool val) { | ||||
|     prefs?.setBool('bgUpdatesWhileChargingOnly', val); | ||||
|     notifyListeners(); | ||||
|   } | ||||
|  | ||||
|   DateTime get lastCompletedBGCheckTime { | ||||
|     int? temp = prefs?.getInt('lastCompletedBGCheckTime'); | ||||
|     return temp != null | ||||
|   | ||||
		Reference in New Issue
	
	Block a user