Merge pull request #845 from detherminal/testing

fix deprecated fee func and null fees.
This commit is contained in:
julian-CStack 2024-04-29 10:56:42 -06:00 committed by GitHub
commit 3331ab2180
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -1,9 +1,11 @@
import 'dart:convert';
import 'dart:io'; import 'dart:io';
import 'dart:math'; import 'dart:math';
import 'package:isar/isar.dart'; import 'package:isar/isar.dart';
import 'package:socks5_proxy/socks_client.dart'; import 'package:socks5_proxy/socks_client.dart';
import 'package:solana/dto.dart'; import 'package:solana/dto.dart';
import 'package:solana/encoder.dart';
import 'package:solana/solana.dart'; import 'package:solana/solana.dart';
import 'package:stackwallet/models/balance.dart'; import 'package:stackwallet/models/balance.dart';
import 'package:stackwallet/models/isar/models/blockchain_data/transaction.dart' import 'package:stackwallet/models/isar/models/blockchain_data/transaction.dart'
@ -53,6 +55,21 @@ class SolanaWallet extends Bip39Wallet<Solana> {
final balance = await _rpcClient?.getBalance((await _getKeyPair()).address); final balance = await _rpcClient?.getBalance((await _getKeyPair()).address);
return balance!.value; return balance!.value;
} }
Future<int?> _getEstimatedNetworkFee(Amount transferAmount) async {
final latestBlockhash = await _rpcClient?.getLatestBlockhash();
final compiledMessage = Message(instructions: [
SystemInstruction.transfer(
fundingAccount: (await _getKeyPair()).publicKey,
recipientAccount: (await _getKeyPair()).publicKey,
lamports: transferAmount.raw.toInt()),
]).compile(recentBlockhash: latestBlockhash!.value.blockhash, feePayer: (await _getKeyPair()).publicKey);
return await _rpcClient?.getFeeForMessage(
base64Encode(compiledMessage.toByteArray().toList()),
);
}
@override @override
FilterOperation? get changeAddressFilterOperation => FilterOperation? get changeAddressFilterOperation =>
@ -184,12 +201,14 @@ class SolanaWallet extends Bip39Wallet<Solana> {
fractionDigits: cryptoCurrency.fractionDigits, fractionDigits: cryptoCurrency.fractionDigits,
); );
} }
final fee = await _rpcClient?.getFees(); final fee = await _getEstimatedNetworkFee(amount);
// TODO [prio=low]: handle null fee. if (fee == null) {
throw Exception("Failed to get fees, please check your node connection.");
}
return Amount( return Amount(
rawValue: BigInt.from(fee!.value.feeCalculator.lamportsPerSignature), rawValue: BigInt.from(fee as num),
fractionDigits: cryptoCurrency.fractionDigits, fractionDigits: cryptoCurrency.fractionDigits,
); );
} }
@ -197,16 +216,22 @@ class SolanaWallet extends Bip39Wallet<Solana> {
@override @override
Future<FeeObject> get fees async { Future<FeeObject> get fees async {
_checkClient(); _checkClient();
final fees = await _rpcClient?.getFees(); final fee = await _getEstimatedNetworkFee(Amount(
// TODO [prio=low]: handle null fees. rawValue: BigInt.from(1000000000), // 1 SOL
fractionDigits: cryptoCurrency.fractionDigits,
));
if (fee == null) {
throw Exception("Failed to get fees, please check your node connection.");
}
return FeeObject( return FeeObject(
numberOfBlocksFast: 1, numberOfBlocksFast: 1,
numberOfBlocksAverage: 1, numberOfBlocksAverage: 1,
numberOfBlocksSlow: 1, numberOfBlocksSlow: 1,
fast: fees!.value.feeCalculator.lamportsPerSignature, fast: fee,
medium: fees!.value.feeCalculator.lamportsPerSignature, medium: fee,
slow: fees!.value.feeCalculator.lamportsPerSignature); slow: fee);
} }
@override @override