tech.carpentum.sdk.payment.internal.generated.model.BankTransferMethodImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of payment-client-v2 Show documentation
Show all versions of payment-client-v2 Show documentation
Carpentum Payment system Java SDK
The newest version!
//THE FILE IS GENERATED, DO NOT MODIFY IT MANUALLY!!!
package tech.carpentum.sdk.payment.internal.generated.model;
import com.squareup.moshi.JsonClass;
import java.util.Objects;
import java.util.Optional;
import org.jetbrains.annotations.NotNull;
import tech.carpentum.sdk.payment.internal.generated.model.*;
import tech.carpentum.sdk.payment.model.*;
/** BANK_TRANSFER
*
* Payment method for sending funds from your account to external bank account using a country specific payment system to process bank transfers.
It required customer to provide a receiving bank account details which are required by local payment system to process bank transfers.
*
*
*
* The model class is immutable.
* Use static {@link #builder} method to create a new {@link Builder} instance to build the model class instance.
*
*/
@JsonClass(generateAdapter = false)
public class BankTransferMethodImpl implements BankTransferMethod {
private final AccountPayoutRequestBankTransfer account;
@Override
public AccountPayoutRequestBankTransfer getAccount() {
return account;
}
/** One of following can serve as Payment Operator:
* Financial or other institution (such as bank, card payment processor, ...) that manages transactions for your customers
* Mobile wallet
* Blockchain protocol for crypto currency payments
Customer is informed with the payment instructions where funds have to be transferred efficiently based on the selected Payment operator.
For getting list of the available payment options for payins use [POST /payins/!availablePaymentOptions](#operations-Incoming_payments-availablePaymentOptions) API, for payouts use [POST /payouts/!availablePaymentOptions](#operations-Outgoing_payments-availablePaymentOptions) API. */
private final String paymentOperatorCode;
@Override
public String getPaymentOperatorCode() {
return paymentOperatorCode;
}
/** Your customer e-mail address in RFC 5322 format that is used for identification of the customer's payins. */
private final Optional emailAddress;
@Override
public Optional getEmailAddress() {
return emailAddress;
}
private final Optional remark;
@Override
public Optional getRemark() {
return remark;
}
@Override public PaymentMethodCode getPaymentMethodCode() { return PAYMENT_METHOD_CODE; }
private final int hashCode;
private final String toString;
private BankTransferMethodImpl(BuilderImpl builder) {
this.account = Objects.requireNonNull(builder.account, "Property 'account' is required.");
this.paymentOperatorCode = Objects.requireNonNull(builder.paymentOperatorCode, "Property 'paymentOperatorCode' is required.");
this.emailAddress = Optional.ofNullable(builder.emailAddress);
this.remark = Optional.ofNullable(builder.remark);
this.hashCode = Objects.hash(account, paymentOperatorCode, emailAddress, remark);
this.toString = builder.type + "(" +
"account=" + account +
", paymentOperatorCode=" + paymentOperatorCode +
", emailAddress=" + emailAddress +
", remark=" + remark +
')';
}
@Override
public int hashCode() {
return hashCode;
}
@Override
public boolean equals(Object obj) {
if (this == obj) {
return true;
}
if (obj == null) {
return false;
}
if (!(obj instanceof BankTransferMethodImpl)) {
return false;
}
BankTransferMethodImpl that = (BankTransferMethodImpl) obj;
if (!Objects.equals(this.account, that.account)) return false;
if (!Objects.equals(this.paymentOperatorCode, that.paymentOperatorCode)) return false;
if (!Objects.equals(this.emailAddress, that.emailAddress)) return false;
if (!Objects.equals(this.remark, that.remark)) return false;
return true;
}
@Override
public String toString() {
return toString;
}
/** Builder for {@link BankTransferMethod} model class. */
public static class BuilderImpl implements BankTransferMethod.Builder {
private AccountPayoutRequestBankTransfer account = null;
private String paymentOperatorCode = null;
private String emailAddress = null;
private String remark = null;
private final String type;
public BuilderImpl(String type) {
this.type = type;
}
public BuilderImpl() {
this("BankTransferMethod");
}
/**
* Set {@link BankTransferMethod#getAccount} property.
*
*
*/
@Override
public BuilderImpl account(AccountPayoutRequestBankTransfer account) {
this.account = account;
return this;
}
/**
* Set {@link BankTransferMethod#getPaymentOperatorCode} property.
*
* One of following can serve as Payment Operator:
* Financial or other institution (such as bank, card payment processor, ...) that manages transactions for your customers
* Mobile wallet
* Blockchain protocol for crypto currency payments
Customer is informed with the payment instructions where funds have to be transferred efficiently based on the selected Payment operator.
For getting list of the available payment options for payins use [POST /payins/!availablePaymentOptions](#operations-Incoming_payments-availablePaymentOptions) API, for payouts use [POST /payouts/!availablePaymentOptions](#operations-Outgoing_payments-availablePaymentOptions) API.
*/
@Override
public BuilderImpl paymentOperatorCode(String paymentOperatorCode) {
this.paymentOperatorCode = paymentOperatorCode;
return this;
}
/**
* Set {@link BankTransferMethod#getEmailAddress} property.
*
* Your customer e-mail address in RFC 5322 format that is used for identification of the customer's payins.
*/
@Override
public BuilderImpl emailAddress(String emailAddress) {
this.emailAddress = emailAddress;
return this;
}
/**
* Set {@link BankTransferMethod#getRemark} property.
*
*
*/
@Override
public BuilderImpl remark(String remark) {
this.remark = remark;
return this;
}
/**
* Create new instance of {@link BankTransferMethod} model class with the builder instance properties.
*
* @throws NullPointerException in case required properties are not specified.
*/
@Override
public BankTransferMethodImpl build() {
return new BankTransferMethodImpl(this);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy