mirror of
https://github.com/cypherstack/stack_wallet.git
synced 2025-04-17 19:51:58 +00:00
rebase cleanup + xelis bug fixes
This commit is contained in:
parent
0d20cb6b3b
commit
0f7e44fadd
8 changed files with 168 additions and 382 deletions
lib
pages/add_wallet_views/new_wallet_recovery_phrase_warning_view
utilities
wallets
scripts/app_config
|
@ -40,7 +40,6 @@ import '../../../widgets/desktop/desktop_scaffold.dart';
|
|||
import '../../../widgets/rounded_container.dart';
|
||||
import '../../../widgets/rounded_white_container.dart';
|
||||
import '../../../widgets/stack_dialog.dart';
|
||||
import '../../../widgets/xelis_table_progress.dart';
|
||||
import '../new_wallet_options/new_wallet_options_view.dart';
|
||||
import '../new_wallet_recovery_phrase_view/new_wallet_recovery_phrase_view.dart';
|
||||
import 'recovery_phrase_explanation_dialog.dart';
|
||||
|
@ -104,233 +103,6 @@ class _NewWalletRecoveryPhraseWarningViewState
|
|||
);
|
||||
}
|
||||
}
|
||||
|
||||
// () async {
|
||||
// try {
|
||||
// unawaited(
|
||||
// showDialog<dynamic>(
|
||||
// context: context,
|
||||
// barrierDismissible: false,
|
||||
// useSafeArea: true,
|
||||
// builder: (ctx) {
|
||||
// return Center(
|
||||
// child: Column(
|
||||
// mainAxisSize: MainAxisSize.min,
|
||||
// children: [
|
||||
// const LoadingIndicator(
|
||||
// width: 50,
|
||||
// height: 50,
|
||||
// ),
|
||||
// if (widget.coin is Xelis) ...[
|
||||
// const SizedBox(height: 16),
|
||||
// const XelisTableProgress(),
|
||||
// ],
|
||||
// ],
|
||||
// ),
|
||||
// );
|
||||
// },
|
||||
// ),
|
||||
// );
|
||||
// String? otherDataJsonString;
|
||||
// if (widget.coin is Tezos) {
|
||||
// otherDataJsonString = jsonEncode({
|
||||
// WalletInfoKeys
|
||||
// .tezosDerivationPath:
|
||||
// Tezos.standardDerivationPath
|
||||
// .value,
|
||||
// });
|
||||
// // }//todo: probably not needed (broken anyways)
|
||||
// // else if (widget.coin is Epiccash) {
|
||||
// // final int secondsSinceEpoch =
|
||||
// // DateTime.now().millisecondsSinceEpoch ~/ 1000;
|
||||
// // const int epicCashFirstBlock = 1565370278;
|
||||
// // const double overestimateSecondsPerBlock = 61;
|
||||
// // int chosenSeconds = secondsSinceEpoch - epicCashFirstBlock;
|
||||
// // int approximateHeight = chosenSeconds ~/ overestimateSecondsPerBlock;
|
||||
// // /
|
||||
// // // debugPrint(
|
||||
// // // "approximate height: $approximateHeight chosen_seconds: $chosenSeconds");
|
||||
// // height = approximateHeight;
|
||||
// // if (height < 0) {
|
||||
// // height = 0;
|
||||
// // }
|
||||
// //
|
||||
// // otherDataJsonString = jsonEncode(
|
||||
// // {
|
||||
// // WalletInfoKeys.epiccashData: jsonEncode(
|
||||
// // ExtraEpiccashWalletInfo(
|
||||
// // receivingIndex: 0,
|
||||
// // changeIndex: 0,
|
||||
// // slatesToAddresses: {},
|
||||
// // slatesToCommits: {},
|
||||
// // lastScannedBlock: epicCashFirstBlock,
|
||||
// // restoreHeight: height,
|
||||
// // creationHeight: height,
|
||||
// // ).toMap(),
|
||||
// // ),
|
||||
// // },
|
||||
// // );
|
||||
// } else if (widget.coin is Firo) {
|
||||
// otherDataJsonString = jsonEncode(
|
||||
// {
|
||||
// WalletInfoKeys
|
||||
// .lelantusCoinIsarRescanRequired:
|
||||
// false,
|
||||
// },
|
||||
// );
|
||||
// }
|
||||
|
||||
// final info = WalletInfo.createNew(
|
||||
// coin: widget.coin,
|
||||
// name: widget.walletName,
|
||||
// otherDataJsonString:
|
||||
// otherDataJsonString,
|
||||
// );
|
||||
|
||||
// var node = ref
|
||||
// .read(
|
||||
// nodeServiceChangeNotifierProvider,
|
||||
// )
|
||||
// .getPrimaryNodeFor(
|
||||
// currency: coin,
|
||||
// );
|
||||
|
||||
// if (node == null) {
|
||||
// node = coin.defaultNode;
|
||||
// await ref
|
||||
// .read(
|
||||
// nodeServiceChangeNotifierProvider,
|
||||
// )
|
||||
// .setPrimaryNodeFor(
|
||||
// coin: coin,
|
||||
// node: node,
|
||||
// );
|
||||
// }
|
||||
|
||||
// final txTracker =
|
||||
// TransactionNotificationTracker(
|
||||
// walletId: info.walletId,
|
||||
// );
|
||||
|
||||
// int? wordCount;
|
||||
// String? mnemonicPassphrase;
|
||||
// String? mnemonic;
|
||||
// String? privateKey;
|
||||
|
||||
// wordCount = info
|
||||
// .coin.defaultSeedPhraseLength;
|
||||
|
||||
// // TODO: Refactor these to generate each coin in their respective classes
|
||||
// // This code should not be in a random view page file
|
||||
// if (coin is Monero ||
|
||||
// coin is Wownero ||
|
||||
// coin is Xelis) {
|
||||
// // currently a special case due to the
|
||||
// // xmr/wow/xelis libraries handling their
|
||||
// // own mnemonic generation
|
||||
// } else if (wordCount > 0) {
|
||||
// if (ref
|
||||
// .read(
|
||||
// pNewWalletOptions.state,
|
||||
// )
|
||||
// .state !=
|
||||
// null) {
|
||||
// if (coin
|
||||
// .hasMnemonicPassphraseSupport) {
|
||||
// mnemonicPassphrase = ref
|
||||
// .read(
|
||||
// pNewWalletOptions.state,
|
||||
// )
|
||||
// .state!
|
||||
// .mnemonicPassphrase;
|
||||
// } else {
|
||||
// // this may not be epiccash specific?
|
||||
// if (coin is Epiccash) {
|
||||
// mnemonicPassphrase = "";
|
||||
// }
|
||||
// }
|
||||
|
||||
// wordCount = ref
|
||||
// .read(
|
||||
// pNewWalletOptions.state,
|
||||
// )
|
||||
// .state!
|
||||
// .mnemonicWordsCount;
|
||||
// } else {
|
||||
// mnemonicPassphrase = "";
|
||||
// }
|
||||
|
||||
// if (wordCount < 12 ||
|
||||
// 24 < wordCount ||
|
||||
// wordCount % 3 != 0) {
|
||||
// throw Exception(
|
||||
// "Invalid word count",
|
||||
// );
|
||||
// }
|
||||
|
||||
// final strength =
|
||||
// (wordCount ~/ 3) * 32;
|
||||
|
||||
// mnemonic = bip39.generateMnemonic(
|
||||
// strength: strength,
|
||||
// );
|
||||
// }
|
||||
|
||||
// final wallet = await Wallet.create(
|
||||
// walletInfo: info,
|
||||
// mainDB: ref.read(mainDBProvider),
|
||||
// secureStorageInterface:
|
||||
// ref.read(secureStoreProvider),
|
||||
// nodeService: ref.read(
|
||||
// nodeServiceChangeNotifierProvider,
|
||||
// ),
|
||||
// prefs: ref.read(
|
||||
// prefsChangeNotifierProvider,
|
||||
// ),
|
||||
// mnemonicPassphrase:
|
||||
// mnemonicPassphrase,
|
||||
// mnemonic: mnemonic,
|
||||
// privateKey: privateKey,
|
||||
// );
|
||||
|
||||
// await wallet.init();
|
||||
|
||||
// // pop progress dialog
|
||||
// if (context.mounted) {
|
||||
// Navigator.pop(context);
|
||||
// }
|
||||
// // set checkbox back to unchecked to annoy users to agree again :P
|
||||
// ref
|
||||
// .read(
|
||||
// checkBoxStateProvider.state,
|
||||
// )
|
||||
// .state = false;
|
||||
|
||||
// if (context.mounted) {
|
||||
// final nav = Navigator.of(context);
|
||||
// unawaited(
|
||||
// nav.pushNamed(
|
||||
// NewWalletRecoveryPhraseView
|
||||
// .routeName,
|
||||
// arguments: Tuple2(
|
||||
// wallet,
|
||||
// await (wallet
|
||||
// as MnemonicInterface)
|
||||
// .getMnemonicAsWords(),
|
||||
// ),
|
||||
// ),
|
||||
// );
|
||||
// }
|
||||
// } catch (e, s) {
|
||||
// Logging.instance.log(
|
||||
// "$e\n$s",
|
||||
// level: LogLevel.Fatal,
|
||||
// );
|
||||
// // TODO: handle gracefully
|
||||
// // any network/socket exception here will break new wallet creation
|
||||
// rethrow;
|
||||
// }
|
||||
// }
|
||||
}
|
||||
|
||||
Future<(Wallet, List<String>)> _initNewFuture() async {
|
||||
|
@ -419,7 +191,7 @@ class _NewWalletRecoveryPhraseWarningViewState
|
|||
|
||||
// TODO: Refactor these to generate each coin in their respective classes
|
||||
// This code should not be in a random view page file
|
||||
if (coin is Monero || coin is Wownero) {
|
||||
if (coin is Monero || coin is Wownero || coin is Xelis) {
|
||||
// currently a special case due to the
|
||||
// xmr/wow libraries handling their
|
||||
// own mnemonic generation
|
||||
|
|
|
@ -311,9 +311,8 @@ Future<bool> testNodeConnection({
|
|||
final xelis_sdk.GetInfoResult networkInfo = await daemon.getInfo();
|
||||
testPassed = networkInfo.height != null;
|
||||
|
||||
Logging.instance.log(
|
||||
Logging.instance.i(
|
||||
"Xelis testNodeConnection result: \"${networkInfo.toString()}\"",
|
||||
level: LogLevel.Info,
|
||||
);
|
||||
} catch (e, s) {
|
||||
testPassed = false;
|
||||
|
|
|
@ -59,7 +59,7 @@ class Xelis extends ElectrumCurrency {
|
|||
coinName: identifier,
|
||||
isFailover: true,
|
||||
isDown: false,
|
||||
torEnabled: true,
|
||||
torEnabled: false,
|
||||
clearnetEnabled: true,
|
||||
);
|
||||
|
||||
|
@ -74,7 +74,7 @@ class Xelis extends ElectrumCurrency {
|
|||
coinName: identifier,
|
||||
isFailover: true,
|
||||
isDown: false,
|
||||
torEnabled: true,
|
||||
torEnabled: false,
|
||||
clearnetEnabled: true,
|
||||
);
|
||||
|
||||
|
@ -87,7 +87,7 @@ class Xelis extends ElectrumCurrency {
|
|||
int get minConfirms => 1;
|
||||
|
||||
@override
|
||||
bool get torSupport => true;
|
||||
bool get torSupport => false;
|
||||
|
||||
@override
|
||||
bool validateAddress(String address) {
|
||||
|
|
|
@ -139,10 +139,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
try {
|
||||
await open();
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Exception rethrown from recoverFromMnemonic(): $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Exception rethrown from recoverFromMnemonic(): $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -193,10 +193,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
);
|
||||
}
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error in updateBalance(): $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error in updateBalance(): $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
});
|
||||
}
|
||||
|
@ -204,6 +204,8 @@ class XelisWallet extends LibXelisWallet {
|
|||
Future<int> _fetchChainHeight() async {
|
||||
final infoString = await libXelisWallet!.getDaemonInfo();
|
||||
final Map<String, dynamic> nodeInfo = json.decode(infoString);
|
||||
|
||||
pruningHeight = int.parse(nodeInfo['pruned_topoheight'].toString());
|
||||
return int.parse(nodeInfo['topoheight'].toString());
|
||||
}
|
||||
|
||||
|
@ -217,10 +219,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
isar: mainDB.isar,
|
||||
);
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error in updateChainHeight(): $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error in updateChainHeight(): $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -228,15 +230,16 @@ class XelisWallet extends LibXelisWallet {
|
|||
Future<void> updateNode() async {
|
||||
try {
|
||||
final node = getCurrentNode();
|
||||
await libXelisWallet?.offlineMode();
|
||||
await libXelisWallet!.onlineMode(
|
||||
daemonAddress: node.host
|
||||
);
|
||||
final bool online = await libXelisWallet!.isOnline();
|
||||
if (online == true) {
|
||||
await libXelisWallet!.offlineMode();
|
||||
}
|
||||
await super.connect();
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error updating node: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error updating node: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -276,7 +279,7 @@ class XelisWallet extends LibXelisWallet {
|
|||
firstBlock -= 10;
|
||||
}
|
||||
} else {
|
||||
await libXelisWallet!.rescan(topoheight: BigInt.from(topoheight!));
|
||||
await libXelisWallet!.rescan(topoheight: BigInt.from(pruningHeight));
|
||||
}
|
||||
|
||||
final txListJson = rawTransactions ?? await libXelisWallet!.allHistory();
|
||||
|
@ -457,18 +460,18 @@ class XelisWallet extends LibXelisWallet {
|
|||
}),
|
||||
);
|
||||
|
||||
Logging.instance.log(
|
||||
"Entry done ${entryType.toString()}",
|
||||
level: LogLevel.Debug,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Entry done ${entryType.toString()}",
|
||||
// level: LogLevel.Debug,
|
||||
// );
|
||||
|
||||
|
||||
txns.add(txn);
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error handling tx $jsonString: $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error handling tx $jsonString: $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
}
|
||||
await updateBalance();
|
||||
|
@ -574,10 +577,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
}),
|
||||
);
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Exception rethrown from prepareSend(): $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Exception rethrown from prepareSend(): $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -657,10 +660,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
);
|
||||
}
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Exception rethrown from estimateFeeFor(): $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Exception rethrown from estimateFeeFor(): $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -707,10 +710,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
txid: txHash,
|
||||
));
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Exception rethrown from confirmSend(): $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Exception rethrown from confirmSend(): $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -737,10 +740,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
await handleHistorySynced(topoheight);
|
||||
}
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error handling wallet event: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error handling wallet event: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -763,15 +766,15 @@ class XelisWallet extends LibXelisWallet {
|
|||
|
||||
await updateBalance();
|
||||
|
||||
Logging.instance.log(
|
||||
"New transaction processed: ${newTxIds.first}",
|
||||
level: LogLevel.Info,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "New transaction processed: ${newTxIds.first}",
|
||||
// level: LogLevel.Info,
|
||||
// );
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error handling new transaction: $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error handling new transaction: $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -785,10 +788,10 @@ class XelisWallet extends LibXelisWallet {
|
|||
|
||||
// TODO: Update asset balances if needed
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error handling balance change: $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error handling balance change: $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -842,24 +845,35 @@ class XelisWallet extends LibXelisWallet {
|
|||
Future<void> handleNewAsset(xelis_sdk.AssetData asset) async {
|
||||
// TODO: Store asset information if needed
|
||||
// TODO: Update UI/state for new asset
|
||||
Logging.instance.log(
|
||||
"New asset detected: ${asset}",
|
||||
level: LogLevel.Info,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "New asset detected: ${asset}",
|
||||
// level: LogLevel.Info,
|
||||
// );
|
||||
}
|
||||
|
||||
@override
|
||||
Future<void> refresh({int? topoheight}) async {
|
||||
await refreshMutex.protect(() async {
|
||||
try {
|
||||
await updateChainHeight(topoheight: topoheight);
|
||||
await updateBalance();
|
||||
await updateTransactions();
|
||||
final bool online = await libXelisWallet!.isOnline();
|
||||
if (online == true) {
|
||||
await updateChainHeight(topoheight: topoheight);
|
||||
await updateBalance();
|
||||
await updateTransactions();
|
||||
} else {
|
||||
GlobalEventBus.instance.fire(
|
||||
WalletSyncStatusChangedEvent(
|
||||
WalletSyncStatus.unableToSync,
|
||||
walletId,
|
||||
info.coin,
|
||||
),
|
||||
);
|
||||
}
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error in refresh(): $e\n$s",
|
||||
level: LogLevel.Warning,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error in refresh(): $e\n$s",
|
||||
// level: LogLevel.Warning,
|
||||
// );
|
||||
}
|
||||
});
|
||||
}
|
||||
|
|
|
@ -183,6 +183,7 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
static Completer<void>? _tableGenerationCompleter;
|
||||
|
||||
x_wallet.XelisWallet? libXelisWallet;
|
||||
int pruningHeight = 0;
|
||||
|
||||
x_wallet.XelisWallet? get wallet => libXelisWallet;
|
||||
set wallet(x_wallet.XelisWallet? newWallet) {
|
||||
|
@ -273,10 +274,10 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
yield HistorySynced(json['data']['topoheight'] as int);
|
||||
}
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error processing wallet event: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error processing wallet event: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
continue;
|
||||
}
|
||||
}
|
||||
|
@ -300,19 +301,19 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
convertRawEvents().listen(handleEvent);
|
||||
|
||||
final node = getCurrentNode();
|
||||
Logging.instance.log(
|
||||
"Connecting to node: ${node.host}:${node.port}",
|
||||
level: LogLevel.Info,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Connecting to node: ${node.host}:${node.port}",
|
||||
// level: LogLevel.Info,
|
||||
// );
|
||||
await libXelisWallet!.onlineMode(
|
||||
daemonAddress: "${node.host}:${node.port}"
|
||||
);
|
||||
await super.refresh();
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Error connecting to node: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Error connecting to node: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -427,10 +428,10 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
}
|
||||
});
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Failed to open/create wallet: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Failed to open/create wallet: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
});
|
||||
|
@ -465,10 +466,10 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
try {
|
||||
await connect();
|
||||
} catch (e) {
|
||||
Logging.instance.log(
|
||||
"Failed to start sync: $e",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Failed to start sync: $e",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
rethrow;
|
||||
}
|
||||
}
|
||||
|
@ -486,6 +487,7 @@ abstract class LibXelisWallet<T extends ElectrumCurrency> extends ExternalWallet
|
|||
_eventSubscription = null;
|
||||
|
||||
await libXelisWallet?.offlineMode();
|
||||
await libXelisWallet?.close();
|
||||
libXelisWallet?.dispose();
|
||||
libXelisWallet = null;
|
||||
|
||||
|
@ -554,10 +556,10 @@ extension XelisTableManagement on LibXelisWallet {
|
|||
debugPrint("Table upgrade done");
|
||||
LibXelisWallet._tableGenerationCompleter!.complete();
|
||||
} catch (e, s) {
|
||||
Logging.instance.log(
|
||||
"Failed to update tables: $e\n$s",
|
||||
level: LogLevel.Error,
|
||||
);
|
||||
// Logging.instance.log(
|
||||
// "Failed to update tables: $e\n$s",
|
||||
// level: LogLevel.Error,
|
||||
// );
|
||||
await setTableState(state.copyWith(isGenerating: false));
|
||||
|
||||
LibXelisWallet._tableGenerationCompleter!.completeError(e);
|
||||
|
|
104
pubspec.lock
104
pubspec.lock
|
@ -58,10 +58,10 @@ packages:
|
|||
dependency: "direct main"
|
||||
description:
|
||||
name: async
|
||||
sha256: "947bfcf187f74dbc5e146c9eb9c0f10c9f8b30743e341481c1e2ed3ecc18c20c"
|
||||
sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "2.11.0"
|
||||
version: "2.12.0"
|
||||
barcode_scan2:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -159,10 +159,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: boolean_selector
|
||||
sha256: "6cfb5af12253eaf2b368f07bacc5a80d1301a071c73360d746b7f2e32d762c66"
|
||||
sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "2.1.1"
|
||||
version: "2.1.2"
|
||||
borsh_annotation:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -305,10 +305,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: characters
|
||||
sha256: "04a925763edad70e8443c99234dc3328f442e811f1d8fd1a72f1c8ad0f69a605"
|
||||
sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.3.0"
|
||||
version: "1.4.0"
|
||||
charcode:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -337,10 +337,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: clock
|
||||
sha256: cb6d7f03e1de671e34607e909a7213e31d7752be4fb66a86d29fe1eb14bfb5cf
|
||||
sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.1.1"
|
||||
version: "1.1.2"
|
||||
code_builder:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -371,10 +371,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: collection
|
||||
sha256: a1ace0a119f20aabc852d165077c036cd864315bd99b7eaa10a60100341941bf
|
||||
sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.19.0"
|
||||
version: "1.19.1"
|
||||
compat:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -742,10 +742,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: fake_async
|
||||
sha256: "511392330127add0b769b75a987850d136345d9227c6b94c96a04cf4a391bf78"
|
||||
sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.3.1"
|
||||
version: "1.3.2"
|
||||
ffi:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -758,10 +758,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: file
|
||||
sha256: "5fc22d7c25582e38ad9a8515372cd9a93834027aacf1801cf01164dac0ffa08c"
|
||||
sha256: a3b4f84adafef897088c160faf7dfffb7696046cb13ae90b508c2cbc95d3b8d4
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "7.0.0"
|
||||
version: "7.0.1"
|
||||
file_picker:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -967,16 +967,8 @@ packages:
|
|||
description: flutter
|
||||
source: sdk
|
||||
version: "0.0.0"
|
||||
freezed:
|
||||
dependency: "direct dev"
|
||||
description:
|
||||
name: freezed
|
||||
sha256: "44c19278dd9d89292cf46e97dc0c1e52ce03275f40a97c5a348e802a924bf40e"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "2.5.7"
|
||||
freezed_annotation:
|
||||
dependency: "direct main"
|
||||
dependency: transitive
|
||||
description:
|
||||
name: freezed_annotation
|
||||
sha256: c2e2d632dd9b8a2b7751117abcfc2b4888ecfe181bd9fca7170d9ef02e595fe2
|
||||
|
@ -1229,18 +1221,18 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: leak_tracker
|
||||
sha256: "7bb2830ebd849694d1ec25bf1f44582d6ac531a57a365a803a6034ff751d2d06"
|
||||
sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "10.0.7"
|
||||
version: "10.0.8"
|
||||
leak_tracker_flutter_testing:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: leak_tracker_flutter_testing
|
||||
sha256: "9491a714cca3667b60b5c420da8217e6de0d1ba7a5ec322fab01758f6998f379"
|
||||
sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "3.0.8"
|
||||
version: "3.0.9"
|
||||
leak_tracker_testing:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1341,10 +1333,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: matcher
|
||||
sha256: d2323aa2060500f906aa31a895b4030b6da3ebdcc5619d14ce1aada65cd161cb
|
||||
sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "0.12.16+1"
|
||||
version: "0.12.17"
|
||||
material_color_utilities:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1365,10 +1357,10 @@ packages:
|
|||
dependency: "direct main"
|
||||
description:
|
||||
name: meta
|
||||
sha256: bdb68674043280c3428e9ec998512fb681678676b3c54e773629ffe74419f8c7
|
||||
sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.15.0"
|
||||
version: "1.16.0"
|
||||
mime:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1486,10 +1478,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: path
|
||||
sha256: "087ce49c3f0dc39180befefc60fdb4acd8f8620e5682fe2476afd0b3688bb4af"
|
||||
sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.9.0"
|
||||
version: "1.9.1"
|
||||
path_parsing:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1614,10 +1606,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: platform
|
||||
sha256: "9b71283fc13df574056616011fb138fd3b793ea47cc509c189a6c3fa5f8a1a65"
|
||||
sha256: "5d6b1b0036a5f331ebc77c850ebc8506cbc1e9416c27e59b439f917a902a4984"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "3.1.5"
|
||||
version: "3.1.6"
|
||||
plugin_platform_interface:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1654,10 +1646,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: process
|
||||
sha256: "21e54fd2faf1b5bdd5102afd25012184a6793927648ea81eea80552ac9405b32"
|
||||
sha256: "107d8be718f120bbba9dcd1e95e3bd325b1b4a4f07db64154635ba03f2567a0d"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "5.0.2"
|
||||
version: "5.0.3"
|
||||
protobuf:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1861,10 +1853,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: source_span
|
||||
sha256: "53e943d4206a5e30df338fd4c6e7a077e02254531b138a15aec3bd143c1a8b3c"
|
||||
sha256: "254ee5351d6cb365c859e20ee823c3bb479bf4a293c22d17a9f1bf144ce86f7c"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.10.0"
|
||||
version: "1.10.1"
|
||||
sqlite3:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -1885,10 +1877,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: stack_trace
|
||||
sha256: "9f47fd3630d76be3ab26f0ee06d213679aa425996925ff3feffdec504931c377"
|
||||
sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.12.0"
|
||||
version: "1.12.1"
|
||||
stack_wallet_backup:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -1918,10 +1910,10 @@ packages:
|
|||
dependency: "direct main"
|
||||
description:
|
||||
name: stream_channel
|
||||
sha256: ba2aa5d8cc609d96bbb2899c28934f9e1af5cddbd60a827822ea467161eb54e7
|
||||
sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "2.1.2"
|
||||
version: "2.1.4"
|
||||
stream_transform:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -1934,10 +1926,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: string_scanner
|
||||
sha256: "688af5ed3402a4bde5b3a6c15fd768dbf2621a614950b17f04626c431ab3c4c3"
|
||||
sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.3.0"
|
||||
version: "1.4.1"
|
||||
string_validator:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -1958,34 +1950,34 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: term_glyph
|
||||
sha256: a29248a84fbb7c79282b40b8c72a1209db169a2e0542bce341da992fe1bc7e84
|
||||
sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.2.1"
|
||||
version: "1.2.2"
|
||||
test:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: test
|
||||
sha256: "713a8789d62f3233c46b4a90b174737b2c04cb6ae4500f2aa8b1be8f03f5e67f"
|
||||
sha256: "301b213cd241ca982e9ba50266bd3f5bd1ea33f1455554c5abb85d1be0e2d87e"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "1.25.8"
|
||||
version: "1.25.15"
|
||||
test_api:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: test_api
|
||||
sha256: "664d3a9a64782fcdeb83ce9c6b39e78fd2971d4e37827b9b06c3aa1edc5e760c"
|
||||
sha256: fb31f383e2ee25fbbfe06b40fe21e1e458d14080e3c67e7ba0acfde4df4e0bbd
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "0.7.3"
|
||||
version: "0.7.4"
|
||||
test_core:
|
||||
dependency: transitive
|
||||
description:
|
||||
name: test_core
|
||||
sha256: "12391302411737c176b0b5d6491f466b0dd56d4763e347b6714efbaa74d7953d"
|
||||
sha256: "84d17c3486c8dfdbe5e12a50c8ae176d15e2a771b96909a9442b40173649ccaa"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "0.6.5"
|
||||
version: "0.6.8"
|
||||
tezart:
|
||||
dependency: "direct main"
|
||||
description:
|
||||
|
@ -2192,10 +2184,10 @@ packages:
|
|||
dependency: transitive
|
||||
description:
|
||||
name: vm_service
|
||||
sha256: f6be3ed8bd01289b34d679c2b62226f63c0e69f9fd2e50a6b3c1c729a961041b
|
||||
sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14"
|
||||
url: "https://pub.dev"
|
||||
source: hosted
|
||||
version: "14.3.0"
|
||||
version: "14.3.1"
|
||||
wakelock_platform_interface:
|
||||
dependency: transitive
|
||||
description:
|
||||
|
@ -2335,7 +2327,7 @@ packages:
|
|||
source: hosted
|
||||
version: "1.1.0"
|
||||
xelis_dart_sdk:
|
||||
dependency: "direct main"
|
||||
dependency: transitive
|
||||
description:
|
||||
name: xelis_dart_sdk
|
||||
sha256: "2a7f8ab4c30fad2fd824ba6ea4e83ac20c726b47c7aa4f1e713ef3971a3ec1f7"
|
||||
|
|
|
@ -73,6 +73,7 @@ final List<CryptoCurrency> _supportedCoins = List.unmodifiable([
|
|||
Stellar(CryptoCurrencyNetwork.main),
|
||||
Tezos(CryptoCurrencyNetwork.main),
|
||||
Wownero(CryptoCurrencyNetwork.main),
|
||||
Xelis(CryptoCurrencyNetwork.main),
|
||||
Bitcoin(CryptoCurrencyNetwork.test),
|
||||
Bitcoin(CryptoCurrencyNetwork.test4),
|
||||
Bitcoincash(CryptoCurrencyNetwork.test),
|
||||
|
@ -83,6 +84,7 @@ final List<CryptoCurrency> _supportedCoins = List.unmodifiable([
|
|||
Litecoin(CryptoCurrencyNetwork.test),
|
||||
Peercoin(CryptoCurrencyNetwork.test),
|
||||
Stellar(CryptoCurrencyNetwork.test),
|
||||
Xelis(CryptoCurrencyNetwork.test),
|
||||
]);
|
||||
|
||||
final ({String from, String to}) _swapDefaults = (from: "BTC", to: "XMR");
|
||||
|
|
|
@ -30,6 +30,11 @@ dependencies:
|
|||
frostdart:
|
||||
path: ./crypto_plugins/frostdart
|
||||
|
||||
xelis_flutter:
|
||||
git:
|
||||
url: https://github.com/Tritonn204/xelis_flutter_ffi.git
|
||||
ref: v0.1.0
|
||||
|
||||
flutter_libsparkmobile:
|
||||
git:
|
||||
url: https://github.com/cypherstack/flutter_libsparkmobile.git
|
||||
|
|
Loading…
Reference in a new issue