mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 10:56:47 +01:00
bc3979029d
* Add "details" column to LoggerMessage * Include error details in log details page * Move error details out of log message * Add error message to mixin * Create extension for HTTP Response logging * Fix analyze errors * format * fix analyze errors, format again
48 lines
1.3 KiB
Dart
48 lines
1.3 KiB
Dart
import 'package:hooks_riverpod/hooks_riverpod.dart';
|
|
import 'package:immich_mobile/shared/models/asset.dart';
|
|
import 'package:immich_mobile/shared/providers/api.provider.dart';
|
|
import 'package:immich_mobile/shared/services/api.service.dart';
|
|
import 'package:logging/logging.dart';
|
|
import 'package:openapi/api.dart';
|
|
|
|
final trashServiceProvider = Provider<TrashService>((ref) {
|
|
return TrashService(
|
|
ref.watch(apiServiceProvider),
|
|
);
|
|
});
|
|
|
|
class TrashService {
|
|
final _log = Logger("TrashService");
|
|
|
|
final ApiService _apiService;
|
|
|
|
TrashService(this._apiService);
|
|
|
|
Future<bool> restoreAssets(Iterable<Asset> assetList) async {
|
|
try {
|
|
List<String> remoteIds =
|
|
assetList.where((a) => a.isRemote).map((e) => e.remoteId!).toList();
|
|
await _apiService.trashApi.restoreAssets(BulkIdsDto(ids: remoteIds));
|
|
return true;
|
|
} catch (error, stack) {
|
|
_log.severe("Cannot restore assets", error, stack);
|
|
return false;
|
|
}
|
|
}
|
|
|
|
Future<void> emptyTrash() async {
|
|
try {
|
|
await _apiService.trashApi.emptyTrash();
|
|
} catch (error, stack) {
|
|
_log.severe("Cannot empty trash", error, stack);
|
|
}
|
|
}
|
|
|
|
Future<void> restoreTrash() async {
|
|
try {
|
|
await _apiService.trashApi.restoreTrash();
|
|
} catch (error, stack) {
|
|
_log.severe("Cannot restore trash", error, stack);
|
|
}
|
|
}
|
|
}
|