mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-11 05:04:35 +00:00
privkey lookup for signing
This commit is contained in:
parent
e82a5a1fb8
commit
d73a90fb51
3 changed files with 39 additions and 1 deletions
|
@ -1 +1 @@
|
||||||
Subproject commit 56de6e9e8cd3f1af9959be7dc4c14131058e7430
|
Subproject commit dccd3a5c23aee021f49553c2da1ab8d59e6da5ea
|
|
@ -146,6 +146,9 @@ class BitcoinCashWallet extends CoinServiceAPI
|
||||||
},
|
},
|
||||||
getTxCountForAddress: getTxCount,
|
getTxCountForAddress: getTxCount,
|
||||||
getChainHeight: () async => chainHeight,
|
getChainHeight: () async => chainHeight,
|
||||||
|
mnemonic: mnemonicString,
|
||||||
|
mnemonicPassphrase: mnemonicPassphrase,
|
||||||
|
network: _network,
|
||||||
);
|
);
|
||||||
initCoinControlInterface(
|
initCoinControlInterface(
|
||||||
walletId: walletId,
|
walletId: walletId,
|
||||||
|
|
|
@ -1,6 +1,8 @@
|
||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
import 'dart:io';
|
import 'dart:io';
|
||||||
|
import 'dart:typed_data';
|
||||||
|
|
||||||
|
import 'package:bitcoindart/bitcoindart.dart' as btcdart;
|
||||||
import 'package:fusiondart/fusiondart.dart' as fusion;
|
import 'package:fusiondart/fusiondart.dart' as fusion;
|
||||||
import 'package:isar/isar.dart';
|
import 'package:isar/isar.dart';
|
||||||
import 'package:stackwallet/db/isar/main_db.dart';
|
import 'package:stackwallet/db/isar/main_db.dart';
|
||||||
|
@ -8,6 +10,7 @@ import 'package:stackwallet/electrumx_rpc/cached_electrumx.dart';
|
||||||
import 'package:stackwallet/models/fusion_progress_ui_state.dart';
|
import 'package:stackwallet/models/fusion_progress_ui_state.dart';
|
||||||
import 'package:stackwallet/models/isar/models/isar_models.dart';
|
import 'package:stackwallet/models/isar/models/isar_models.dart';
|
||||||
import 'package:stackwallet/services/fusion_tor_service.dart';
|
import 'package:stackwallet/services/fusion_tor_service.dart';
|
||||||
|
import 'package:stackwallet/utilities/bip32_utils.dart';
|
||||||
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
import 'package:stackwallet/utilities/enums/coin_enum.dart';
|
||||||
import 'package:stackwallet/utilities/extensions/impl/string.dart';
|
import 'package:stackwallet/utilities/extensions/impl/string.dart';
|
||||||
import 'package:stackwallet/utilities/stack_file_system.dart';
|
import 'package:stackwallet/utilities/stack_file_system.dart';
|
||||||
|
@ -21,6 +24,9 @@ mixin FusionWalletInterface {
|
||||||
late final Coin _coin;
|
late final Coin _coin;
|
||||||
late final MainDB _db;
|
late final MainDB _db;
|
||||||
late final FusionTorService _torService;
|
late final FusionTorService _torService;
|
||||||
|
late final Future<String?> _mnemonic;
|
||||||
|
late final Future<String?> _mnemonicPassphrase;
|
||||||
|
late final btcdart.NetworkType _network;
|
||||||
|
|
||||||
// setting values on this should notify any listeners (the GUI)
|
// setting values on this should notify any listeners (the GUI)
|
||||||
FusionProgressUIState? _uiState;
|
FusionProgressUIState? _uiState;
|
||||||
|
@ -61,6 +67,9 @@ mixin FusionWalletInterface {
|
||||||
required String address,
|
required String address,
|
||||||
}) getTxCountForAddress,
|
}) getTxCountForAddress,
|
||||||
required Future<int> Function() getChainHeight,
|
required Future<int> Function() getChainHeight,
|
||||||
|
required Future<String?> mnemonic,
|
||||||
|
required Future<String?> mnemonicPassphrase,
|
||||||
|
required btcdart.NetworkType network,
|
||||||
}) async {
|
}) async {
|
||||||
// Set passed in wallet data.
|
// Set passed in wallet data.
|
||||||
_walletId = walletId;
|
_walletId = walletId;
|
||||||
|
@ -71,6 +80,9 @@ mixin FusionWalletInterface {
|
||||||
_getWalletCachedElectrumX = getWalletCachedElectrumX;
|
_getWalletCachedElectrumX = getWalletCachedElectrumX;
|
||||||
_getTxCountForAddress = getTxCountForAddress;
|
_getTxCountForAddress = getTxCountForAddress;
|
||||||
_getChainHeight = getChainHeight;
|
_getChainHeight = getChainHeight;
|
||||||
|
_mnemonic = mnemonic;
|
||||||
|
_mnemonicPassphrase = mnemonicPassphrase;
|
||||||
|
_network = network;
|
||||||
}
|
}
|
||||||
|
|
||||||
// callback to update the ui state object
|
// callback to update the ui state object
|
||||||
|
@ -112,6 +124,28 @@ mixin FusionWalletInterface {
|
||||||
return await Future.wait(futures);
|
return await Future.wait(futures);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Future<Uint8List> getPrivateKeyForPubKey(List<int> pubKey) async {
|
||||||
|
// can't directly query for equal lists in isar so we need to fetch
|
||||||
|
// all addresses then search in dart
|
||||||
|
try {
|
||||||
|
final derivationPath = (await getFusionAddresses())
|
||||||
|
.firstWhere((e) => e.publicKey.toString() == pubKey.toString())
|
||||||
|
.derivationPath!
|
||||||
|
.value;
|
||||||
|
|
||||||
|
final node = await Bip32Utils.getBip32Node(
|
||||||
|
(await _mnemonic)!,
|
||||||
|
(await _mnemonicPassphrase)!,
|
||||||
|
_network,
|
||||||
|
derivationPath,
|
||||||
|
);
|
||||||
|
|
||||||
|
return node.privateKey!;
|
||||||
|
} catch (_) {
|
||||||
|
throw Exception("Derivation path for pubkey=$pubKey could not be found");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/// Returns a list of all UTXOs in the wallet for the given address.
|
/// Returns a list of all UTXOs in the wallet for the given address.
|
||||||
Future<List<fusion.UtxoDTO>> getInputsByAddress(String address) async {
|
Future<List<fusion.UtxoDTO>> getInputsByAddress(String address) async {
|
||||||
final _utxos = await _db.getUTXOsByAddress(_walletId, address).findAll();
|
final _utxos = await _db.getUTXOsByAddress(_walletId, address).findAll();
|
||||||
|
@ -251,6 +285,7 @@ mixin FusionWalletInterface {
|
||||||
coin: _coin,
|
coin: _coin,
|
||||||
txHash: txid,
|
txHash: txid,
|
||||||
),
|
),
|
||||||
|
getPrivateKeyForPubKey: getPrivateKeyForPubKey,
|
||||||
);
|
);
|
||||||
|
|
||||||
// Add stack UTXOs.
|
// Add stack UTXOs.
|
||||||
|
|
Loading…
Reference in a new issue