particl isar tx parse fixes

This commit is contained in:
julian 2023-01-17 16:11:04 -06:00
parent 957b4cba9b
commit ef9205a0a9

View file

@ -1994,11 +1994,11 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
); );
if (!_duplicateTxCheck(allTransactions, tx["txid"] as String)) { if (!_duplicateTxCheck(allTransactions, tx["txid"] as String)) {
tx["address"] = await db tx["address"] = (await db
.getAddresses(walletId) .getAddresses(walletId)
.filter() .filter()
.valueEqualTo(txHash["address"] as String) .valueEqualTo(txHash["address"] as String)
.findFirst(); .findFirst())!;
tx["height"] = txHash["height"]; tx["height"] = txHash["height"];
allTransactions.add(tx); allTransactions.add(tx);
} }
@ -2053,7 +2053,8 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
for (final out in tx["vout"] as List) { for (final out in tx["vout"] as List) {
if (prevOut == out["n"]) { if (prevOut == out["n"]) {
final address = out["scriptPubKey"]["addresses"][0] as String?; final address = out["scriptPubKey"]?["address"] as String? ??
out["scriptPubKey"]?["addresses"]?[0] as String?;
if (address != null) { if (address != null) {
sendersArray.add(address); sendersArray.add(address);
} }
@ -2067,7 +2068,8 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
// Particl has different tx types that need to be detected and handled here // Particl has different tx types that need to be detected and handled here
if (output.containsKey('scriptPubKey') as bool) { if (output.containsKey('scriptPubKey') as bool) {
// Logging.instance.log("output is transparent", level: LogLevel.Info); // Logging.instance.log("output is transparent", level: LogLevel.Info);
final address = output["scriptPubKey"]["addresses"][0] as String?; final address = output["scriptPubKey"]?["address"] as String? ??
output["scriptPubKey"]?["addresses"]?[0] as String?;
if (address != null) { if (address != null) {
recipientsArray.add(address); recipientsArray.add(address);
} }
@ -2137,10 +2139,18 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
} else { } else {
// change address from 'sent from' to the 'sent to' address // change address from 'sent from' to the 'sent to' address
txObject["address"] = await db txObject["address"] = await db
.getAddresses(walletId) .getAddresses(walletId)
.filter() .filter()
.valueEqualTo(address) .valueEqualTo(address)
.findFirst(); .findFirst() ??
isar_models.Address(
walletId: walletId,
type: isar_models.AddressType.nonWallet,
subType: isar_models.AddressSubType.nonWallet,
value: address,
publicKey: [],
derivationIndex: -1,
);
} }
} catch (s) { } catch (s) {
Logging.instance.log(s.toString(), level: LogLevel.Warning); Logging.instance.log(s.toString(), level: LogLevel.Warning);
@ -2186,14 +2196,15 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
// add up received tx value // add up received tx value
for (final output in txObject["vout"] as List) { for (final output in txObject["vout"] as List) {
try { try {
final address = output["scriptPubKey"]["addresses"][0]; final address = output["scriptPubKey"]?["address"] as String? ??
output["scriptPubKey"]?["addresses"]?[0] as String?;
if (address != null) { if (address != null) {
final value = (Decimal.parse(output["value"].toString()) * final value = (Decimal.parse((output["value"] ?? 0).toString()) *
Decimal.fromInt(Constants.satsPerCoin(coin))) Decimal.fromInt(Constants.satsPerCoin(coin)))
.toBigInt() .toBigInt()
.toInt(); .toInt();
totalOut += value; totalOut += value;
if (allAddresses.contains(address)) { if (allAddresses.where((e) => e.value == address).isNotEmpty) {
outputAmtAddressedToWallet += value; outputAmtAddressedToWallet += value;
} }
} }
@ -2214,7 +2225,7 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
for (final out in tx["vout"] as List) { for (final out in tx["vout"] as List) {
if (prevOut == out["n"]) { if (prevOut == out["n"]) {
totalIn += (Decimal.parse(out["value"].toString()) * totalIn += (Decimal.parse((out["value"] ?? 0).toString()) *
Decimal.fromInt(Constants.satsPerCoin(coin))) Decimal.fromInt(Constants.satsPerCoin(coin)))
.toBigInt() .toBigInt()
.toInt(); .toInt();
@ -2260,13 +2271,13 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
otherData: null, otherData: null,
); );
isar_models.Address? transactionAddress = isar_models.Address transactionAddress =
midSortedTx["address"] as isar_models.Address?; midSortedTx["address"] as isar_models.Address;
List<isar_models.Input> inputs = []; List<isar_models.Input> inputs = [];
List<isar_models.Output> outputs = []; List<isar_models.Output> outputs = [];
for (final json in midSortedTx["vin"] as List) { for (final json in txObject["vin"] as List) {
bool isCoinBase = json['coinbase'] != null; bool isCoinBase = json['coinbase'] != null;
final input = isar_models.Input( final input = isar_models.Input(
walletId: walletId, walletId: walletId,
@ -2281,7 +2292,7 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
inputs.add(input); inputs.add(input);
} }
for (final json in midSortedTx["vout"] as List) { for (final json in txObject["vout"] as List) {
final output = isar_models.Output( final output = isar_models.Output(
walletId: walletId, walletId: walletId,
scriptPubKey: json['scriptPubKey']?['hex'] as String?, scriptPubKey: json['scriptPubKey']?['hex'] as String?,
@ -2289,10 +2300,10 @@ class ParticlWallet extends CoinServiceAPI with WalletCache, WalletDB {
scriptPubKeyType: json['scriptPubKey']?['type'] as String?, scriptPubKeyType: json['scriptPubKey']?['type'] as String?,
scriptPubKeyAddress: scriptPubKeyAddress:
json["scriptPubKey"]?["addresses"]?[0] as String? ?? json["scriptPubKey"]?["addresses"]?[0] as String? ??
json['scriptPubKey']['type'] as String? ?? json['scriptPubKey']?['type'] as String? ??
"", "",
value: Format.decimalAmountToSatoshis( value: Format.decimalAmountToSatoshis(
Decimal.parse(json["value"].toString()), Decimal.parse((json["value"] ?? 0).toString()),
coin, coin,
), ),
); );