This commit is contained in:
Rafael Saes 2024-11-27 19:01:10 -03:00
parent 3ee697b4c1
commit 95bb566d09
14 changed files with 207 additions and 151 deletions

View file

@ -84,7 +84,11 @@ class BitcoinAddressRecord extends BaseBitcoinAddressRecord {
throw ArgumentError('either scriptHash or network must be provided'); throw ArgumentError('either scriptHash or network must be provided');
} }
try {
this.scriptHash = scriptHash ?? BitcoinAddressUtils.scriptHash(address, network: network!); this.scriptHash = scriptHash ?? BitcoinAddressUtils.scriptHash(address, network: network!);
} catch (_) {
this.scriptHash = '';
}
} }
factory BitcoinAddressRecord.fromJSON(String jsonSource) { factory BitcoinAddressRecord.fromJSON(String jsonSource) {

View file

@ -424,6 +424,7 @@ abstract class ElectrumWalletBase
uri: node.uri, uri: node.uri,
useSSL: node.useSSL ?? false, useSSL: node.useSSL ?? false,
network: network, network: network,
walletType: walletInfo.type,
).toJson(), ).toJson(),
); );
} else { } else {

View file

@ -414,11 +414,11 @@ abstract class ElectrumWalletAddressesBase extends WalletAddresses with Store {
required BitcoinAddressType addressType, required BitcoinAddressType addressType,
required BitcoinDerivationInfo derivationInfo, required BitcoinDerivationInfo derivationInfo,
}) async { }) async {
final count = (isChange final count = isChange
? ElectrumWalletAddressesBase.defaultChangeAddressesCount ? ElectrumWalletAddressesBase.defaultChangeAddressesCount
: ElectrumWalletAddressesBase.defaultReceiveAddressesCount); : ElectrumWalletAddressesBase.defaultReceiveAddressesCount;
final startIndex = (isChange ? receiveAddresses : changeAddresses) final startIndex = (isChange ? changeAddresses : receiveAddresses)
.where((addr) => addr.derivationType == derivationType && addr.addressType == addressType) .where((addr) => addr.derivationType == derivationType && addr.addressType == addressType)
.length; .length;

View file

@ -23,9 +23,11 @@ import 'package:sp_scanner/sp_scanner.dart';
class ElectrumWorker { class ElectrumWorker {
final SendPort sendPort; final SendPort sendPort;
ElectrumApiProvider? _electrumClient; ElectrumApiProvider? _electrumClient;
BasedUtxoNetwork? _network;
BehaviorSubject<Map<String, dynamic>>? _scanningStream; BehaviorSubject<Map<String, dynamic>>? _scanningStream;
BasedUtxoNetwork? _network;
WalletType? _walletType;
ElectrumWorker._(this.sendPort, {ElectrumApiProvider? electrumClient}) ElectrumWorker._(this.sendPort, {ElectrumApiProvider? electrumClient})
: _electrumClient = electrumClient; : _electrumClient = electrumClient;
@ -134,6 +136,7 @@ class ElectrumWorker {
Future<void> _handleConnect(ElectrumWorkerConnectionRequest request) async { Future<void> _handleConnect(ElectrumWorkerConnectionRequest request) async {
_network = request.network; _network = request.network;
_walletType = request.walletType;
try { try {
_electrumClient = await ElectrumApiProvider.connect( _electrumClient = await ElectrumApiProvider.connect(
@ -198,6 +201,10 @@ class ElectrumWorker {
// https://electrumx.readthedocs.io/en/latest/protocol-basics.html#status // https://electrumx.readthedocs.io/en/latest/protocol-basics.html#status
// The status of the script hash is the hash of the tx history, or null if the string is empty because there are no transactions // The status of the script hash is the hash of the tx history, or null if the string is empty because there are no transactions
stream.listen((status) async { stream.listen((status) async {
if (status == null) {
return;
}
print("status: $status"); print("status: $status");
_sendResponse(ElectrumWorkerScripthashesSubscribeResponse( _sendResponse(ElectrumWorkerScripthashesSubscribeResponse(
@ -213,6 +220,10 @@ class ElectrumWorker {
final addresses = result.addresses; final addresses = result.addresses;
await Future.wait(addresses.map((addressRecord) async { await Future.wait(addresses.map((addressRecord) async {
if (addressRecord.scriptHash.isEmpty) {
return;
}
final history = await _electrumClient!.request(ElectrumScriptHashGetHistory( final history = await _electrumClient!.request(ElectrumScriptHashGetHistory(
scriptHash: addressRecord.scriptHash, scriptHash: addressRecord.scriptHash,
)); ));
@ -313,6 +324,10 @@ class ElectrumWorker {
final balanceFutures = <Future<Map<String, dynamic>>>[]; final balanceFutures = <Future<Map<String, dynamic>>>[];
for (final scripthash in request.scripthashes) { for (final scripthash in request.scripthashes) {
if (scripthash.isEmpty) {
continue;
}
final balanceFuture = _electrumClient!.request( final balanceFuture = _electrumClient!.request(
ElectrumGetScriptHashBalance(scriptHash: scripthash), ElectrumGetScriptHashBalance(scriptHash: scripthash),
); );
@ -347,9 +362,15 @@ class ElectrumWorker {
final unspents = <String, List<ElectrumUtxo>>{}; final unspents = <String, List<ElectrumUtxo>>{};
await Future.wait(request.scripthashes.map((scriptHash) async { await Future.wait(request.scripthashes.map((scriptHash) async {
final scriptHashUnspents = await _electrumClient!.request( if (scriptHash.isEmpty) {
return;
}
final scriptHashUnspents = await _electrumClient!
.request(
ElectrumScriptHashListUnspent(scriptHash: scriptHash), ElectrumScriptHashListUnspent(scriptHash: scriptHash),
); )
.timeout(const Duration(seconds: 3));
if (scriptHashUnspents.isNotEmpty) { if (scriptHashUnspents.isNotEmpty) {
unspents[scriptHash] = scriptHashUnspents; unspents[scriptHash] = scriptHashUnspents;
@ -389,11 +410,21 @@ class ElectrumWorker {
int? height; int? height;
bool? isDateValidated; bool? isDateValidated;
final transactionHex = await _electrumClient!.request( final transactionVerbose = await _electrumClient!.request(
ElectrumGetTransactionVerbose(transactionHash: hash),
);
String transactionHex;
if (transactionVerbose.isNotEmpty) {
transactionHex = transactionVerbose['hex'] as String;
time = transactionVerbose['time'] as int?;
confirmations = transactionVerbose['confirmations'] as int?;
} else {
transactionHex = await _electrumClient!.request(
ElectrumGetTransactionHex(transactionHash: hash), ElectrumGetTransactionHex(transactionHash: hash),
); );
if (getTime) { if (getTime && _walletType == WalletType.bitcoin) {
if (mempoolAPIEnabled) { if (mempoolAPIEnabled) {
try { try {
// TODO: mempool api class // TODO: mempool api class
@ -441,6 +472,8 @@ class ElectrumWorker {
} }
} catch (_) {} } catch (_) {}
} }
}
}
if (confirmations == null && height != null) { if (confirmations == null && height != null) {
final tip = currentChainTip; final tip = currentChainTip;
@ -449,7 +482,6 @@ class ElectrumWorker {
confirmations = tip - height + 1; confirmations = tip - height + 1;
} }
} }
}
final original = BtcTransaction.fromRaw(transactionHex); final original = BtcTransaction.fromRaw(transactionHex);
final ins = <BtcTransaction>[]; final ins = <BtcTransaction>[];

View file

@ -5,12 +5,14 @@ class ElectrumWorkerConnectionRequest implements ElectrumWorkerRequest {
required this.uri, required this.uri,
required this.network, required this.network,
required this.useSSL, required this.useSSL,
required this.walletType,
this.id, this.id,
}); });
final Uri uri; final Uri uri;
final bool useSSL; final bool useSSL;
final BasedUtxoNetwork network; final BasedUtxoNetwork network;
final WalletType walletType;
final int? id; final int? id;
@override @override
@ -23,6 +25,9 @@ class ElectrumWorkerConnectionRequest implements ElectrumWorkerRequest {
network: BasedUtxoNetwork.values.firstWhere( network: BasedUtxoNetwork.values.firstWhere(
(e) => e.toString() == json['network'] as String, (e) => e.toString() == json['network'] as String,
), ),
walletType: WalletType.values.firstWhere(
(e) => e.toString() == json['walletType'] as String,
),
useSSL: json['useSSL'] as bool, useSSL: json['useSSL'] as bool,
id: json['id'] as int?, id: json['id'] as int?,
); );
@ -34,6 +39,7 @@ class ElectrumWorkerConnectionRequest implements ElectrumWorkerRequest {
'method': method, 'method': method,
'uri': uri.toString(), 'uri': uri.toString(),
'network': network.toString(), 'network': network.toString(),
'walletType': walletType.toString(),
'useSSL': useSSL, 'useSSL': useSSL,
}; };
} }

View file

@ -6,6 +6,7 @@ import 'dart:math';
import 'package:collection/collection.dart'; import 'package:collection/collection.dart';
import 'package:crypto/crypto.dart'; import 'package:crypto/crypto.dart';
import 'package:cw_bitcoin/bitcoin_transaction_credentials.dart'; import 'package:cw_bitcoin/bitcoin_transaction_credentials.dart';
import 'package:cw_bitcoin/electrum_wallet_addresses.dart';
// import 'package:cw_bitcoin/electrum_wallet_addresses.dart'; // import 'package:cw_bitcoin/electrum_wallet_addresses.dart';
import 'package:cw_core/cake_hive.dart'; import 'package:cw_core/cake_hive.dart';
import 'package:cw_core/mweb_utxo.dart'; import 'package:cw_core/mweb_utxo.dart';
@ -58,7 +59,7 @@ abstract class LitecoinWalletBase extends ElectrumWallet with Store {
required WalletInfo walletInfo, required WalletInfo walletInfo,
required Box<UnspentCoinsInfo> unspentCoinsInfo, required Box<UnspentCoinsInfo> unspentCoinsInfo,
required EncryptionFileUtils encryptionFileUtils, required EncryptionFileUtils encryptionFileUtils,
Uint8List? seedBytes, List<int>? seedBytes,
String? mnemonic, String? mnemonic,
String? xpub, String? xpub,
String? passphrase, String? passphrase,
@ -155,20 +156,61 @@ abstract class LitecoinWalletBase extends ElectrumWallet with Store {
Map<String, int>? initialChangeAddressIndex, Map<String, int>? initialChangeAddressIndex,
required bool mempoolAPIEnabled, required bool mempoolAPIEnabled,
}) async { }) async {
late Uint8List seedBytes; List<int>? seedBytes = null;
final Map<CWBitcoinDerivationType, Bip32Slip10Secp256k1> hdWallets = {};
if (walletInfo.isRecovery) {
for (final derivation in walletInfo.derivations ?? <DerivationInfo>[]) {
if (derivation.description?.contains("SP") ?? false) {
continue;
}
if (derivation.derivationType == DerivationType.bip39) {
seedBytes = Bip39SeedGenerator.generateFromString(mnemonic, passphrase);
hdWallets[CWBitcoinDerivationType.bip39] = Bip32Slip10Secp256k1.fromSeed(seedBytes);
break;
} else {
try {
seedBytes = ElectrumV2SeedGenerator.generateFromString(mnemonic, passphrase);
hdWallets[CWBitcoinDerivationType.electrum] = Bip32Slip10Secp256k1.fromSeed(seedBytes);
} catch (e) {
print("electrum_v2 seed error: $e");
try {
seedBytes = ElectrumV1SeedGenerator(mnemonic).generate();
hdWallets[CWBitcoinDerivationType.electrum] =
Bip32Slip10Secp256k1.fromSeed(seedBytes);
} catch (e) {
print("electrum_v1 seed error: $e");
}
}
break;
}
}
if (hdWallets[CWBitcoinDerivationType.bip39] != null) {
hdWallets[CWBitcoinDerivationType.old_bip39] = hdWallets[CWBitcoinDerivationType.bip39]!;
}
if (hdWallets[CWBitcoinDerivationType.electrum] != null) {
hdWallets[CWBitcoinDerivationType.old_electrum] =
hdWallets[CWBitcoinDerivationType.electrum]!;
}
} else {
switch (walletInfo.derivationInfo?.derivationType) { switch (walletInfo.derivationInfo?.derivationType) {
case DerivationType.bip39: case DerivationType.bip39:
seedBytes = await bip39.mnemonicToSeed( seedBytes = await Bip39SeedGenerator.generateFromString(mnemonic, passphrase);
mnemonic, hdWallets[CWBitcoinDerivationType.bip39] = Bip32Slip10Secp256k1.fromSeed(seedBytes);
passphrase: passphrase ?? "",
);
break; break;
case DerivationType.electrum: case DerivationType.electrum:
default: default:
seedBytes = await mnemonicToSeedBytes(mnemonic, passphrase: passphrase ?? ""); seedBytes = await ElectrumV2SeedGenerator.generateFromString(mnemonic, passphrase);
hdWallets[CWBitcoinDerivationType.electrum] = Bip32Slip10Secp256k1.fromSeed(seedBytes);
break; break;
} }
}
return LitecoinWallet( return LitecoinWallet(
mnemonic: mnemonic, mnemonic: mnemonic,
password: password, password: password,
@ -232,7 +274,7 @@ abstract class LitecoinWalletBase extends ElectrumWallet with Store {
walletInfo.derivationInfo!.derivationPath ??= snp?.derivationPath ?? ELECTRUM_PATH; walletInfo.derivationInfo!.derivationPath ??= snp?.derivationPath ?? ELECTRUM_PATH;
walletInfo.derivationInfo!.derivationType ??= snp?.derivationType ?? DerivationType.electrum; walletInfo.derivationInfo!.derivationType ??= snp?.derivationType ?? DerivationType.electrum;
Uint8List? seedBytes = null; List<int>? seedBytes = null;
final mnemonic = keysData.mnemonic; final mnemonic = keysData.mnemonic;
final passphrase = keysData.passphrase; final passphrase = keysData.passphrase;

View file

@ -117,6 +117,7 @@ abstract class LitecoinWalletAddressesBase extends ElectrumWalletAddresses with
await ensureMwebAddressUpToIndexExists(20); await ensureMwebAddressUpToIndexExists(20);
return; return;
} }
}
@override @override
BitcoinBaseAddress generateAddress({ BitcoinBaseAddress generateAddress({
@ -131,13 +132,12 @@ abstract class LitecoinWalletAddressesBase extends ElectrumWalletAddresses with
} }
return P2wpkhAddress.fromDerivation( return P2wpkhAddress.fromDerivation(
bip32: hdWallet, bip32: hdWallets[derivationType]!,
derivationInfo: derivationInfo, derivationInfo: derivationInfo,
isChange: isChange, isChange: isChange,
index: index, index: index,
); );
} }
}
@override @override
Future<String> getAddressAsync({ Future<String> getAddressAsync({

View file

@ -86,20 +86,16 @@ packages:
bitcoin_base: bitcoin_base:
dependency: "direct overridden" dependency: "direct overridden"
description: description:
path: "." path: "/home/rafael/Working/bitcoin_base"
ref: cake-update-v15 relative: false
resolved-ref: "49db5748d2edc73c0c8213e11ab6a39fa3a7ff7f" source: path
url: "https://github.com/cake-tech/bitcoin_base.git"
source: git
version: "4.7.0" version: "4.7.0"
blockchain_utils: blockchain_utils:
dependency: "direct main" dependency: "direct main"
description: description:
path: "." path: "/home/rafael/Working/blockchain_utils"
ref: cake-update-v3 relative: false
resolved-ref: "9b64c43bcfe129e7f01300a63607fde083dd0357" source: path
url: "https://github.com/cake-tech/blockchain_utils"
source: git
version: "3.3.0" version: "3.3.0"
bluez: bluez:
dependency: transitive dependency: transitive
@ -415,10 +411,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: google_identity_services_web name: google_identity_services_web
sha256: "0c56c2c5d60d6dfaf9725f5ad4699f04749fb196ee5a70487a46ef184837ccf6" sha256: "55580f436822d64c8ff9a77e37d61f5fb1e6c7ec9d632a43ee324e2a05c3c6c9"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "0.3.0+2" version: "0.3.3"
googleapis_auth: googleapis_auth:
dependency: transitive dependency: transitive
description: description:
@ -471,10 +467,10 @@ packages:
dependency: "direct main" dependency: "direct main"
description: description:
name: http name: http
sha256: a2bbf9d017fcced29139daa8ed2bba4ece450ab222871df93ca9eec6f80c34ba sha256: b9c29a161230ee03d3ccf545097fccd9b87a5264228c5d348202e0f0c28f9010
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "1.2.0" version: "1.2.2"
http2: http2:
dependency: transitive dependency: transitive
description: description:
@ -849,10 +845,10 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: shared_preferences_web name: shared_preferences_web
sha256: "7b15ffb9387ea3e237bb7a66b8a23d2147663d391cafc5c8f37b2e7b4bde5d21" sha256: d2ca4132d3946fec2184261726b355836a82c33d7d5b67af32692aff18a4684e
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "2.2.2" version: "2.4.2"
shared_preferences_windows: shared_preferences_windows:
dependency: transitive dependency: transitive
description: description:
@ -917,11 +913,9 @@ packages:
sp_scanner: sp_scanner:
dependency: "direct main" dependency: "direct main"
description: description:
path: "." path: "/home/rafael/Working/sp_scanner"
ref: cake-update-v3 relative: false
resolved-ref: "2c21e53fd652e0aee1ee5fcd891376c10334237b" source: path
url: "https://github.com/cake-tech/sp_scanner.git"
source: git
version: "0.0.1" version: "0.0.1"
stack_trace: stack_trace:
dependency: transitive dependency: transitive
@ -1047,18 +1041,26 @@ packages:
dependency: transitive dependency: transitive
description: description:
name: web name: web
sha256: "4188706108906f002b3a293509234588823c8c979dc83304e229ff400c996b05" sha256: cd3543bd5798f6ad290ea73d210f423502e71900302dde696f8bff84bf89a1cb
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "0.4.2" version: "1.1.0"
web_socket:
dependency: transitive
description:
name: web_socket
sha256: "3c12d96c0c9a4eec095246debcea7b86c0324f22df69893d538fcc6f1b8cce83"
url: "https://pub.dev"
source: hosted
version: "0.1.6"
web_socket_channel: web_socket_channel:
dependency: transitive dependency: transitive
description: description:
name: web_socket_channel name: web_socket_channel
sha256: "939ab60734a4f8fa95feacb55804fa278de28bdeef38e616dc08e44a84adea23" sha256: "9f187088ed104edd8662ca07af4b124465893caf063ba29758f97af57e61da8f"
url: "https://pub.dev" url: "https://pub.dev"
source: hosted source: hosted
version: "2.4.3" version: "3.0.1"
xdg_directories: xdg_directories:
dependency: transitive dependency: transitive
description: description:

View file

@ -27,16 +27,12 @@ dependencies:
rxdart: ^0.28.0 rxdart: ^0.28.0
cryptography: ^2.0.5 cryptography: ^2.0.5
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
cw_mweb: cw_mweb:
path: ../cw_mweb path: ../cw_mweb
grpc: ^3.2.4 grpc: ^3.2.4
sp_scanner: sp_scanner:
git: path: /home/rafael/Working/sp_scanner
url: https://github.com/cake-tech/sp_scanner.git
ref: cake-update-v3
bech32: bech32:
git: git:
url: https://github.com/cake-tech/bech32.git url: https://github.com/cake-tech/bech32.git
@ -62,13 +58,9 @@ dependency_overrides:
watcher: ^1.1.0 watcher: ^1.1.0
protobuf: ^3.1.0 protobuf: ^3.1.0
bitcoin_base: bitcoin_base:
git: path: /home/rafael/Working/bitcoin_base
url: https://github.com/cake-tech/bitcoin_base.git
ref: cake-update-v15
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
pointycastle: 3.7.4 pointycastle: 3.7.4
ffi: 2.1.0 ffi: 2.1.0

View file

@ -26,9 +26,7 @@ dependencies:
url: https://github.com/cake-tech/bitbox-flutter.git url: https://github.com/cake-tech/bitbox-flutter.git
ref: Add-Support-For-OP-Return-data ref: Add-Support-For-OP-Return-data
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
dev_dependencies: dev_dependencies:
flutter_test: flutter_test:
@ -40,13 +38,9 @@ dev_dependencies:
dependency_overrides: dependency_overrides:
watcher: ^1.1.0 watcher: ^1.1.0
bitcoin_base: bitcoin_base:
git: path: /home/rafael/Working/bitcoin_base
url: https://github.com/cake-tech/bitcoin_base.git
ref: cake-update-v15
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
# For information on the generic Dart part of this file, see the # For information on the generic Dart part of this file, see the
# following page: https://dart.dev/tools/pub/pubspec # following page: https://dart.dev/tools/pub/pubspec

View file

@ -16,13 +16,9 @@ dependencies:
cw_evm: cw_evm:
path: ../cw_evm path: ../cw_evm
on_chain: on_chain:
git: path: /home/rafael/Working/On_chain
url: https://github.com/cake-tech/on_chain.git
ref: cake-update-v3
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
mobx: ^2.3.0+1 mobx: ^2.3.0+1
bip39: ^1.0.6 bip39: ^1.0.6
hive: ^2.2.3 hive: ^2.2.3
@ -37,9 +33,7 @@ dev_dependencies:
dependency_overrides: dependency_overrides:
blockchain_utils: blockchain_utils:
git: path: /home/rafael/Working/blockchain_utils
url: https://github.com/cake-tech/blockchain_utils
ref: cake-update-v3
flutter: flutter:
# assets: # assets:

View file

@ -372,8 +372,6 @@ class CWBitcoin extends Bitcoin {
); );
} }
oldList.addAll(bitcoin!.getOldSPDerivationInfos());
return oldList; return oldList;
} }
@ -385,24 +383,13 @@ class CWBitcoin extends Bitcoin {
}) async { }) async {
final list = <DerivationInfo>[]; final list = <DerivationInfo>[];
late BasedUtxoNetwork network;
switch (node.type) {
case WalletType.litecoin:
network = LitecoinNetwork.mainnet;
break;
case WalletType.bitcoin:
default:
network = BitcoinNetwork.mainnet;
break;
}
var electrumSeedBytes; var electrumSeedBytes;
try { try {
electrumSeedBytes = ElectrumV2SeedGenerator.generateFromString(mnemonic, passphrase); electrumSeedBytes = ElectrumV2SeedGenerator.generateFromString(mnemonic, passphrase);
} catch (e) { } catch (e) {
print("electrum_v2 seed error: $e"); print("electrum_v2 seed error: $e");
if (passphrase != null && passphrase.isEmpty) { if (passphrase == null || passphrase.isEmpty) {
try { try {
// TODO: language pick // TODO: language pick
electrumSeedBytes = ElectrumV1SeedGenerator(mnemonic).generate(); electrumSeedBytes = ElectrumV1SeedGenerator(mnemonic).generate();

View file

@ -268,6 +268,10 @@ abstract class WalletRestoreViewModelBase extends WalletCreationVM with Store {
// is restoring? = add old used derivations // is restoring? = add old used derivations
final oldList = bitcoin!.getOldDerivationInfos(list); final oldList = bitcoin!.getOldDerivationInfos(list);
if (walletType == WalletType.bitcoin) {
oldList.addAll(bitcoin!.getOldSPDerivationInfos());
}
return oldList; return oldList;
case WalletType.nano: case WalletType.nano:
String? mnemonic = credentials['seed'] as String?; String? mnemonic = credentials['seed'] as String?;

View file

@ -142,9 +142,7 @@ dependency_overrides:
flutter_secure_storage_platform_interface: 1.0.2 flutter_secure_storage_platform_interface: 1.0.2
protobuf: ^3.1.0 protobuf: ^3.1.0
bitcoin_base: bitcoin_base:
git: path: /home/rafael/Working/bitcoin_base
url: https://github.com/cake-tech/bitcoin_base.git
ref: cake-update-v15
ffi: 2.1.0 ffi: 2.1.0
flutter_icons: flutter_icons: