nc-photos/lib/use_case/compat/v32.dart

54 lines
1.7 KiB
Dart
Raw Normal View History

2021-10-19 21:49:41 +02:00
import 'dart:convert';
import 'package:logging/logging.dart';
import 'package:nc_photos/entity/exif.dart';
2021-10-19 21:49:41 +02:00
import 'package:nc_photos/type.dart';
import 'package:shared_preferences/shared_preferences.dart';
/// Compatibility helper for v32
class CompatV32 {
static Future<bool> isPrefNeedMigration() async {
final pref = await SharedPreferences.getInstance();
return pref.containsKey("accounts");
}
static Future<void> migratePref() async {
final pref = await SharedPreferences.getInstance();
final jsons = pref.getStringList("accounts");
if (jsons == null) {
return;
}
2021-10-26 20:42:02 +02:00
_log.info("[migratePref] Migrate Pref.accounts");
2021-10-19 21:49:41 +02:00
final newJsons = <JsonObj>[];
for (final j in jsons) {
newJsons.add(<String, dynamic>{
"account": jsonDecode(j),
"settings": <String, dynamic>{
"isEnableFaceRecognitionApp": true,
},
2021-10-19 21:49:41 +02:00
});
}
if (await pref.setStringList(
"accounts2", newJsons.map((e) => jsonEncode(e)).toList())) {
2021-10-26 20:42:02 +02:00
_log.info("[migratePref] Migrated ${newJsons.length} accounts");
2021-10-19 21:49:41 +02:00
await pref.remove("accounts");
} else {
2021-10-26 20:42:02 +02:00
_log.severe("[migratePref] Failed while writing pref");
2021-10-19 21:49:41 +02:00
}
}
static bool isExifNeedMigration(Exif exif) =>
exif.data.containsKey("UserComment") ||
exif.data.containsKey("MakerNote");
static Exif migrateExif(Exif exif, String logFilename) {
_log.info("[migrateExif] Migrate EXIF for file: $logFilename");
final newData = Map.of(exif.data);
newData.removeWhere(
(key, value) => key == "UserComment" || key == "MakerNote");
return Exif(newData);
}
2021-10-19 21:49:41 +02:00
static final _log = Logger("use_case.compat.v32.CompatV32");
}