From 80c48f62e96704861e72b43091f89962ea92e7c3 Mon Sep 17 00:00:00 2001 From: Erdem Yerebasmaz Date: Tue, 16 Jul 2024 10:13:40 +0300 Subject: [PATCH] Compare payment amount against maxPayableSat from onchainPaymentLimits --- lib/bloc/reverse_swap/reverse_swap_bloc.dart | 7 ++++--- .../redeem_onchain_funds_page.dart | 2 +- .../withdraw/reverse_swap/reverse_swap_form.dart | 4 ++-- .../withdraw/reverse_swap/reverse_swap_page.dart | 15 ++++++++------- .../withdraw_funds_amount_text_form_field.dart | 4 ++-- 5 files changed, 17 insertions(+), 15 deletions(-) diff --git a/lib/bloc/reverse_swap/reverse_swap_bloc.dart b/lib/bloc/reverse_swap/reverse_swap_bloc.dart index ee9b183c6..8df895f2c 100644 --- a/lib/bloc/reverse_swap/reverse_swap_bloc.dart +++ b/lib/bloc/reverse_swap/reverse_swap_bloc.dart @@ -133,12 +133,13 @@ class ReverseSwapBloc extends Cubit { try { OnchainPaymentLimitsResponse paymentLimits = await _breezSDK.onchainPaymentLimits(); _log.info( - "Current maximum ${paymentLimits.maxSat} and " - "minimum ${paymentLimits.minSat} payment limits for onchain payments", + "Current minimum ${paymentLimits.minSat} and " + "maximum ${paymentLimits.maxSat} payment limits, in sats, for onchain payments." + "\nMaximum amount this node can send with the current channels and the current local balance: ${paymentLimits.maxPayableSat} (sats).", ); return paymentLimits; } catch (e) { - _log.severe("fetchOnchainPaymentLimits error", e); + _log.severe("onchainPaymentLimits error", e); rethrow; } } diff --git a/lib/routes/withdraw/redeem_onchain_funds/redeem_onchain_funds_page.dart b/lib/routes/withdraw/redeem_onchain_funds/redeem_onchain_funds_page.dart index 0ddfd65b3..a6ea89988 100644 --- a/lib/routes/withdraw/redeem_onchain_funds/redeem_onchain_funds_page.dart +++ b/lib/routes/withdraw/redeem_onchain_funds/redeem_onchain_funds_page.dart @@ -88,7 +88,7 @@ class _RedeemFundsPageState extends State { widget.walletBalanceSat, widget.walletBalanceSat, ), - balanceSat: widget.walletBalanceSat, + maxPayableSat: widget.walletBalanceSat, ); }, ), diff --git a/lib/routes/withdraw/reverse_swap/reverse_swap_form.dart b/lib/routes/withdraw/reverse_swap/reverse_swap_form.dart index 487a7350f..e8c4215d0 100644 --- a/lib/routes/withdraw/reverse_swap/reverse_swap_form.dart +++ b/lib/routes/withdraw/reverse_swap/reverse_swap_form.dart @@ -84,7 +84,7 @@ class _ReverseSwapFormState extends State { bitcoinCurrency: widget.bitcoinCurrency, controller: widget.amountController, withdrawMaxValue: widget.withdrawMaxValue, - balanceSat: widget.paymentLimits.maxSat, + maxPayableSat: widget.paymentLimits.maxPayableSat, policy: WithdrawFundsPolicy( WithdrawKind.withdraw_funds, widget.paymentLimits.minSat, @@ -105,7 +105,7 @@ class _ReverseSwapFormState extends State { setState(() { widget.onChanged(value); if (widget.withdrawMaxValue) { - _setAmount(widget.paymentLimits.maxSat); + _setAmount(widget.paymentLimits.maxPayableSat); } else { widget.amountController.text = ""; } diff --git a/lib/routes/withdraw/reverse_swap/reverse_swap_page.dart b/lib/routes/withdraw/reverse_swap/reverse_swap_page.dart index 7dcf72761..626038f15 100644 --- a/lib/routes/withdraw/reverse_swap/reverse_swap_page.dart +++ b/lib/routes/withdraw/reverse_swap/reverse_swap_page.dart @@ -14,6 +14,7 @@ final _log = Logger("ReverseSwapPage"); class ReverseSwapPage extends StatefulWidget { final BitcoinAddressData? btcAddressData; + const ReverseSwapPage({super.key, required this.btcAddressData}); @override @@ -21,25 +22,25 @@ class ReverseSwapPage extends StatefulWidget { } class _ReverseSwapPageState extends State { - Future? _revSwapOptionsFuture; + Future? _onchainPaymentLimitsFuture; @override void initState() { super.initState(); - _fetchReverseSwapPairInfo(); + _fetchOnchainPaymentLimits(); } void didChangeAppLifecycleState(AppLifecycleState state) { if (state == AppLifecycleState.resumed) { - _fetchReverseSwapPairInfo(); + _fetchOnchainPaymentLimits(); } } - Future _fetchReverseSwapPairInfo() async { - _log.info("Fetching reverse swap pair info"); + Future _fetchOnchainPaymentLimits() async { + _log.info("Fetching onchain payment limits"); final revSwapBloc = context.read(); setState(() { - _revSwapOptionsFuture = revSwapBloc.onchainPaymentLimits(); + _onchainPaymentLimitsFuture = revSwapBloc.onchainPaymentLimits(); }); } @@ -54,7 +55,7 @@ class _ReverseSwapPageState extends State { title: Text(texts.reverse_swap_title), ), body: FutureBuilder( - future: _revSwapOptionsFuture, + future: _onchainPaymentLimitsFuture, builder: (BuildContext context, AsyncSnapshot snapshot) { if (snapshot.hasError) { return Center( diff --git a/lib/routes/withdraw/widgets/withdraw_funds_amount_text_form_field.dart b/lib/routes/withdraw/widgets/withdraw_funds_amount_text_form_field.dart index 0cc8169cf..214f957f6 100644 --- a/lib/routes/withdraw/widgets/withdraw_funds_amount_text_form_field.dart +++ b/lib/routes/withdraw/widgets/withdraw_funds_amount_text_form_field.dart @@ -18,7 +18,7 @@ class WithdrawFundsAmountTextFormField extends AmountFormField { required TextEditingController super.controller, required bool withdrawMaxValue, required WithdrawFundsPolicy policy, - required int balanceSat, + required int maxPayableSat, }) : super( texts: context.texts(), readOnly: policy.withdrawKind == WithdrawKind.unexpected_funds || withdrawMaxValue, @@ -36,7 +36,7 @@ class WithdrawFundsAmountTextFormField extends AmountFormField { if (amountSat > policy.maxValue) { throw PaymentExceededLimitError(policy.maxValue); } - if (amountSat > balanceSat) { + if (amountSat > maxPayableSat) { throw const InsufficientLocalBalanceError(); } },