diff --git a/src/main/java/com/gocardless/resources/BillingRequest.java b/src/main/java/com/gocardless/resources/BillingRequest.java index de4bf608..1f944fb9 100644 --- a/src/main/java/com/gocardless/resources/BillingRequest.java +++ b/src/main/java/com/gocardless/resources/BillingRequest.java @@ -406,8 +406,8 @@ private InstalmentScheduleRequest() { } private Integer appFee; - private Currency currency; - private List instalments; + private String currency; + private Map instalments; private Links links; private Map metadata; private String name; @@ -426,9 +426,9 @@ public Integer getAppFee() { /** * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently - * "AUD", "CAD", "DKK", "EUR", "GBP", "NZD", "SEK" and "USD" are supported. + * "USD" and "CAD" are supported. */ - public Currency getCurrency() { + public String getCurrency() { return currency; } @@ -438,7 +438,7 @@ public Currency getCurrency() { * schedule)](#instalment-schedules-create-with-schedule) for more information on how to * specify instalments. */ - public List getInstalments() { + public Map getInstalments() { return instalments; } @@ -493,19 +493,6 @@ public Integer getTotalAmount() { return totalAmount; } - public enum Currency { - @SerializedName("AUD") - AUD, @SerializedName("CAD") - CAD, @SerializedName("DKK") - DKK, @SerializedName("EUR") - EUR, @SerializedName("GBP") - GBP, @SerializedName("NZD") - NZD, @SerializedName("SEK") - SEK, @SerializedName("USD") - USD, @SerializedName("unknown") - UNKNOWN - } - public static class Links { private Links() { // blank to prevent instantiation @@ -1521,7 +1508,7 @@ public Integer getCount() { /** * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently - * "AUD", "CAD", "DKK", "EUR", "GBP", "NZD", "SEK" and "USD" are supported. + * "USD" and "CAD" are supported. */ public String getCurrency() { return currency; diff --git a/src/main/java/com/gocardless/services/BillingRequestService.java b/src/main/java/com/gocardless/services/BillingRequestService.java index 9ffc7059..93fce077 100644 --- a/src/main/java/com/gocardless/services/BillingRequestService.java +++ b/src/main/java/com/gocardless/services/BillingRequestService.java @@ -37,14 +37,34 @@ public BillingRequestService(HttpClient httpClient) { /** *

- * Important: All properties associated with `subscription_request` and - * `instalment_schedule_request` are only supported for ACH and PAD schemes. + * Important: All properties associated with `subscription_request` are only + * supported for ACH and PAD schemes. *

*/ public BillingRequestCreateRequest create() { return new BillingRequestCreateRequest(httpClient); } + /** + *

+ * Important: All properties associated with `instalment_schedule_request` are + * only supported for ACH and PAD schemes. + *

+ */ + public BillingRequestCreateWithInstalmentsWithDatesRequest createWithInstalmentsWithDates() { + return new BillingRequestCreateWithInstalmentsWithDatesRequest(httpClient); + } + + /** + *

+ * Important: All properties associated with `instalment_schedule_request` are + * only supported for ACH and PAD schemes. + *

+ */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest createWithInstalmentsWithSchedule() { + return new BillingRequestCreateWithInstalmentsWithScheduleRequest(httpClient); + } + /** * If the billing request has a pending collect_customer_details action, this * endpoint can be used to collect the details in order to complete it. @@ -165,14 +185,13 @@ public BillingRequestSelectInstitutionRequest selectInstitution(String identity) * Request class for {@link BillingRequestService#create }. * *

- * Important: All properties associated with `subscription_request` and - * `instalment_schedule_request` are only supported for ACH and PAD schemes. + * Important: All properties associated with `subscription_request` are only + * supported for ACH and PAD schemes. *

*/ public static final class BillingRequestCreateRequest extends IdempotentPostRequest { private Boolean fallbackEnabled; - private InstalmentScheduleRequest instalmentScheduleRequest; private Links links; private MandateRequest mandateRequest; private Map metadata; @@ -193,124 +212,6 @@ public BillingRequestCreateRequest withFallbackEnabled(Boolean fallbackEnabled) return this; } - public BillingRequestCreateRequest withInstalmentScheduleRequest( - InstalmentScheduleRequest instalmentScheduleRequest) { - this.instalmentScheduleRequest = instalmentScheduleRequest; - return this; - } - - /** - * The amount to be deducted from each payment as an app fee, to be paid to the partner - * integration which created the subscription, in the lowest denomination for the currency - * (e.g. pence in GBP, cents in EUR). - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestAppFee(Integer appFee) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withAppFee(appFee); - return this; - } - - /** - * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently - * "AUD", "CAD", "DKK", "EUR", "GBP", "NZD", "SEK" and "USD" are supported. - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestCurrency( - InstalmentScheduleRequest.Currency currency) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withCurrency(currency); - return this; - } - - /** - * instalments to be created. See [create (with - * dates)](#instalment-schedules-create-with-dates) and [create (with - * schedule)](#instalment-schedules-create-with-schedule) for more information on how to - * specify instalments. - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestInstalments( - List instalments) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withInstalments(instalments); - return this; - } - - /** - * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 - * characters and values up to 500 characters. - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestMetadata( - Map metadata) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withMetadata(metadata); - return this; - } - - /** - * Name of the instalment schedule, up to 100 chars. This name will also be copied to the - * payments of the instalment schedule if you use schedule-based creation. - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestName(String name) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withName(name); - return this; - } - - /** - * An optional payment reference. This will be set as the reference on each payment created - * and will appear on your customer's bank statement. See the documentation for the [create - * payment endpoint](#payments-create-a-payment) for more details.
- */ - public BillingRequestCreateRequest withInstalmentScheduleRequestPaymentReference( - String paymentReference) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withPaymentReference(paymentReference); - return this; - } - - /** - * On failure, automatically retry payments using [intelligent - * retries](#success-intelligent-retries). Default is `false`. - *

- * Important: To be able to use intelligent retries, Success+ needs to be - * enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). - *

- */ - public BillingRequestCreateRequest withInstalmentScheduleRequestRetryIfPossible( - Boolean retryIfPossible) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withRetryIfPossible(retryIfPossible); - return this; - } - - /** - * The total amount of the instalment schedule, defined as the sum of all individual - * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in EUR). - * If the requested payment amounts do not sum up correctly, a validation error will be - * returned. - */ - public BillingRequestCreateRequest withInstalmentScheduleRequestTotalAmount( - Integer totalAmount) { - if (instalmentScheduleRequest == null) { - instalmentScheduleRequest = new InstalmentScheduleRequest(); - } - instalmentScheduleRequest.withTotalAmount(totalAmount); - return this; - } - public BillingRequestCreateRequest withLinks(Links links) { this.links = links; return this; @@ -890,117 +791,6 @@ public String toString() { } } - public static class InstalmentScheduleRequest { - private Integer appFee; - private Currency currency; - private List instalments; - private Map metadata; - private String name; - private String paymentReference; - private Boolean retryIfPossible; - private Integer totalAmount; - - /** - * The amount to be deducted from each payment as an app fee, to be paid to the partner - * integration which created the subscription, in the lowest denomination for the - * currency (e.g. pence in GBP, cents in EUR). - */ - public InstalmentScheduleRequest withAppFee(Integer appFee) { - this.appFee = appFee; - return this; - } - - /** - * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. - * Currently "AUD", "CAD", "DKK", "EUR", "GBP", "NZD", "SEK" and "USD" are supported. - */ - public InstalmentScheduleRequest withCurrency(Currency currency) { - this.currency = currency; - return this; - } - - /** - * instalments to be created. See [create (with - * dates)](#instalment-schedules-create-with-dates) and [create (with - * schedule)](#instalment-schedules-create-with-schedule) for more information on how to - * specify instalments. - */ - public InstalmentScheduleRequest withInstalments(List instalments) { - this.instalments = instalments; - return this; - } - - /** - * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 - * characters and values up to 500 characters. - */ - public InstalmentScheduleRequest withMetadata(Map metadata) { - this.metadata = metadata; - return this; - } - - /** - * Name of the instalment schedule, up to 100 chars. This name will also be copied to - * the payments of the instalment schedule if you use schedule-based creation. - */ - public InstalmentScheduleRequest withName(String name) { - this.name = name; - return this; - } - - /** - * An optional payment reference. This will be set as the reference on each payment - * created and will appear on your customer's bank statement. See the documentation for - * the [create payment endpoint](#payments-create-a-payment) for more details.
- */ - public InstalmentScheduleRequest withPaymentReference(String paymentReference) { - this.paymentReference = paymentReference; - return this; - } - - /** - * On failure, automatically retry payments using [intelligent - * retries](#success-intelligent-retries). Default is `false`. - *

- * Important: To be able to use intelligent retries, Success+ needs to - * be enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). - *

- */ - public InstalmentScheduleRequest withRetryIfPossible(Boolean retryIfPossible) { - this.retryIfPossible = retryIfPossible; - return this; - } - - /** - * The total amount of the instalment schedule, defined as the sum of all individual - * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in - * EUR). If the requested payment amounts do not sum up correctly, a validation error - * will be returned. - */ - public InstalmentScheduleRequest withTotalAmount(Integer totalAmount) { - this.totalAmount = totalAmount; - return this; - } - - public enum Currency { - @SerializedName("AUD") - AUD, @SerializedName("CAD") - CAD, @SerializedName("DKK") - DKK, @SerializedName("EUR") - EUR, @SerializedName("GBP") - GBP, @SerializedName("NZD") - NZD, @SerializedName("SEK") - SEK, @SerializedName("USD") - USD, @SerializedName("unknown") - UNKNOWN; - - @Override - public String toString() { - return name(); - } - } - } - public static class Links { private String creditor; private String customer; @@ -1652,6 +1442,1916 @@ public String toString() { } } + /** + * Request class for {@link BillingRequestService#createWithInstalmentsWithDates }. + * + *

+ * Important: All properties associated with `instalment_schedule_request` are + * only supported for ACH and PAD schemes. + *

+ */ + public static final class BillingRequestCreateWithInstalmentsWithDatesRequest + extends IdempotentPostRequest { + private Boolean fallbackEnabled; + private InstalmentScheduleRequest instalmentScheduleRequest; + private Links links; + private MandateRequest mandateRequest; + private Map metadata; + private PaymentRequest paymentRequest; + + /** + * (Optional) If true, this billing request can fallback from instant payment to direct + * debit. Should not be set if GoCardless payment intelligence feature is used. + * + * See [Billing Requests: Retain customers with + * Fallbacks](https://developer.gocardless.com/billing-requests/retain-customers-with-fallbacks/) + * for more information. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withFallbackEnabled( + Boolean fallbackEnabled) { + this.fallbackEnabled = fallbackEnabled; + return this; + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequest( + InstalmentScheduleRequest instalmentScheduleRequest) { + this.instalmentScheduleRequest = instalmentScheduleRequest; + return this; + } + + /** + * The amount to be deducted from each payment as an app fee, to be paid to the partner + * integration which created the subscription, in the lowest denomination for the currency + * (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestAppFee( + Integer appFee) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withAppFee(appFee); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestCurrency( + String currency) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withCurrency(currency); + return this; + } + + /** + * An explicit array of instalment payments, each specifying at least an `amount` and + * `charge_date`. See [create (with dates)](#instalment-schedules-create-with-dates) + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestInstalments( + List instalments) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withInstalments(instalments); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestMetadata( + Map metadata) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withMetadata(metadata); + return this; + } + + /** + * Name of the instalment schedule, up to 100 chars. This name will also be copied to the + * payments of the instalment schedule if you use schedule-based creation. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestName( + String name) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withName(name); + return this; + } + + /** + * An optional payment reference. This will be set as the reference on each payment created + * and will appear on your customer's bank statement. See the documentation for the [create + * payment endpoint](#payments-create-a-payment) for more details.
+ */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestPaymentReference( + String paymentReference) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withPaymentReference(paymentReference); + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to be + * enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestRetryIfPossible( + Boolean retryIfPossible) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withRetryIfPossible(retryIfPossible); + return this; + } + + /** + * The total amount of the instalment schedule, defined as the sum of all individual + * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in EUR). + * If the requested payment amounts do not sum up correctly, a validation error will be + * returned. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withInstalmentScheduleRequestTotalAmount( + Integer totalAmount) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withTotalAmount(totalAmount); + return this; + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withLinks(Links links) { + this.links = links; + return this; + } + + /** + * ID of the associated [creditor](#core-endpoints-creditors). Only required if your account + * manages multiple creditors. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withLinksCreditor( + String creditor) { + if (links == null) { + links = new Links(); + } + links.withCreditor(creditor); + return this; + } + + /** + * ID of the [customer](#core-endpoints-customers) against which this request should be + * made. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withLinksCustomer( + String customer) { + if (links == null) { + links = new Links(); + } + links.withCustomer(customer); + return this; + } + + /** + * (Optional) ID of the [customer_bank_account](#core-endpoints-customer-bank-accounts) + * against which this request should be made. + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withLinksCustomerBankAccount( + String customerBankAccount) { + if (links == null) { + links = new Links(); + } + links.withCustomerBankAccount(customerBankAccount); + return this; + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequest( + MandateRequest mandateRequest) { + this.mandateRequest = mandateRequest; + return this; + } + + /** + * This field is ACH specific, sometimes referred to as [SEC + * code](https://www.moderntreasury.com/learn/sec-codes). + * + * This is the way that the payer gives authorisation to the merchant. web: Authorisation is + * Internet Initiated or via Mobile Entry (maps to SEC code: WEB) telephone: Authorisation + * is provided orally over telephone (maps to SEC code: TEL) paper: Authorisation is + * provided in writing and signed, or similarly authenticated (maps to SEC code: PPD) + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestAuthorisationSource( + MandateRequest.AuthorisationSource authorisationSource) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withAuthorisationSource(authorisationSource); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestCurrency( + String currency) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withCurrency(currency); + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to the + * payer when authorising the billing request. + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestDescription( + String description) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withDescription(description); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestMetadata( + Map metadata) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withMetadata(metadata); + return this; + } + + /** + * Unique reference. Different schemes have different length and [character + * set](#appendix-character-sets) requirements. GoCardless will generate a unique reference + * satisfying the different scheme requirements if this field is left blank. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestReference( + String reference) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withReference(reference); + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada (CAD) + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestScheme( + String scheme) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withScheme(scheme); + return this; + } + + /** + * Verification preference for the mandate. One of: + *
    + *
  • `minimum`: only verify if absolutely required, such as when part of scheme rules
  • + *
  • `recommended`: in addition to `minimum`, use the GoCardless payment intelligence + * solution to decide if a payer should be verified
  • + *
  • `when_available`: if verification mechanisms are available, use them
  • + *
  • `always`: as `when_available`, but fail to create the Billing Request if a mechanism + * isn't available
  • + *
+ * + * By default, all Billing Requests use the `recommended` verification preference. It uses + * GoCardless payment intelligence solution to determine if a payer is fraudulent or not. + * The verification mechanism is based on the response and the payer may be asked to verify + * themselves. If the feature is not available, `recommended` behaves like `minimum`. + * + * If you never wish to take advantage of our reduced risk products and Verified Mandates as + * they are released in new schemes, please use the `minimum` verification preference. + * + * See [Billing Requests: Creating Verified + * Mandates](https://developer.gocardless.com/getting-started/billing-requests/verified-mandates/) + * for more information. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMandateRequestVerify( + MandateRequest.Verify verify) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withVerify(verify); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMetadata( + Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withMetadata(String key, + String value) { + if (metadata == null) { + metadata = new HashMap<>(); + } + metadata.put(key, value); + return this; + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequest( + PaymentRequest paymentRequest) { + this.paymentRequest = paymentRequest; + return this; + } + + /** + * Amount in minor unit (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestAmount( + Integer amount) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withAmount(amount); + return this; + } + + /** + * The amount to be deducted from the payment as an app fee, to be paid to the partner + * integration which created the billing request, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestAppFee( + Integer appFee) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withAppFee(appFee); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestCurrency( + String currency) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withCurrency(currency); + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to the + * payer when authorising the billing request. + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestDescription( + String description) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withDescription(description); + return this; + } + + /** + * This field will decide how GoCardless handles settlement of funds from the customer. + * + * - `managed` will be moved through GoCardless' account, batched, and payed out. - `direct` + * will be a direct transfer from the payer's account to the merchant where invoicing will + * be handled separately. + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestFundsSettlement( + PaymentRequest.FundsSettlement fundsSettlement) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withFundsSettlement(fundsSettlement); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestMetadata( + Map metadata) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withMetadata(metadata); + return this; + } + + /** + * A custom payment reference defined by the merchant. It is only available for payments + * using the Direct Funds settlement model on the Faster Payments scheme. + * + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestReference( + String reference) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withReference(reference); + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to be + * enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestRetryIfPossible( + Boolean retryIfPossible) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withRetryIfPossible(retryIfPossible); + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada (CAD) + */ + public BillingRequestCreateWithInstalmentsWithDatesRequest withPaymentRequestScheme( + String scheme) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withScheme(scheme); + return this; + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withIdempotencyKey( + String idempotencyKey) { + super.setIdempotencyKey(idempotencyKey); + return this; + } + + @Override + protected GetRequest handleConflict(HttpClient httpClient, String id) { + BillingRequestGetRequest request = new BillingRequestGetRequest(httpClient, id); + for (Map.Entry header : this.getCustomHeaders().entrySet()) { + request = request.withHeader(header.getKey(), header.getValue()); + } + return request; + } + + private BillingRequestCreateWithInstalmentsWithDatesRequest(HttpClient httpClient) { + super(httpClient); + } + + public BillingRequestCreateWithInstalmentsWithDatesRequest withHeader(String headerName, + String headerValue) { + this.addHeader(headerName, headerValue); + return this; + } + + @Override + protected String getPathTemplate() { + return "billing_requests"; + } + + @Override + protected String getEnvelope() { + return "billing_requests"; + } + + @Override + protected Class getResponseClass() { + return BillingRequest.class; + } + + @Override + protected boolean hasBody() { + return true; + } + + public static class Instalments { + private Integer amount; + private String chargeDate; + private String description; + + /** + * Amount, in the lowest denomination for the currency (e.g. pence in GBP, cents in + * EUR). + */ + public Instalments withAmount(Integer amount) { + this.amount = amount; + return this; + } + + /** + * A future date on which the payment should be collected. If the date is before the + * next_possible_charge_date on the [mandate](#core-endpoints-mandates), it will be + * automatically rolled forwards to that date. + */ + public Instalments withChargeDate(String chargeDate) { + this.chargeDate = chargeDate; + return this; + } + + /** + * A human-readable description of the payment. This will be included in the + * notification email GoCardless sends to your customer if your organisation does not + * send its own notifications (see [compliance + * requirements](#appendix-compliance-requirements)). + */ + public Instalments withDescription(String description) { + this.description = description; + return this; + } + + public Map getQueryParams() { + ImmutableMap.Builder params = ImmutableMap.builder(); + if (amount != null) { + params.put("instalments[amount]", amount); + } + if (chargeDate != null) { + params.put("instalments[charge_date]", chargeDate); + } + if (description != null) { + params.put("instalments[description]", description); + } + return params.build(); + } + } + + public static class InstalmentScheduleRequest { + private Integer appFee; + private String currency; + private List instalments; + private Map metadata; + private String name; + private String paymentReference; + private Boolean retryIfPossible; + private Integer totalAmount; + + /** + * The amount to be deducted from each payment as an app fee, to be paid to the partner + * integration which created the subscription, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public InstalmentScheduleRequest withAppFee(Integer appFee) { + this.appFee = appFee; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public InstalmentScheduleRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * An explicit array of instalment payments, each specifying at least an `amount` and + * `charge_date`. See [create (with dates)](#instalment-schedules-create-with-dates) + */ + public InstalmentScheduleRequest withInstalments(List instalments) { + this.instalments = instalments; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public InstalmentScheduleRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Name of the instalment schedule, up to 100 chars. This name will also be copied to + * the payments of the instalment schedule if you use schedule-based creation. + */ + public InstalmentScheduleRequest withName(String name) { + this.name = name; + return this; + } + + /** + * An optional payment reference. This will be set as the reference on each payment + * created and will appear on your customer's bank statement. See the documentation for + * the [create payment endpoint](#payments-create-a-payment) for more details.
+ */ + public InstalmentScheduleRequest withPaymentReference(String paymentReference) { + this.paymentReference = paymentReference; + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to + * be enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public InstalmentScheduleRequest withRetryIfPossible(Boolean retryIfPossible) { + this.retryIfPossible = retryIfPossible; + return this; + } + + /** + * The total amount of the instalment schedule, defined as the sum of all individual + * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in + * EUR). If the requested payment amounts do not sum up correctly, a validation error + * will be returned. + */ + public InstalmentScheduleRequest withTotalAmount(Integer totalAmount) { + this.totalAmount = totalAmount; + return this; + } + } + + public static class Links { + private String creditor; + private String customer; + private String customerBankAccount; + + /** + * ID of the associated [creditor](#core-endpoints-creditors). Only required if your + * account manages multiple creditors. + */ + public Links withCreditor(String creditor) { + this.creditor = creditor; + return this; + } + + /** + * ID of the [customer](#core-endpoints-customers) against which this request should be + * made. + */ + public Links withCustomer(String customer) { + this.customer = customer; + return this; + } + + /** + * (Optional) ID of the [customer_bank_account](#core-endpoints-customer-bank-accounts) + * against which this request should be made. + * + */ + public Links withCustomerBankAccount(String customerBankAccount) { + this.customerBankAccount = customerBankAccount; + return this; + } + } + + public static class MandateRequest { + private AuthorisationSource authorisationSource; + private String currency; + private String description; + private Map metadata; + private String reference; + private String scheme; + private Verify verify; + + /** + * This field is ACH specific, sometimes referred to as [SEC + * code](https://www.moderntreasury.com/learn/sec-codes). + * + * This is the way that the payer gives authorisation to the merchant. web: + * Authorisation is Internet Initiated or via Mobile Entry (maps to SEC code: WEB) + * telephone: Authorisation is provided orally over telephone (maps to SEC code: TEL) + * paper: Authorisation is provided in writing and signed, or similarly authenticated + * (maps to SEC code: PPD) + * + */ + public MandateRequest withAuthorisationSource(AuthorisationSource authorisationSource) { + this.authorisationSource = authorisationSource; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public MandateRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to + * the payer when authorising the billing request. + * + */ + public MandateRequest withDescription(String description) { + this.description = description; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public MandateRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Unique reference. Different schemes have different length and [character + * set](#appendix-character-sets) requirements. GoCardless will generate a unique + * reference satisfying the different scheme requirements if this field is left blank. + */ + public MandateRequest withReference(String reference) { + this.reference = reference; + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada + * (CAD) + */ + public MandateRequest withScheme(String scheme) { + this.scheme = scheme; + return this; + } + + /** + * Verification preference for the mandate. One of: + *
    + *
  • `minimum`: only verify if absolutely required, such as when part of scheme + * rules
  • + *
  • `recommended`: in addition to `minimum`, use the GoCardless payment intelligence + * solution to decide if a payer should be verified
  • + *
  • `when_available`: if verification mechanisms are available, use them
  • + *
  • `always`: as `when_available`, but fail to create the Billing Request if a + * mechanism isn't available
  • + *
+ * + * By default, all Billing Requests use the `recommended` verification preference. It + * uses GoCardless payment intelligence solution to determine if a payer is fraudulent + * or not. The verification mechanism is based on the response and the payer may be + * asked to verify themselves. If the feature is not available, `recommended` behaves + * like `minimum`. + * + * If you never wish to take advantage of our reduced risk products and Verified + * Mandates as they are released in new schemes, please use the `minimum` verification + * preference. + * + * See [Billing Requests: Creating Verified + * Mandates](https://developer.gocardless.com/getting-started/billing-requests/verified-mandates/) + * for more information. + */ + public MandateRequest withVerify(Verify verify) { + this.verify = verify; + return this; + } + + public enum AuthorisationSource { + @SerializedName("web") + WEB, @SerializedName("telephone") + TELEPHONE, @SerializedName("paper") + PAPER, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + + public enum Verify { + @SerializedName("minimum") + MINIMUM, @SerializedName("recommended") + RECOMMENDED, @SerializedName("when_available") + WHEN_AVAILABLE, @SerializedName("always") + ALWAYS, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + } + + public static class PaymentRequest { + private Integer amount; + private Integer appFee; + private String currency; + private String description; + private FundsSettlement fundsSettlement; + private Map metadata; + private String reference; + private Boolean retryIfPossible; + private String scheme; + + /** + * Amount in minor unit (e.g. pence in GBP, cents in EUR). + */ + public PaymentRequest withAmount(Integer amount) { + this.amount = amount; + return this; + } + + /** + * The amount to be deducted from the payment as an app fee, to be paid to the partner + * integration which created the billing request, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public PaymentRequest withAppFee(Integer appFee) { + this.appFee = appFee; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public PaymentRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to + * the payer when authorising the billing request. + * + */ + public PaymentRequest withDescription(String description) { + this.description = description; + return this; + } + + /** + * This field will decide how GoCardless handles settlement of funds from the customer. + * + * - `managed` will be moved through GoCardless' account, batched, and payed out. - + * `direct` will be a direct transfer from the payer's account to the merchant where + * invoicing will be handled separately. + * + */ + public PaymentRequest withFundsSettlement(FundsSettlement fundsSettlement) { + this.fundsSettlement = fundsSettlement; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public PaymentRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * A custom payment reference defined by the merchant. It is only available for payments + * using the Direct Funds settlement model on the Faster Payments scheme. + * + */ + public PaymentRequest withReference(String reference) { + this.reference = reference; + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to + * be enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public PaymentRequest withRetryIfPossible(Boolean retryIfPossible) { + this.retryIfPossible = retryIfPossible; + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada + * (CAD) + */ + public PaymentRequest withScheme(String scheme) { + this.scheme = scheme; + return this; + } + + public enum FundsSettlement { + @SerializedName("managed") + MANAGED, @SerializedName("direct") + DIRECT, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + } + } + + /** + * Request class for {@link BillingRequestService#createWithInstalmentsWithSchedule }. + * + *

+ * Important: All properties associated with `instalment_schedule_request` are + * only supported for ACH and PAD schemes. + *

+ */ + public static final class BillingRequestCreateWithInstalmentsWithScheduleRequest + extends IdempotentPostRequest { + private Boolean fallbackEnabled; + private InstalmentScheduleRequest instalmentScheduleRequest; + private Links links; + private MandateRequest mandateRequest; + private Map metadata; + private PaymentRequest paymentRequest; + + /** + * (Optional) If true, this billing request can fallback from instant payment to direct + * debit. Should not be set if GoCardless payment intelligence feature is used. + * + * See [Billing Requests: Retain customers with + * Fallbacks](https://developer.gocardless.com/billing-requests/retain-customers-with-fallbacks/) + * for more information. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withFallbackEnabled( + Boolean fallbackEnabled) { + this.fallbackEnabled = fallbackEnabled; + return this; + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequest( + InstalmentScheduleRequest instalmentScheduleRequest) { + this.instalmentScheduleRequest = instalmentScheduleRequest; + return this; + } + + /** + * The amount to be deducted from each payment as an app fee, to be paid to the partner + * integration which created the subscription, in the lowest denomination for the currency + * (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestAppFee( + Integer appFee) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withAppFee(appFee); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestCurrency( + String currency) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withCurrency(currency); + return this; + } + + /** + * Frequency of the payments you want to create, together with an array of payment amounts + * to be collected, with a specified start date for the first payment. See [create (with + * schedule)](#instalment-schedules-create-with-schedule) + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestInstalments( + Instalments instalments) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withInstalments(instalments); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestMetadata( + Map metadata) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withMetadata(metadata); + return this; + } + + /** + * Name of the instalment schedule, up to 100 chars. This name will also be copied to the + * payments of the instalment schedule if you use schedule-based creation. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestName( + String name) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withName(name); + return this; + } + + /** + * An optional payment reference. This will be set as the reference on each payment created + * and will appear on your customer's bank statement. See the documentation for the [create + * payment endpoint](#payments-create-a-payment) for more details.
+ */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestPaymentReference( + String paymentReference) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withPaymentReference(paymentReference); + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to be + * enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestRetryIfPossible( + Boolean retryIfPossible) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withRetryIfPossible(retryIfPossible); + return this; + } + + /** + * The total amount of the instalment schedule, defined as the sum of all individual + * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in EUR). + * If the requested payment amounts do not sum up correctly, a validation error will be + * returned. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withInstalmentScheduleRequestTotalAmount( + Integer totalAmount) { + if (instalmentScheduleRequest == null) { + instalmentScheduleRequest = new InstalmentScheduleRequest(); + } + instalmentScheduleRequest.withTotalAmount(totalAmount); + return this; + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withLinks(Links links) { + this.links = links; + return this; + } + + /** + * ID of the associated [creditor](#core-endpoints-creditors). Only required if your account + * manages multiple creditors. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withLinksCreditor( + String creditor) { + if (links == null) { + links = new Links(); + } + links.withCreditor(creditor); + return this; + } + + /** + * ID of the [customer](#core-endpoints-customers) against which this request should be + * made. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withLinksCustomer( + String customer) { + if (links == null) { + links = new Links(); + } + links.withCustomer(customer); + return this; + } + + /** + * (Optional) ID of the [customer_bank_account](#core-endpoints-customer-bank-accounts) + * against which this request should be made. + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withLinksCustomerBankAccount( + String customerBankAccount) { + if (links == null) { + links = new Links(); + } + links.withCustomerBankAccount(customerBankAccount); + return this; + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequest( + MandateRequest mandateRequest) { + this.mandateRequest = mandateRequest; + return this; + } + + /** + * This field is ACH specific, sometimes referred to as [SEC + * code](https://www.moderntreasury.com/learn/sec-codes). + * + * This is the way that the payer gives authorisation to the merchant. web: Authorisation is + * Internet Initiated or via Mobile Entry (maps to SEC code: WEB) telephone: Authorisation + * is provided orally over telephone (maps to SEC code: TEL) paper: Authorisation is + * provided in writing and signed, or similarly authenticated (maps to SEC code: PPD) + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestAuthorisationSource( + MandateRequest.AuthorisationSource authorisationSource) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withAuthorisationSource(authorisationSource); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestCurrency( + String currency) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withCurrency(currency); + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to the + * payer when authorising the billing request. + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestDescription( + String description) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withDescription(description); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestMetadata( + Map metadata) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withMetadata(metadata); + return this; + } + + /** + * Unique reference. Different schemes have different length and [character + * set](#appendix-character-sets) requirements. GoCardless will generate a unique reference + * satisfying the different scheme requirements if this field is left blank. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestReference( + String reference) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withReference(reference); + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada (CAD) + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestScheme( + String scheme) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withScheme(scheme); + return this; + } + + /** + * Verification preference for the mandate. One of: + *
    + *
  • `minimum`: only verify if absolutely required, such as when part of scheme rules
  • + *
  • `recommended`: in addition to `minimum`, use the GoCardless payment intelligence + * solution to decide if a payer should be verified
  • + *
  • `when_available`: if verification mechanisms are available, use them
  • + *
  • `always`: as `when_available`, but fail to create the Billing Request if a mechanism + * isn't available
  • + *
+ * + * By default, all Billing Requests use the `recommended` verification preference. It uses + * GoCardless payment intelligence solution to determine if a payer is fraudulent or not. + * The verification mechanism is based on the response and the payer may be asked to verify + * themselves. If the feature is not available, `recommended` behaves like `minimum`. + * + * If you never wish to take advantage of our reduced risk products and Verified Mandates as + * they are released in new schemes, please use the `minimum` verification preference. + * + * See [Billing Requests: Creating Verified + * Mandates](https://developer.gocardless.com/getting-started/billing-requests/verified-mandates/) + * for more information. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMandateRequestVerify( + MandateRequest.Verify verify) { + if (mandateRequest == null) { + mandateRequest = new MandateRequest(); + } + mandateRequest.withVerify(verify); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMetadata( + Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withMetadata(String key, + String value) { + if (metadata == null) { + metadata = new HashMap<>(); + } + metadata.put(key, value); + return this; + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequest( + PaymentRequest paymentRequest) { + this.paymentRequest = paymentRequest; + return this; + } + + /** + * Amount in minor unit (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestAmount( + Integer amount) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withAmount(amount); + return this; + } + + /** + * The amount to be deducted from the payment as an app fee, to be paid to the partner + * integration which created the billing request, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestAppFee( + Integer appFee) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withAppFee(appFee); + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. Currently + * "USD" and "CAD" are supported. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestCurrency( + String currency) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withCurrency(currency); + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to the + * payer when authorising the billing request. + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestDescription( + String description) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withDescription(description); + return this; + } + + /** + * This field will decide how GoCardless handles settlement of funds from the customer. + * + * - `managed` will be moved through GoCardless' account, batched, and payed out. - `direct` + * will be a direct transfer from the payer's account to the merchant where invoicing will + * be handled separately. + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestFundsSettlement( + PaymentRequest.FundsSettlement fundsSettlement) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withFundsSettlement(fundsSettlement); + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestMetadata( + Map metadata) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withMetadata(metadata); + return this; + } + + /** + * A custom payment reference defined by the merchant. It is only available for payments + * using the Direct Funds settlement model on the Faster Payments scheme. + * + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestReference( + String reference) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withReference(reference); + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to be + * enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestRetryIfPossible( + Boolean retryIfPossible) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withRetryIfPossible(retryIfPossible); + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada (CAD) + */ + public BillingRequestCreateWithInstalmentsWithScheduleRequest withPaymentRequestScheme( + String scheme) { + if (paymentRequest == null) { + paymentRequest = new PaymentRequest(); + } + paymentRequest.withScheme(scheme); + return this; + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withIdempotencyKey( + String idempotencyKey) { + super.setIdempotencyKey(idempotencyKey); + return this; + } + + @Override + protected GetRequest handleConflict(HttpClient httpClient, String id) { + BillingRequestGetRequest request = new BillingRequestGetRequest(httpClient, id); + for (Map.Entry header : this.getCustomHeaders().entrySet()) { + request = request.withHeader(header.getKey(), header.getValue()); + } + return request; + } + + private BillingRequestCreateWithInstalmentsWithScheduleRequest(HttpClient httpClient) { + super(httpClient); + } + + public BillingRequestCreateWithInstalmentsWithScheduleRequest withHeader(String headerName, + String headerValue) { + this.addHeader(headerName, headerValue); + return this; + } + + @Override + protected String getPathTemplate() { + return "billing_requests"; + } + + @Override + protected String getEnvelope() { + return "billing_requests"; + } + + @Override + protected Class getResponseClass() { + return BillingRequest.class; + } + + @Override + protected boolean hasBody() { + return true; + } + + public static class Instalments { + private List amounts; + private Integer interval; + private IntervalUnit intervalUnit; + private String startDate; + + /** + * List of amounts of each instalment, in the lowest denomination for the currency (e.g. + * cents in USD). + * + */ + public Instalments withAmounts(List amounts) { + this.amounts = amounts; + return this; + } + + /** + * Number of `interval_units` between charge dates. Must be greater than or equal to + * `1`. + * + */ + public Instalments withInterval(Integer interval) { + this.interval = interval; + return this; + } + + /** + * The unit of time between customer charge dates. One of `weekly`, `monthly` or + * `yearly`. + */ + public Instalments withIntervalUnit(IntervalUnit intervalUnit) { + this.intervalUnit = intervalUnit; + return this; + } + + /** + * The date on which the first payment should be charged. Must be on or after the + * [mandate](#core-endpoints-mandates)'s `next_possible_charge_date`. When left blank + * and `month` or `day_of_month` are provided, this will be set to the date of the first + * payment. If created without `month` or `day_of_month` this will be set as the + * mandate's `next_possible_charge_date` + */ + public Instalments withStartDate(String startDate) { + this.startDate = startDate; + return this; + } + + public Map getQueryParams() { + ImmutableMap.Builder params = ImmutableMap.builder(); + if (amounts != null) { + params.put("instalments[amounts]", amounts); + } + if (interval != null) { + params.put("instalments[interval]", interval); + } + if (intervalUnit != null) { + params.put("instalments[interval_unit]", intervalUnit); + } + if (startDate != null) { + params.put("instalments[start_date]", startDate); + } + return params.build(); + } + + public enum IntervalUnit { + @SerializedName("weekly") + WEEKLY, @SerializedName("monthly") + MONTHLY, @SerializedName("yearly") + YEARLY, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + } + + public static class InstalmentScheduleRequest { + private Integer appFee; + private String currency; + private Instalments instalments; + private Map metadata; + private String name; + private String paymentReference; + private Boolean retryIfPossible; + private Integer totalAmount; + + /** + * The amount to be deducted from each payment as an app fee, to be paid to the partner + * integration which created the subscription, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public InstalmentScheduleRequest withAppFee(Integer appFee) { + this.appFee = appFee; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public InstalmentScheduleRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * Frequency of the payments you want to create, together with an array of payment + * amounts to be collected, with a specified start date for the first payment. See + * [create (with schedule)](#instalment-schedules-create-with-schedule) + * + */ + public InstalmentScheduleRequest withInstalments(Instalments instalments) { + this.instalments = instalments; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public InstalmentScheduleRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Name of the instalment schedule, up to 100 chars. This name will also be copied to + * the payments of the instalment schedule if you use schedule-based creation. + */ + public InstalmentScheduleRequest withName(String name) { + this.name = name; + return this; + } + + /** + * An optional payment reference. This will be set as the reference on each payment + * created and will appear on your customer's bank statement. See the documentation for + * the [create payment endpoint](#payments-create-a-payment) for more details.
+ */ + public InstalmentScheduleRequest withPaymentReference(String paymentReference) { + this.paymentReference = paymentReference; + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to + * be enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public InstalmentScheduleRequest withRetryIfPossible(Boolean retryIfPossible) { + this.retryIfPossible = retryIfPossible; + return this; + } + + /** + * The total amount of the instalment schedule, defined as the sum of all individual + * payments, in the lowest denomination for the currency (e.g. pence in GBP, cents in + * EUR). If the requested payment amounts do not sum up correctly, a validation error + * will be returned. + */ + public InstalmentScheduleRequest withTotalAmount(Integer totalAmount) { + this.totalAmount = totalAmount; + return this; + } + } + + public static class Links { + private String creditor; + private String customer; + private String customerBankAccount; + + /** + * ID of the associated [creditor](#core-endpoints-creditors). Only required if your + * account manages multiple creditors. + */ + public Links withCreditor(String creditor) { + this.creditor = creditor; + return this; + } + + /** + * ID of the [customer](#core-endpoints-customers) against which this request should be + * made. + */ + public Links withCustomer(String customer) { + this.customer = customer; + return this; + } + + /** + * (Optional) ID of the [customer_bank_account](#core-endpoints-customer-bank-accounts) + * against which this request should be made. + * + */ + public Links withCustomerBankAccount(String customerBankAccount) { + this.customerBankAccount = customerBankAccount; + return this; + } + } + + public static class MandateRequest { + private AuthorisationSource authorisationSource; + private String currency; + private String description; + private Map metadata; + private String reference; + private String scheme; + private Verify verify; + + /** + * This field is ACH specific, sometimes referred to as [SEC + * code](https://www.moderntreasury.com/learn/sec-codes). + * + * This is the way that the payer gives authorisation to the merchant. web: + * Authorisation is Internet Initiated or via Mobile Entry (maps to SEC code: WEB) + * telephone: Authorisation is provided orally over telephone (maps to SEC code: TEL) + * paper: Authorisation is provided in writing and signed, or similarly authenticated + * (maps to SEC code: PPD) + * + */ + public MandateRequest withAuthorisationSource(AuthorisationSource authorisationSource) { + this.authorisationSource = authorisationSource; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public MandateRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to + * the payer when authorising the billing request. + * + */ + public MandateRequest withDescription(String description) { + this.description = description; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public MandateRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * Unique reference. Different schemes have different length and [character + * set](#appendix-character-sets) requirements. GoCardless will generate a unique + * reference satisfying the different scheme requirements if this field is left blank. + */ + public MandateRequest withReference(String reference) { + this.reference = reference; + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada + * (CAD) + */ + public MandateRequest withScheme(String scheme) { + this.scheme = scheme; + return this; + } + + /** + * Verification preference for the mandate. One of: + *
    + *
  • `minimum`: only verify if absolutely required, such as when part of scheme + * rules
  • + *
  • `recommended`: in addition to `minimum`, use the GoCardless payment intelligence + * solution to decide if a payer should be verified
  • + *
  • `when_available`: if verification mechanisms are available, use them
  • + *
  • `always`: as `when_available`, but fail to create the Billing Request if a + * mechanism isn't available
  • + *
+ * + * By default, all Billing Requests use the `recommended` verification preference. It + * uses GoCardless payment intelligence solution to determine if a payer is fraudulent + * or not. The verification mechanism is based on the response and the payer may be + * asked to verify themselves. If the feature is not available, `recommended` behaves + * like `minimum`. + * + * If you never wish to take advantage of our reduced risk products and Verified + * Mandates as they are released in new schemes, please use the `minimum` verification + * preference. + * + * See [Billing Requests: Creating Verified + * Mandates](https://developer.gocardless.com/getting-started/billing-requests/verified-mandates/) + * for more information. + */ + public MandateRequest withVerify(Verify verify) { + this.verify = verify; + return this; + } + + public enum AuthorisationSource { + @SerializedName("web") + WEB, @SerializedName("telephone") + TELEPHONE, @SerializedName("paper") + PAPER, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + + public enum Verify { + @SerializedName("minimum") + MINIMUM, @SerializedName("recommended") + RECOMMENDED, @SerializedName("when_available") + WHEN_AVAILABLE, @SerializedName("always") + ALWAYS, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + } + + public static class PaymentRequest { + private Integer amount; + private Integer appFee; + private String currency; + private String description; + private FundsSettlement fundsSettlement; + private Map metadata; + private String reference; + private Boolean retryIfPossible; + private String scheme; + + /** + * Amount in minor unit (e.g. pence in GBP, cents in EUR). + */ + public PaymentRequest withAmount(Integer amount) { + this.amount = amount; + return this; + } + + /** + * The amount to be deducted from the payment as an app fee, to be paid to the partner + * integration which created the billing request, in the lowest denomination for the + * currency (e.g. pence in GBP, cents in EUR). + */ + public PaymentRequest withAppFee(Integer appFee) { + this.appFee = appFee; + return this; + } + + /** + * [ISO 4217](http://en.wikipedia.org/wiki/ISO_4217#Active_codes) currency code. + * Currently "USD" and "CAD" are supported. + */ + public PaymentRequest withCurrency(String currency) { + this.currency = currency; + return this; + } + + /** + * A human-readable description of the payment and/or mandate. This will be displayed to + * the payer when authorising the billing request. + * + */ + public PaymentRequest withDescription(String description) { + this.description = description; + return this; + } + + /** + * This field will decide how GoCardless handles settlement of funds from the customer. + * + * - `managed` will be moved through GoCardless' account, batched, and payed out. - + * `direct` will be a direct transfer from the payer's account to the merchant where + * invoicing will be handled separately. + * + */ + public PaymentRequest withFundsSettlement(FundsSettlement fundsSettlement) { + this.fundsSettlement = fundsSettlement; + return this; + } + + /** + * Key-value store of custom data. Up to 3 keys are permitted, with key names up to 50 + * characters and values up to 500 characters. + */ + public PaymentRequest withMetadata(Map metadata) { + this.metadata = metadata; + return this; + } + + /** + * A custom payment reference defined by the merchant. It is only available for payments + * using the Direct Funds settlement model on the Faster Payments scheme. + * + */ + public PaymentRequest withReference(String reference) { + this.reference = reference; + return this; + } + + /** + * On failure, automatically retry payments using [intelligent + * retries](#success-intelligent-retries). Default is `false`. + *

+ * Important: To be able to use intelligent retries, Success+ needs to + * be enabled in [GoCardless dashboard](https://manage.gocardless.com/success-plus). + *

+ */ + public PaymentRequest withRetryIfPossible(Boolean retryIfPossible) { + this.retryIfPossible = retryIfPossible; + return this; + } + + /** + * Payment scheme. Currently supports `ach` in the US (USD) and 'pad' in the Canada + * (CAD) + */ + public PaymentRequest withScheme(String scheme) { + this.scheme = scheme; + return this; + } + + public enum FundsSettlement { + @SerializedName("managed") + MANAGED, @SerializedName("direct") + DIRECT, @SerializedName("unknown") + UNKNOWN; + + @Override + public String toString() { + return name().toLowerCase(); + } + } + } + } + /** * Request class for {@link BillingRequestService#collectCustomerDetails }. * diff --git a/src/main/java/com/gocardless/services/InstalmentScheduleService.java b/src/main/java/com/gocardless/services/InstalmentScheduleService.java index 090a45f3..fbe604c6 100644 --- a/src/main/java/com/gocardless/services/InstalmentScheduleService.java +++ b/src/main/java/com/gocardless/services/InstalmentScheduleService.java @@ -153,7 +153,7 @@ public InstalmentScheduleCreateWithDatesRequest withCurrency(Currency currency) /** * An explicit array of instalment payments, each specifying at least an `amount` and - * `charge_date`. + * `charge_date`. See [create (with dates)](#instalment-schedules-create-with-dates) */ public InstalmentScheduleCreateWithDatesRequest withInstalments( List instalments) { @@ -163,7 +163,7 @@ public InstalmentScheduleCreateWithDatesRequest withInstalments( /** * An explicit array of instalment payments, each specifying at least an `amount` and - * `charge_date`. + * `charge_date`. See [create (with dates)](#instalment-schedules-create-with-dates) */ public InstalmentScheduleCreateWithDatesRequest withInstalments(Instalments instalments) { if (this.instalments == null) { @@ -433,7 +433,8 @@ public InstalmentScheduleCreateWithScheduleRequest withCurrency(Currency currenc /** * Frequency of the payments you want to create, together with an array of payment amounts - * to be collected, with a specified start date for the first payment. + * to be collected, with a specified start date for the first payment. See [create (with + * schedule)](#instalment-schedules-create-with-schedule) * */ public InstalmentScheduleCreateWithScheduleRequest withInstalments( diff --git a/src/main/java/com/gocardless/services/MandatePdfService.java b/src/main/java/com/gocardless/services/MandatePdfService.java index 57ed02a7..f81e501e 100644 --- a/src/main/java/com/gocardless/services/MandatePdfService.java +++ b/src/main/java/com/gocardless/services/MandatePdfService.java @@ -245,6 +245,18 @@ public MandatePdfCreateRequest withLinks(Links links) { return this; } + /** + * ID of an existing [creditor](#core-endpoints-creditors). Only required if your account + * manages multiple creditors. + */ + public MandatePdfCreateRequest withLinksCreditor(String creditor) { + if (links == null) { + links = new Links(); + } + links.withCreditor(creditor); + return this; + } + /** * ID of an existing [mandate](#core-endpoints-mandates) to build the PDF from. The * customer's bank details will be censored in the generated PDF. No other parameters may be @@ -391,8 +403,18 @@ public String toString() { } public static class Links { + private String creditor; private String mandate; + /** + * ID of an existing [creditor](#core-endpoints-creditors). Only required if your + * account manages multiple creditors. + */ + public Links withCreditor(String creditor) { + this.creditor = creditor; + return this; + } + /** * ID of an existing [mandate](#core-endpoints-mandates) to build the PDF from. The * customer's bank details will be censored in the generated PDF. No other parameters