on battery and on data sync options

This commit is contained in:
Matthew Fosse 2024-12-18 16:36:39 -05:00
parent 7c651d7fb1
commit ac847d8b93
2 changed files with 23 additions and 5 deletions

View file

@ -2,6 +2,7 @@ import 'dart:async';
import 'dart:io'; import 'dart:io';
import 'dart:ui'; import 'dart:ui';
import 'package:battery_plus/battery_plus.dart';
import 'package:cake_wallet/bitcoin/bitcoin.dart'; import 'package:cake_wallet/bitcoin/bitcoin.dart';
import 'package:cake_wallet/core/wallet_loading_service.dart'; import 'package:cake_wallet/core/wallet_loading_service.dart';
import 'package:cake_wallet/store/settings_store.dart'; import 'package:cake_wallet/store/settings_store.dart';
@ -10,6 +11,7 @@ import 'package:cake_wallet/utils/feature_flag.dart';
import 'package:cake_wallet/view_model/settings/sync_mode.dart'; import 'package:cake_wallet/view_model/settings/sync_mode.dart';
import 'package:cake_wallet/view_model/wallet_list/wallet_list_item.dart'; import 'package:cake_wallet/view_model/wallet_list/wallet_list_item.dart';
import 'package:cake_wallet/view_model/wallet_list/wallet_list_view_model.dart'; import 'package:cake_wallet/view_model/wallet_list/wallet_list_view_model.dart';
import 'package:connectivity_plus/connectivity_plus.dart';
import 'package:cw_bitcoin/electrum_wallet.dart'; import 'package:cw_bitcoin/electrum_wallet.dart';
import 'package:cw_core/sync_status.dart'; import 'package:cw_core/sync_status.dart';
import 'package:cw_core/utils/print_verbose.dart'; import 'package:cw_core/utils/print_verbose.dart';
@ -39,6 +41,8 @@ const spNodeNotificationMessage =
"Currently configured Bitcoin node does not support Silent Payments. skipping wallet"; "Currently configured Bitcoin node does not support Silent Payments. skipping wallet";
const SYNC_THRESHOLD = 0.98; const SYNC_THRESHOLD = 0.98;
Duration REFRESH_QUEUE_DURATION = Duration(hours: 1); Duration REFRESH_QUEUE_DURATION = Duration(hours: 1);
bool syncOnBattery = false;
bool syncOnData = false;
void setMainNotification( void setMainNotification(
FlutterLocalNotificationsPlugin flutterLocalNotificationsPlugin, { FlutterLocalNotificationsPlugin flutterLocalNotificationsPlugin, {
@ -247,8 +251,6 @@ Future<void> onStart(ServiceInstance service) async {
final progressPercent = (progress * 100).toStringAsPrecision(5) + "%"; final progressPercent = (progress * 100).toStringAsPrecision(5) + "%";
bool shouldSync = i == 0; bool shouldSync = i == 0;
if (progress > 0.999 && shouldSync) { if (progress > 0.999 && shouldSync) {
syncedTicks++; syncedTicks++;
if (syncedTicks > 10) { if (syncedTicks > 10) {
@ -338,6 +340,21 @@ Future<void> onStart(ServiceInstance service) async {
_queueTimer?.cancel(); _queueTimer?.cancel();
// add a timer that checks all wallets and adds them to the queue if they are less than SYNC_THRESHOLD synced: // add a timer that checks all wallets and adds them to the queue if they are less than SYNC_THRESHOLD synced:
_queueTimer = Timer.periodic(REFRESH_QUEUE_DURATION, (timer) async { _queueTimer = Timer.periodic(REFRESH_QUEUE_DURATION, (timer) async {
final batteryState = await Battery().batteryState;
bool onBattery = batteryState == BatteryState.connectedNotCharging ||
batteryState == BatteryState.discharging;
ConnectivityResult connectivityResult = await Connectivity().checkConnectivity();
bool onData = connectivityResult == ConnectivityResult.mobile;
if (onBattery && !syncOnBattery) {
return;
}
if (onData && !syncOnData) {
return;
}
for (int i = 0; i < standbyWallets.length; i++) { for (int i = 0; i < standbyWallets.length; i++) {
final wallet = standbyWallets[i]; final wallet = standbyWallets[i];
final syncStatus = wallet.syncStatus; final syncStatus = wallet.syncStatus;
@ -348,7 +365,7 @@ Future<void> onStart(ServiceInstance service) async {
await wallet.startSync(); await wallet.startSync();
} }
// wait a few seconds before checking progress: // wait a while before checking progress:
await Future.delayed(const Duration(seconds: 20)); await Future.delayed(const Duration(seconds: 20));
if (syncStatus.progress() < SYNC_THRESHOLD) { if (syncStatus.progress() < SYNC_THRESHOLD) {
@ -500,8 +517,8 @@ class BackgroundTasks {
final SyncMode syncMode = settingsStore.currentSyncMode; final SyncMode syncMode = settingsStore.currentSyncMode;
final bool useNotifications = settingsStore.showSyncNotification; final bool useNotifications = settingsStore.showSyncNotification;
final bool syncEnabled = settingsStore.backgroundSyncEnabled; final bool syncEnabled = settingsStore.backgroundSyncEnabled;
final bool syncOnBattery = settingsStore.backgroundSyncOnBattery; syncOnBattery = settingsStore.backgroundSyncOnBattery;
final bool syncOnData = settingsStore.backgroundSyncOnData; syncOnData = settingsStore.backgroundSyncOnData;
if (useNotifications) { if (useNotifications) {
flutterLocalNotificationsPlugin flutterLocalNotificationsPlugin

View file

@ -71,6 +71,7 @@ dependencies:
workmanager: ^0.5.2 workmanager: ^0.5.2
flutter_background_service: ^5.0.9 flutter_background_service: ^5.0.9
flutter_local_notifications: ^17.2.2 flutter_local_notifications: ^17.2.2
battery_plus: ^6.2.1
wakelock_plus: ^1.2.5 wakelock_plus: ^1.2.5
flutter_mailer: flutter_mailer:
git: git: