mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-18 16:55:58 +00:00
7410daacff
* feat: Create central package for EVM chains * chore: Cleanup pubspec and add core evm dependencies * feat: Replicated core evm chain files, time to start fixing the issues * feat: Setup evm central package to handle all evm chains * feat: Link up Polygon and Ethereum wallets to the centra evm package, fix bugs and issues, and optimze for better performance * feat: Setup and adjust configs to reflect new evm configurations * Remove unneeded file * fix: Changes done while re-reviewing entire structure and refactor * fix: Add evm chain wallet path to imports in configure file * feat: Adjust implementation of parent class, remove unneeded files, remove windows, linux and mac directories, restructure the evm child classes * fix: Make EVMChainWallet a central abstract class and adjust accordingly * fix: Adjust transaction info, restructure EVMWalletChain to be an abstract, adjust external facing interfaces for polygon and ethereum, adjust configuration for ethereum and polygon in configure file * fix: Testing issues * fix: Add localization for nft tile and details page texts and add dashes for null responses * fix: merge conflicts * Minor fixes for building Monero.com --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
39 lines
1.1 KiB
Dart
39 lines
1.1 KiB
Dart
import 'dart:io';
|
|
import 'package:cw_core/key.dart';
|
|
import 'package:encrypt/encrypt.dart' as encrypt;
|
|
|
|
Future<void> write(
|
|
{required String path,
|
|
required String password,
|
|
required String data}) async {
|
|
final keys = extractKeys(password);
|
|
final key = encrypt.Key.fromBase64(keys.first);
|
|
final iv = encrypt.IV.fromBase64(keys.last);
|
|
final encrypted = await encode(key: key, iv: iv, data: data);
|
|
final f = File(path);
|
|
f.writeAsStringSync(encrypted);
|
|
}
|
|
|
|
Future<void> writeData(
|
|
{required String path,
|
|
required String password,
|
|
required String data}) async {
|
|
final keys = extractKeys(password);
|
|
final key = encrypt.Key.fromBase64(keys.first);
|
|
final iv = encrypt.IV.fromBase64(keys.last);
|
|
final encrypted = await encode(key: key, iv: iv, data: data);
|
|
final f = File(path);
|
|
f.writeAsStringSync(encrypted);
|
|
}
|
|
|
|
Future<String> read({required String path, required String password}) async {
|
|
final file = File(path);
|
|
|
|
if (!file.existsSync()) {
|
|
file.createSync();
|
|
}
|
|
|
|
final encrypted = file.readAsStringSync();
|
|
|
|
return decode(password: password, data: encrypted);
|
|
}
|