mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-25 20:03:44 +02:00 
			
		
		
		
	Trying a new recursive BG update task due2 mem limits
This commit is contained in:
		
							
								
								
									
										105
									
								
								lib/main.dart
									
									
									
									
									
								
							
							
						
						
									
										105
									
								
								lib/main.dart
									
									
									
									
									
								
							| @@ -71,31 +71,23 @@ Future<void> loadTranslations() async { | ||||
|       fallbackTranslations: controller.fallbackTranslations); | ||||
| } | ||||
|  | ||||
| @pragma('vm:entry-point') | ||||
| Future<void> bgUpdateCheckApps(int taskId, Map<String, dynamic>? params) async { | ||||
|   WidgetsFlutterBinding.ensureInitialized(); | ||||
|   await EasyLocalization.ensureInitialized(); | ||||
|   await AndroidAlarmManager.initialize(); | ||||
|   await loadTranslations(); | ||||
|  | ||||
|   LogsProvider logs = LogsProvider(); | ||||
|   AppsProvider appsProvider = AppsProvider(); | ||||
|   await appsProvider.loadApps(); | ||||
|  | ||||
|   logs.add('BG update parent task started.'); | ||||
|   var appIds = appsProvider.getAppsSortedByUpdateCheckTime(); | ||||
|   for (var id in appIds) { | ||||
|     AndroidAlarmManager.oneShot( | ||||
|         const Duration(minutes: 0), id.hashCode, bgUpdateCheckApp, | ||||
|         params: {'appId': id}); | ||||
|     await Future.delayed(const Duration(seconds: 1)); | ||||
| moveStrToEnd(List<String> arr, String str, {String? strB}) { | ||||
|   String? temp; | ||||
|   arr.removeWhere((element) { | ||||
|     bool res = element == str || element == strB; | ||||
|     if (res) { | ||||
|       temp = element; | ||||
|     } | ||||
|   logs.add( | ||||
|       'BG update parent task ended (${appIds.length} child task(s) started).'); | ||||
|     return res; | ||||
|   }); | ||||
|   if (temp != null) { | ||||
|     arr = [...arr, temp!]; | ||||
|   } | ||||
|   return arr; | ||||
| } | ||||
|  | ||||
| @pragma('vm:entry-point') | ||||
| Future<void> bgUpdateCheckApp(int taskId, Map<String, dynamic>? params) async { | ||||
| Future<void> bgUpdateCheck(int taskId, Map<String, dynamic>? params) async { | ||||
|   WidgetsFlutterBinding.ensureInitialized(); | ||||
|   await EasyLocalization.ensureInitialized(); | ||||
|   await AndroidAlarmManager.initialize(); | ||||
| @@ -104,31 +96,50 @@ Future<void> bgUpdateCheckApp(int taskId, Map<String, dynamic>? params) async { | ||||
|   LogsProvider logs = LogsProvider(); | ||||
|   NotificationsProvider notificationsProvider = NotificationsProvider(); | ||||
|   AppsProvider appsProvider = AppsProvider(); | ||||
|   await appsProvider.loadApps(); | ||||
|  | ||||
|   String appId = params!['appId']; | ||||
|   params['attemptCount'] = (params['attemptCount'] ?? 0) + 1; | ||||
|   int maxAttempts = 5; | ||||
|  | ||||
|   params ??= {}; | ||||
|   params['attemptCount'] = (params['attemptCount'] ?? 0) + 1; | ||||
|   params['toCheck'] = | ||||
|       params['toCheck'] ?? appsProvider.getAppsSortedByUpdateCheckTime(); | ||||
|   params['toInstall'] = params['toInstall'] ?? []; | ||||
|  | ||||
|   List<String> toCheck = params['toCheck']; | ||||
|   List<String> toInstall = params['toCheck']; | ||||
|  | ||||
|   logs.add( | ||||
|       'BG update task for $appId started (attempt #${params['attemptCount']}).'); | ||||
|   try { | ||||
|     await appsProvider.loadApps(singleId: appId); | ||||
|     AppInMemory app = appsProvider.apps[appId]!; | ||||
|     App? newApp; | ||||
|     if (app.app.installedVersion == app.app.latestVersion && | ||||
|         app.app.installedVersion != null) { | ||||
|       'BG update task $taskId started - ${toCheck.length} to check and ${toInstall.length} to install${params['attemptCount'] > 1 ? ' (attempt #${params['attemptCount']})' : ''}.'); | ||||
|  | ||||
|   if (toCheck.isNotEmpty) { | ||||
|     String appId = toCheck.removeAt(0); | ||||
|     AppInMemory? app = appsProvider.apps[appId]; | ||||
|     if (app?.app.installedVersion != null) { | ||||
|       try { | ||||
|         notificationsProvider.notify(checkingUpdatesNotification, | ||||
|             cancelExisting: true); | ||||
|         newApp = await appsProvider.checkUpdate(appId); | ||||
|         App? newApp = await appsProvider.checkUpdate(appId); | ||||
|         if (newApp != null) { | ||||
|           if (!(await appsProvider.canInstallSilently(app!.app))) { | ||||
|             notificationsProvider.notify( | ||||
|                 UpdateNotification([newApp], id: newApp.id.hashCode * 10)); | ||||
|           } else { | ||||
|             toInstall.add(appId); | ||||
|           } | ||||
|         } | ||||
|       } catch (e) { | ||||
|         logs.add('BG update check for $appId got error \'${e.toString()}\'.'); | ||||
|         logs.add( | ||||
|             'BG update check got error on checking for $appId \'${e.toString()}\'.'); | ||||
|         if (e is RateLimitError || | ||||
|             e is ClientException && params['attemptCount'] < maxAttempts) { | ||||
|           var remainingMinutes = e is RateLimitError ? e.remainingMinutes : 15; | ||||
|           logs.add( | ||||
|               'BG update check for $appId will be retried in $remainingMinutes minutes.'); | ||||
|               'BG update task $taskId will be retried in $remainingMinutes minutes (with $appId moved to the end of the line).'); | ||||
|           toCheck = toInstall = []; // So the next task will not start | ||||
|           params['toCheck'] = moveStrToEnd(params['toCheck'], appId); | ||||
|           AndroidAlarmManager.oneShot( | ||||
|               Duration(minutes: remainingMinutes), taskId, bgUpdateCheckApp, | ||||
|               Duration(minutes: remainingMinutes), taskId + 1, bgUpdateCheck, | ||||
|               params: params); | ||||
|         } else { | ||||
|           rethrow; | ||||
| @@ -137,24 +148,20 @@ Future<void> bgUpdateCheckApp(int taskId, Map<String, dynamic>? params) async { | ||||
|         notificationsProvider.cancel(checkingUpdatesNotification.id); | ||||
|       } | ||||
|     } | ||||
|     if (newApp != null) { | ||||
|       var canInstallSilently = await appsProvider.canInstallSilently(app.app); | ||||
|       if (!canInstallSilently) { | ||||
|         notificationsProvider | ||||
|             .notify(UpdateNotification([newApp], id: newApp.id.hashCode * 10)); | ||||
|       } else { | ||||
|   } else if (toInstall.isNotEmpty) { | ||||
|     toInstall = moveStrToEnd(toInstall, obtainiumId); | ||||
|     String appId = toInstall.removeAt(0); | ||||
|     logs.add('Attempting to update $appId in the background.'); | ||||
|     await appsProvider.downloadAndInstallLatestApps([appId], null, | ||||
|         notificationsProvider: notificationsProvider); | ||||
|   } | ||||
|     } | ||||
|   } catch (e) { | ||||
|     notificationsProvider.notify(ErrorCheckingUpdatesNotification( | ||||
|         '$appId: ${e.toString()}', | ||||
|         id: appId.hashCode * 20)); | ||||
|   } finally { | ||||
|     logs.add( | ||||
|         'BG update task for $appId ended (attempt #${params['attemptCount']}).'); | ||||
|  | ||||
|   logs.add('BG update task $taskId ended.'); | ||||
|  | ||||
|   if (toCheck.isNotEmpty || toInstall.isNotEmpty) { | ||||
|     AndroidAlarmManager.oneShot(Duration(seconds: toCheck.isNotEmpty ? 1 : 5), | ||||
|         taskId + 1, bgUpdateCheck, | ||||
|         params: {'toCheck': toCheck, 'toInstall': toInstall}); | ||||
|   } | ||||
| } | ||||
|  | ||||
| @@ -254,7 +261,7 @@ class _ObtainiumState extends State<Obtainium> { | ||||
|           AndroidAlarmManager.periodic( | ||||
|               Duration(minutes: existingUpdateInterval), | ||||
|               bgUpdateCheckAlarmId, | ||||
|               bgUpdateCheckApps, | ||||
|               bgUpdateCheck, | ||||
|               rescheduleOnReboot: true, | ||||
|               wakeup: true); | ||||
|         } | ||||
|   | ||||
| @@ -15,6 +15,7 @@ import 'package:flutter/services.dart'; | ||||
| import 'package:obtainium/components/generated_form.dart'; | ||||
| import 'package:obtainium/components/generated_form_modal.dart'; | ||||
| import 'package:obtainium/custom_errors.dart'; | ||||
| import 'package:obtainium/main.dart'; | ||||
| import 'package:obtainium/providers/logs_provider.dart'; | ||||
| import 'package:obtainium/providers/notifications_provider.dart'; | ||||
| import 'package:obtainium/providers/settings_provider.dart'; | ||||
| @@ -555,17 +556,8 @@ class AppsProvider with ChangeNotifier { | ||||
|     List<String> installedIds = []; | ||||
|  | ||||
|     // Move Obtainium to the end of the line (let all other apps update first) | ||||
|     String? temp; | ||||
|     appsToInstall.removeWhere((element) { | ||||
|       bool res = element == obtainiumId || element == obtainiumTempId; | ||||
|       if (res) { | ||||
|         temp = element; | ||||
|       } | ||||
|       return res; | ||||
|     }); | ||||
|     if (temp != null) { | ||||
|       appsToInstall = [...appsToInstall, temp!]; | ||||
|     } | ||||
|     appsToInstall = | ||||
|         moveStrToEnd(appsToInstall, obtainiumId, strB: obtainiumTempId); | ||||
|  | ||||
|     for (var id in appsToInstall) { | ||||
|       try { | ||||
|   | ||||
		Reference in New Issue
	
	Block a user