All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.ning.billing.recurly.model.Coupon Maven / Gradle / Ivy

/*
 * Copyright 2010-2014 Ning, Inc.
 * Copyright 2014-2018 The Billing Project, LLC
 *
 * The Billing Project licenses this file to you under the Apache License, version 2.0
 * (the "License"); you may not use this file except in compliance with the
 * License.  You may obtain a copy of the License at:
 *
 *    http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the
 * License for the specific language governing permissions and limitations
 * under the License.
 */

package com.ning.billing.recurly.model;

import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlElementWrapper;
import javax.xml.bind.annotation.XmlRootElement;
import javax.xml.bind.annotation.XmlTransient;

import org.joda.time.DateTime;
import com.google.common.base.Objects;

/**
 * Class that represents the Concept of a Coupon within the Recurly API.
 */
@XmlRootElement(name = "coupon")
public class Coupon extends RecurlyObject {
    public enum DiscountType {
        percent, dollars, free_trial
    }

    public enum Duration {
        forever, single_use, temporal
    }

    public enum FreeTrialUnit {
        day, week, month
    }

    public enum RedemptionResource {
        account, subscription
    }

    public enum TemporalUnit {
        day, week, month, year;
    }

    public enum Type {
        single_code, bulk, unique_code
    }

    @XmlTransient
    public static final String COUPON_RESOURCE = "/coupons";

    @XmlTransient
    public static final String GENERATE_RESOURCE = "/generate";

    @XmlTransient
    public static final String UNIQUE_CODES_RESOURCE = "/unique_coupon_codes";

    @XmlTransient
    public static final String RESTORE_RESOURCE = "/restore";

    @XmlElement(name = "id")
    private Long id;

    @XmlElement(name = "name")
    private String name;

    @XmlElement(name = "coupon_code")
    private String couponCode;

    /**
     * Description of the coupon on the hosted payment pages.
     */
    @XmlElement(name = "description")
    private String description;

    /**
     * Description of the coupon on the invoice.
     */
    @XmlElement(name = "invoice_description")
    private String invoiceDescription;

    /**
     * Last date to redeem the coupon, defaults to no date
     */
    @XmlElement(name = "redeem_by_date")
    private DateTime redeemByDate;

    /**
     * Number of months after redemption that the coupon is valid, defaults to no date
     * @deprecated Please use temporal_unit and temporal_amount
     */
    @XmlElement(name = "applies_for_months")
    private Integer appliesForMonths;

    /**
     * Maximum number of accounts that may use the coupon before it can no longer be redeemed
     */
    @XmlElement(name = "max_redemptions")
    private Integer maxRedemptions;

    /**
     * The coupon is valid for all plans if true, defaults to true
     */
    @XmlElement(name = "applies_to_all_plans")
    private Boolean appliesToAllPlans;

    /**
     * The coupon is valid for all items if true, defaults to false
     */
    @XmlElement(name = "applies_to_all_items")
    private Boolean appliesToAllItems;

    /**
     * If true, the coupon applies to the first invoice only
     * @deprecated Please use duration
     */
    @XmlElement(name = "single_use")
    private Boolean singleUse;

    @XmlElement(name = "discount_type")
    private DiscountType discountType;

    @XmlElement(name = "free_trial_unit")
    private FreeTrialUnit freeTrialUnit;

    @XmlElement(name = "free_trial_amount")
    private Integer freeTrialAmount;

    /**
     * Discount percentage if discount_type is "percent"
     */
    @XmlElement(name = "discount_percent")
    private Integer discountPercent;

    @XmlElement(name = "discount_in_cents")
    private RecurlyUnitCurrency discountInCents;

    @XmlElement(name = "state")
    private String state;

    @XmlElement(name = "created_at")
    private DateTime createdAt;

    @XmlElement(name = "updated_at")
    private DateTime updatedAt;

    public PlanCodes getPlanCodes() {
        return planCodes;
    }

    public void setPlanCodes(final PlanCodes planCodes) {
        this.planCodes = planCodes;
    }

    @XmlElement(name = "plan_code")
    @XmlElementWrapper(name = "plan_codes")
    private PlanCodes planCodes;

    public ItemCodes getItemCodes() {
        return itemCodes;
    }

    public void setItemCodes(final ItemCodes itemCodes) {
        this.itemCodes = itemCodes;
    }

    @XmlElement(name = "item_code")
    @XmlElementWrapper(name = "item_codes")
    private ItemCodes itemCodes;

    /**
     * forever, single_use, or temporal. If single_use, the coupon applies to
     * the first invoice only. If temporal the coupon will apply to invoices for
     * the duration determined by the temporal_unit and temporal_amount
     * attributes.
     */
    @XmlElement(name = "duration")
    private Duration duration;

    /**
     * day, week, month, or year. If duration is temporal then temporal_unit is
     * multiplied by temporal_amount to define the duration that the coupon will
     * be applied to invoices for.
     */
    @XmlElement(name = "temporal_unit")
    private TemporalUnit temporalUnit;

    /**
     * If duration is temporal then temporal_amount is an integer which is
     * multiplied by temporal_unit to define the duration that the coupon will
     * be applied to invoices for.
     */
    @XmlElement(name = "temporal_amount")
    private Integer temporalAmount;

    /**
     * The coupon is valid for one-time, non-plan charges if true, defaults to
     * false.
     */
    @XmlElement(name = "applies_to_non_plan_charges")
    private Boolean appliesToNonPlanCharges;

    /**
     * Whether the discount is for all eligible charges on the account, or only
     * a specific subscription. Values are account or subscription.
     */
    @XmlElement(name = "redemption_resource")
    private RedemptionResource redemptionResource;

    /**
     * The number of times the coupon can be redeemed on a specific account
     */
    @XmlElement(name = "max_redemptions_per_account")
    private Integer maxRedemptionsPerAccount;

    /**
     * Whether the coupon is single_code or bulk. Bulk coupons will require a
     * unique_code_template and will generate unique codes through the generate
     * endpoint.
     */
    @XmlElement(name = "coupon_type")
    private Type type;

    /**
     * The template for generating unique codes.
     * 
     * @see https://dev.recurly.com/docs/create-coupon
     */
    @XmlElement(name = "unique_code_template")
    private String uniqueCodeTemplate;

    /**
     * The number of unique codes to generate.
     *
     * @see https://dev.recurly.com/docs/generate-unique-codes
     */
    @XmlElement(name = "number_of_unique_codes")
    private Integer numberOfUniqueCodes;

    public void setId(final Object id) {
        this.id = longOrNull(id);
    }

    public Long getId() {
        return this.id;
    }

    public String getState() {
        return state;
    }

    public void setState(final Object state) {
        this.state = stringOrNull(state);
    }

    /**
     * Gets the name of the {@link Coupon}
     *
     * @return The {@link Coupon} name
     */
    public String getName() {
        return name;
    }

    /**
     * Sets the name of the {@link Coupon}
     *
     * @param name The Name that is to be given to the {@link Coupon}
     */
    public void setName(final Object name) {
        this.name = stringOrNull(name);
    }

    /**
     * Gets the coupon code for a {@link Coupon}
     *
     * @return The coupon code for the {@link Coupon}
     */
    public String getCouponCode() {
        return couponCode;
    }

    /**
     * Sets the coupon code for the {@link Coupon}
     *
     * @param couponCode The coupon code
     */
    public void setCouponCode(final Object couponCode) {
        this.couponCode = stringOrNull(couponCode);
    }

    /**
     * Sets the discount type for a {@link Coupon}
     *
     * @param discountType
     */
    public void setDiscountType(final Object discountType) {
        this.discountType = enumOrNull(DiscountType.class, discountType);
    }

    /**
     * Gets the discount type associated with the {@link Coupon}
     *
     * @return the DiscountType
     */
    public DiscountType getDiscountType() {
        return discountType;
    }

    /**
     * Gets the percentage discount for a coupon
     *
     * @return The percentage
     */
    public Integer getDiscountPercent() {
        return discountPercent;
    }

    public void setDiscountPercent(final Object discountPercent) {
        this.discountPercent = integerOrNull(discountPercent);
    }

    public DateTime getRedeemByDate() {
        return redeemByDate;
    }

    public void setRedeemByDate(final Object redeemByDate) {
        this.redeemByDate = dateTimeOrNull(redeemByDate);
    }

    public Integer getAppliesForMonths() {
        return appliesForMonths;
    }

    public void setAppliesForMonths(final Object appliesForMonths) {
        this.appliesForMonths = integerOrNull(appliesForMonths);
    }

    public Integer getMaxRedemptions() {
        return maxRedemptions;
    }

    public void setMaxRedemptions(final Object maxRedemptions) {
        this.maxRedemptions = integerOrNull(maxRedemptions);
    }

    public Boolean getSingleUse() {
        return singleUse;
    }

    public void setSingleUse(final Object singleUse) {
        this.singleUse = booleanOrNull(singleUse);
    }

    public RecurlyUnitCurrency getDiscountInCents() {
        return discountInCents;
    }

    public void setDiscountInCents(final Object discountInCents) {
        this.discountInCents = RecurlyUnitCurrency.build(discountInCents);
    }

    public Boolean getAppliesToAllPlans() {
        return appliesToAllPlans;
    }

    public void setAppliesToAllPlans(final Object appliesToAllPlans) {
        this.appliesToAllPlans = booleanOrNull(appliesToAllPlans);
    }

    public Boolean getAppliesToAllItems() {
        return appliesToAllItems;
    }

    public void setAppliesToAllItems(final Object appliesToAllItems) {
        this.appliesToAllItems = booleanOrNull(appliesToAllItems);
    }

    public FreeTrialUnit getFreeTrialUnit() {
        return freeTrialUnit;
    }

    public void setFreeTrialUnit(final Object freeTrialUnit) {
        this.freeTrialUnit = enumOrNull(FreeTrialUnit.class, freeTrialUnit);
    }

    public Integer getFreeTrialAmount() {
        return freeTrialAmount;
    }

    public void setFreeTrialAmount(final Object freeTrialAmount) {
        this.freeTrialAmount = integerOrNull(freeTrialAmount);
    }

    public DateTime getCreatedAt() {
        return createdAt;
    }

    public void setCreatedAt(final Object createdAt) {
        this.createdAt = dateTimeOrNull(createdAt);
    }

    public DateTime getUpdatedAt() {
        return updatedAt;
    }

    public void setUpdatedAt(final Object updatedAt) {
        this.updatedAt = dateTimeOrNull(updatedAt);
    }

    public String getDescription() {
      return description;
    }

    public void setDescription(Object description) {
      this.description = stringOrNull(description);
    }

    public String getInvoiceDescription() {
      return invoiceDescription;
    }

    public void setInvoiceDescription(Object invoiceDescription) {
      this.invoiceDescription = stringOrNull(invoiceDescription);
    }

    public Duration getDuration() {
      return duration;
    }

    public void setDuration(Object duration) {
      this.duration = enumOrNull(Duration.class, duration);
    }

    public TemporalUnit getTemporalUnit() {
      return temporalUnit;
    }

    public void setTemporalUnit(Object temporalUnit) {
      this.temporalUnit = enumOrNull(TemporalUnit.class, temporalUnit);
    }

    public Integer getTemporalAmount() {
      return temporalAmount;
    }

    public void setTemporalAmount(Object temporalAmount) {
      this.temporalAmount = integerOrNull(temporalAmount);
    }

    public Boolean getAppliesToNonPlanCharges() {
      return appliesToNonPlanCharges;
    }

    public void setAppliesToNonPlanCharges(Object appliesToNonPlanCharges) {
      this.appliesToNonPlanCharges = booleanOrNull(appliesToNonPlanCharges);
    }

    public RedemptionResource getRedemptionResource() {
      return redemptionResource;
    }

    public void setRedemptionResource(Object redemptionResource) {
      this.redemptionResource = enumOrNull(RedemptionResource.class, redemptionResource);
    }

    public Integer getMaxRedemptionsPerAccount() {
      return maxRedemptionsPerAccount;
    }

    public void setMaxRedemptionsPerAccount(Object maxRedemptionsPerAccount) {
      this.maxRedemptionsPerAccount = integerOrNull(maxRedemptionsPerAccount);
    }

    public Type getType() {
      return type;
    }

    public void setType(Type type) {
      this.type = enumOrNull(Type.class, type);
    }

    public String getUniqueCodeTemplate() {
      return uniqueCodeTemplate;
    }

    public void setUniqueCodeTemplate(Object uniqueCodeTemplate) {
      this.uniqueCodeTemplate = stringOrNull(uniqueCodeTemplate);
    }

    public Integer getNumberOfUniqueCodes() {
        return numberOfUniqueCodes;
    }

    public void setNumberOfUniqueCodes(Integer numberOfUniqueCodes) {
        this.numberOfUniqueCodes = numberOfUniqueCodes;
    }

    @Override
    public String toString() {
        final StringBuilder sb = new StringBuilder();
        sb.append("Coupon");
        sb.append("{name='").append(name).append('\'');
        sb.append(", id=").append(id);
        sb.append(", couponCode='").append(couponCode).append('\'');
        sb.append(", discountType='").append(discountType).append('\'');
        sb.append(", discountPercent='").append(discountPercent).append('\'');
        sb.append(", createdAt=").append(createdAt);
        sb.append(", updatedAt=").append(updatedAt);
        sb.append('}');
        return sb.toString();
    }

    @Override
    public boolean equals(final Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        final Coupon coupon = (Coupon) o;

        if (appliesForMonths != null ? !appliesForMonths.equals(coupon.appliesForMonths) : coupon.appliesForMonths != null) {
            return false;
        }
        if (appliesToNonPlanCharges != null ? !appliesToNonPlanCharges.equals(coupon.appliesToNonPlanCharges) : coupon.appliesToNonPlanCharges != null) {
            return false;
        }
        if (appliesToAllPlans != null ? !appliesToAllPlans.equals(coupon.appliesToAllPlans) : coupon.appliesToAllPlans != null) {
            return false;
        }
        if (appliesToAllItems != null ? !appliesToAllItems.equals(coupon.appliesToAllItems) : coupon.appliesToAllItems != null) {
            return false;
        }
        if (couponCode != null ? !couponCode.equals(coupon.couponCode) : coupon.couponCode != null) {
            return false;
        }
        if (planCodes != null ? !planCodes.equals(coupon.planCodes) : coupon.planCodes != null) {
            return false;
        }
        if (itemCodes != null ? !itemCodes.equals(coupon.itemCodes) : coupon.itemCodes != null) {
            return false;
        }
        if (createdAt != null ? createdAt.compareTo(coupon.createdAt) != 0 : coupon.createdAt != null) {
            return false;
        }
        if (description != null ? !description.equals(coupon.description) : coupon.description != null) {
            return false;
        }
        if (discountInCents != null ? !discountInCents.equals(coupon.discountInCents) : coupon.discountInCents != null) {
            return false;
        }
        if (discountPercent != null ? !discountPercent.equals(coupon.discountPercent) : coupon.discountPercent != null) {
            return false;
        }
        if (discountType != null ? !discountType.equals(coupon.discountType) : coupon.discountType != null) {
            return false;
        }
        if (duration != null ? !duration.equals(coupon.duration) : coupon.duration != null) {
            return false;
        }
        if (id != null ? !id.equals(coupon.id) : coupon.id != null) {
            return false;
        }
        if (invoiceDescription != null ? !invoiceDescription.equals(coupon.invoiceDescription) : coupon.invoiceDescription != null) {
            return false;
        }
        if (maxRedemptions != null ? !maxRedemptions.equals(coupon.maxRedemptions) : coupon.maxRedemptions != null) {
            return false;
        }
        if (name != null ? !name.equals(coupon.name) : coupon.name != null) {
            return false;
        }
        if (redeemByDate != null ? redeemByDate.compareTo(coupon.redeemByDate) != 0 : coupon.redeemByDate != null) {
            return false;
        }
        if (redemptionResource != null ? redemptionResource.compareTo(coupon.redemptionResource) != 0 : coupon.redemptionResource != null) {
            return false;
        }
        if (singleUse != null ? singleUse.compareTo(coupon.singleUse) != 0 : coupon.singleUse != null) {
            return false;
        }
        if (temporalAmount != null ? temporalAmount.compareTo(coupon.temporalAmount) != 0 : coupon.temporalAmount != null) {
            return false;
        }
        if (temporalUnit != null ? temporalUnit.compareTo(coupon.temporalUnit) != 0 : coupon.temporalUnit != null) {
            return false;
        }
        if (type != null ? type.compareTo(coupon.type) != 0 : coupon.type != null) {
            return false;
        }
        if (uniqueCodeTemplate != null ? uniqueCodeTemplate.compareTo(coupon.uniqueCodeTemplate) != 0 : coupon.uniqueCodeTemplate != null) {
            return false;
        }
        if (freeTrialUnit != null ? !freeTrialUnit.equals(coupon.freeTrialUnit) : coupon.freeTrialUnit != null) {
            return false;
        }
        if (freeTrialAmount != null ? !freeTrialAmount.equals(coupon.freeTrialAmount) : coupon.freeTrialAmount != null) {
            return false;
        }
        if (updatedAt != null ? updatedAt.compareTo(coupon.updatedAt) != 0 : coupon.updatedAt != null) {
            return false;
        }

        return true;
    }

    @Override
    public int hashCode() {
        return Objects.hashCode(
                appliesForMonths,
                appliesToAllPlans,
                appliesToAllItems,
                appliesToNonPlanCharges,
                name,
                couponCode,
                planCodes,
                itemCodes,
                description,
                discountType,
                discountPercent,
                discountInCents,
                duration,
                id,
                invoiceDescription,
                redeemByDate,
                singleUse,
                maxRedemptions,
                freeTrialUnit,
                freeTrialAmount,
                createdAt,
                redemptionResource,
                temporalAmount,
                temporalUnit,
                type,
                uniqueCodeTemplate,
                updatedAt
        );
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy