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

com.intuit.payment.data.Refund Maven / Gradle / Ivy

The newest version!
/*******************************************************************************
 * Copyright (c) 2019 Intuit
 *
 * Licensed 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.intuit.payment.data;

import java.math.BigDecimal;
import java.util.Date;

import org.apache.commons.lang.builder.ReflectionToStringBuilder;

import com.fasterxml.jackson.annotation.JsonIgnoreProperties;

/**
 * @author dderose
 *
 */
@JsonIgnoreProperties(ignoreUnknown = true)
public class Refund extends Entity {

	private static final long serialVersionUID = 1L;

	private String id = null;
	private Date created = null;
	private RefundStatus status = null;

	public enum RefundStatus {
		ISSUED, DECLINED, SETTLED, VOIDED, SUCCEEDED
	};

	private BigDecimal amount = null;
	private PaymentContext context = null;
	private String description = null;
	private String type = null;

	public Refund() {
	}

	private Refund(Builder builder) {
		this.id = builder.id;
		this.created = builder.created;
		this.status = builder.status;
		this.amount = builder.amount;
		this.context = builder.context;
		this.description = builder.description;
		this.type = builder.type;
	}

	/**
	 * System generated alpha-numeric id
	 *
	 * @return System generated alpha-numeric id
	 */
	public String getId() {
		return id;
	}

	/**
	 * System generated alpha-numeric id
	 *
	 * @param id
	 *            System generated alpha-numeric id
	 */
	public void setId(String id) {
		this.id = id;
	}

	/**
	 * Object create time, in ISO 8601 date-time format
	 *
	 * @return Object create time, in ISO 8601 date-time format
	 */
	public Date getCreated() {
		return created;
	}

	/**
	 * Object create time, in ISO 8601 date-time format
	 *
	 * @param created
	 *            Object create time, in ISO 8601 date-time format
	 */
	public void setCreated(Date created) {
		this.created = created;
	}

	/**
	 * Status of this refund
	 *
	 * @return Status of this refund
	 */
	public RefundStatus getStatus() {
		return status;
	}

	/**
	 * Status of this refund
	 *
	 * @param status
	 *            Status of this refund
	 */
	public void setStatus(RefundStatus status) {
		this.status = status;
	}

	/**
	 * Amount of the transaction. Valid values for amount are in the range 0.00
	 * through 99999.99
	 *
	 * @return Amount of the transaction. Valid values for amount are in the
	 *         range 0.00 through 99999.99
	 */
	public BigDecimal getAmount() {
		return amount;
	}

	/**
	 * Amount of the transaction. Valid values for amount are in the range 0.00
	 * through 99999.99
	 *
	 * @param amount
	 *            Amount of the transaction. Valid values for amount are in the
	 *            range 0.00 through 99999.99
	 */
	public void setAmount(BigDecimal amount) {
		this.amount = amount;
	}

	/**
	 * Optional additional data that will be stored with this refund
	 *
	 * @return Optional additional data that will be stored with this refund
	 */
	public PaymentContext getContext() {
		return context;
	}

	/**
	 * Optional additional data that will be stored with this refund
	 *
	 * @param context
	 *            Optional additional data that will be stored with this refund
	 */
	public void setContext(PaymentContext context) {
		this.context = context;
	}

	/**
	 * Optional description that will be stored with this refund
	 *
	 * @return Optional description that will be stored with this refund
	 */
	public String getDescription() {
		return description;
	}

	/**
	 * Optional description that will be stored with this refund
	 *
	 * @param description
	 *            Optional description that will be stored with this refund
	 */
	public void setDescription(String description) {
		this.description = description;
	}

	/**
	 * @return
	 */
	public String getType() {
		return type;
	}

	/**
	 * @param type
	 */
	public void setType(String type) {
		this.type = type;
	}

	@Override
	public String toString() {
		return ReflectionToStringBuilder.toString(this);
	}

	/**
	 * Builder class for Refund
	 * 
	 * @author dderose
	 *
	 */
	public static class Builder {

		private String id = null;
		private Date created = null;
		private RefundStatus status = null;
		private BigDecimal amount = null;
		private PaymentContext context = null;
		private String description = null;
		private String type = null;

		public Builder() {
		}

		public Builder id(String id) {
			this.id = id;
			return this;
		}

		public Builder created(Date created) {
			this.created = created;
			return this;
		}

		public Builder status(RefundStatus status) {
			this.status = status;
			return this;
		}

		public Builder amount(BigDecimal amount) {
			this.amount = amount;
			return this;
		}

		public Builder context(PaymentContext context) {
			this.context = context;
			return this;
		}

		public Builder description(String description) {
			this.description = description;
			return this;
		}

		public Builder type(String type) {
			this.type = type;
			return this;
		}

		public Refund build() {
			return new Refund(this);
		}

	}
}





© 2015 - 2024 Weber Informatics LLC | Privacy Policy