mirror of
https://github.com/immich-app/immich.git
synced 2025-01-01 08:31:59 +00:00
fix(mobile, Android): throttle all background backup notifications
This commit is contained in:
parent
dcefd53bfe
commit
dc7df5bcfa
1 changed files with 48 additions and 31 deletions
|
@ -33,6 +33,7 @@ class BackgroundService {
|
||||||
static const MethodChannel _backgroundChannel =
|
static const MethodChannel _backgroundChannel =
|
||||||
MethodChannel('immich/backgroundChannel');
|
MethodChannel('immich/backgroundChannel');
|
||||||
static final NumberFormat numberFormat = NumberFormat("###0.##");
|
static final NumberFormat numberFormat = NumberFormat("###0.##");
|
||||||
|
static const notifyInterval = Duration(milliseconds: 400);
|
||||||
bool _isBackgroundInitialized = false;
|
bool _isBackgroundInitialized = false;
|
||||||
CancellationToken? _cancellationToken;
|
CancellationToken? _cancellationToken;
|
||||||
bool _canceledBySystem = false;
|
bool _canceledBySystem = false;
|
||||||
|
@ -43,9 +44,12 @@ class BackgroundService {
|
||||||
bool _errorGracePeriodExceeded = true;
|
bool _errorGracePeriodExceeded = true;
|
||||||
int _uploadedAssetsCount = 0;
|
int _uploadedAssetsCount = 0;
|
||||||
int _assetsToUploadCount = 0;
|
int _assetsToUploadCount = 0;
|
||||||
String _lastPrintedProgress = "";
|
String _lastPrintedDetailContent = "";
|
||||||
late final _Throttle _throttleNotificationUpdates =
|
String? _lastPrintedDetailTitle;
|
||||||
_Throttle(_updateDetailProgress, const Duration(milliseconds: 400));
|
late final _Throttle _throttledNotifiy =
|
||||||
|
_Throttle(_updateProgress, notifyInterval);
|
||||||
|
late final _Throttle _throttledDetailNotify =
|
||||||
|
_Throttle(_updateDetailProgress, notifyInterval);
|
||||||
|
|
||||||
bool get isBackgroundInitialized {
|
bool get isBackgroundInitialized {
|
||||||
return _isBackgroundInitialized;
|
return _isBackgroundInitialized;
|
||||||
|
@ -438,33 +442,40 @@ class BackgroundService {
|
||||||
}
|
}
|
||||||
|
|
||||||
void _onAssetUploaded(String deviceAssetId, String deviceId, bool isDup) {
|
void _onAssetUploaded(String deviceAssetId, String deviceId, bool isDup) {
|
||||||
debugPrint("Uploaded $deviceAssetId from $deviceId");
|
|
||||||
_uploadedAssetsCount++;
|
_uploadedAssetsCount++;
|
||||||
_updateNotification(
|
_throttledNotifiy();
|
||||||
progress: _uploadedAssetsCount,
|
|
||||||
max: _assetsToUploadCount,
|
|
||||||
content: _formatAssetBackupProgress(),
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void _onProgress(int sent, int total) {
|
void _onProgress(int sent, int total) {
|
||||||
_throttleNotificationUpdates(sent, total);
|
_throttledDetailNotify(progress: sent, total: total);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _updateDetailProgress(int sent, int total) {
|
void _updateDetailProgress(String? title, int progress, int total) {
|
||||||
final String msg = _humanReadableBytesProgress(sent, total);
|
final String msg =
|
||||||
|
total > 0 ? _humanReadableBytesProgress(progress, total) : "";
|
||||||
// only update if message actually differs (to stop many useless notification updates on large assets or slow connections)
|
// only update if message actually differs (to stop many useless notification updates on large assets or slow connections)
|
||||||
if (msg != _lastPrintedProgress) {
|
if (msg != _lastPrintedDetailContent || _lastPrintedDetailTitle != title) {
|
||||||
_lastPrintedProgress = msg;
|
_lastPrintedDetailContent = msg;
|
||||||
|
_lastPrintedDetailTitle = title;
|
||||||
_updateNotification(
|
_updateNotification(
|
||||||
progress: sent,
|
progress: total > 0 ? (progress * 1000) ~/ total : 0,
|
||||||
max: total,
|
max: 1000,
|
||||||
isDetail: true,
|
isDetail: true,
|
||||||
|
title: title,
|
||||||
content: msg,
|
content: msg,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void _updateProgress(String? title, int progress, int total) {
|
||||||
|
_updateNotification(
|
||||||
|
progress: _uploadedAssetsCount,
|
||||||
|
max: _assetsToUploadCount,
|
||||||
|
title: title,
|
||||||
|
content: _formatAssetBackupProgress(),
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
void _onBackupError(ErrorUploadAsset errorAssetInfo) {
|
void _onBackupError(ErrorUploadAsset errorAssetInfo) {
|
||||||
_showErrorNotification(
|
_showErrorNotification(
|
||||||
title: "backup_background_service_upload_failure_notification"
|
title: "backup_background_service_upload_failure_notification"
|
||||||
|
@ -474,14 +485,11 @@ class BackgroundService {
|
||||||
}
|
}
|
||||||
|
|
||||||
void _onSetCurrentBackupAsset(CurrentUploadAsset currentUploadAsset) {
|
void _onSetCurrentBackupAsset(CurrentUploadAsset currentUploadAsset) {
|
||||||
_updateNotification(
|
_throttledDetailNotify.title =
|
||||||
title: "backup_background_service_current_upload_notification"
|
"backup_background_service_current_upload_notification"
|
||||||
.tr(args: [currentUploadAsset.fileName]),
|
.tr(args: [currentUploadAsset.fileName]);
|
||||||
content: "",
|
_throttledDetailNotify.progress = 0;
|
||||||
isDetail: true,
|
_throttledDetailNotify.total = 0;
|
||||||
progress: 0,
|
|
||||||
max: 0,
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool _isErrorGracePeriodExceeded(AppSettingsService appSettingsService) {
|
bool _isErrorGracePeriodExceeded(AppSettingsService appSettingsService) {
|
||||||
|
@ -534,17 +542,24 @@ class BackgroundService {
|
||||||
|
|
||||||
class _Throttle {
|
class _Throttle {
|
||||||
_Throttle(this._fun, Duration interval) : _interval = interval.inMicroseconds;
|
_Throttle(this._fun, Duration interval) : _interval = interval.inMicroseconds;
|
||||||
final void Function(int, int) _fun;
|
final void Function(String?, int, int) _fun;
|
||||||
final int _interval;
|
final int _interval;
|
||||||
int _invokedAt = 0;
|
int _invokedAt = 0;
|
||||||
Timer? _timer;
|
Timer? _timer;
|
||||||
int _progress = 0;
|
|
||||||
int _total = 0;
|
|
||||||
|
|
||||||
void call(int progress, int total) {
|
String? title;
|
||||||
|
int progress = 0;
|
||||||
|
int total = 0;
|
||||||
|
|
||||||
|
void call({
|
||||||
|
final String? title,
|
||||||
|
final int progress = 0,
|
||||||
|
final int total = 0,
|
||||||
|
}) {
|
||||||
final time = Timeline.now;
|
final time = Timeline.now;
|
||||||
_progress = progress;
|
this.title = title ?? this.title;
|
||||||
_total = total;
|
this.progress = progress;
|
||||||
|
this.total = total;
|
||||||
if (time > _invokedAt + _interval) {
|
if (time > _invokedAt + _interval) {
|
||||||
_timer?.cancel();
|
_timer?.cancel();
|
||||||
_onTimeElapsed();
|
_onTimeElapsed();
|
||||||
|
@ -555,8 +570,10 @@ class _Throttle {
|
||||||
|
|
||||||
void _onTimeElapsed() {
|
void _onTimeElapsed() {
|
||||||
_invokedAt = Timeline.now;
|
_invokedAt = Timeline.now;
|
||||||
_fun(_progress, _total);
|
_fun(title, progress, total);
|
||||||
_timer = null;
|
_timer = null;
|
||||||
|
// clear title to not send/overwrite it next time if unchanged
|
||||||
|
title = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue