001
002package com.commercetools.history.models.change;
003
004import java.time.*;
005import java.util.*;
006
007import com.fasterxml.jackson.annotation.JsonCreator;
008import com.fasterxml.jackson.annotation.JsonProperty;
009import com.fasterxml.jackson.databind.annotation.*;
010
011import io.vrap.rmf.base.client.ModelBase;
012import io.vrap.rmf.base.client.utils.Generated;
013
014import org.apache.commons.lang3.builder.EqualsBuilder;
015import org.apache.commons.lang3.builder.HashCodeBuilder;
016
017/**
018 *  <p>Change triggered by the Remove Associate update action.</p>
019 */
020@Generated(value = "io.vrap.rmf.codegen.rendering.CoreCodeGenerator", comments = "https://github.com/commercetools/rmf-codegen")
021public class RemoveAssociateChangeImpl implements RemoveAssociateChange, ModelBase {
022
023    private String type;
024
025    private String change;
026
027    private com.commercetools.history.models.common.Associate previousValue;
028
029    /**
030     * create instance with all properties
031     */
032    @JsonCreator
033    RemoveAssociateChangeImpl(@JsonProperty("change") final String change,
034            @JsonProperty("previousValue") final com.commercetools.history.models.common.Associate previousValue) {
035        this.change = change;
036        this.previousValue = previousValue;
037        this.type = REMOVE_ASSOCIATE_CHANGE;
038    }
039
040    /**
041     * create empty instance
042     */
043    public RemoveAssociateChangeImpl() {
044        this.type = REMOVE_ASSOCIATE_CHANGE;
045    }
046
047    /**
048     *
049     */
050
051    public String getType() {
052        return this.type;
053    }
054
055    /**
056     *
057     */
058
059    public String getChange() {
060        return this.change;
061    }
062
063    /**
064     *  <p>Value before the change.</p>
065     */
066
067    public com.commercetools.history.models.common.Associate getPreviousValue() {
068        return this.previousValue;
069    }
070
071    public void setChange(final String change) {
072        this.change = change;
073    }
074
075    public void setPreviousValue(final com.commercetools.history.models.common.Associate previousValue) {
076        this.previousValue = previousValue;
077    }
078
079    @Override
080    public boolean equals(Object o) {
081        if (this == o)
082            return true;
083
084        if (o == null || getClass() != o.getClass())
085            return false;
086
087        RemoveAssociateChangeImpl that = (RemoveAssociateChangeImpl) o;
088
089        return new EqualsBuilder().append(type, that.type)
090                .append(change, that.change)
091                .append(previousValue, that.previousValue)
092                .append(type, that.type)
093                .append(change, that.change)
094                .append(previousValue, that.previousValue)
095                .isEquals();
096    }
097
098    @Override
099    public int hashCode() {
100        return new HashCodeBuilder(17, 37).append(type).append(change).append(previousValue).toHashCode();
101    }
102
103}