mirror of
https://github.com/cake-tech/cake_wallet.git
synced 2025-01-18 00:34:58 +00:00
CW-674: Improve Exchange Flow With Timeout For Rates (#1536)
* fix: Improve exchange flow by adding a timeout to the call to fetch rate from providers * fix: Adjust time limit for fetching rate to 7 seconds and add timelimit to fetching limits * Improve loadlimits function [skip ci] --------- Co-authored-by: OmarHatem <omarh.ismail1@gmail.com>
This commit is contained in:
parent
415d2a3573
commit
341e06196d
2 changed files with 52 additions and 22 deletions
|
@ -1,4 +1,5 @@
|
|||
import 'dart:convert';
|
||||
import 'dart:developer';
|
||||
|
||||
import 'package:cake_wallet/.secrets.g.dart' as secrets;
|
||||
import 'package:cake_wallet/exchange/provider/exchange_provider.dart';
|
||||
|
@ -29,6 +30,7 @@ class SideShiftExchangeProvider extends ExchangeProvider {
|
|||
CryptoCurrency.bttc,
|
||||
CryptoCurrency.usdt,
|
||||
CryptoCurrency.eos,
|
||||
CryptoCurrency.xmr,
|
||||
];
|
||||
|
||||
static const affiliateId = secrets.sideShiftAffiliateId;
|
||||
|
@ -137,8 +139,20 @@ class SideShiftExchangeProvider extends ExchangeProvider {
|
|||
final response = await get(uri);
|
||||
final responseJSON = json.decode(response.body) as Map<String, dynamic>;
|
||||
|
||||
if (response.statusCode == 500) {
|
||||
final responseJSON = json.decode(response.body) as Map<String, dynamic>;
|
||||
final error = responseJSON['error']['message'] as String;
|
||||
|
||||
throw Exception('SideShift Internal Server Error: $error');
|
||||
}
|
||||
|
||||
if (response.statusCode != 200) {
|
||||
throw Exception('Unexpected http status: ${response.statusCode}');
|
||||
}
|
||||
|
||||
return double.parse(responseJSON['rate'] as String);
|
||||
} catch (_) {
|
||||
} catch (e) {
|
||||
log('Error fetching rate in SideShift Provider: ${e.toString()}');
|
||||
return 0.00;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -405,13 +405,22 @@ abstract class ExchangeViewModelBase extends WalletChangeListenerViewModel with
|
|||
.where((element) => !isFixedRateMode || element.supportsFixedRate)
|
||||
.toList();
|
||||
|
||||
final result = await Future.wait<double>(_providers.map((element) => element.fetchRate(
|
||||
from: depositCurrency,
|
||||
to: receiveCurrency,
|
||||
amount: amount,
|
||||
isFixedRateMode: isFixedRateMode,
|
||||
isReceiveAmount: isFixedRateMode)));
|
||||
|
||||
final result = await Future.wait<double>(
|
||||
_providers.map(
|
||||
(element) => element
|
||||
.fetchRate(
|
||||
from: depositCurrency,
|
||||
to: receiveCurrency,
|
||||
amount: amount,
|
||||
isFixedRateMode: isFixedRateMode,
|
||||
isReceiveAmount: isFixedRateMode,
|
||||
)
|
||||
.timeout(
|
||||
Duration(seconds: 7),
|
||||
onTimeout: () => 0.0,
|
||||
),
|
||||
),
|
||||
);
|
||||
_sortedAvailableProviders.clear();
|
||||
|
||||
for (int i = 0; i < result.length; i++) {
|
||||
|
@ -441,22 +450,29 @@ abstract class ExchangeViewModelBase extends WalletChangeListenerViewModel with
|
|||
double? highestMax = 0.0;
|
||||
|
||||
try {
|
||||
for (var provider in selectedProviders) {
|
||||
/// if this provider is not valid for the current pair, skip it
|
||||
if (!providersForCurrentPair().contains(provider)) continue;
|
||||
final result = await Future.wait(selectedProviders
|
||||
.where((element) => providersForCurrentPair().contains(provider))
|
||||
.map((provider) => provider
|
||||
.fetchLimits(
|
||||
from: from,
|
||||
to: to,
|
||||
isFixedRateMode: isFixedRateMode,
|
||||
)
|
||||
.onError((error, stackTrace) => Limits(max: 0.0, min: double.maxFinite))
|
||||
.timeout(
|
||||
Duration(seconds: 7),
|
||||
onTimeout: () => Limits(max: 0.0, min: double.maxFinite),
|
||||
)));
|
||||
|
||||
try {
|
||||
final tempLimits =
|
||||
await provider.fetchLimits(from: from, to: to, isFixedRateMode: isFixedRateMode);
|
||||
|
||||
if (lowestMin != null && (tempLimits.min ?? -1) < lowestMin) lowestMin = tempLimits.min;
|
||||
|
||||
if (highestMax != null && (tempLimits.max ?? double.maxFinite) > highestMax)
|
||||
highestMax = tempLimits.max;
|
||||
} catch (e) {
|
||||
continue;
|
||||
result.forEach((tempLimits) {
|
||||
if (lowestMin != null && (tempLimits.min ?? -1) < lowestMin!) {
|
||||
lowestMin = tempLimits.min;
|
||||
}
|
||||
}
|
||||
|
||||
if (highestMax != null && (tempLimits.max ?? double.maxFinite) > highestMax!) {
|
||||
highestMax = tempLimits.max;
|
||||
}
|
||||
});
|
||||
} on ConcurrentModificationError {
|
||||
/// if user changed the selected providers while fetching limits
|
||||
/// then delay the fetching limits a bit and try again
|
||||
|
|
Loading…
Reference in a new issue