de.terrestris.shogun.model.BaseModel.java Source code

Java tutorial

Introduction

Here is the source code for de.terrestris.shogun.model.BaseModel.java

Source

/* Copyright (c) 2012-2014, terrestris GmbH & Co. KG
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 * 1. Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions and the following disclaimer in the documentation
 *    and/or other materials provided with the distribution.
 * 3. Neither the name of the copyright holder nor the names of its contributors
 *    may be used to endorse or promote products derived from this software
 *    without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
 * POSSIBILITY OF SUCH DAMAGE.
 *
 * (This is the BSD 3-Clause, sometimes called 'BSD New' or 'BSD Simplified',
 * see http://opensource.org/licenses/BSD-3-Clause)
 */
package de.terrestris.shogun.model;

import java.util.Date;

import javax.persistence.Column;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.MappedSuperclass;

import org.apache.commons.lang3.builder.EqualsBuilder;
import org.apache.commons.lang3.builder.HashCodeBuilder;
import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;

import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;

import de.terrestris.shogun.deserializer.DateDeserializer;
import de.terrestris.shogun.serializer.DateSerializer;

/**
 * BaseModel POJO
 *   ensures that a primary key ID and
 *   the internal metadata
 *   <ul>
 *     <li>created_at</li>
 *     <li>updated_at</li>
 *     <li>app_user</li>
 *   <ul>
 * are available in every model instance (DB table)
 *
 * @author terrestris GmbH & Co. KG
 * @author Christian Mayer
 *
 * @version $Id$
 *
 */
@MappedSuperclass
public class BaseModel implements BaseModelInterface {

    private int id;

    private Date created_at;
    private Date updated_at;
    private String app_user;

    /**
     * Ensure that these not null fields are set.
     */
    public BaseModel() {

        this.setCreated_at(new Date());
        this.setUpdated_at(new Date());
        this.setApp_user("default");
    }

    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    @Column(name = "ID", nullable = false)
    public int getId() {
        return this.id;
    }

    public void setId(int id) {
        this.id = id;
    }

    // ----------------------------------------------------------------
    // SOME METADATA
    // ----------------------------------------------------------------

    /**
     *
     */
    @Column(name = "CREATED_AT", nullable = false)
    @JsonSerialize(using = DateSerializer.class)
    public Date getCreated_at() {
        return created_at;
    }

    /**
     *
     * @param created_at
     */
    @JsonDeserialize(using = DateDeserializer.class)
    public void setCreated_at(Date created_at) {
        this.created_at = created_at;
    }

    /**
     *
     * @return
     */
    @Column(name = "UPDATED_AT", nullable = false)
    @JsonSerialize(using = DateSerializer.class)
    public Date getUpdated_at() {
        return updated_at;
    }

    /**
     *
     * @param updated_at
     */
    @JsonIgnore
    public void setUpdated_at(Date updated_at) {
        this.updated_at = updated_at;
    }

    /**
     *
     * @return
     */
    @Column(name = "APP_USER", nullable = false)
    public String getApp_user() {
        return app_user;
    }

    /**
     *
     * @param user
     */
    public void setApp_user(String user) {
        this.app_user = user;
    }

    /**
     * @see java.lang.Object#hashCode()
     *
     * According to
     * http://stackoverflow.com/questions/27581/overriding-equals-and-hashcode-in-java
     * it is recommended only to use getter-methods when using ORM like Hibernate
     */
    @Override
    public int hashCode() {
        return new HashCodeBuilder(17, 31). // two randomly chosen prime numbers
                append(getCreated_at()).toHashCode();
    }

    /**
     * @see java.lang.Object#equals(java.lang.Object)
     *
     * According to
     * http://stackoverflow.com/questions/27581/overriding-equals-and-hashcode-in-java
     * it is recommended only to use getter-methods when using ORM like Hibernate
     */
    @Override
    public boolean equals(Object obj) {
        if (this == obj)
            return true;
        if (obj == null)
            return false;
        if (!(obj instanceof BaseModel))
            return false;
        BaseModel other = (BaseModel) obj;

        return new EqualsBuilder().append(getId(), other.getId()).append(getCreated_at(), other.getCreated_at())
                .isEquals();
    }

    /**
     *
     */
    public String toString() {
        return new ToStringBuilder(this, ToStringStyle.MULTI_LINE_STYLE).append("id", id)
                .append("created_at", created_at).append("updated_at", updated_at).append("app_user", app_user)
                .toString();
    }

    /**
     * Returns a short string which contains the most basic info about the
     * object instance: the simple class name and the id.
     *
     * Useful e.g. for logging purposes.
     * @return
     */
    public String info() {
        String identity = this.getClass().getSimpleName() + " (id=" + this.id + ")";
        return identity;
    }
}