PlaceGroup.java 5.64 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;

/**
 * 
 * @author jkj
 */
@Entity
@Table(name = "groups")
@NamedQueries( {
	@NamedQuery(name = "PlaceGroup.findAll", query = "SELECT p FROM PlaceGroup p"),
	@NamedQuery(name = "PlaceGroup.findByGroupsId", query = "SELECT p FROM PlaceGroup p WHERE p.groupsId = :groupsId"),
	@NamedQuery(name = "PlaceGroup.findByGroupCreated", query = "SELECT p FROM PlaceGroup p WHERE p.groupCreated = :groupCreated"),
	@NamedQuery(name = "PlaceGroup.findByGroupEdited", query = "SELECT p FROM PlaceGroup p WHERE p.groupEdited = :groupEdited"),
	@NamedQuery(name = "PlaceGroup.findByGroupCode", query = "SELECT p FROM PlaceGroup p WHERE p.groupCode = :groupCode"),
	@NamedQuery(name = "PlaceGroup.findByGroupName", query = "SELECT p FROM PlaceGroup p WHERE p.groupName = :groupName"),
	@NamedQuery(name = "PlaceGroup.findByGroupActive", query = "SELECT p FROM PlaceGroup p WHERE p.groupActive = :groupActive"),
	@NamedQuery(name = "PlaceGroup.findByGroupDetails", query = "SELECT p FROM PlaceGroup p WHERE p.groupDetails = :groupDetails") })
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 groupCreated;

    @Column(name = "group_edited", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date groupEdited;
    @Column(name = "group_code")
    private String groupCode;
    @Column(name = "group_name")
    private String groupName;

    @Column(name = "group_active", nullable = false)
    private boolean groupActive;
    @Column(name = "group_details")
    private String groupDetails;
    @JoinColumn(name = "group_creator", referencedColumnName = "users_id")
    @ManyToOne
    private User groupCreator;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "groupsId")
    private List<GroupMembership> groupMembershipList;
    @OneToMany(mappedBy = "groupsId")
    private List<Place> placeList;
    @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.groupCreated = groupCreated;
	this.groupEdited = groupEdited;
	this.groupActive = groupActive;
    }

    public Date getGroupCreated() {
	return groupCreated;
    }

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

    public Date getGroupEdited() {
	return groupEdited;
    }

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

    public String getGroupCode() {
	return groupCode;
    }

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

    public String getGroupName() {
	return groupName;
    }

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

    public boolean getGroupActive() {
	return groupActive;
    }

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

    public String getGroupDetails() {
	return groupDetails;
    }

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

    public User getGroupCreator() {
	return groupCreator;
    }

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

    public List<GroupMembership> getGroupMembershipList() {
	return groupMembershipList;
    }

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

    public List<Place> getPlaceList() {
	return placeList;
    }

    public void setPlaceList(List<Place> placeList) {
	this.placeList = 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[groupsId=" + 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;
    }
}