nc-photos/app/lib/entity/album/data_source.dart

175 lines
4.8 KiB
Dart
Raw Normal View History

import 'package:logging/logging.dart';
import 'package:nc_photos/account.dart';
import 'package:nc_photos/di_container.dart';
import 'package:nc_photos/entity/album.dart';
import 'package:nc_photos/entity/album/data_source2.dart';
import 'package:nc_photos/entity/album/repo2.dart';
import 'package:nc_photos/entity/file.dart';
import 'package:nc_photos/entity/file_descriptor.dart';
2023-02-20 15:21:35 +01:00
import 'package:nc_photos/entity/sqlite/database.dart' as sql;
import 'package:nc_photos/exception.dart';
import 'package:nc_photos/exception_event.dart';
import 'package:nc_photos/iterable_extension.dart';
2022-12-16 16:01:04 +01:00
import 'package:np_codegen/np_codegen.dart';
2022-12-16 16:01:04 +01:00
part 'data_source.g.dart';
/// Backward compatibility only, use [AlbumRemoteDataSource2] instead
2022-12-16 16:01:04 +01:00
@npLog
class AlbumRemoteDataSource implements AlbumDataSource {
@override
get(Account account, File albumFile) async {
_log.info("[get] ${albumFile.path}");
final albums = await const AlbumRemoteDataSource2().getAlbums(
account,
[albumFile],
onError: (_, error, stackTrace) {
Error.throwWithStackTrace(error, stackTrace ?? StackTrace.current);
},
);
return albums.first;
}
@override
getAll(Account account, List<File> albumFiles) async* {
_log.info(
"[getAll] ${albumFiles.map((f) => f.filename).toReadableString()}");
final failed = <String, Map>{};
final albums = await const AlbumRemoteDataSource2().getAlbums(
account,
albumFiles,
onError: (v, error, stackTrace) {
failed[v.path] = {
"file": v,
"error": error,
"stackTrace": stackTrace,
};
},
);
var i = 0;
for (final af in albumFiles) {
final v = failed[af.path];
if (v != null) {
yield ExceptionEvent(v["error"], v["stackTrace"]);
} else {
yield albums[i++];
}
}
}
@override
create(Account account, Album album) async {
_log.info("[create]");
return const AlbumRemoteDataSource2().create(account, album);
}
@override
update(Account account, Album album) async {
_log.info("[update] ${album.albumFile!.path}");
return const AlbumRemoteDataSource2().update(account, album);
}
}
/// Backward compatibility only, use [AlbumSqliteDbDataSource2] instead
2022-12-16 16:01:04 +01:00
@npLog
class AlbumSqliteDbDataSource implements AlbumDataSource {
AlbumSqliteDbDataSource(this._c);
@override
get(Account account, File albumFile) async {
final results = await getAll(account, [albumFile]).toList();
if (results.first is! Album) {
throw results.first;
} else {
return results.first;
}
}
@override
getAll(Account account, List<File> albumFiles) async* {
_log.info(
"[getAll] ${albumFiles.map((f) => f.filename).toReadableString()}");
final failed = <String, Map>{};
final albums = await AlbumSqliteDbDataSource2(_c.sqliteDb).getAlbums(
account,
albumFiles,
onError: (v, error, stackTrace) {
failed[v.path] = {
"file": v,
"error": error,
"stackTrace": stackTrace,
};
},
);
var i = 0;
for (final af in albumFiles) {
final v = failed[af.path];
if (v != null) {
if (v["error"] is CacheNotFoundException) {
yield const CacheNotFoundException();
} else {
yield ExceptionEvent(v["error"], v["stackTrace"]);
}
} else {
yield albums[i++];
}
}
}
@override
create(Account account, Album album) async {
_log.info("[create]");
return AlbumSqliteDbDataSource2(_c.sqliteDb).create(account, album);
}
@override
update(Account account, Album album) async {
_log.info("[update] ${album.albumFile!.path}");
return AlbumSqliteDbDataSource2(_c.sqliteDb).update(account, album);
}
final DiContainer _c;
}
/// Backward compatibility only, use [CachedAlbumRepo2] instead
2022-12-16 16:01:04 +01:00
@npLog
class AlbumCachedDataSource implements AlbumDataSource {
AlbumCachedDataSource(DiContainer c) : sqliteDb = c.sqliteDb;
@override
get(Account account, File albumFile) async {
final result = await getAll(account, [albumFile]).first;
return result as Album;
}
@override
getAll(Account account, List<File> albumFiles) async* {
final repo = CachedAlbumRepo2(
const AlbumRemoteDataSource2(),
AlbumSqliteDbDataSource2(sqliteDb),
);
final albums = await repo.getAlbums(account, albumFiles).last;
for (final a in albums) {
yield a;
}
}
@override
update(Account account, Album album) {
return CachedAlbumRepo2(
const AlbumRemoteDataSource2(),
AlbumSqliteDbDataSource2(sqliteDb),
).update(account, album);
}
@override
create(Account account, Album album) {
return CachedAlbumRepo2(
const AlbumRemoteDataSource2(),
AlbumSqliteDbDataSource2(sqliteDb),
).create(account, album);
}
final sql.SqliteDb sqliteDb;
}