PlaceGroup.java 5.27 KB
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package fi.insomnia.bortal.model;

import java.util.Date;
import java.util.List;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.Table;
import javax.persistence.Temporal;
import javax.persistence.TemporalType;
import javax.persistence.Version;

/**
 * 
 */
@Entity
@Table(name = "groups")
@NamedQueries( {
	@NamedQuery(name = "PlaceGroup.findAll", query = "SELECT p FROM PlaceGroup p"),
	@NamedQuery(name = "PlaceGroup.findById", query = "SELECT p FROM PlaceGroup p WHERE p.id = :id"),
	@NamedQuery(name = "PlaceGroup.findByCreated", query = "SELECT p FROM PlaceGroup p WHERE p.created = :created"),
	@NamedQuery(name = "PlaceGroup.findByEdited", query = "SELECT p FROM PlaceGroup p WHERE p.edited = :edited"),
	@NamedQuery(name = "PlaceGroup.findByCode", query = "SELECT p FROM PlaceGroup p WHERE p.code = :code"),
	@NamedQuery(name = "PlaceGroup.findByName", query = "SELECT p FROM PlaceGroup p WHERE p.name = :name"),
	@NamedQuery(name = "PlaceGroup.findByActive", query = "SELECT p FROM PlaceGroup p WHERE p.active = :active"),
	@NamedQuery(name = "PlaceGroup.findByDetails", query = "SELECT p FROM PlaceGroup p WHERE p.details = :details") })
public class PlaceGroup implements ModelInterface {

    private static final long serialVersionUID = 1L;
    @Id
    @Column(name = "groups_id", nullable = false)
    private Integer id;

    @Column(name = "group_created", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date created;

    @Column(name = "group_edited", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date edited;

    @Column(name = "group_code")
    private String code;

    @Column(name = "group_name")
    private String name;

    @Column(name = "group_active", nullable = false)
    private boolean active;

    @Column(name = "group_details")
    private String details;

    @JoinColumn(name = "group_creator", referencedColumnName = "users_id")
    @ManyToOne
    private User creator;

    @OneToMany(cascade = CascadeType.ALL, mappedBy = "placeGroup")
    private List<GroupMembership> members;

    @OneToMany(mappedBy = "placeGroup")
    private List<Place> places;

    @Version
    @Column(nullable = false)
    private int jpaVersionField;

    public PlaceGroup() {
    }

    public PlaceGroup(Integer groupsId) {
	this.id = groupsId;
    }

    public PlaceGroup(Integer groupsId, Date groupCreated, Date groupEdited,
	    boolean groupActive) {
	this.id = groupsId;
	this.created = groupCreated;
	this.edited = groupEdited;
	this.active = groupActive;
    }

    public Date getCreated() {
	return created;
    }

    public void setCreated(Date groupCreated) {
	this.created = groupCreated;
    }

    public Date getEdited() {
	return edited;
    }

    public void setEdited(Date groupEdited) {
	this.edited = groupEdited;
    }

    public String getCode() {
	return code;
    }

    public void setCode(String groupCode) {
	this.code = groupCode;
    }

    public String getName() {
	return name;
    }

    public void setName(String groupName) {
	this.name = groupName;
    }

    public boolean getActive() {
	return active;
    }

    public void setActive(boolean groupActive) {
	this.active = groupActive;
    }

    public String getDetails() {
	return details;
    }

    public void setDetails(String groupDetails) {
	this.details = groupDetails;
    }

    public User getCreator() {
	return creator;
    }

    public void setCreator(User groupCreator) {
	this.creator = groupCreator;
    }

    public List<GroupMembership> getMembers() {
	return members;
    }

    public void setMembers(List<GroupMembership> groupMembershipList) {
	this.members = groupMembershipList;
    }

    public List<Place> getPlaces() {
	return places;
    }

    public void setPlaces(List<Place> placeList) {
	this.places = placeList;
    }

    @Override
    public int hashCode() {
	int hash = 0;
	hash += (getId() != null ? getId().hashCode() : 0);
	return hash;
    }

    @Override
    public boolean equals(Object object) {
	// TODO: Warning - this method won't work in the case the id fields are
	// not set
	if (!(object instanceof PlaceGroup)) {
	    return false;
	}
	PlaceGroup other = (PlaceGroup) object;
	if ((this.getId() == null && other.getId() != null)
		|| (this.getId() != null && !this.id.equals(other.id))) {
	    return false;
	}
	return true;
    }

    @Override
    public String toString() {
	return "fi.insomnia.bortal.model.PlaceGroup[id=" + getId() + "]";
    }

    /**
     * @return the id
     */
    public Integer getId() {
	return id;
    }

    /**
     * @param id
     *            the id to set
     */
    public void setId(Integer id) {
	this.id = id;
    }

    /**
     * @return the jpaVersionField
     */
    public int getJpaVersionField() {
	return jpaVersionField;
    }

    /**
     * @param jpaVersionField
     *            the jpaVersionField to set
     */
    public void setJpaVersionField(int jpaVersionField) {
	this.jpaVersionField = jpaVersionField;
    }
}