PlaceGroup.java 5.69 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.Basic;
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
    @Basic(optional = false)
    @Column(name = "groups_id", nullable = false)
    private Integer groupsId;
    @Basic(optional = false)
    @Column(name = "group_created", nullable = false)
    @Temporal(TemporalType.TIMESTAMP)
    private Date groupCreated;
    @Basic(optional = false)
    @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;
    @Basic(optional = false)
    @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 + "]";
    }

}