mirror of
https://github.com/haveno-dex/haveno.git
synced 2025-01-10 12:54:32 +00:00
support uphold
This commit is contained in:
parent
6dbd1660e5
commit
27f4b18330
6 changed files with 27 additions and 19 deletions
|
@ -74,7 +74,8 @@ public final class PaymentAccountForm implements PersistablePayload {
|
||||||
F2F,
|
F2F,
|
||||||
STRIKE,
|
STRIKE,
|
||||||
MONEY_GRAM,
|
MONEY_GRAM,
|
||||||
FASTER_PAYMENTS;
|
FASTER_PAYMENTS,
|
||||||
|
UPHOLD;
|
||||||
|
|
||||||
public static PaymentAccountForm.FormId fromProto(protobuf.PaymentAccountForm.FormId formId) {
|
public static PaymentAccountForm.FormId fromProto(protobuf.PaymentAccountForm.FormId formId) {
|
||||||
return ProtoUtil.enumFromProto(PaymentAccountForm.FormId.class, formId.name());
|
return ProtoUtil.enumFromProto(PaymentAccountForm.FormId.class, formId.name());
|
||||||
|
|
|
@ -35,6 +35,7 @@ import bisq.core.payment.validation.EmailValidator;
|
||||||
import bisq.core.payment.validation.IBANValidator;
|
import bisq.core.payment.validation.IBANValidator;
|
||||||
import bisq.core.payment.validation.LengthValidator;
|
import bisq.core.payment.validation.LengthValidator;
|
||||||
import bisq.core.proto.CoreProtoResolver;
|
import bisq.core.proto.CoreProtoResolver;
|
||||||
|
import bisq.core.util.validation.InputValidator;
|
||||||
import bisq.core.util.validation.InputValidator.ValidationResult;
|
import bisq.core.util.validation.InputValidator.ValidationResult;
|
||||||
import bisq.common.proto.ProtoUtil;
|
import bisq.common.proto.ProtoUtil;
|
||||||
import bisq.common.proto.persistable.PersistablePayload;
|
import bisq.common.proto.persistable.PersistablePayload;
|
||||||
|
@ -310,7 +311,8 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case ACCOUNT_ID:
|
case ACCOUNT_ID:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
processValidationResult(new InputValidator().validate(value));
|
||||||
|
break;
|
||||||
case ACCOUNT_NAME:
|
case ACCOUNT_NAME:
|
||||||
processValidationResult(new LengthValidator(2, 100).validate(value));
|
processValidationResult(new LengthValidator(2, 100).validate(value));
|
||||||
break;
|
break;
|
||||||
|
@ -318,7 +320,8 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
processValidationResult(new AccountNrValidator("GB").validate(value));
|
processValidationResult(new AccountNrValidator("GB").validate(value));
|
||||||
break;
|
break;
|
||||||
case ACCOUNT_OWNER:
|
case ACCOUNT_OWNER:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
processValidationResult(new LengthValidator(2, 100).validate(value));
|
||||||
|
break;
|
||||||
case ACCOUNT_TYPE:
|
case ACCOUNT_TYPE:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
throw new IllegalArgumentException("Not implemented");
|
||||||
case ANSWER:
|
case ANSWER:
|
||||||
|
@ -380,7 +383,7 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
processValidationResult(new LengthValidator(2, 34).validate(value));
|
processValidationResult(new LengthValidator(2, 34).validate(value));
|
||||||
break;
|
break;
|
||||||
case CONTACT:
|
case CONTACT:
|
||||||
checkNotEmpty(value);
|
processValidationResult(new InputValidator().validate(value));
|
||||||
break;
|
break;
|
||||||
case COUNTRY:
|
case COUNTRY:
|
||||||
if (this instanceof CountryBasedPaymentAccount) {
|
if (this instanceof CountryBasedPaymentAccount) {
|
||||||
|
@ -394,11 +397,9 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
if (!CountryUtil.findCountryByCode(value).isPresent()) throw new IllegalArgumentException("Invalid country code: " + value);
|
if (!CountryUtil.findCountryByCode(value).isPresent()) throw new IllegalArgumentException("Invalid country code: " + value);
|
||||||
break;
|
break;
|
||||||
case EMAIL:
|
case EMAIL:
|
||||||
checkNotEmpty(value);
|
|
||||||
processValidationResult(new EmailValidator().validate(value));
|
processValidationResult(new EmailValidator().validate(value));
|
||||||
break;
|
break;
|
||||||
case EMAIL_OR_MOBILE_NR:
|
case EMAIL_OR_MOBILE_NR:
|
||||||
checkNotEmpty(value);
|
|
||||||
processValidationResult(new EmailOrMobileNrValidator().validate(value));
|
processValidationResult(new EmailOrMobileNrValidator().validate(value));
|
||||||
break;
|
break;
|
||||||
case EXTRA_INFO:
|
case EXTRA_INFO:
|
||||||
|
@ -454,13 +455,12 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case TRADE_CURRENCIES:
|
case TRADE_CURRENCIES:
|
||||||
checkNotEmpty(value);
|
processValidationResult(new InputValidator().validate(value));
|
||||||
List<String> currencyCodes = commaDelimitedCodesToList.apply(value);
|
List<String> currencyCodes = commaDelimitedCodesToList.apply(value);
|
||||||
Optional<List<TradeCurrency>> tradeCurrencies = CurrencyUtil.getTradeCurrenciesInList(currencyCodes, getSupportedCurrencies());
|
Optional<List<TradeCurrency>> tradeCurrencies = CurrencyUtil.getTradeCurrenciesInList(currencyCodes, getSupportedCurrencies());
|
||||||
if (!tradeCurrencies.isPresent()) throw new IllegalArgumentException("No trade currencies were found in the " + getPaymentMethod().getDisplayString() + " account form");
|
if (!tradeCurrencies.isPresent()) throw new IllegalArgumentException("No trade currencies were found in the " + getPaymentMethod().getDisplayString() + " account form");
|
||||||
break;
|
break;
|
||||||
case USER_NAME:
|
case USER_NAME:
|
||||||
checkNotEmpty(value);
|
|
||||||
processValidationResult(new LengthValidator(3, 100).validate(value));
|
processValidationResult(new LengthValidator(3, 100).validate(value));
|
||||||
break;
|
break;
|
||||||
case VIRTUAL_PAYMENT_ADDRESS:
|
case VIRTUAL_PAYMENT_ADDRESS:
|
||||||
|
@ -470,10 +470,6 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void checkNotEmpty(String input) {
|
|
||||||
if (input == null || "".equals(input)) throw new IllegalArgumentException("Field must not be empty");
|
|
||||||
}
|
|
||||||
|
|
||||||
protected void processValidationResult(ValidationResult result) {
|
protected void processValidationResult(ValidationResult result) {
|
||||||
if (!result.isValid) throw new IllegalArgumentException(result.errorMessage);
|
if (!result.isValid) throw new IllegalArgumentException(result.errorMessage);
|
||||||
}
|
}
|
||||||
|
@ -487,7 +483,9 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
field.setSupportedCountries(((CountryBasedPaymentAccount) this).getSupportedCountries());
|
field.setSupportedCountries(((CountryBasedPaymentAccount) this).getSupportedCountries());
|
||||||
break;
|
break;
|
||||||
case ACCOUNT_ID:
|
case ACCOUNT_ID:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
field.setComponent(PaymentAccountFormField.Component.TEXT);
|
||||||
|
field.setLabel("Username or email or phone no.");
|
||||||
|
break;
|
||||||
case ACCOUNT_NAME:
|
case ACCOUNT_NAME:
|
||||||
field.setComponent(PaymentAccountFormField.Component.TEXT);
|
field.setComponent(PaymentAccountFormField.Component.TEXT);
|
||||||
field.setLabel("Account name"); // TODO: pull all labels from language file
|
field.setLabel("Account name"); // TODO: pull all labels from language file
|
||||||
|
@ -499,7 +497,9 @@ public abstract class PaymentAccount implements PersistablePayload {
|
||||||
field.setLabel("Account number");
|
field.setLabel("Account number");
|
||||||
break;
|
break;
|
||||||
case ACCOUNT_OWNER:
|
case ACCOUNT_OWNER:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
field.setComponent(PaymentAccountFormField.Component.TEXT);
|
||||||
|
field.setLabel("Account owner full name");
|
||||||
|
break;
|
||||||
case ACCOUNT_TYPE:
|
case ACCOUNT_TYPE:
|
||||||
throw new IllegalArgumentException("Not implemented");
|
throw new IllegalArgumentException("Not implemented");
|
||||||
case ANSWER:
|
case ANSWER:
|
||||||
|
|
|
@ -34,6 +34,14 @@ import org.jetbrains.annotations.NotNull;
|
||||||
@EqualsAndHashCode(callSuper = true)
|
@EqualsAndHashCode(callSuper = true)
|
||||||
public final class UpholdAccount extends PaymentAccount {
|
public final class UpholdAccount extends PaymentAccount {
|
||||||
|
|
||||||
|
private static final List<PaymentAccountFormField.FieldId> INPUT_FIELD_IDS = List.of(
|
||||||
|
PaymentAccountFormField.FieldId.ACCOUNT_NAME,
|
||||||
|
PaymentAccountFormField.FieldId.ACCOUNT_OWNER,
|
||||||
|
PaymentAccountFormField.FieldId.ACCOUNT_ID,
|
||||||
|
PaymentAccountFormField.FieldId.TRADE_CURRENCIES,
|
||||||
|
PaymentAccountFormField.FieldId.SALT
|
||||||
|
);
|
||||||
|
|
||||||
// https://support.uphold.com/hc/en-us/articles/202473803-Supported-currencies
|
// https://support.uphold.com/hc/en-us/articles/202473803-Supported-currencies
|
||||||
public static final List<TradeCurrency> SUPPORTED_CURRENCIES = List.of(
|
public static final List<TradeCurrency> SUPPORTED_CURRENCIES = List.of(
|
||||||
new FiatCurrency("AED"),
|
new FiatCurrency("AED"),
|
||||||
|
@ -78,7 +86,7 @@ public final class UpholdAccount extends PaymentAccount {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public @NotNull List<PaymentAccountFormField.FieldId> getInputFieldIds() {
|
public @NotNull List<PaymentAccountFormField.FieldId> getInputFieldIds() {
|
||||||
throw new RuntimeException("Not implemented");
|
return INPUT_FIELD_IDS;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setAccountId(String accountId) {
|
public void setAccountId(String accountId) {
|
||||||
|
|
|
@ -337,7 +337,8 @@ public final class PaymentMethod implements PersistablePayload, Comparable<Payme
|
||||||
F2F_ID,
|
F2F_ID,
|
||||||
STRIKE_ID,
|
STRIKE_ID,
|
||||||
MONEY_GRAM_ID,
|
MONEY_GRAM_ID,
|
||||||
FASTER_PAYMENTS_ID);
|
FASTER_PAYMENTS_ID,
|
||||||
|
UPHOLD_ID);
|
||||||
return paymentMethods.stream().filter(paymentMethod -> paymentMethodIds.contains(paymentMethod.getId())).collect(Collectors.toList());
|
return paymentMethods.stream().filter(paymentMethod -> paymentMethodIds.contains(paymentMethod.getId())).collect(Collectors.toList());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -41,9 +41,6 @@ import lombok.extern.slf4j.Slf4j;
|
||||||
@Slf4j
|
@Slf4j
|
||||||
public final class UpholdAccountPayload extends PaymentAccountPayload {
|
public final class UpholdAccountPayload extends PaymentAccountPayload {
|
||||||
private String accountId = "";
|
private String accountId = "";
|
||||||
|
|
||||||
// For backward compatibility we need to exclude the new field from the contract json.
|
|
||||||
@JsonExclude
|
|
||||||
private String accountOwner = "";
|
private String accountOwner = "";
|
||||||
|
|
||||||
public UpholdAccountPayload(String paymentMethod, String id) {
|
public UpholdAccountPayload(String paymentMethod, String id) {
|
||||||
|
|
|
@ -2084,6 +2084,7 @@ message PaymentAccountForm {
|
||||||
STRIKE = 7;
|
STRIKE = 7;
|
||||||
MONEY_GRAM = 8;
|
MONEY_GRAM = 8;
|
||||||
FASTER_PAYMENTS = 9;
|
FASTER_PAYMENTS = 9;
|
||||||
|
UPHOLD = 10;
|
||||||
}
|
}
|
||||||
FormId id = 1;
|
FormId id = 1;
|
||||||
repeated PaymentAccountFormField fields = 2;
|
repeated PaymentAccountFormField fields = 2;
|
||||||
|
|
Loading…
Reference in a new issue