nc-photos/lib/mobile/metadata_loader.dart

80 lines
2.5 KiB
Dart
Raw Normal View History

2021-04-10 06:28:12 +02:00
import 'dart:async';
import 'package:exifdart/exifdart_io.dart';
import 'package:exifdart/exifdart_memory.dart';
import 'package:flutter_cache_manager/flutter_cache_manager.dart';
import 'package:logging/logging.dart';
import 'package:nc_photos/account.dart';
import 'package:nc_photos/api/api.dart';
import 'package:nc_photos/api/api_util.dart' as api_util;
import 'package:nc_photos/cache_manager_util.dart';
import 'package:nc_photos/entity/file.dart';
import 'package:nc_photos/exception.dart';
import 'package:nc_photos/image_size_getter_util.dart';
import 'package:nc_photos/platform/metadata_loader.dart' as itf;
class MetadataLoader implements itf.MetadataLoader {
@override
loadCacheFile(Account account, File file) async {
final getFileFuture =
_getFileTask.getFileUntil(api_util.getFileUrl(account, file));
final result = await Future.any([
getFileFuture,
Future.delayed(Duration(seconds: 10)),
]);
if (_getFileTask.isGood && result is FileInfo) {
return _onGetFile(file, result);
2021-04-10 06:28:12 +02:00
} else {
// timeout
_getFileTask.cancel();
throw TimeoutException("Timeout loading file: ${file.strippedPath}");
}
}
@override
loadNewFile(Account account, File file) async {
final response =
await Api(account).files().get(path: api_util.getFileUrlRelative(file));
if (!response.isGood) {
2021-04-27 22:06:16 +02:00
_log.severe("[loadNewFile] Failed requesting server: $response");
2021-04-10 06:28:12 +02:00
throw ApiException(
response: response,
message: "Failed communicating with server: ${response.statusCode}");
}
2021-04-14 23:09:31 +02:00
return itf.MetadataLoader.loadMetadata(
file: file,
2021-04-14 23:09:31 +02:00
exifdartReaderBuilder: () => MemoryBlobReader(response.body),
imageSizeGetterInputBuilder: () => AsyncMemoryInput(response.body),
);
2021-04-10 06:28:12 +02:00
}
@override
loadFile(Account account, File file) async {
final store = DefaultCacheManager().store;
final info = await store.getFile(api_util.getFileUrl(account, file));
if (info == null) {
// no cache
return loadNewFile(account, file);
} else {
return _onGetFile(file, info);
2021-04-10 06:28:12 +02:00
}
}
@override
cancel() {
_getFileTask.cancel();
}
Future<Map<String, dynamic>> _onGetFile(File file, FileInfo info) {
2021-04-14 23:09:31 +02:00
return itf.MetadataLoader.loadMetadata(
file: file,
exifdartReaderBuilder: () => FileReader(info.file),
imageSizeGetterInputBuilder: () => AsyncFileInput(info.file),
2021-04-14 23:09:31 +02:00
);
2021-04-10 06:28:12 +02:00
}
final _getFileTask = CancelableGetFile(DefaultCacheManager().store);
static final _log = Logger("mobile.metadata_loader.MetadataLoader");
}