nc-photos/lib/use_case/resync_album.dart

75 lines
2.7 KiB
Dart
Raw Normal View History

import 'package:idb_shim/idb_client.dart';
import 'package:logging/logging.dart';
import 'package:nc_photos/account.dart';
import 'package:nc_photos/app_db.dart';
2021-09-04 14:35:04 +02:00
import 'package:nc_photos/debug_util.dart';
import 'package:nc_photos/entity/album.dart';
2021-07-05 09:54:01 +02:00
import 'package:nc_photos/entity/album/item.dart';
2021-06-24 18:26:56 +02:00
import 'package:nc_photos/entity/album/provider.dart';
import 'package:nc_photos/entity/file_util.dart' as file_util;
/// Resync files inside an album with the file db
class ResyncAlbum {
Future<Album> call(Account account, Album album) async {
2021-06-24 18:26:56 +02:00
if (album.provider is! AlbumStaticProvider) {
_log.warning(
"[call] Resync only make sense for static albums: ${album.name}");
return album;
}
return await AppDb.use((db) async {
final transaction =
db.transaction(AppDb.fileDbStoreName, idbModeReadWrite);
final store = transaction.objectStore(AppDb.fileDbStoreName);
final index = store.index(AppDbFileDbEntry.indexName);
final newItems = <AlbumItem>[];
2021-06-24 18:26:56 +02:00
for (final item in AlbumStaticProvider.of(album).items) {
if (item is AlbumFileItem) {
try {
newItems.add(await _syncOne(account, item, store, index));
} catch (e, stacktrace) {
_log.shout(
"[call] Failed syncing file in album" +
2021-09-04 14:35:04 +02:00
(shouldLogFileName ? ": '${item.file.path}'" : ""),
e,
stacktrace);
newItems.add(item);
}
} else {
newItems.add(item);
}
}
2021-06-24 18:26:56 +02:00
return album.copyWith(provider: AlbumStaticProvider(items: newItems));
});
}
Future<AlbumFileItem> _syncOne(Account account, AlbumFileItem item,
ObjectStore objStore, Index index) async {
2021-07-23 22:05:57 +02:00
Map? dbItem;
if (item.file.fileId != null) {
final List dbItems = await index
.getAll(AppDbFileDbEntry.toNamespacedFileId(account, item.file));
// find the one owned by us
2021-07-23 22:05:57 +02:00
try {
dbItem = dbItems.firstWhere((element) {
final e = AppDbFileDbEntry.fromJson(element.cast<String, dynamic>());
return file_util.getUserDirName(e.file) == account.username;
});
} on StateError catch (_) {
// not found
}
} else {
dbItem = await objStore
2021-07-23 22:05:57 +02:00
.getObject(AppDbFileDbEntry.toPrimaryKey(account, item.file)) as Map;
}
if (dbItem == null) {
_log.warning(
"[_syncOne] File doesn't exist in DB, removed?: '${item.file.path}'");
return item;
}
final dbEntry = AppDbFileDbEntry.fromJson(dbItem.cast<String, dynamic>());
return AlbumFileItem(file: dbEntry.file);
}
static final _log = Logger("use_case.resync_album.ResyncAlbum");
}