PlaceGroup.java 5.28 KB
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package fi.insomnia.bortal.model;

import java.io.Serializable;
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;

/**
 * 
 * @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 Serializable {
    private static final long serialVersionUID = 1L;
    @Id
    @Column(name = "groups_id", nullable = false)
    private Integer groupsId;
    @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", length = 2147483647)
    private String groupCode;
    @Column(name = "group_name", length = 2147483647)
    private String groupName;
    @Column(name = "group_active", nullable = false)
    private boolean groupActive;
    @Column(name = "group_details", length = 2147483647)
    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;

    public PlaceGroup() {
    }

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

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

    public Integer getGroupsId() {
	return groupsId;
    }

    public void setGroupsId(Integer groupsId) {
	this.groupsId = groupsId;
    }

    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 += (groupsId != null ? groupsId.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.groupsId == null && other.groupsId != null)
		|| (this.groupsId != null && !this.groupsId
			.equals(other.groupsId))) {
	    return false;
	}
	return true;
    }

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

}