com.stripe.param.billingportal.SessionCreateParams Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.param.billingportal;
import com.google.gson.annotations.SerializedName;
import com.stripe.net.ApiRequestParams;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import lombok.Getter;
@Getter
public class SessionCreateParams extends ApiRequestParams {
/**
* The ID of an existing configuration to use for
* this session, describing its functionality and features. If not specified, the session uses the
* default configuration.
*/
@SerializedName("configuration")
String configuration;
/** Required. The ID of an existing customer. */
@SerializedName("customer")
String customer;
/** Specifies which fields in the response should be expanded. */
@SerializedName("expand")
List expand;
/**
* Map of extra parameters for custom features not available in this client library. The content
* in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
* key/value pair is serialized as if the key is a root-level field (serialized) name in this
* param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/**
* Information about a specific flow for the customer to go through. See the docs to learn more
* about using customer portal deep links and flows.
*/
@SerializedName("flow_data")
FlowData flowData;
/**
* The IETF language tag of the locale customer portal is displayed in. If blank or auto, the
* customer’s {@code preferred_locales} or browser’s locale is used.
*/
@SerializedName("locale")
Locale locale;
/**
* The {@code on_behalf_of} account to use for this session. When specified, only subscriptions
* and invoices with this {@code on_behalf_of} account appear in the portal. For more information,
* see the docs.
* Use the Accounts
* API to modify the {@code on_behalf_of} account's branding settings, which the portal
* displays.
*/
@SerializedName("on_behalf_of")
String onBehalfOf;
/**
* The default URL to redirect customers to when they click on the portal's link to return to your
* website.
*/
@SerializedName("return_url")
String returnUrl;
private SessionCreateParams(
String configuration,
String customer,
List expand,
Map extraParams,
FlowData flowData,
Locale locale,
String onBehalfOf,
String returnUrl) {
this.configuration = configuration;
this.customer = customer;
this.expand = expand;
this.extraParams = extraParams;
this.flowData = flowData;
this.locale = locale;
this.onBehalfOf = onBehalfOf;
this.returnUrl = returnUrl;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private String configuration;
private String customer;
private List expand;
private Map extraParams;
private FlowData flowData;
private Locale locale;
private String onBehalfOf;
private String returnUrl;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams build() {
return new SessionCreateParams(
this.configuration,
this.customer,
this.expand,
this.extraParams,
this.flowData,
this.locale,
this.onBehalfOf,
this.returnUrl);
}
/**
* The ID of an existing configuration to use for
* this session, describing its functionality and features. If not specified, the session uses
* the default configuration.
*/
public Builder setConfiguration(String configuration) {
this.configuration = configuration;
return this;
}
/** Required. The ID of an existing customer. */
public Builder setCustomer(String customer) {
this.customer = customer;
return this;
}
/**
* Add an element to `expand` list. A list is initialized for the first `add/addAll` call, and
* subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams#expand} for the field documentation.
*/
public Builder addExpand(String element) {
if (this.expand == null) {
this.expand = new ArrayList<>();
}
this.expand.add(element);
return this;
}
/**
* Add all elements to `expand` list. A list is initialized for the first `add/addAll` call, and
* subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams#expand} for the field documentation.
*/
public Builder addAllExpand(List elements) {
if (this.expand == null) {
this.expand = new ArrayList<>();
}
this.expand.addAll(elements);
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll`
* call, and subsequent calls add additional key/value pairs to the original map. See {@link
* SessionCreateParams#extraParams} for the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
* See {@link SessionCreateParams#extraParams} for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/**
* Information about a specific flow for the customer to go through. See the docs to learn more
* about using customer portal deep links and flows.
*/
public Builder setFlowData(SessionCreateParams.FlowData flowData) {
this.flowData = flowData;
return this;
}
/**
* The IETF language tag of the locale customer portal is displayed in. If blank or auto, the
* customer’s {@code preferred_locales} or browser’s locale is used.
*/
public Builder setLocale(SessionCreateParams.Locale locale) {
this.locale = locale;
return this;
}
/**
* The {@code on_behalf_of} account to use for this session. When specified, only subscriptions
* and invoices with this {@code on_behalf_of} account appear in the portal. For more
* information, see the docs.
* Use the Accounts
* API to modify the {@code on_behalf_of} account's branding settings, which the portal
* displays.
*/
public Builder setOnBehalfOf(String onBehalfOf) {
this.onBehalfOf = onBehalfOf;
return this;
}
/**
* The default URL to redirect customers to when they click on the portal's link to return to
* your website.
*/
public Builder setReturnUrl(String returnUrl) {
this.returnUrl = returnUrl;
return this;
}
}
@Getter
public static class FlowData {
/** Behavior after the flow is completed. */
@SerializedName("after_completion")
AfterCompletion afterCompletion;
/**
* Map of extra parameters for custom features not available in this client library. The content
* in this map is not serialized under this field's {@code @SerializedName} value. Instead, each
* key/value pair is serialized as if the key is a root-level field (serialized) name in this
* param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** Configuration when {@code flow_data.type=subscription_cancel}. */
@SerializedName("subscription_cancel")
SubscriptionCancel subscriptionCancel;
/** Configuration when {@code flow_data.type=subscription_update}. */
@SerializedName("subscription_update")
SubscriptionUpdate subscriptionUpdate;
/** Configuration when {@code flow_data.type=subscription_update_confirm}. */
@SerializedName("subscription_update_confirm")
SubscriptionUpdateConfirm subscriptionUpdateConfirm;
/** Required. Type of flow that the customer will go through. */
@SerializedName("type")
Type type;
private FlowData(
AfterCompletion afterCompletion,
Map extraParams,
SubscriptionCancel subscriptionCancel,
SubscriptionUpdate subscriptionUpdate,
SubscriptionUpdateConfirm subscriptionUpdateConfirm,
Type type) {
this.afterCompletion = afterCompletion;
this.extraParams = extraParams;
this.subscriptionCancel = subscriptionCancel;
this.subscriptionUpdate = subscriptionUpdate;
this.subscriptionUpdateConfirm = subscriptionUpdateConfirm;
this.type = type;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private AfterCompletion afterCompletion;
private Map extraParams;
private SubscriptionCancel subscriptionCancel;
private SubscriptionUpdate subscriptionUpdate;
private SubscriptionUpdateConfirm subscriptionUpdateConfirm;
private Type type;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData build() {
return new SessionCreateParams.FlowData(
this.afterCompletion,
this.extraParams,
this.subscriptionCancel,
this.subscriptionUpdate,
this.subscriptionUpdateConfirm,
this.type);
}
/** Behavior after the flow is completed. */
public Builder setAfterCompletion(
SessionCreateParams.FlowData.AfterCompletion afterCompletion) {
this.afterCompletion = afterCompletion;
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first `put/putAll`
* call, and subsequent calls add additional key/value pairs to the original map. See {@link
* SessionCreateParams.FlowData#extraParams} for the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original map.
* See {@link SessionCreateParams.FlowData#extraParams} for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Configuration when {@code flow_data.type=subscription_cancel}. */
public Builder setSubscriptionCancel(
SessionCreateParams.FlowData.SubscriptionCancel subscriptionCancel) {
this.subscriptionCancel = subscriptionCancel;
return this;
}
/** Configuration when {@code flow_data.type=subscription_update}. */
public Builder setSubscriptionUpdate(
SessionCreateParams.FlowData.SubscriptionUpdate subscriptionUpdate) {
this.subscriptionUpdate = subscriptionUpdate;
return this;
}
/** Configuration when {@code flow_data.type=subscription_update_confirm}. */
public Builder setSubscriptionUpdateConfirm(
SessionCreateParams.FlowData.SubscriptionUpdateConfirm subscriptionUpdateConfirm) {
this.subscriptionUpdateConfirm = subscriptionUpdateConfirm;
return this;
}
/** Required. Type of flow that the customer will go through. */
public Builder setType(SessionCreateParams.FlowData.Type type) {
this.type = type;
return this;
}
}
@Getter
public static class AfterCompletion {
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
* name in this param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** Configuration when {@code after_completion.type=hosted_confirmation}. */
@SerializedName("hosted_confirmation")
HostedConfirmation hostedConfirmation;
/** Configuration when {@code after_completion.type=redirect}. */
@SerializedName("redirect")
Redirect redirect;
/** Required. The specified behavior after the flow is completed. */
@SerializedName("type")
Type type;
private AfterCompletion(
Map extraParams,
HostedConfirmation hostedConfirmation,
Redirect redirect,
Type type) {
this.extraParams = extraParams;
this.hostedConfirmation = hostedConfirmation;
this.redirect = redirect;
this.type = type;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private HostedConfirmation hostedConfirmation;
private Redirect redirect;
private Type type;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.AfterCompletion build() {
return new SessionCreateParams.FlowData.AfterCompletion(
this.extraParams, this.hostedConfirmation, this.redirect, this.type);
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.AfterCompletion#extraParams} for the field
* documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.AfterCompletion#extraParams} for the field
* documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Configuration when {@code after_completion.type=hosted_confirmation}. */
public Builder setHostedConfirmation(
SessionCreateParams.FlowData.AfterCompletion.HostedConfirmation hostedConfirmation) {
this.hostedConfirmation = hostedConfirmation;
return this;
}
/** Configuration when {@code after_completion.type=redirect}. */
public Builder setRedirect(SessionCreateParams.FlowData.AfterCompletion.Redirect redirect) {
this.redirect = redirect;
return this;
}
/** Required. The specified behavior after the flow is completed. */
public Builder setType(SessionCreateParams.FlowData.AfterCompletion.Type type) {
this.type = type;
return this;
}
}
@Getter
public static class HostedConfirmation {
/** A custom message to display to the customer after the flow is completed. */
@SerializedName("custom_message")
String customMessage;
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its parent
* instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
private HostedConfirmation(String customMessage, Map extraParams) {
this.customMessage = customMessage;
this.extraParams = extraParams;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private String customMessage;
private Map extraParams;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.AfterCompletion.HostedConfirmation build() {
return new SessionCreateParams.FlowData.AfterCompletion.HostedConfirmation(
this.customMessage, this.extraParams);
}
/** A custom message to display to the customer after the flow is completed. */
public Builder setCustomMessage(String customMessage) {
this.customMessage = customMessage;
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.AfterCompletion.HostedConfirmation#extraParams} for the
* field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.AfterCompletion.HostedConfirmation#extraParams} for the
* field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
}
}
@Getter
public static class Redirect {
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its parent
* instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/**
* Required. The URL the customer will be redirected to after the flow is
* completed.
*/
@SerializedName("return_url")
String returnUrl;
private Redirect(Map extraParams, String returnUrl) {
this.extraParams = extraParams;
this.returnUrl = returnUrl;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private String returnUrl;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.AfterCompletion.Redirect build() {
return new SessionCreateParams.FlowData.AfterCompletion.Redirect(
this.extraParams, this.returnUrl);
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.AfterCompletion.Redirect#extraParams} for
* the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.AfterCompletion.Redirect#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/**
* Required. The URL the customer will be redirected to after the flow is
* completed.
*/
public Builder setReturnUrl(String returnUrl) {
this.returnUrl = returnUrl;
return this;
}
}
}
public enum Type implements ApiRequestParams.EnumParam {
@SerializedName("hosted_confirmation")
HOSTED_CONFIRMATION("hosted_confirmation"),
@SerializedName("portal_homepage")
PORTAL_HOMEPAGE("portal_homepage"),
@SerializedName("redirect")
REDIRECT("redirect");
@Getter(onMethod_ = {@Override})
private final String value;
Type(String value) {
this.value = value;
}
}
}
@Getter
public static class SubscriptionCancel {
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
* name in this param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** Specify a retention strategy to be used in the cancellation flow. */
@SerializedName("retention")
Retention retention;
/** Required. The ID of the subscription to be canceled. */
@SerializedName("subscription")
String subscription;
private SubscriptionCancel(
Map extraParams, Retention retention, String subscription) {
this.extraParams = extraParams;
this.retention = retention;
this.subscription = subscription;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private Retention retention;
private String subscription;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionCancel build() {
return new SessionCreateParams.FlowData.SubscriptionCancel(
this.extraParams, this.retention, this.subscription);
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionCancel#extraParams} for the
* field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionCancel#extraParams} for the
* field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Specify a retention strategy to be used in the cancellation flow. */
public Builder setRetention(
SessionCreateParams.FlowData.SubscriptionCancel.Retention retention) {
this.retention = retention;
return this;
}
/** Required. The ID of the subscription to be canceled. */
public Builder setSubscription(String subscription) {
this.subscription = subscription;
return this;
}
}
@Getter
public static class Retention {
/** Required. Configuration when {@code retention.type=coupon_offer}. */
@SerializedName("coupon_offer")
CouponOffer couponOffer;
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its parent
* instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** Required. Type of retention strategy to use with the customer. */
@SerializedName("type")
Type type;
private Retention(CouponOffer couponOffer, Map extraParams, Type type) {
this.couponOffer = couponOffer;
this.extraParams = extraParams;
this.type = type;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private CouponOffer couponOffer;
private Map extraParams;
private Type type;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionCancel.Retention build() {
return new SessionCreateParams.FlowData.SubscriptionCancel.Retention(
this.couponOffer, this.extraParams, this.type);
}
/** Required. Configuration when {@code retention.type=coupon_offer}. */
public Builder setCouponOffer(
SessionCreateParams.FlowData.SubscriptionCancel.Retention.CouponOffer couponOffer) {
this.couponOffer = couponOffer;
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionCancel.Retention#extraParams}
* for the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionCancel.Retention#extraParams}
* for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. Type of retention strategy to use with the customer. */
public Builder setType(
SessionCreateParams.FlowData.SubscriptionCancel.Retention.Type type) {
this.type = type;
return this;
}
}
@Getter
public static class CouponOffer {
/** Required. The ID of the coupon to be offered. */
@SerializedName("coupon")
String coupon;
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its
* parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
private CouponOffer(String coupon, Map extraParams) {
this.coupon = coupon;
this.extraParams = extraParams;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private String coupon;
private Map extraParams;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionCancel.Retention.CouponOffer build() {
return new SessionCreateParams.FlowData.SubscriptionCancel.Retention.CouponOffer(
this.coupon, this.extraParams);
}
/** Required. The ID of the coupon to be offered. */
public Builder setCoupon(String coupon) {
this.coupon = coupon;
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the
* original map. See {@link
* SessionCreateParams.FlowData.SubscriptionCancel.Retention.CouponOffer#extraParams}
* for the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the
* original map. See {@link
* SessionCreateParams.FlowData.SubscriptionCancel.Retention.CouponOffer#extraParams}
* for the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
}
}
public enum Type implements ApiRequestParams.EnumParam {
@SerializedName("coupon_offer")
COUPON_OFFER("coupon_offer");
@Getter(onMethod_ = {@Override})
private final String value;
Type(String value) {
this.value = value;
}
}
}
}
@Getter
public static class SubscriptionUpdate {
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
* name in this param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** Required. The ID of the subscription to be updated. */
@SerializedName("subscription")
String subscription;
private SubscriptionUpdate(Map extraParams, String subscription) {
this.extraParams = extraParams;
this.subscription = subscription;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private String subscription;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionUpdate build() {
return new SessionCreateParams.FlowData.SubscriptionUpdate(
this.extraParams, this.subscription);
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionUpdate#extraParams} for the
* field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionUpdate#extraParams} for the
* field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** Required. The ID of the subscription to be updated. */
public Builder setSubscription(String subscription) {
this.subscription = subscription;
return this;
}
}
}
@Getter
public static class SubscriptionUpdateConfirm {
/**
* The coupon or promotion code to apply to this subscription update. Currently, only up to
* one may be specified.
*/
@SerializedName("discounts")
List discounts;
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field (serialized)
* name in this param object. Effectively, this map is flattened to its parent instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/**
* Required. The subscription item to be updated
* through this flow. Currently, only up to one may be specified and subscriptions with
* multiple items are not updatable.
*/
@SerializedName("items")
List items;
/** Required. The ID of the subscription to be updated. */
@SerializedName("subscription")
String subscription;
private SubscriptionUpdateConfirm(
List discounts,
Map extraParams,
List items,
String subscription) {
this.discounts = discounts;
this.extraParams = extraParams;
this.items = items;
this.subscription = subscription;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private List discounts;
private Map extraParams;
private List items;
private String subscription;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionUpdateConfirm build() {
return new SessionCreateParams.FlowData.SubscriptionUpdateConfirm(
this.discounts, this.extraParams, this.items, this.subscription);
}
/**
* Add an element to `discounts` list. A list is initialized for the first `add/addAll`
* call, and subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm#discounts} for the field
* documentation.
*/
public Builder addDiscount(
SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Discount element) {
if (this.discounts == null) {
this.discounts = new ArrayList<>();
}
this.discounts.add(element);
return this;
}
/**
* Add all elements to `discounts` list. A list is initialized for the first `add/addAll`
* call, and subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm#discounts} for the field
* documentation.
*/
public Builder addAllDiscount(
List elements) {
if (this.discounts == null) {
this.discounts = new ArrayList<>();
}
this.discounts.addAll(elements);
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionUpdateConfirm#extraParams} for
* the field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link SessionCreateParams.FlowData.SubscriptionUpdateConfirm#extraParams} for
* the field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/**
* Add an element to `items` list. A list is initialized for the first `add/addAll` call,
* and subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm#items} for the field
* documentation.
*/
public Builder addItem(
SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Item element) {
if (this.items == null) {
this.items = new ArrayList<>();
}
this.items.add(element);
return this;
}
/**
* Add all elements to `items` list. A list is initialized for the first `add/addAll` call,
* and subsequent calls adds additional elements to the original list. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm#items} for the field
* documentation.
*/
public Builder addAllItem(
List elements) {
if (this.items == null) {
this.items = new ArrayList<>();
}
this.items.addAll(elements);
return this;
}
/** Required. The ID of the subscription to be updated. */
public Builder setSubscription(String subscription) {
this.subscription = subscription;
return this;
}
}
@Getter
public static class Discount {
/** The ID of the coupon to apply to this subscription update. */
@SerializedName("coupon")
String coupon;
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its parent
* instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/** The ID of a promotion code to apply to this subscription update. */
@SerializedName("promotion_code")
String promotionCode;
private Discount(String coupon, Map extraParams, String promotionCode) {
this.coupon = coupon;
this.extraParams = extraParams;
this.promotionCode = promotionCode;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private String coupon;
private Map extraParams;
private String promotionCode;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Discount build() {
return new SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Discount(
this.coupon, this.extraParams, this.promotionCode);
}
/** The ID of the coupon to apply to this subscription update. */
public Builder setCoupon(String coupon) {
this.coupon = coupon;
return this;
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Discount#extraParams} for the
* field documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Discount#extraParams} for the
* field documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/** The ID of a promotion code to apply to this subscription update. */
public Builder setPromotionCode(String promotionCode) {
this.promotionCode = promotionCode;
return this;
}
}
}
@Getter
public static class Item {
/**
* Map of extra parameters for custom features not available in this client library. The
* content in this map is not serialized under this field's {@code @SerializedName} value.
* Instead, each key/value pair is serialized as if the key is a root-level field
* (serialized) name in this param object. Effectively, this map is flattened to its parent
* instance.
*/
@SerializedName(ApiRequestParams.EXTRA_PARAMS_KEY)
Map extraParams;
/**
* Required. The ID of the subscription
* item to be updated.
*/
@SerializedName("id")
String id;
/**
* The price the customer should subscribe to through this flow. The price must also be
* included in the configuration's {@code
* features.subscription_update.products}.
*/
@SerializedName("price")
String price;
/**
* Quantity for this item
* that the customer should subscribe to through this flow.
*/
@SerializedName("quantity")
Long quantity;
private Item(Map extraParams, String id, String price, Long quantity) {
this.extraParams = extraParams;
this.id = id;
this.price = price;
this.quantity = quantity;
}
public static Builder builder() {
return new Builder();
}
public static class Builder {
private Map extraParams;
private String id;
private String price;
private Long quantity;
/** Finalize and obtain parameter instance from this builder. */
public SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Item build() {
return new SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Item(
this.extraParams, this.id, this.price, this.quantity);
}
/**
* Add a key/value pair to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Item#extraParams} for the field
* documentation.
*/
public Builder putExtraParam(String key, Object value) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.put(key, value);
return this;
}
/**
* Add all map key/value pairs to `extraParams` map. A map is initialized for the first
* `put/putAll` call, and subsequent calls add additional key/value pairs to the original
* map. See {@link
* SessionCreateParams.FlowData.SubscriptionUpdateConfirm.Item#extraParams} for the field
* documentation.
*/
public Builder putAllExtraParam(Map map) {
if (this.extraParams == null) {
this.extraParams = new HashMap<>();
}
this.extraParams.putAll(map);
return this;
}
/**
* Required. The ID of the subscription
* item to be updated.
*/
public Builder setId(String id) {
this.id = id;
return this;
}
/**
* The price the customer should subscribe to through this flow. The price must also be
* included in the configuration's {@code
* features.subscription_update.products}.
*/
public Builder setPrice(String price) {
this.price = price;
return this;
}
/**
* Quantity for this item
* that the customer should subscribe to through this flow.
*/
public Builder setQuantity(Long quantity) {
this.quantity = quantity;
return this;
}
}
}
}
public enum Type implements ApiRequestParams.EnumParam {
@SerializedName("payment_method_update")
PAYMENT_METHOD_UPDATE("payment_method_update"),
@SerializedName("subscription_cancel")
SUBSCRIPTION_CANCEL("subscription_cancel"),
@SerializedName("subscription_update")
SUBSCRIPTION_UPDATE("subscription_update"),
@SerializedName("subscription_update_confirm")
SUBSCRIPTION_UPDATE_CONFIRM("subscription_update_confirm");
@Getter(onMethod_ = {@Override})
private final String value;
Type(String value) {
this.value = value;
}
}
}
public enum Locale implements ApiRequestParams.EnumParam {
@SerializedName("auto")
AUTO("auto"),
@SerializedName("bg")
BG("bg"),
@SerializedName("cs")
CS("cs"),
@SerializedName("da")
DA("da"),
@SerializedName("de")
DE("de"),
@SerializedName("el")
EL("el"),
@SerializedName("en")
EN("en"),
@SerializedName("en-AU")
EN_AU("en-AU"),
@SerializedName("en-CA")
EN_CA("en-CA"),
@SerializedName("en-GB")
EN_GB("en-GB"),
@SerializedName("en-IE")
EN_IE("en-IE"),
@SerializedName("en-IN")
EN_IN("en-IN"),
@SerializedName("en-NZ")
EN_NZ("en-NZ"),
@SerializedName("en-SG")
EN_SG("en-SG"),
@SerializedName("es")
ES("es"),
@SerializedName("es-419")
ES_419("es-419"),
@SerializedName("et")
ET("et"),
@SerializedName("fi")
FI("fi"),
@SerializedName("fil")
FIL("fil"),
@SerializedName("fr")
FR("fr"),
@SerializedName("fr-CA")
FR_CA("fr-CA"),
@SerializedName("hr")
HR("hr"),
@SerializedName("hu")
HU("hu"),
@SerializedName("id")
ID("id"),
@SerializedName("it")
IT("it"),
@SerializedName("ja")
JA("ja"),
@SerializedName("ko")
KO("ko"),
@SerializedName("lt")
LT("lt"),
@SerializedName("lv")
LV("lv"),
@SerializedName("ms")
MS("ms"),
@SerializedName("mt")
MT("mt"),
@SerializedName("nb")
NB("nb"),
@SerializedName("nl")
NL("nl"),
@SerializedName("pl")
PL("pl"),
@SerializedName("pt")
PT("pt"),
@SerializedName("pt-BR")
PT_BR("pt-BR"),
@SerializedName("ro")
RO("ro"),
@SerializedName("ru")
RU("ru"),
@SerializedName("sk")
SK("sk"),
@SerializedName("sl")
SL("sl"),
@SerializedName("sv")
SV("sv"),
@SerializedName("th")
TH("th"),
@SerializedName("tr")
TR("tr"),
@SerializedName("vi")
VI("vi"),
@SerializedName("zh")
ZH("zh"),
@SerializedName("zh-HK")
ZH_HK("zh-HK"),
@SerializedName("zh-TW")
ZH_TW("zh-TW");
@Getter(onMethod_ = {@Override})
private final String value;
Locale(String value) {
this.value = value;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy