mirror of
				https://github.com/ImranR98/Obtainium.git
				synced 2025-10-25 11:53:45 +02:00 
			
		
		
		
	Revert "Switched to WorkManager for reliability (#608)"
This reverts commit d3247a9ec1.
			
			
This commit is contained in:
		| @@ -12,7 +12,7 @@ import 'package:permission_handler/permission_handler.dart'; | |||||||
| import 'package:provider/provider.dart'; | import 'package:provider/provider.dart'; | ||||||
| import 'package:dynamic_color/dynamic_color.dart'; | import 'package:dynamic_color/dynamic_color.dart'; | ||||||
| import 'package:device_info_plus/device_info_plus.dart'; | import 'package:device_info_plus/device_info_plus.dart'; | ||||||
| import 'package:workmanager/workmanager.dart'; | import 'package:android_alarm_manager_plus/android_alarm_manager_plus.dart'; | ||||||
| import 'package:easy_localization/easy_localization.dart'; | import 'package:easy_localization/easy_localization.dart'; | ||||||
| // ignore: implementation_imports | // ignore: implementation_imports | ||||||
| import 'package:easy_localization/src/easy_localization_controller.dart'; | import 'package:easy_localization/src/easy_localization_controller.dart'; | ||||||
| @@ -23,7 +23,7 @@ const String currentVersion = '0.14.31'; | |||||||
| const String currentReleaseTag = | const String currentReleaseTag = | ||||||
|     'v$currentVersion-beta'; // KEEP THIS IN SYNC WITH GITHUB RELEASES |     'v$currentVersion-beta'; // KEEP THIS IN SYNC WITH GITHUB RELEASES | ||||||
|  |  | ||||||
| const String bgUpdateTaskId = 'bgUpdate'; | const int bgUpdateCheckAlarmId = 666; | ||||||
|  |  | ||||||
| List<MapEntry<Locale, String>> supportedLocales = const [ | List<MapEntry<Locale, String>> supportedLocales = const [ | ||||||
|   MapEntry(Locale('en'), 'English'), |   MapEntry(Locale('en'), 'English'), | ||||||
| @@ -71,17 +71,6 @@ Future<void> loadTranslations() async { | |||||||
|       fallbackTranslations: controller.fallbackTranslations); |       fallbackTranslations: controller.fallbackTranslations); | ||||||
| } | } | ||||||
|  |  | ||||||
| @pragma('vm:entry-point') |  | ||||||
| void bgTaskDispatcher() { |  | ||||||
|   Workmanager().executeTask((taskId, params) { |  | ||||||
|     if (taskId == bgUpdateTaskId) { |  | ||||||
|       return bgUpdateTask(taskId, params); |  | ||||||
|     } else { |  | ||||||
|       return Future.value(true); |  | ||||||
|     } |  | ||||||
|   }); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| void main() async { | void main() async { | ||||||
|   WidgetsFlutterBinding.ensureInitialized(); |   WidgetsFlutterBinding.ensureInitialized(); | ||||||
|   try { |   try { | ||||||
| @@ -99,7 +88,7 @@ void main() async { | |||||||
|     ); |     ); | ||||||
|     SystemChrome.setEnabledSystemUIMode(SystemUiMode.edgeToEdge); |     SystemChrome.setEnabledSystemUIMode(SystemUiMode.edgeToEdge); | ||||||
|   } |   } | ||||||
|   await Workmanager().initialize(bgTaskDispatcher); |   await AndroidAlarmManager.initialize(); | ||||||
|   runApp(MultiProvider( |   runApp(MultiProvider( | ||||||
|     providers: [ |     providers: [ | ||||||
|       ChangeNotifierProvider(create: (context) => AppsProvider()), |       ChangeNotifierProvider(create: (context) => AppsProvider()), | ||||||
| @@ -169,7 +158,7 @@ class _ObtainiumState extends State<Obtainium> { | |||||||
|       var actualUpdateInterval = settingsProvider.updateInterval; |       var actualUpdateInterval = settingsProvider.updateInterval; | ||||||
|       if (existingUpdateInterval != actualUpdateInterval) { |       if (existingUpdateInterval != actualUpdateInterval) { | ||||||
|         if (actualUpdateInterval == 0) { |         if (actualUpdateInterval == 0) { | ||||||
|           Workmanager().cancelByUniqueName(bgUpdateTaskId); |           AndroidAlarmManager.cancel(bgUpdateCheckAlarmId); | ||||||
|         } else { |         } else { | ||||||
|           var settingChanged = existingUpdateInterval != -1; |           var settingChanged = existingUpdateInterval != -1; | ||||||
|           var lastCheckWasTooLongAgo = actualUpdateInterval != 0 && |           var lastCheckWasTooLongAgo = actualUpdateInterval != 0 && | ||||||
| @@ -179,10 +168,12 @@ class _ObtainiumState extends State<Obtainium> { | |||||||
|           if (settingChanged || lastCheckWasTooLongAgo) { |           if (settingChanged || lastCheckWasTooLongAgo) { | ||||||
|             logs.add( |             logs.add( | ||||||
|                 'Update interval was set to ${actualUpdateInterval.toString()} (reason: ${settingChanged ? 'setting changed' : 'last check was ${settingsProvider.lastBGCheckTime.toLocal().toString()}'}).'); |                 'Update interval was set to ${actualUpdateInterval.toString()} (reason: ${settingChanged ? 'setting changed' : 'last check was ${settingsProvider.lastBGCheckTime.toLocal().toString()}'}).'); | ||||||
|             Workmanager().registerPeriodicTask( |             AndroidAlarmManager.periodic( | ||||||
|                 bgUpdateTaskId, "BG Update Main Loop", |                 Duration(minutes: actualUpdateInterval), | ||||||
|                 initialDelay: Duration(minutes: actualUpdateInterval), |                 bgUpdateCheckAlarmId, | ||||||
|                 existingWorkPolicy: ExistingWorkPolicy.replace); |                 bgUpdateCheck, | ||||||
|  |                 rescheduleOnReboot: true, | ||||||
|  |                 wakeup: true); | ||||||
|           } |           } | ||||||
|         } |         } | ||||||
|         existingUpdateInterval = actualUpdateInterval; |         existingUpdateInterval = actualUpdateInterval; | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| import 'package:workmanager/workmanager.dart'; | import 'package:android_alarm_manager_plus/android_alarm_manager_plus.dart'; | ||||||
| import 'package:device_info_plus/device_info_plus.dart'; | import 'package:device_info_plus/device_info_plus.dart'; | ||||||
| import 'package:easy_localization/easy_localization.dart'; | import 'package:easy_localization/easy_localization.dart'; | ||||||
| import 'package:flutter/material.dart'; | import 'package:flutter/material.dart'; | ||||||
| @@ -591,10 +591,10 @@ class _SettingsPageState extends State<SettingsPage> { | |||||||
|                           height16, |                           height16, | ||||||
|                           TextButton( |                           TextButton( | ||||||
|                               onPressed: () { |                               onPressed: () { | ||||||
|                                 Workmanager().registerOneOffTask( |                                 AndroidAlarmManager.oneShot( | ||||||
|                                     '$bgUpdateTaskId+Manual', bgUpdateTaskId, |                                     const Duration(seconds: 0), | ||||||
|                                     existingWorkPolicy: |                                     bgUpdateCheckAlarmId + 200, | ||||||
|                                         ExistingWorkPolicy.replace); |                                     bgUpdateCheck); | ||||||
|                                 showMessage(tr('bgTaskStarted'), context); |                                 showMessage(tr('bgTaskStarted'), context); | ||||||
|                               }, |                               }, | ||||||
|                               child: Text(tr('runBgCheckNow'))) |                               child: Text(tr('runBgCheckNow'))) | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ import 'dart:io'; | |||||||
| import 'dart:math'; | import 'dart:math'; | ||||||
| import 'package:http/http.dart' as http; | import 'package:http/http.dart' as http; | ||||||
|  |  | ||||||
| import 'package:workmanager/workmanager.dart'; | import 'package:android_alarm_manager_plus/android_alarm_manager_plus.dart'; | ||||||
| import 'package:android_intent_plus/flag.dart'; | import 'package:android_intent_plus/flag.dart'; | ||||||
| import 'package:android_package_installer/android_package_installer.dart'; | import 'package:android_package_installer/android_package_installer.dart'; | ||||||
| import 'package:android_package_manager/android_package_manager.dart'; | import 'package:android_package_manager/android_package_manager.dart'; | ||||||
| @@ -1356,14 +1356,14 @@ class _APKOriginWarningDialogState extends State<APKOriginWarningDialog> { | |||||||
| /// If there is an error, the offending app is moved to the back of the line of remaining apps, and the task is retried. | /// If there is an error, the offending app is moved to the back of the line of remaining apps, and the task is retried. | ||||||
| /// If an app repeatedly fails to install up to its retry limit, the user is notified. | /// If an app repeatedly fails to install up to its retry limit, the user is notified. | ||||||
| /// | /// | ||||||
| Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | @pragma('vm:entry-point') | ||||||
|  | Future<void> bgUpdateCheck(int taskId, Map<String, dynamic>? params) async { | ||||||
|   WidgetsFlutterBinding.ensureInitialized(); |   WidgetsFlutterBinding.ensureInitialized(); | ||||||
|   await EasyLocalization.ensureInitialized(); |   await EasyLocalization.ensureInitialized(); | ||||||
|   await Workmanager().initialize(bgTaskDispatcher); |   await AndroidAlarmManager.initialize(); | ||||||
|   await loadTranslations(); |   await loadTranslations(); | ||||||
|  |  | ||||||
|   LogsProvider logs = LogsProvider(); |   LogsProvider logs = LogsProvider(); | ||||||
|   try { |  | ||||||
|   NotificationsProvider notificationsProvider = NotificationsProvider(); |   NotificationsProvider notificationsProvider = NotificationsProvider(); | ||||||
|   AppsProvider appsProvider = AppsProvider(isBg: true); |   AppsProvider appsProvider = AppsProvider(isBg: true); | ||||||
|   await appsProvider.loadApps(); |   await appsProvider.loadApps(); | ||||||
| @@ -1375,10 +1375,10 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|     appsProvider.settingsProvider.lastBGCheckTime = DateTime.now(); |     appsProvider.settingsProvider.lastBGCheckTime = DateTime.now(); | ||||||
|   } |   } | ||||||
|   List<MapEntry<String, int>> toCheck = <MapEntry<String, int>>[ |   List<MapEntry<String, int>> toCheck = <MapEntry<String, int>>[ | ||||||
|       ...(params['toCheck']?.map((str) { |     ...(params['toCheck'] | ||||||
|             var temp = str.split(','); |             ?.map((entry) => MapEntry<String, int>( | ||||||
|             return MapEntry<String, int>(temp[0], int.parse(temp[1])); |                 entry['key'] as String, entry['value'] as int)) | ||||||
|           }).toList() ?? |             .toList() ?? | ||||||
|         appsProvider |         appsProvider | ||||||
|             .getAppsSortedByUpdateCheckTime( |             .getAppsSortedByUpdateCheckTime( | ||||||
|                 onlyCheckInstalledOrTrackOnlyApps: appsProvider |                 onlyCheckInstalledOrTrackOnlyApps: appsProvider | ||||||
| @@ -1386,10 +1386,10 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|             .map((e) => MapEntry(e, 0))) |             .map((e) => MapEntry(e, 0))) | ||||||
|   ]; |   ]; | ||||||
|   List<MapEntry<String, int>> toInstall = <MapEntry<String, int>>[ |   List<MapEntry<String, int>> toInstall = <MapEntry<String, int>>[ | ||||||
|       ...(params['toInstall']?.map((str) { |     ...(params['toInstall'] | ||||||
|             var temp = str.split(','); |             ?.map((entry) => MapEntry<String, int>( | ||||||
|             return MapEntry<String, int>(temp[0], int.parse(temp[1])); |                 entry['key'] as String, entry['value'] as int)) | ||||||
|           }).toList() ?? |             .toList() ?? | ||||||
|         (<List<MapEntry<String, int>>>[])) |         (<List<MapEntry<String, int>>>[])) | ||||||
|   ]; |   ]; | ||||||
|  |  | ||||||
| @@ -1403,17 +1403,18 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|         DateTime.now().add(Duration(minutes: networkBasedRetryInterval)); |         DateTime.now().add(Duration(minutes: networkBasedRetryInterval)); | ||||||
|     var shouldRetry = potentialNetworkRetryCheck.isBefore(nextRegularCheck); |     var shouldRetry = potentialNetworkRetryCheck.isBefore(nextRegularCheck); | ||||||
|     logs.add( |     logs.add( | ||||||
|           'BG task $taskId: No network. Will ${shouldRetry ? 'retry in $networkBasedRetryInterval minutes' : 'not retry'}.'); |         'BG update task $taskId: No network. Will ${shouldRetry ? 'retry in $networkBasedRetryInterval minutes' : 'not retry'}.'); | ||||||
|       await Workmanager().registerOneOffTask("$taskId+Retry", taskId, |     AndroidAlarmManager.oneShot( | ||||||
|           initialDelay: const Duration(minutes: 15), |         const Duration(minutes: 15), taskId + 1, bgUpdateCheck, | ||||||
|           existingWorkPolicy: ExistingWorkPolicy.replace, |         params: { | ||||||
|           inputData: { |           'toCheck': toCheck | ||||||
|             'toCheck': |               .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                 toCheck.map((entry) => '${entry.key},${entry.value}').toList(), |               .toList(), | ||||||
|           'toInstall': toInstall |           'toInstall': toInstall | ||||||
|                 .map((entry) => '${entry.key},${entry.value}') |               .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|               .toList(), |               .toList(), | ||||||
|         }); |         }); | ||||||
|  |     return; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   var networkRestricted = false; |   var networkRestricted = false; | ||||||
| @@ -1474,9 +1475,8 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|         errors = e['errors']; |         errors = e['errors']; | ||||||
|         errors!.rawErrors.forEach((key, err) { |         errors!.rawErrors.forEach((key, err) { | ||||||
|           logs.add( |           logs.add( | ||||||
|                 'BG task $taskId: Got error on checking for $key \'${err.toString()}\'.'); |               'BG update task $taskId: Got error on checking for $key \'${err.toString()}\'.'); | ||||||
|             var toCheckApp = |           var toCheckApp = toCheck.where((element) => element.key == key).first; | ||||||
|                 toCheck.where((element) => element.key == key).first; |  | ||||||
|           if (toCheckApp.value < maxAttempts) { |           if (toCheckApp.value < maxAttempts) { | ||||||
|             toRetry.add(MapEntry(toCheckApp.key, toCheckApp.value + 1)); |             toRetry.add(MapEntry(toCheckApp.key, toCheckApp.value + 1)); | ||||||
|             // Next task interval is based on the error with the longest retry time |             // Next task interval is based on the error with the longest retry time | ||||||
| @@ -1494,7 +1494,7 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|         }); |         }); | ||||||
|       } else { |       } else { | ||||||
|         // We don't expect to ever get here in any situation so no need to catch (but log it in case) |         // We don't expect to ever get here in any situation so no need to catch (but log it in case) | ||||||
|           logs.add('Fatal error in BG task: ${e.toString()}'); |         logs.add('Fatal error in BG update task: ${e.toString()}'); | ||||||
|         rethrow; |         rethrow; | ||||||
|       } |       } | ||||||
|     } finally { |     } finally { | ||||||
| @@ -1505,8 +1505,7 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|     for (var i = 0; i < updates.length; i++) { |     for (var i = 0; i < updates.length; i++) { | ||||||
|       if (networkRestricted || |       if (networkRestricted || | ||||||
|           !(await appsProvider.canInstallSilently(updates[i]))) { |           !(await appsProvider.canInstallSilently(updates[i]))) { | ||||||
|           if (updates[i].additionalSettings['skipUpdateNotifications'] != |         if (updates[i].additionalSettings['skipUpdateNotifications'] != true) { | ||||||
|               true) { |  | ||||||
|           toNotify.add(updates[i]); |           toNotify.add(updates[i]); | ||||||
|         } |         } | ||||||
|       } |       } | ||||||
| @@ -1528,29 +1527,28 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|  |  | ||||||
|     // if there are update checks to retry, schedule a retry task |     // if there are update checks to retry, schedule a retry task | ||||||
|     if (toRetry.isNotEmpty) { |     if (toRetry.isNotEmpty) { | ||||||
|         logs.add('BG task $taskId: Will retry in $retryAfterXSeconds seconds.'); |       logs.add( | ||||||
|         await Workmanager().registerOneOffTask("$taskId+Retry", taskId, |           'BG update task $taskId: Will retry in $retryAfterXSeconds seconds.'); | ||||||
|             initialDelay: Duration(seconds: retryAfterXSeconds), |       AndroidAlarmManager.oneShot( | ||||||
|             existingWorkPolicy: ExistingWorkPolicy.replace, |           Duration(seconds: retryAfterXSeconds), taskId + 1, bgUpdateCheck, | ||||||
|             inputData: { |           params: { | ||||||
|             'toCheck': toRetry |             'toCheck': toRetry | ||||||
|                   .map((entry) => '${entry.key},${entry.value}') |                 .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                 .toList(), |                 .toList(), | ||||||
|             'toInstall': toInstall |             'toInstall': toInstall | ||||||
|                   .map((entry) => '${entry.key},${entry.value}') |                 .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                 .toList(), |                 .toList(), | ||||||
|           }); |           }); | ||||||
|     } else { |     } else { | ||||||
|       // If there are no more update checks, schedule an install task |       // If there are no more update checks, schedule an install task | ||||||
|       logs.add( |       logs.add( | ||||||
|             'BG task $taskId: Done. Scheduling install task to run immediately.'); |           'BG update task $taskId: Done. Scheduling install task to run immediately.'); | ||||||
|         await Workmanager().registerOneOffTask( |       AndroidAlarmManager.oneShot( | ||||||
|             "$bgUpdateTaskId+Install", taskId, |           const Duration(minutes: 0), taskId + 1, bgUpdateCheck, | ||||||
|             existingWorkPolicy: ExistingWorkPolicy.replace, |           params: { | ||||||
|             inputData: { |             'toCheck': [], | ||||||
|               'toCheck': <String>[], |  | ||||||
|             'toInstall': toInstall |             'toInstall': toInstall | ||||||
|                   .map((entry) => '${entry.key},${entry.value}') |                 .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                 .toList() |                 .toList() | ||||||
|           }); |           }); | ||||||
|     } |     } | ||||||
| @@ -1579,7 +1577,7 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|       var retryCount = toInstall[i].value; |       var retryCount = toInstall[i].value; | ||||||
|       try { |       try { | ||||||
|         logs.add( |         logs.add( | ||||||
|               'BG task $taskId: Attempting to update $appId in the background.'); |             'BG install task $taskId: Attempting to update $appId in the background.'); | ||||||
|         await appsProvider.downloadAndInstallLatestApps([appId], null, |         await appsProvider.downloadAndInstallLatestApps([appId], null, | ||||||
|             notificationsProvider: notificationsProvider); |             notificationsProvider: notificationsProvider); | ||||||
|         await Future.delayed(const Duration( |         await Future.delayed(const Duration( | ||||||
| @@ -1591,22 +1589,21 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|       } catch (e) { |       } catch (e) { | ||||||
|         // If you got an error, move the offender to the back of the line (increment their fail count) and schedule another task to continue installing shortly |         // If you got an error, move the offender to the back of the line (increment their fail count) and schedule another task to continue installing shortly | ||||||
|         logs.add( |         logs.add( | ||||||
|               'BG task $taskId: Got error on updating $appId \'${e.toString()}\'.'); |             'BG install task $taskId: Got error on updating $appId \'${e.toString()}\'.'); | ||||||
|         if (retryCount < maxAttempts) { |         if (retryCount < maxAttempts) { | ||||||
|           var remainingSeconds = retryCount; |           var remainingSeconds = retryCount; | ||||||
|           logs.add( |           logs.add( | ||||||
|                 'BG task $taskId: Will continue in $remainingSeconds seconds (with $appId moved to the end of the line).'); |               'BG install task $taskId: Will continue in $remainingSeconds seconds (with $appId moved to the end of the line).'); | ||||||
|           var remainingToInstall = moveStrToEndMapEntryWithCount( |           var remainingToInstall = moveStrToEndMapEntryWithCount( | ||||||
|               toInstall.sublist(i), MapEntry(appId, retryCount + 1)); |               toInstall.sublist(i), MapEntry(appId, retryCount + 1)); | ||||||
|             await Workmanager().registerOneOffTask("$taskId+Retry", taskId, |           AndroidAlarmManager.oneShot( | ||||||
|                 initialDelay: Duration(seconds: remainingSeconds), |               Duration(seconds: remainingSeconds), taskId + 1, bgUpdateCheck, | ||||||
|                 existingWorkPolicy: ExistingWorkPolicy.replace, |               params: { | ||||||
|                 inputData: { |  | ||||||
|                 'toCheck': toCheck |                 'toCheck': toCheck | ||||||
|                       .map((entry) => '${entry.key},${entry.value}') |                     .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                     .toList(), |                     .toList(), | ||||||
|                 'toInstall': remainingToInstall |                 'toInstall': remainingToInstall | ||||||
|                       .map((entry) => '${entry.key},${entry.value}') |                     .map((entry) => {'key': entry.key, 'value': entry.value}) | ||||||
|                     .toList(), |                     .toList(), | ||||||
|               }); |               }); | ||||||
|           break; |           break; | ||||||
| @@ -1620,12 +1617,7 @@ Future<bool> bgUpdateTask(String taskId, Map<String, dynamic>? params) async { | |||||||
|       } |       } | ||||||
|     } |     } | ||||||
|     if (didCompleteInstalling || toInstall.isEmpty) { |     if (didCompleteInstalling || toInstall.isEmpty) { | ||||||
|         logs.add('BG task $taskId: Done.'); |       logs.add('BG install task $taskId: Done.'); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|     return true; |  | ||||||
|   } catch (e) { |  | ||||||
|     logs.add(e.toString()); |  | ||||||
|     return false; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										18
									
								
								pubspec.lock
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								pubspec.lock
									
									
									
									
									
								
							| @@ -1,6 +1,14 @@ | |||||||
| # Generated by pub | # Generated by pub | ||||||
| # See https://dart.dev/tools/pub/glossary#lockfile | # See https://dart.dev/tools/pub/glossary#lockfile | ||||||
| packages: | packages: | ||||||
|  |   android_alarm_manager_plus: | ||||||
|  |     dependency: "direct main" | ||||||
|  |     description: | ||||||
|  |       name: android_alarm_manager_plus | ||||||
|  |       sha256: "82fb28c867c4b3dd7e9157728e46426b8916362f977dbba46b949210f00099f4" | ||||||
|  |       url: "https://pub.dev" | ||||||
|  |     source: hosted | ||||||
|  |     version: "3.0.3" | ||||||
|   android_intent_plus: |   android_intent_plus: | ||||||
|     dependency: "direct main" |     dependency: "direct main" | ||||||
|     description: |     description: | ||||||
| @@ -923,14 +931,6 @@ packages: | |||||||
|       url: "https://pub.dev" |       url: "https://pub.dev" | ||||||
|     source: hosted |     source: hosted | ||||||
|     version: "1.1.2" |     version: "1.1.2" | ||||||
|   workmanager: |  | ||||||
|     dependency: "direct main" |  | ||||||
|     description: |  | ||||||
|       name: workmanager |  | ||||||
|       sha256: ed13530cccd28c5c9959ad42d657cd0666274ca74c56dea0ca183ddd527d3a00 |  | ||||||
|       url: "https://pub.dev" |  | ||||||
|     source: hosted |  | ||||||
|     version: "0.5.2" |  | ||||||
|   xdg_directories: |   xdg_directories: | ||||||
|     dependency: transitive |     dependency: transitive | ||||||
|     description: |     description: | ||||||
| @@ -956,5 +956,5 @@ packages: | |||||||
|     source: hosted |     source: hosted | ||||||
|     version: "3.1.2" |     version: "3.1.2" | ||||||
| sdks: | sdks: | ||||||
|   dart: ">=3.1.2 <4.0.0" |   dart: ">=3.1.0 <4.0.0" | ||||||
|   flutter: ">=3.13.0" |   flutter: ">=3.13.0" | ||||||
|   | |||||||
| @@ -17,7 +17,7 @@ publish_to: 'none' # Remove this line if you wish to publish to pub.dev | |||||||
| # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html | # https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html | ||||||
| # In Windows, build-name is used as the major, minor, and patch parts | # In Windows, build-name is used as the major, minor, and patch parts | ||||||
| # of the product and file versions while build-number is used as the build suffix. | # of the product and file versions while build-number is used as the build suffix. | ||||||
| version: 0.14.31+224 # When changing this, update the tag in main() accordingly | version: 0.14.31+223 # When changing this, update the tag in main() accordingly | ||||||
|  |  | ||||||
| environment: | environment: | ||||||
|   sdk: '>=3.0.0 <4.0.0' |   sdk: '>=3.0.0 <4.0.0' | ||||||
| @@ -57,6 +57,7 @@ dependencies: | |||||||
|       ref: main |       ref: main | ||||||
|   android_package_manager: ^0.6.0 |   android_package_manager: ^0.6.0 | ||||||
|   share_plus: ^7.0.0 |   share_plus: ^7.0.0 | ||||||
|  |   android_alarm_manager_plus: ^3.0.0 | ||||||
|   sqflite: ^2.2.0+3 |   sqflite: ^2.2.0+3 | ||||||
|   easy_localization: ^3.0.1 |   easy_localization: ^3.0.1 | ||||||
|   android_intent_plus: ^4.0.0 |   android_intent_plus: ^4.0.0 | ||||||
| @@ -65,7 +66,6 @@ dependencies: | |||||||
|   hsluv: ^1.1.3 |   hsluv: ^1.1.3 | ||||||
|   connectivity_plus: ^5.0.0 |   connectivity_plus: ^5.0.0 | ||||||
|   shared_storage: ^0.8.0 |   shared_storage: ^0.8.0 | ||||||
|   workmanager: ^0.5.2 |  | ||||||
|  |  | ||||||
| dev_dependencies: | dev_dependencies: | ||||||
|   flutter_test: |   flutter_test: | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user