mirror of
https://github.com/immich-app/immich.git
synced 2025-12-29 17:25:00 +03:00
* fix(drift backup notifier): add lifecycle guards and dispose logging * fix(drift backup notifier): re-read notifiers in callbacks to avoid disposed backup notifier * fix(drift backup notifier): increase the log level to warning. --------- Co-authored-by: Peter Ombodi <peter.ombodi@gmail.com>
35 lines
1.4 KiB
Dart
35 lines
1.4 KiB
Dart
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/domain/utils/background_sync.dart';
|
|
import 'package:immich_mobile/providers/backup/drift_backup.provider.dart';
|
|
import 'package:immich_mobile/providers/sync_status.provider.dart';
|
|
|
|
final backgroundSyncProvider = Provider<BackgroundSyncManager>((ref) {
|
|
final syncStatusNotifier = ref.read(syncStatusProvider.notifier);
|
|
|
|
final manager = BackgroundSyncManager(
|
|
onRemoteSyncStart: () {
|
|
syncStatusNotifier.startRemoteSync();
|
|
final backupProvider = ref.read(driftBackupProvider.notifier);
|
|
if (backupProvider.mounted) {
|
|
backupProvider.updateError(BackupError.none);
|
|
}
|
|
},
|
|
onRemoteSyncComplete: (isSuccess) {
|
|
syncStatusNotifier.completeRemoteSync();
|
|
final backupProvider = ref.read(driftBackupProvider.notifier);
|
|
if (backupProvider.mounted) {
|
|
backupProvider.updateError(isSuccess == true ? BackupError.none : BackupError.syncFailed);
|
|
}
|
|
},
|
|
onRemoteSyncError: syncStatusNotifier.errorRemoteSync,
|
|
onLocalSyncStart: syncStatusNotifier.startLocalSync,
|
|
onLocalSyncComplete: syncStatusNotifier.completeLocalSync,
|
|
onLocalSyncError: syncStatusNotifier.errorLocalSync,
|
|
onHashingStart: syncStatusNotifier.startHashJob,
|
|
onHashingComplete: syncStatusNotifier.completeHashJob,
|
|
onHashingError: syncStatusNotifier.errorHashJob,
|
|
);
|
|
ref.onDispose(manager.cancel);
|
|
return manager;
|
|
});
|