mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-22 18:44:31 +00:00
add receiving address derivation to secure storage
This commit is contained in:
parent
9cc0d74b16
commit
9b74f52ce9
2 changed files with 64 additions and 10 deletions
|
@ -1118,6 +1118,8 @@ class DogecoinWallet extends CoinServiceAPI
|
||||||
fetchBuildTxData: fetchBuildTxData,
|
fetchBuildTxData: fetchBuildTxData,
|
||||||
refresh: refresh,
|
refresh: refresh,
|
||||||
checkChangeAddressForTransactions: checkChangeAddressForTransactions,
|
checkChangeAddressForTransactions: checkChangeAddressForTransactions,
|
||||||
|
addDerivation: addDerivation,
|
||||||
|
addDerivations: addDerivations,
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -54,6 +54,18 @@ mixin PaynymWalletInterface {
|
||||||
) _fetchBuildTxData;
|
) _fetchBuildTxData;
|
||||||
late final Future<void> Function() _refresh;
|
late final Future<void> Function() _refresh;
|
||||||
late final Future<void> Function() _checkChangeAddressForTransactions;
|
late final Future<void> Function() _checkChangeAddressForTransactions;
|
||||||
|
late final Future<void> Function({
|
||||||
|
required int chain,
|
||||||
|
required String address,
|
||||||
|
required String pubKey,
|
||||||
|
required String wif,
|
||||||
|
required DerivePathType derivePathType,
|
||||||
|
}) _addDerivation;
|
||||||
|
late final Future<void> Function({
|
||||||
|
required int chain,
|
||||||
|
required DerivePathType derivePathType,
|
||||||
|
required Map<String, dynamic> derivationsToAdd,
|
||||||
|
}) _addDerivations;
|
||||||
|
|
||||||
// initializer
|
// initializer
|
||||||
void initPaynymWalletInterface({
|
void initPaynymWalletInterface({
|
||||||
|
@ -87,6 +99,20 @@ mixin PaynymWalletInterface {
|
||||||
fetchBuildTxData,
|
fetchBuildTxData,
|
||||||
required Future<void> Function() refresh,
|
required Future<void> Function() refresh,
|
||||||
required Future<void> Function() checkChangeAddressForTransactions,
|
required Future<void> Function() checkChangeAddressForTransactions,
|
||||||
|
required Future<void> Function({
|
||||||
|
required int chain,
|
||||||
|
required String address,
|
||||||
|
required String pubKey,
|
||||||
|
required String wif,
|
||||||
|
required DerivePathType derivePathType,
|
||||||
|
})
|
||||||
|
addDerivation,
|
||||||
|
required Future<void> Function({
|
||||||
|
required int chain,
|
||||||
|
required DerivePathType derivePathType,
|
||||||
|
required Map<String, dynamic> derivationsToAdd,
|
||||||
|
})
|
||||||
|
addDerivations,
|
||||||
}) {
|
}) {
|
||||||
_walletId = walletId;
|
_walletId = walletId;
|
||||||
_walletName = walletName;
|
_walletName = walletName;
|
||||||
|
@ -103,6 +129,8 @@ mixin PaynymWalletInterface {
|
||||||
_fetchBuildTxData = fetchBuildTxData;
|
_fetchBuildTxData = fetchBuildTxData;
|
||||||
_refresh = refresh;
|
_refresh = refresh;
|
||||||
_checkChangeAddressForTransactions = checkChangeAddressForTransactions;
|
_checkChangeAddressForTransactions = checkChangeAddressForTransactions;
|
||||||
|
_addDerivation = addDerivation;
|
||||||
|
_addDerivations = addDerivations;
|
||||||
}
|
}
|
||||||
|
|
||||||
// convenience getter
|
// convenience getter
|
||||||
|
@ -140,7 +168,7 @@ mixin PaynymWalletInterface {
|
||||||
index,
|
index,
|
||||||
);
|
);
|
||||||
final pair = paymentAddress.getReceiveAddressKeyPair();
|
final pair = paymentAddress.getReceiveAddressKeyPair();
|
||||||
final address = generatePaynymReceivingAddressFromKeyPair(
|
final address = await generatePaynymReceivingAddressFromKeyPair(
|
||||||
pair: pair,
|
pair: pair,
|
||||||
derivationIndex: index,
|
derivationIndex: index,
|
||||||
derivePathType: DerivePathType.bip44,
|
derivePathType: DerivePathType.bip44,
|
||||||
|
@ -704,7 +732,7 @@ mixin PaynymWalletInterface {
|
||||||
i, // index to use
|
i, // index to use
|
||||||
);
|
);
|
||||||
|
|
||||||
if (receivingGapCounter < maxUnusedAddressGap) {
|
if (outgoingGapCounter < maxUnusedAddressGap) {
|
||||||
final pair = paymentAddress.getSendAddressKeyPair();
|
final pair = paymentAddress.getSendAddressKeyPair();
|
||||||
final address = generatePaynymSendAddressFromKeyPair(
|
final address = generatePaynymSendAddressFromKeyPair(
|
||||||
pair: pair,
|
pair: pair,
|
||||||
|
@ -717,15 +745,15 @@ mixin PaynymWalletInterface {
|
||||||
final count = await _getTxCount(address: address.value);
|
final count = await _getTxCount(address: address.value);
|
||||||
|
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
receivingGapCounter++;
|
outgoingGapCounter++;
|
||||||
} else {
|
} else {
|
||||||
receivingGapCounter = 0;
|
outgoingGapCounter = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (outgoingGapCounter < maxUnusedAddressGap) {
|
if (receivingGapCounter < maxUnusedAddressGap) {
|
||||||
final pair = paymentAddress.getReceiveAddressKeyPair();
|
final pair = paymentAddress.getReceiveAddressKeyPair();
|
||||||
final address = generatePaynymReceivingAddressFromKeyPair(
|
final address = await generatePaynymReceivingAddressFromKeyPair(
|
||||||
pair: pair,
|
pair: pair,
|
||||||
derivationIndex: i,
|
derivationIndex: i,
|
||||||
derivePathType: DerivePathType.bip44,
|
derivePathType: DerivePathType.bip44,
|
||||||
|
@ -736,9 +764,9 @@ mixin PaynymWalletInterface {
|
||||||
final count = await _getTxCount(address: address.value);
|
final count = await _getTxCount(address: address.value);
|
||||||
|
|
||||||
if (count > 0) {
|
if (count > 0) {
|
||||||
outgoingGapCounter++;
|
receivingGapCounter++;
|
||||||
} else {
|
} else {
|
||||||
outgoingGapCounter = 0;
|
receivingGapCounter = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -803,12 +831,12 @@ mixin PaynymWalletInterface {
|
||||||
return address;
|
return address;
|
||||||
}
|
}
|
||||||
|
|
||||||
Address generatePaynymReceivingAddressFromKeyPair({
|
Future<Address> generatePaynymReceivingAddressFromKeyPair({
|
||||||
required btc_dart.ECPair pair,
|
required btc_dart.ECPair pair,
|
||||||
required int derivationIndex,
|
required int derivationIndex,
|
||||||
required DerivePathType derivePathType,
|
required DerivePathType derivePathType,
|
||||||
required PaymentCode fromPaymentCode,
|
required PaymentCode fromPaymentCode,
|
||||||
}) {
|
}) async {
|
||||||
final data = btc_dart.PaymentData(pubkey: pair.publicKey);
|
final data = btc_dart.PaymentData(pubkey: pair.publicKey);
|
||||||
|
|
||||||
String addressString;
|
String addressString;
|
||||||
|
@ -867,6 +895,30 @@ mixin PaynymWalletInterface {
|
||||||
otherData: fromPaymentCode.toString(),
|
otherData: fromPaymentCode.toString(),
|
||||||
);
|
);
|
||||||
|
|
||||||
|
final myCode = await getPaymentCode(DerivePathType.bip44);
|
||||||
|
|
||||||
|
final bip32NetworkType = bip32.NetworkType(
|
||||||
|
wif: _network.wif,
|
||||||
|
bip32: bip32.Bip32Type(
|
||||||
|
public: _network.bip32.public,
|
||||||
|
private: _network.bip32.private,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
|
||||||
|
final bip32.BIP32 node = bip32.BIP32.fromPrivateKey(
|
||||||
|
pair.privateKey!,
|
||||||
|
myCode.getChain(),
|
||||||
|
bip32NetworkType,
|
||||||
|
);
|
||||||
|
|
||||||
|
await _addDerivation(
|
||||||
|
chain: 0,
|
||||||
|
address: address.value,
|
||||||
|
derivePathType: DerivePathType.bip44,
|
||||||
|
pubKey: Format.uint8listToString(node.publicKey),
|
||||||
|
wif: node.toWIF(),
|
||||||
|
);
|
||||||
|
|
||||||
return address;
|
return address;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue