2022-07-05 22:20:24 +02:00
|
|
|
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';
|
2023-04-13 17:32:31 +02:00
|
|
|
import 'package:nc_photos/entity/album/data_source2.dart';
|
|
|
|
import 'package:nc_photos/entity/album/repo2.dart';
|
2022-07-05 22:20:24 +02:00
|
|
|
import 'package:nc_photos/entity/file.dart';
|
2022-10-15 16:29:18 +02:00
|
|
|
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;
|
2022-07-05 22:20:24 +02:00
|
|
|
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-07-05 22:20:24 +02:00
|
|
|
|
2022-12-16 16:01:04 +01:00
|
|
|
part 'data_source.g.dart';
|
|
|
|
|
2023-04-13 17:32:31 +02:00
|
|
|
/// Backward compatibility only, use [AlbumRemoteDataSource2] instead
|
2022-12-16 16:01:04 +01:00
|
|
|
@npLog
|
2022-07-05 22:20:24 +02:00
|
|
|
class AlbumRemoteDataSource implements AlbumDataSource {
|
|
|
|
@override
|
|
|
|
get(Account account, File albumFile) async {
|
|
|
|
_log.info("[get] ${albumFile.path}");
|
2023-04-13 17:32:31 +02:00
|
|
|
final albums = await const AlbumRemoteDataSource2().getAlbums(
|
|
|
|
account,
|
|
|
|
[albumFile],
|
|
|
|
onError: (_, error, stackTrace) {
|
|
|
|
Error.throwWithStackTrace(error, stackTrace ?? StackTrace.current);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
return albums.first;
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
getAll(Account account, List<File> albumFiles) async* {
|
|
|
|
_log.info(
|
|
|
|
"[getAll] ${albumFiles.map((f) => f.filename).toReadableString()}");
|
2023-04-13 17:32:31 +02:00
|
|
|
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,
|
|
|
|
};
|
|
|
|
},
|
2022-07-05 22:20:24 +02:00
|
|
|
);
|
2023-04-13 17:32:31 +02:00
|
|
|
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++];
|
|
|
|
}
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
create(Account account, Album album) async {
|
|
|
|
_log.info("[create]");
|
2023-04-13 17:32:31 +02:00
|
|
|
return const AlbumRemoteDataSource2().create(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
update(Account account, Album album) async {
|
|
|
|
_log.info("[update] ${album.albumFile!.path}");
|
2023-04-13 17:32:31 +02:00
|
|
|
return const AlbumRemoteDataSource2().update(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-04-13 17:32:31 +02:00
|
|
|
/// Backward compatibility only, use [AlbumSqliteDbDataSource2] instead
|
2022-12-16 16:01:04 +01:00
|
|
|
@npLog
|
2022-07-05 22:20:24 +02:00
|
|
|
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()}");
|
2023-04-13 17:32:31 +02:00
|
|
|
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"]);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
} else {
|
2023-04-13 17:32:31 +02:00
|
|
|
yield albums[i++];
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
create(Account account, Album album) async {
|
|
|
|
_log.info("[create]");
|
2023-04-13 17:32:31 +02:00
|
|
|
return AlbumSqliteDbDataSource2(_c.sqliteDb).create(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
|
|
|
update(Account account, Album album) async {
|
|
|
|
_log.info("[update] ${album.albumFile!.path}");
|
2023-04-13 17:32:31 +02:00
|
|
|
return AlbumSqliteDbDataSource2(_c.sqliteDb).update(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
final DiContainer _c;
|
|
|
|
}
|
|
|
|
|
2023-04-13 17:32:31 +02:00
|
|
|
/// Backward compatibility only, use [CachedAlbumRepo2] instead
|
2022-12-16 16:01:04 +01:00
|
|
|
@npLog
|
2022-07-05 22:20:24 +02:00
|
|
|
class AlbumCachedDataSource implements AlbumDataSource {
|
2023-04-13 17:32:31 +02:00
|
|
|
AlbumCachedDataSource(DiContainer c) : sqliteDb = c.sqliteDb;
|
2022-07-05 22:20:24 +02:00
|
|
|
|
|
|
|
@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* {
|
2023-04-13 17:32:31 +02:00
|
|
|
final repo = CachedAlbumRepo2(
|
|
|
|
const AlbumRemoteDataSource2(),
|
|
|
|
AlbumSqliteDbDataSource2(sqliteDb),
|
|
|
|
);
|
|
|
|
final albums = await repo.getAlbums(account, albumFiles).last;
|
|
|
|
for (final a in albums) {
|
|
|
|
yield a;
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
2023-04-13 17:32:31 +02:00
|
|
|
update(Account account, Album album) {
|
|
|
|
return CachedAlbumRepo2(
|
|
|
|
const AlbumRemoteDataSource2(),
|
|
|
|
AlbumSqliteDbDataSource2(sqliteDb),
|
|
|
|
).update(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@override
|
2023-04-13 17:32:31 +02:00
|
|
|
create(Account account, Album album) {
|
|
|
|
return CachedAlbumRepo2(
|
|
|
|
const AlbumRemoteDataSource2(),
|
|
|
|
AlbumSqliteDbDataSource2(sqliteDb),
|
|
|
|
).create(account, album);
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|
|
|
|
|
2023-04-13 17:32:31 +02:00
|
|
|
final sql.SqliteDb sqliteDb;
|
2022-07-05 22:20:24 +02:00
|
|
|
}
|