com.stripe.model.PromotionCode Maven / Gradle / Ivy
// File generated from our OpenAPI spec
package com.stripe.model;
import com.google.gson.annotations.SerializedName;
import com.stripe.exception.StripeException;
import com.stripe.net.ApiRequest;
import com.stripe.net.ApiRequestParams;
import com.stripe.net.ApiResource;
import com.stripe.net.BaseAddress;
import com.stripe.net.RequestOptions;
import com.stripe.net.StripeResponseGetter;
import com.stripe.param.PromotionCodeCreateParams;
import com.stripe.param.PromotionCodeListParams;
import com.stripe.param.PromotionCodeRetrieveParams;
import com.stripe.param.PromotionCodeUpdateParams;
import java.util.Map;
import lombok.EqualsAndHashCode;
import lombok.Getter;
import lombok.Setter;
/**
* A Promotion Code represents a customer-redeemable code for a coupon. It can be used to create multiple codes
* for a single coupon.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public class PromotionCode extends ApiResource implements HasId, MetadataStore {
/**
* Whether the promotion code is currently active. A promotion code is only active if the coupon
* is also valid.
*/
@SerializedName("active")
Boolean active;
/**
* The customer-facing code. Regardless of case, this code must be unique across all active
* promotion codes for each customer. Valid characters are lower case letters (a-z), upper case
* letters (A-Z), and digits (0-9).
*/
@SerializedName("code")
String code;
/**
* A coupon contains information about a percent-off or amount-off discount you might want to
* apply to a customer. Coupons may be applied to subscriptions, invoices, checkout sessions, quotes, and more. Coupons do not work with
* conventional one-off charges or payment intents.
*/
@SerializedName("coupon")
Coupon coupon;
/** Time at which the object was created. Measured in seconds since the Unix epoch. */
@SerializedName("created")
Long created;
/** The customer that this promotion code can be used by. */
@SerializedName("customer")
@Getter(lombok.AccessLevel.NONE)
@Setter(lombok.AccessLevel.NONE)
ExpandableField customer;
/** Date at which the promotion code can no longer be redeemed. */
@SerializedName("expires_at")
Long expiresAt;
/** Unique identifier for the object. */
@Getter(onMethod_ = {@Override})
@SerializedName("id")
String id;
/**
* Has the value {@code true} if the object exists in live mode or the value {@code false} if the
* object exists in test mode.
*/
@SerializedName("livemode")
Boolean livemode;
/** Maximum number of times this promotion code can be redeemed. */
@SerializedName("max_redemptions")
Long maxRedemptions;
/**
* Set of key-value pairs that you can attach
* to an object. This can be useful for storing additional information about the object in a
* structured format.
*/
@Getter(onMethod_ = {@Override})
@SerializedName("metadata")
Map metadata;
/**
* String representing the object's type. Objects of the same type share the same value.
*
* Equal to {@code promotion_code}.
*/
@SerializedName("object")
String object;
@SerializedName("restrictions")
Restrictions restrictions;
/** Number of times this promotion code has been used. */
@SerializedName("times_redeemed")
Long timesRedeemed;
/** Get ID of expandable {@code customer} object. */
public String getCustomer() {
return (this.customer != null) ? this.customer.getId() : null;
}
public void setCustomer(String id) {
this.customer = ApiResource.setExpandableFieldId(id, this.customer);
}
/** Get expanded {@code customer}. */
public Customer getCustomerObject() {
return (this.customer != null) ? this.customer.getExpanded() : null;
}
public void setCustomerObject(Customer expandableObject) {
this.customer = new ExpandableField(expandableObject.getId(), expandableObject);
}
/**
* A promotion code points to a coupon. You can optionally restrict the code to a specific
* customer, redemption limit, and expiration date.
*/
public static PromotionCode create(Map params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* A promotion code points to a coupon. You can optionally restrict the code to a specific
* customer, redemption limit, and expiration date.
*/
public static PromotionCode create(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/promotion_codes";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getGlobalResponseGetter().request(request, PromotionCode.class);
}
/**
* A promotion code points to a coupon. You can optionally restrict the code to a specific
* customer, redemption limit, and expiration date.
*/
public static PromotionCode create(PromotionCodeCreateParams params) throws StripeException {
return create(params, (RequestOptions) null);
}
/**
* A promotion code points to a coupon. You can optionally restrict the code to a specific
* customer, redemption limit, and expiration date.
*/
public static PromotionCode create(PromotionCodeCreateParams params, RequestOptions options)
throws StripeException {
String path = "/v1/promotion_codes";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, PromotionCode.class);
}
/** Returns a list of your promotion codes. */
public static PromotionCodeCollection list(Map params) throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of your promotion codes. */
public static PromotionCodeCollection list(Map params, RequestOptions options)
throws StripeException {
String path = "/v1/promotion_codes";
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, PromotionCodeCollection.class);
}
/** Returns a list of your promotion codes. */
public static PromotionCodeCollection list(PromotionCodeListParams params)
throws StripeException {
return list(params, (RequestOptions) null);
}
/** Returns a list of your promotion codes. */
public static PromotionCodeCollection list(PromotionCodeListParams params, RequestOptions options)
throws StripeException {
String path = "/v1/promotion_codes";
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, PromotionCodeCollection.class);
}
/**
* Retrieves the promotion code with the given ID. In order to retrieve a promotion code by the
* customer-facing {@code code} use list with the desired {@code code}.
*/
public static PromotionCode retrieve(String promotionCode) throws StripeException {
return retrieve(promotionCode, (Map) null, (RequestOptions) null);
}
/**
* Retrieves the promotion code with the given ID. In order to retrieve a promotion code by the
* customer-facing {@code code} use list with the desired {@code code}.
*/
public static PromotionCode retrieve(String promotionCode, RequestOptions options)
throws StripeException {
return retrieve(promotionCode, (Map) null, options);
}
/**
* Retrieves the promotion code with the given ID. In order to retrieve a promotion code by the
* customer-facing {@code code} use list with the desired {@code code}.
*/
public static PromotionCode retrieve(
String promotionCode, Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/promotion_codes/%s", ApiResource.urlEncodeId(promotionCode));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.GET, path, params, options);
return getGlobalResponseGetter().request(request, PromotionCode.class);
}
/**
* Retrieves the promotion code with the given ID. In order to retrieve a promotion code by the
* customer-facing {@code code} use list with the desired {@code code}.
*/
public static PromotionCode retrieve(
String promotionCode, PromotionCodeRetrieveParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/promotion_codes/%s", ApiResource.urlEncodeId(promotionCode));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.GET,
path,
ApiRequestParams.paramsToMap(params),
options);
return getGlobalResponseGetter().request(request, PromotionCode.class);
}
/**
* Updates the specified promotion code by setting the values of the parameters passed. Most
* fields are, by design, not editable.
*/
@Override
public PromotionCode update(Map params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates the specified promotion code by setting the values of the parameters passed. Most
* fields are, by design, not editable.
*/
@Override
public PromotionCode update(Map params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/promotion_codes/%s", ApiResource.urlEncodeId(this.getId()));
ApiRequest request =
new ApiRequest(BaseAddress.API, ApiResource.RequestMethod.POST, path, params, options);
return getResponseGetter().request(request, PromotionCode.class);
}
/**
* Updates the specified promotion code by setting the values of the parameters passed. Most
* fields are, by design, not editable.
*/
public PromotionCode update(PromotionCodeUpdateParams params) throws StripeException {
return update(params, (RequestOptions) null);
}
/**
* Updates the specified promotion code by setting the values of the parameters passed. Most
* fields are, by design, not editable.
*/
public PromotionCode update(PromotionCodeUpdateParams params, RequestOptions options)
throws StripeException {
String path = String.format("/v1/promotion_codes/%s", ApiResource.urlEncodeId(this.getId()));
ApiResource.checkNullTypedParams(path, params);
ApiRequest request =
new ApiRequest(
BaseAddress.API,
ApiResource.RequestMethod.POST,
path,
ApiRequestParams.paramsToMap(params),
options);
return getResponseGetter().request(request, PromotionCode.class);
}
/**
* For more details about Restrictions, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class Restrictions extends StripeObject {
/**
* Promotion code restrictions defined in each available currency option. Each key must be a
* three-letter ISO currency code
* and a supported currency.
*/
@SerializedName("currency_options")
Map currencyOptions;
/**
* A Boolean indicating if the Promotion Code should only be redeemed for Customers without any
* successful payments or invoices.
*/
@SerializedName("first_time_transaction")
Boolean firstTimeTransaction;
/**
* Minimum amount required to redeem this Promotion Code into a Coupon (e.g., a purchase must be
* $100 or more to work).
*/
@SerializedName("minimum_amount")
Long minimumAmount;
/** Three-letter ISO code for minimum_amount */
@SerializedName("minimum_amount_currency")
String minimumAmountCurrency;
/**
* For more details about CurrencyOption, please refer to the API Reference.
*/
@Getter
@Setter
@EqualsAndHashCode(callSuper = false)
public static class CurrencyOption extends StripeObject {
/**
* Minimum amount required to redeem this Promotion Code into a Coupon (e.g., a purchase must
* be $100 or more to work).
*/
@SerializedName("minimum_amount")
Long minimumAmount;
}
}
@Override
public void setResponseGetter(StripeResponseGetter responseGetter) {
super.setResponseGetter(responseGetter);
trySetResponseGetter(coupon, responseGetter);
trySetResponseGetter(customer, responseGetter);
trySetResponseGetter(restrictions, responseGetter);
}
}