mirror of
https://github.com/immich-app/immich.git
synced 2025-01-16 16:56:46 +01:00
fix(mobile): use sets in album refresh, concurrent futures (#14193)
* use sets in album sync, concurrent futures * batch excluded asset IDs * update test * take advantage of sets in Recents check * move log statement * smaller diff
This commit is contained in:
parent
2604940f09
commit
6b5defc27b
2 changed files with 31 additions and 26 deletions
|
@ -76,10 +76,16 @@ class AlbumService {
|
||||||
final Stopwatch sw = Stopwatch()..start();
|
final Stopwatch sw = Stopwatch()..start();
|
||||||
bool changes = false;
|
bool changes = false;
|
||||||
try {
|
try {
|
||||||
final List<String> excludedIds = await _backupAlbumRepository
|
final (selectedIds, excludedIds, onDevice) = await (
|
||||||
.getIdsBySelection(BackupSelection.exclude);
|
_backupAlbumRepository
|
||||||
final List<String> selectedIds = await _backupAlbumRepository
|
.getIdsBySelection(BackupSelection.select)
|
||||||
.getIdsBySelection(BackupSelection.select);
|
.then((value) => value.toSet()),
|
||||||
|
_backupAlbumRepository
|
||||||
|
.getIdsBySelection(BackupSelection.exclude)
|
||||||
|
.then((value) => value.toSet()),
|
||||||
|
_albumMediaRepository.getAll()
|
||||||
|
).wait;
|
||||||
|
_log.info("Found ${onDevice.length} device albums");
|
||||||
if (selectedIds.isEmpty) {
|
if (selectedIds.isEmpty) {
|
||||||
final numLocal = await _albumRepository.count(local: true);
|
final numLocal = await _albumRepository.count(local: true);
|
||||||
if (numLocal > 0) {
|
if (numLocal > 0) {
|
||||||
|
@ -87,8 +93,6 @@ class AlbumService {
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
final List<Album> onDevice = await _albumMediaRepository.getAll();
|
|
||||||
_log.info("Found ${onDevice.length} device albums");
|
|
||||||
Set<String>? excludedAssets;
|
Set<String>? excludedAssets;
|
||||||
if (excludedIds.isNotEmpty) {
|
if (excludedIds.isNotEmpty) {
|
||||||
if (Platform.isIOS) {
|
if (Platform.isIOS) {
|
||||||
|
@ -108,22 +112,19 @@ class AlbumService {
|
||||||
"Ignoring ${excludedIds.length} excluded albums resulting in ${onDevice.length} device albums",
|
"Ignoring ${excludedIds.length} excluded albums resulting in ${onDevice.length} device albums",
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
final hasAll = selectedIds
|
|
||||||
.map(
|
final allAlbum = onDevice.firstWhereOrNull((album) => album.isAll);
|
||||||
(id) => onDevice.firstWhereOrNull((album) => album.localId == id),
|
final hasAll = allAlbum != null && selectedIds.contains(allAlbum.localId);
|
||||||
)
|
|
||||||
.whereNotNull()
|
|
||||||
.any((a) => a.isAll);
|
|
||||||
if (hasAll) {
|
if (hasAll) {
|
||||||
if (Platform.isAndroid) {
|
if (Platform.isAndroid) {
|
||||||
// remove the virtual "Recent" album and keep and individual albums
|
// remove the virtual "Recent" album and keep and individual albums
|
||||||
// on Android, the virtual "Recent" `lastModified` value is always null
|
// on Android, the virtual "Recent" `lastModified` value is always null
|
||||||
onDevice.removeWhere((e) => e.isAll);
|
onDevice.removeWhere((album) => album.isAll);
|
||||||
_log.info("'Recents' is selected, keeping all individual albums");
|
_log.info("'Recents' is selected, keeping all individual albums");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
// keep only the explicitly selected albums
|
// keep only the explicitly selected albums
|
||||||
onDevice.removeWhere((e) => !selectedIds.contains(e.localId));
|
onDevice.removeWhere((album) => !selectedIds.contains(album.localId));
|
||||||
_log.info("'Recents' is not selected, keeping only selected albums");
|
_log.info("'Recents' is not selected, keeping only selected albums");
|
||||||
}
|
}
|
||||||
changes =
|
changes =
|
||||||
|
@ -138,15 +139,19 @@ class AlbumService {
|
||||||
|
|
||||||
Future<Set<String>> _loadExcludedAssetIds(
|
Future<Set<String>> _loadExcludedAssetIds(
|
||||||
List<Album> albums,
|
List<Album> albums,
|
||||||
List<String> excludedAlbumIds,
|
Set<String> excludedAlbumIds,
|
||||||
) async {
|
) async {
|
||||||
final Set<String> result = HashSet<String>();
|
final Set<String> result = HashSet<String>();
|
||||||
for (Album album in albums) {
|
for (final batchAlbums in albums
|
||||||
if (excludedAlbumIds.contains(album.localId)) {
|
.where((album) => excludedAlbumIds.contains(album.localId))
|
||||||
final assetIds =
|
.slices(5)) {
|
||||||
await _albumMediaRepository.getAssetIds(album.localId!);
|
await batchAlbums
|
||||||
result.addAll(assetIds);
|
.map(
|
||||||
}
|
(album) => _albumMediaRepository
|
||||||
|
.getAssetIds(album.localId!)
|
||||||
|
.then((assetIds) => result.addAll(assetIds)),
|
||||||
|
)
|
||||||
|
.wait;
|
||||||
}
|
}
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
@ -163,11 +168,10 @@ class AlbumService {
|
||||||
bool changes = false;
|
bool changes = false;
|
||||||
try {
|
try {
|
||||||
await _userService.refreshUsers();
|
await _userService.refreshUsers();
|
||||||
final List<Album> sharedAlbum =
|
final (sharedAlbum, ownedAlbum) = await (
|
||||||
await _albumApiRepository.getAll(shared: true);
|
_albumApiRepository.getAll(shared: true),
|
||||||
|
_albumApiRepository.getAll(shared: null)
|
||||||
final List<Album> ownedAlbum =
|
).wait;
|
||||||
await _albumApiRepository.getAll(shared: null);
|
|
||||||
|
|
||||||
final albums = HashSet<Album>(
|
final albums = HashSet<Album>(
|
||||||
equals: (a, b) => a.remoteId == b.remoteId,
|
equals: (a, b) => a.remoteId == b.remoteId,
|
||||||
|
|
|
@ -54,6 +54,7 @@ void main() {
|
||||||
.thenAnswer((_) async => []);
|
.thenAnswer((_) async => []);
|
||||||
when(() => backupRepository.getIdsBySelection(BackupSelection.select))
|
when(() => backupRepository.getIdsBySelection(BackupSelection.select))
|
||||||
.thenAnswer((_) async => []);
|
.thenAnswer((_) async => []);
|
||||||
|
when(() => albumMediaRepository.getAll()).thenAnswer((_) async => []);
|
||||||
when(() => albumRepository.count(local: true)).thenAnswer((_) async => 1);
|
when(() => albumRepository.count(local: true)).thenAnswer((_) async => 1);
|
||||||
when(() => syncService.removeAllLocalAlbumsAndAssets())
|
when(() => syncService.removeAllLocalAlbumsAndAssets())
|
||||||
.thenAnswer((_) async => true);
|
.thenAnswer((_) async => true);
|
||||||
|
|
Loading…
Reference in a new issue