mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-10 04:44:43 +00:00
e276181f88
Fix Conflicts with main
51 lines
1.7 KiB
Dart
51 lines
1.7 KiB
Dart
import 'dart:io';
|
|
|
|
import 'package:collection/collection.dart';
|
|
import 'package:cw_core/pathForWallet.dart';
|
|
import 'package:cw_core/wallet_base.dart';
|
|
import 'package:cw_core/wallet_info.dart';
|
|
import 'package:cw_core/wallet_service.dart';
|
|
import 'package:cw_core/wallet_type.dart';
|
|
import 'package:cw_evm/evm_chain_wallet.dart';
|
|
import 'package:cw_evm/evm_chain_wallet_creation_credentials.dart';
|
|
import 'package:hive/hive.dart';
|
|
|
|
abstract class EVMChainWalletService<T extends EVMChainWallet> extends WalletService<
|
|
EVMChainNewWalletCredentials,
|
|
EVMChainRestoreWalletFromSeedCredentials,
|
|
EVMChainRestoreWalletFromPrivateKey> {
|
|
EVMChainWalletService(this.walletInfoSource, this.isDirect);
|
|
|
|
final Box<WalletInfo> walletInfoSource;
|
|
final bool isDirect;
|
|
|
|
@override
|
|
WalletType getType();
|
|
|
|
@override
|
|
Future<T> create(EVMChainNewWalletCredentials credentials);
|
|
|
|
@override
|
|
Future<T> openWallet(String name, String password);
|
|
|
|
@override
|
|
Future<void> rename(String currentName, String password, String newName);
|
|
|
|
@override
|
|
Future<T> restoreFromKeys(EVMChainRestoreWalletFromPrivateKey credentials);
|
|
|
|
@override
|
|
Future<T> restoreFromSeed(EVMChainRestoreWalletFromSeedCredentials credentials);
|
|
|
|
@override
|
|
Future<bool> isWalletExit(String name) async =>
|
|
File(await pathForWallet(name: name, type: getType())).existsSync();
|
|
|
|
@override
|
|
Future<void> remove(String wallet) async {
|
|
File(await pathForWalletDir(name: wallet, type: getType())).delete(recursive: true);
|
|
final walletInfo = walletInfoSource.values
|
|
.firstWhereOrNull((info) => info.id == WalletBase.idFor(wallet, getType()))!;
|
|
await walletInfoSource.delete(walletInfo.key);
|
|
}
|
|
}
|