mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-01-25 19:55:52 +00:00
xtz: filter other operations
This commit is contained in:
parent
68f3bc8731
commit
f4688bd041
1 changed files with 51 additions and 50 deletions
|
@ -332,40 +332,36 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
|
|||
|
||||
Future<void> updateTransactions() async {
|
||||
// TODO: Use node RPC instead of tzstats API
|
||||
var api =
|
||||
"https://api.tzstats.com/tables/op?address=${await currentReceivingAddress}";
|
||||
var jsonResponse =
|
||||
jsonDecode(await get(Uri.parse(api)).then((value) => value.body));
|
||||
var api = "https://api.tzstats.com/tables/op?address=${await currentReceivingAddress}";
|
||||
var jsonResponse = jsonDecode(await get(Uri.parse(api)).then((value) => value.body));
|
||||
List<Tuple2<Transaction, Address>> txs = [];
|
||||
for (var tx in jsonResponse as List) {
|
||||
var txApi = "https://api.tzstats.com/explorer/op/${tx["hash"]}";
|
||||
var txJsonResponse = jsonDecode(
|
||||
await get(Uri.parse(txApi)).then((value) => value.body))[0];
|
||||
if (tx[1] == "transaction") {
|
||||
var txApi = "https://api.tzstats.com/explorer/op/${tx[2]}";
|
||||
var txJsonResponse = jsonDecode(await get(Uri.parse(txApi)).then((value) => value.body));
|
||||
// Check if list is larger than 1 (if it is, it's a batch transaction)
|
||||
if (!((txJsonResponse as List).length > 1)) {
|
||||
for (var (opJson as Map) in txJsonResponse) {
|
||||
if (opJson.containsKey("volume")) { // This is to check if transaction is a token transfer
|
||||
TransactionType txType;
|
||||
if (txJsonResponse["sender"] == (await currentReceivingAddress)) {
|
||||
if (opJson["sender"] == (await currentReceivingAddress)) {
|
||||
txType = TransactionType.outgoing;
|
||||
} else {
|
||||
txType = TransactionType.incoming;
|
||||
}
|
||||
var theTx = Transaction(
|
||||
walletId: walletId,
|
||||
txid: txJsonResponse["hash"].toString(),
|
||||
timestamp: DateTime.parse(txJsonResponse["time"].toString())
|
||||
.toUtc()
|
||||
.millisecondsSinceEpoch ~/
|
||||
1000,
|
||||
txid: opJson["hash"].toString(),
|
||||
timestamp: DateTime.parse(opJson["time"].toString()).toUtc().millisecondsSinceEpoch ~/ 1000,
|
||||
type: txType,
|
||||
subType: TransactionSubType.none,
|
||||
amount: (float.parse(txJsonResponse["volume"].toString()) * 1000000)
|
||||
.toInt(),
|
||||
amount: (float.parse(opJson["volume"].toString()) * 1000000).toInt(),
|
||||
amountString: Amount(
|
||||
rawValue: BigInt.parse(
|
||||
(float.parse(txJsonResponse["volume"].toString()) * 1000000)
|
||||
.toString()),
|
||||
fractionDigits: 6)
|
||||
.toJsonString(),
|
||||
fee: (float.parse(txJsonResponse["fee"].toString()) * 1000000).toInt(),
|
||||
height: int.parse(txJsonResponse["height"].toString()),
|
||||
rawValue: BigInt.parse((float.parse(opJson["volume"].toString()) * 1000000).toInt().toString()),
|
||||
fractionDigits: 6
|
||||
).toJsonString(),
|
||||
fee: (float.parse(opJson["fee"].toString()) * 1000000).toInt(),
|
||||
height: int.parse(opJson["height"].toString()),
|
||||
isCancelled: false,
|
||||
isLelantus: false,
|
||||
slateId: "",
|
||||
|
@ -377,7 +373,7 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
|
|||
);
|
||||
var theAddress = Address(
|
||||
walletId: walletId,
|
||||
value: txJsonResponse["receiver"].toString(),
|
||||
value: opJson["receiver"].toString(),
|
||||
publicKey: [], // TODO: Add public key
|
||||
derivationIndex: 0,
|
||||
derivationPath: null,
|
||||
|
@ -386,6 +382,11 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
|
|||
);
|
||||
txs.add(Tuple2(theTx, theAddress));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
Logging.instance.log("Transactions: $txs", level: LogLevel.Info);
|
||||
await db.addNewTransactionData(txs, walletId);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue