tech.carpentum.sdk.payment.model.OnlineMethod 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.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.*;
/** ONLINE
*
* Online Bank Transfer. Payment method where Customer is redirected to his own preferred Payment service application right after the payment is submitted and create the Payment transfer with pre-filled Payment instruction.
For ZAR currency, the system validates the transaction using customer's account name sent on the request versus the name on the bank. If the comparison reached above the threshold, transaction will go through, otherwise, it will be rejected. If no accountName was sent, transaction will be processed as normal.
*
*
*
* 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 interface OnlineMethod extends PayinMethod {
/** A discriminator value of property {@link #getPaymentMethodCode}. The model class extends {@link PayinMethod}. */
PayinMethod.PaymentMethodCode PAYMENT_METHOD_CODE = PayinMethod.PaymentMethodCode.ONLINE;
@NotNull Optional getAccount();
/** 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. */
@NotNull Optional getPaymentOperatorCode();
/** Your customer e-mail address in RFC 5322 format that is used for identification of the customer's payins. */
@NotNull Optional getEmailAddress();
@NotNull static Builder builder(OnlineMethod copyOf) {
Builder builder = builder();
builder.account(copyOf.getAccount().orElse(null));
builder.paymentOperatorCode(copyOf.getPaymentOperatorCode().orElse(null));
builder.emailAddress(copyOf.getEmailAddress().orElse(null));
return builder;
}
@NotNull static Builder builder() {
return new OnlineMethodImpl.BuilderImpl();
}
/** Builder for {@link OnlineMethod} model class. */
interface Builder {
/**
* Set {@link OnlineMethod#getAccount} property.
*
*
*/
@NotNull Builder account(AccountPayinRequestOnline account);
/**
* Set {@link OnlineMethod#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.
*/
@NotNull Builder paymentOperatorCode(String paymentOperatorCode);
/**
* Set {@link OnlineMethod#getEmailAddress} property.
*
* Your customer e-mail address in RFC 5322 format that is used for identification of the customer's payins.
*/
@NotNull Builder emailAddress(String emailAddress);
/**
* Create new instance of {@link OnlineMethod} model class with the builder instance properties.
*
* @throws NullPointerException in case required properties are not specified.
*/
@NotNull OnlineMethod build();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy