mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-05 10:29:23 +00:00
96b9b60f50
* feat: rebase btc-addr-types, migrate to bitcoin_base * feat: allow scanning elect-rs using get_tweaks * feat: scanning and adding addresses working with getTweaks, add btc SP address type * chore: pubspec.lock * chore: pubspec.lock * fix: scan when switching, fix multiple unspents in same tx * fix: initial scan * fix: initial scan * fix: scanning issues * fix: sync, storing silent unspents * chore: deps * fix: label issues, clear spent utxo * chore: deps * fix: build * fix: missing types * feat: new electrs API & changes, fixes for last block scanning * feat: Scan Silent Payments homepage toggle * chore: build configure * feat: generic fixes, testnet UI improvements, useSSL on bitcoin nodes * fix: invalid Object in sendData * feat: improve addresses page & address book displays * feat: silent payments labeled addresses disclaimer * fix: missing i18n * chore: print * feat: single block scan, rescan by date working for btc mainnet * feat: new cake features page replace market page, move sp scan toggle, auto switch node pop up alert * feat: delete silent addresses * fix: red dot in non ssl nodes * fix: inconsistent connection states, fix tx history * fix: tx & balance displays, cpfp sending * feat: new rust lib * chore: node path * fix: check node based on network * fix: missing txcount from addresses * style: padding in feature page cards * fix: restore not getting all wallet addresses by type * fix: auto switch node broken * fix: silent payment txs not being restored * feat: change scanning to subscription model, sync improvements * fix: scan re-subscription * fix: default nodes * fix: improve scanning by date, fix single block scan * refactor: common function for input tx selection * fix: nodes & build * fix: send all with multiple outs * refactor: unchanged file * Update pr_test_build.yml * chore: upgrade * chore: merge changes * refactor: unchanged files [skip ci] * fix: scan fixes, add date, allow sending while scanning * feat: sync fixes, sp settings * feat: fix resyncing * fix: date from height logic, status disconnected & chain tip get * fix: params * feat: electrum migration if using cake electrum * fix nodes update versions * re-enable tron * update sp_scanner to work on iOS [skip ci] * fix: wrong socket for old electrum nodes * Fix unchecked wallet type call * fix: double balance * feat: node domain * fix: menu name * fix: update tip on set scanning * fix: connection switching back and forth * feat: check if node is electrs, and supports sp * chore: fix build * minor enhancements * fixes and enhancements * solve conflicts with main * fix: status toggle * minor enhancement * Monero.com fixes * update sp_scanner to include windows and linux --------- Co-authored-by: Omar Hatem <omarh.ismail1@gmail.com>
86 lines
2.7 KiB
Dart
86 lines
2.7 KiB
Dart
import 'dart:convert';
|
|
|
|
import 'package:cw_bitcoin/electrum_transaction_info.dart';
|
|
import 'package:cw_core/pathForWallet.dart';
|
|
import 'package:cw_core/transaction_history.dart';
|
|
import 'package:cw_core/utils/file.dart';
|
|
import 'package:cw_core/wallet_info.dart';
|
|
import 'package:mobx/mobx.dart';
|
|
|
|
part 'electrum_transaction_history.g.dart';
|
|
|
|
const transactionsHistoryFileName = 'transactions.json';
|
|
|
|
class ElectrumTransactionHistory = ElectrumTransactionHistoryBase with _$ElectrumTransactionHistory;
|
|
|
|
abstract class ElectrumTransactionHistoryBase
|
|
extends TransactionHistoryBase<ElectrumTransactionInfo> with Store {
|
|
ElectrumTransactionHistoryBase({required this.walletInfo, required String password})
|
|
: _password = password,
|
|
_height = 0 {
|
|
transactions = ObservableMap<String, ElectrumTransactionInfo>();
|
|
}
|
|
|
|
final WalletInfo walletInfo;
|
|
String _password;
|
|
int _height;
|
|
|
|
Future<void> init() async => await _load();
|
|
|
|
@override
|
|
void addOne(ElectrumTransactionInfo transaction) => transactions[transaction.id] = transaction;
|
|
|
|
@override
|
|
void addMany(Map<String, ElectrumTransactionInfo> transactions) =>
|
|
transactions.forEach((_, tx) => _update(tx));
|
|
|
|
@override
|
|
Future<void> save() async {
|
|
try {
|
|
final dirPath = await pathForWalletDir(name: walletInfo.name, type: walletInfo.type);
|
|
final path = '$dirPath/$transactionsHistoryFileName';
|
|
final txjson = {};
|
|
for (final tx in transactions.entries) {
|
|
txjson[tx.key] = tx.value.toJson();
|
|
}
|
|
final data = json.encode({'height': _height, 'transactions': txjson});
|
|
await writeData(path: path, password: _password, data: data);
|
|
} catch (e) {
|
|
print('Error while save bitcoin transaction history: ${e.toString()}');
|
|
}
|
|
}
|
|
|
|
Future<void> changePassword(String password) async {
|
|
_password = password;
|
|
await save();
|
|
}
|
|
|
|
Future<Map<String, dynamic>> _read() async {
|
|
final dirPath = await pathForWalletDir(name: walletInfo.name, type: walletInfo.type);
|
|
final path = '$dirPath/$transactionsHistoryFileName';
|
|
final content = await read(path: path, password: _password);
|
|
return json.decode(content) as Map<String, dynamic>;
|
|
}
|
|
|
|
Future<void> _load() async {
|
|
try {
|
|
final content = await _read();
|
|
final txs = content['transactions'] as Map<String, dynamic>? ?? {};
|
|
|
|
txs.entries.forEach((entry) {
|
|
final val = entry.value;
|
|
|
|
if (val is Map<String, dynamic>) {
|
|
final tx = ElectrumTransactionInfo.fromJson(val, walletInfo.type);
|
|
_update(tx);
|
|
}
|
|
});
|
|
|
|
_height = content['height'] as int;
|
|
} catch (e) {
|
|
print(e);
|
|
}
|
|
}
|
|
|
|
void _update(ElectrumTransactionInfo transaction) => transactions[transaction.id] = transaction;
|
|
}
|