Merge pull request #639 from detherminal/add-xtz

xtz: update api and add price
This commit is contained in:
Rylee Davis 2023-07-28 08:45:24 -06:00 committed by GitHub
commit 78be92110d
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 45 additions and 44 deletions

View file

@ -306,30 +306,32 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
} }
Future<void> updateTransactions() async { Future<void> updateTransactions() async {
var api = "https://api.mainnet.tzkt.io/v1/accounts/${await currentReceivingAddress}/balance_history"; // TODO: Can we use current node instead of this? // TODO: Use node RPC instead of tzstats API
var returnedTxs = await get(Uri.parse(api)).then((value) => value.body); var api = "https://api.tzstats.com/tables/op?address=${await currentReceivingAddress}";
Logging.instance.log( var jsonResponse = jsonDecode(await get(Uri.parse(api)).then((value) => value.body));
"Transactions for ${await currentReceivingAddress}: $returnedTxs",
level: LogLevel.Info);
List<Tuple2<Transaction, Address>> txs = []; List<Tuple2<Transaction, Address>> txs = [];
Object? jsonTxs = jsonDecode(returnedTxs); for (var tx in jsonResponse as List) {
if (jsonTxs == null) { var txApi = "https://api.tzstats.com/explorer/op/${tx["hash"]}";
await db.addNewTransactionData(txs, walletId); var txJsonResponse = jsonDecode(await get(Uri.parse(txApi)).then((value) => value.body))[0];
TransactionType txType;
if (txJsonResponse["sender"] == (await currentReceivingAddress)) {
txType = TransactionType.outgoing;
} else { } else {
for (var tx in jsonTxs as List) { txType = TransactionType.incoming;
}
var theTx = Transaction( var theTx = Transaction(
walletId: walletId, walletId: walletId,
txid: "", txid: txJsonResponse["hash"].toString(),
timestamp: DateTime.parse(tx["timestamp"].toString()).toUtc().millisecondsSinceEpoch ~/ 1000, timestamp: DateTime.parse(txJsonResponse["time"].toString()).toUtc().millisecondsSinceEpoch ~/ 1000,
type: TransactionType.unknown, type: txType,
subType: TransactionSubType.none, subType: TransactionSubType.none,
amount: int.parse(tx["balance"].toString()), amount: (float.parse(txJsonResponse["volume"].toString()) * 1000000).toInt(),
amountString: Amount( amountString: Amount(
rawValue: BigInt.parse(tx["balance"].toString()), rawValue: BigInt.parse((float.parse(txJsonResponse["volume"].toString()) * 1000000).toString()),
fractionDigits: 6 fractionDigits: 6
).toJsonString(), ).toJsonString(),
fee: 0, fee: (float.parse(txJsonResponse["fee"].toString()) * 1000000).toInt(),
height: int.parse(tx["level"].toString()), height: int.parse(txJsonResponse["height"].toString()),
isCancelled: false, isCancelled: false,
isLelantus: false, isLelantus: false,
slateId: "", slateId: "",
@ -341,7 +343,7 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
); );
var theAddress = Address( var theAddress = Address(
walletId: walletId, walletId: walletId,
value: await currentReceivingAddress, value: txJsonResponse["receiver"].toString(),
publicKey: [], // TODO: Add public key publicKey: [], // TODO: Add public key
derivationIndex: 0, derivationIndex: 0,
derivationPath: null, derivationPath: null,
@ -352,7 +354,6 @@ class TezosWallet extends CoinServiceAPI with WalletCache, WalletDB {
} }
await db.addNewTransactionData(txs, walletId); await db.addNewTransactionData(txs, walletId);
} }
}
Future<void> updateChainHeight() async { Future<void> updateChainHeight() async {
var api = "${getCurrentNode().host}:${getCurrentNode().port}/chains/main/blocks/head/header/shell"; var api = "${getCurrentNode().host}:${getCurrentNode().port}/chains/main/blocks/head/header/shell";

View file

@ -100,7 +100,7 @@ class PriceAPI {
Uri.parse("https://api.coingecko.com/api/v3/coins/markets?vs_currency" Uri.parse("https://api.coingecko.com/api/v3/coins/markets?vs_currency"
"=${baseCurrency.toLowerCase()}" "=${baseCurrency.toLowerCase()}"
"&ids=monero,bitcoin,litecoin,ecash,epic-cash,zcoin,dogecoin," "&ids=monero,bitcoin,litecoin,ecash,epic-cash,zcoin,dogecoin,"
"bitcoin-cash,namecoin,wownero,ethereum,particl,nano,banano" "bitcoin-cash,namecoin,wownero,ethereum,particl,nano,banano,tezos"
"&order=market_cap_desc&per_page=50&page=1&sparkline=false"); "&order=market_cap_desc&per_page=50&page=1&sparkline=false");
final coinGeckoResponse = await client.get( final coinGeckoResponse = await client.get(