mirror of
https://github.com/immich-app/immich.git
synced 2026-02-28 17:49:05 +03:00
* feat: bring back manual backup * expose iCloud retrieval progress * wip * unify http upload method, check for connectivity on iOS * handle LivePhotos progress * feat: speed calculation * wip * better upload detail page * handle error * handle error * pr feedback * feat: share intent upload * feat: manual upload * feat: manual upload progress * chore: styling * refactor * refactor * remove unused logs * fix: background android backup * feat: add error section * remove complete section * remove empty state and prevent slot jumps * more refactor * fix: background test * chore: add metadata to foreground upload * fix: email and name get reset in auth provider * pr feedback * remove version check for metadata field in upload payload * chore: fix unit test --------- Co-authored-by: shenlong-tanwen <139912620+shalong-tanwen@users.noreply.github.com>
154 lines
4.4 KiB
Dart
154 lines
4.4 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:immich_mobile/domain/models/asset/base_asset.model.dart';
|
|
import 'package:immich_mobile/extensions/platform_extensions.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:photo_manager/photo_manager.dart';
|
|
|
|
class StorageRepository {
|
|
final log = Logger('StorageRepository');
|
|
|
|
StorageRepository();
|
|
|
|
Future<File?> getFileForAsset(String assetId) async {
|
|
File? file;
|
|
final log = Logger('StorageRepository');
|
|
|
|
try {
|
|
final entity = await AssetEntity.fromId(assetId);
|
|
file = await entity?.originFile;
|
|
if (file == null) {
|
|
log.warning("Cannot get file for asset $assetId");
|
|
return null;
|
|
}
|
|
|
|
final exists = await file.exists();
|
|
if (!exists) {
|
|
log.warning("File for asset $assetId does not exist");
|
|
return null;
|
|
}
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error getting file for asset $assetId", error, stackTrace);
|
|
}
|
|
return file;
|
|
}
|
|
|
|
Future<File?> getMotionFileForAsset(LocalAsset asset) async {
|
|
File? file;
|
|
final log = Logger('StorageRepository');
|
|
|
|
try {
|
|
final entity = await AssetEntity.fromId(asset.id);
|
|
file = await entity?.originFileWithSubtype;
|
|
if (file == null) {
|
|
log.warning(
|
|
"Cannot get motion file for asset ${asset.id}, name: ${asset.name}, created on: ${asset.createdAt}",
|
|
);
|
|
return null;
|
|
}
|
|
|
|
final exists = await file.exists();
|
|
if (!exists) {
|
|
log.warning("Motion file for asset ${asset.id} does not exist");
|
|
return null;
|
|
}
|
|
} catch (error, stackTrace) {
|
|
log.warning(
|
|
"Error getting motion file for asset ${asset.id}, name: ${asset.name}, created on: ${asset.createdAt}",
|
|
error,
|
|
stackTrace,
|
|
);
|
|
}
|
|
return file;
|
|
}
|
|
|
|
Future<AssetEntity?> getAssetEntityForAsset(LocalAsset asset) async {
|
|
final log = Logger('StorageRepository');
|
|
|
|
AssetEntity? entity;
|
|
|
|
try {
|
|
entity = await AssetEntity.fromId(asset.id);
|
|
if (entity == null) {
|
|
log.warning(
|
|
"Cannot get AssetEntity for asset ${asset.id}, name: ${asset.name}, created on: ${asset.createdAt}",
|
|
);
|
|
}
|
|
} catch (error, stackTrace) {
|
|
log.warning(
|
|
"Error getting AssetEntity for asset ${asset.id}, name: ${asset.name}, created on: ${asset.createdAt}",
|
|
error,
|
|
stackTrace,
|
|
);
|
|
}
|
|
return entity;
|
|
}
|
|
|
|
Future<bool> isAssetAvailableLocally(String assetId) async {
|
|
try {
|
|
final entity = await AssetEntity.fromId(assetId);
|
|
if (entity == null) {
|
|
log.warning("Cannot get AssetEntity for asset $assetId");
|
|
return false;
|
|
}
|
|
|
|
return await entity.isLocallyAvailable(isOrigin: true);
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error checking if asset is locally available $assetId", error, stackTrace);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
Future<File?> loadFileFromCloud(String assetId, {PMProgressHandler? progressHandler}) async {
|
|
try {
|
|
final entity = await AssetEntity.fromId(assetId);
|
|
if (entity == null) {
|
|
log.warning("Cannot get AssetEntity for asset $assetId");
|
|
return null;
|
|
}
|
|
|
|
return await entity.loadFile(progressHandler: progressHandler);
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error loading file from cloud for asset $assetId", error, stackTrace);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
Future<File?> loadMotionFileFromCloud(String assetId, {PMProgressHandler? progressHandler}) async {
|
|
try {
|
|
final entity = await AssetEntity.fromId(assetId);
|
|
if (entity == null) {
|
|
log.warning("Cannot get AssetEntity for asset $assetId");
|
|
return null;
|
|
}
|
|
|
|
return await entity.loadFile(withSubtype: true, progressHandler: progressHandler);
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error loading motion file from cloud for asset $assetId", error, stackTrace);
|
|
return null;
|
|
}
|
|
}
|
|
|
|
Future<void> clearCache() async {
|
|
final log = Logger('StorageRepository');
|
|
|
|
try {
|
|
await PhotoManager.clearFileCache();
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error clearing cache", error, stackTrace);
|
|
}
|
|
|
|
if (!CurrentPlatform.isIOS) {
|
|
return;
|
|
}
|
|
|
|
try {
|
|
if (await Directory.systemTemp.exists()) {
|
|
await Directory.systemTemp.delete(recursive: true);
|
|
}
|
|
} catch (error, stackTrace) {
|
|
log.warning("Error deleting temporary directory", error, stackTrace);
|
|
}
|
|
}
|
|
}
|