mirror of
https://gitlab.com/famedly/fluffychat.git
synced 2024-12-25 15:02:33 +01:00
chore: Follow up migrate old preferences
This commit is contained in:
parent
ffe387a7e2
commit
ddecffa531
@ -1,7 +1,10 @@
|
|||||||
import 'dart:core';
|
import 'dart:core';
|
||||||
|
|
||||||
|
import 'package:matrix/matrix.dart';
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
|
||||||
|
import 'legacy_famedlysdk_store.dart' as legacy;
|
||||||
|
|
||||||
class Store {
|
class Store {
|
||||||
SharedPreferences? _prefs;
|
SharedPreferences? _prefs;
|
||||||
|
|
||||||
@ -11,11 +14,25 @@ class Store {
|
|||||||
|
|
||||||
Future<String?> getItem(String key) async {
|
Future<String?> getItem(String key) async {
|
||||||
await _setupLocalStorage();
|
await _setupLocalStorage();
|
||||||
|
final legacyVal = await legacy.Store().getItem(key);
|
||||||
|
if (legacyVal != null) {
|
||||||
|
Logs().d('Found legacy preference for $key');
|
||||||
|
await setItem(key, legacyVal);
|
||||||
|
legacy.Store().deleteItem(key);
|
||||||
|
return legacyVal;
|
||||||
|
}
|
||||||
return _prefs!.getString(key);
|
return _prefs!.getString(key);
|
||||||
}
|
}
|
||||||
|
|
||||||
Future<bool> getItemBool(String key, [bool? defaultValue]) async {
|
Future<bool> getItemBool(String key, [bool? defaultValue]) async {
|
||||||
await _setupLocalStorage();
|
await _setupLocalStorage();
|
||||||
|
final legacyVal = await legacy.Store().getItemBool(key);
|
||||||
|
if (legacyVal != null) {
|
||||||
|
Logs().d('Found legacy preference for $key');
|
||||||
|
await setItemBool(key, legacyVal);
|
||||||
|
legacy.Store().deleteItem(key);
|
||||||
|
return legacyVal;
|
||||||
|
}
|
||||||
return _prefs!.getBool(key) ?? defaultValue ?? true;
|
return _prefs!.getBool(key) ?? defaultValue ?? true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
121
lib/utils/legacy_famedlysdk_store.dart
Normal file
121
lib/utils/legacy_famedlysdk_store.dart
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
import 'dart:async';
|
||||||
|
import 'dart:core';
|
||||||
|
|
||||||
|
import 'package:device_info_plus/device_info_plus.dart';
|
||||||
|
import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
||||||
|
import 'package:localstorage/localstorage.dart';
|
||||||
|
import 'package:path_provider/path_provider.dart';
|
||||||
|
|
||||||
|
import 'package:fluffychat/utils/platform_infos.dart';
|
||||||
|
|
||||||
|
// import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
||||||
|
|
||||||
|
// see https://github.com/mogol/flutter_secure_storage/issues/161#issuecomment-704578453
|
||||||
|
class AsyncMutex {
|
||||||
|
Completer<void>? _completer;
|
||||||
|
|
||||||
|
Future<void> lock() async {
|
||||||
|
while (_completer != null) {
|
||||||
|
await _completer!.future;
|
||||||
|
}
|
||||||
|
|
||||||
|
_completer = Completer<void>();
|
||||||
|
}
|
||||||
|
|
||||||
|
void unlock() {
|
||||||
|
assert(_completer != null);
|
||||||
|
final completer = _completer!;
|
||||||
|
_completer = null;
|
||||||
|
completer.complete();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class Store {
|
||||||
|
FlutterSecureStorage? secureStorage;
|
||||||
|
|
||||||
|
LocalStorage? storage;
|
||||||
|
static final _mutex = AsyncMutex();
|
||||||
|
|
||||||
|
Future<void> _setupLocalStorage() async {
|
||||||
|
if (PlatformInfos.isMobile) {
|
||||||
|
if (PlatformInfos.isAndroid) {
|
||||||
|
return DeviceInfoPlugin().androidInfo.then((info) {
|
||||||
|
if ((info.version.sdkInt ?? 16) >= 19) {
|
||||||
|
secureStorage = const FlutterSecureStorage();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
secureStorage = const FlutterSecureStorage();
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (storage == null) {
|
||||||
|
final directory = PlatformInfos.isBetaDesktop
|
||||||
|
? await getApplicationSupportDirectory()
|
||||||
|
: (PlatformInfos.isWeb
|
||||||
|
? null
|
||||||
|
: await getApplicationDocumentsDirectory());
|
||||||
|
storage = LocalStorage('LocalStorage', directory?.path);
|
||||||
|
await storage!.ready;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<String?> getItem(String key) async {
|
||||||
|
final storage = this.storage;
|
||||||
|
if (!PlatformInfos.isMobile && storage != null) {
|
||||||
|
await _setupLocalStorage();
|
||||||
|
try {
|
||||||
|
return storage.getItem(key)?.toString();
|
||||||
|
} catch (_) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
await _mutex.lock();
|
||||||
|
return await secureStorage!.read(key: key);
|
||||||
|
} catch (_) {
|
||||||
|
return null;
|
||||||
|
} finally {
|
||||||
|
_mutex.unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<bool?> getItemBool(String key, [bool? defaultValue]) async {
|
||||||
|
final value = await getItem(key);
|
||||||
|
if (value == null) {
|
||||||
|
return defaultValue;
|
||||||
|
}
|
||||||
|
// we also check for '1' for legacy reasons, some booleans were stored that way
|
||||||
|
return value == '1' || value.toLowerCase() == 'true';
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> setItem(String key, String? value) async {
|
||||||
|
await _setupLocalStorage();
|
||||||
|
if (!PlatformInfos.isMobile) {
|
||||||
|
return await storage!.setItem(key, value);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
await _mutex.lock();
|
||||||
|
return await secureStorage!.write(key: key, value: value);
|
||||||
|
} finally {
|
||||||
|
_mutex.unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> setItemBool(String key, bool value) async {
|
||||||
|
await setItem(key, value.toString());
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> deleteItem(String key) async {
|
||||||
|
if (!PlatformInfos.isMobile) {
|
||||||
|
await _setupLocalStorage();
|
||||||
|
return await storage!.deleteItem(key);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
await _mutex.lock();
|
||||||
|
return await secureStorage!.delete(key: key);
|
||||||
|
} finally {
|
||||||
|
_mutex.unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -903,6 +903,13 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.0.1"
|
version: "1.0.1"
|
||||||
|
localstorage:
|
||||||
|
dependency: "direct main"
|
||||||
|
description:
|
||||||
|
name: localstorage
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "4.0.0+1"
|
||||||
logging:
|
logging:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
|
@ -54,6 +54,7 @@ dependencies:
|
|||||||
image: ^3.1.1
|
image: ^3.1.1
|
||||||
image_picker: ^0.8.4+8
|
image_picker: ^0.8.4+8
|
||||||
intl: any
|
intl: any
|
||||||
|
localstorage: ^4.0.0+1
|
||||||
lottie: ^1.2.2
|
lottie: ^1.2.2
|
||||||
matrix: ^0.8.9
|
matrix: ^0.8.9
|
||||||
matrix_link_text: ^1.0.2
|
matrix_link_text: ^1.0.2
|
||||||
|
Loading…
Reference in New Issue
Block a user