Event.java 6.03 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.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;
import javax.persistence.Version;

/**
 *
 * @author jkj
 */
@Entity
@Table(name = "events")
@NamedQueries({
    @NamedQuery(name = "Event.findAll", query = "SELECT e FROM Event e"),
    @NamedQuery(name = "Event.findByEventsId", query = "SELECT e FROM Event e WHERE e.eventsId = :eventsId"),
    @NamedQuery(name = "Event.findByStartTime", query = "SELECT e FROM Event e WHERE e.startTime = :startTime"),
    @NamedQuery(name = "Event.findByEndTime", query = "SELECT e FROM Event e WHERE e.endTime = :endTime"),
    @NamedQuery(name = "Event.findByName", query = "SELECT e FROM Event e WHERE e.name = :name"),
    @NamedQuery(name = "Event.findByReferer", query = "SELECT e FROM Event e WHERE e.referer = :referer")})
public class Event implements ModelInterface {

    private static final long serialVersionUID = 1L;
    @Id
    
    @Column(name = "events_id", nullable = false)
    private Integer id;
    @Column(name = "start_time")
    @Temporal(TemporalType.TIMESTAMP)
    private Date startTime;
    @Column(name = "end_time")
    @Temporal(TemporalType.TIMESTAMP)
    private Date endTime;
    
    @Column(name = "name", nullable = false)
    private String name;
    @Column(name = "referer")
    private String referer;
    @JoinColumn(name = "event_settings_id", referencedColumnName = "event_settings_id", nullable = false)
    @ManyToOne(optional = false)
    private EventSettings eventSettingsId;
    @JoinColumn(name = "event_status_id", referencedColumnName = "event_status_id", nullable = false)
    @ManyToOne(optional = false)
    private EventStatus eventStatusId;
    @JoinColumn(name = "default_role", referencedColumnName = "roles_id")
    @ManyToOne
    private Role defaultRole;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "eventsId")
    private List<Compo> compoList;
    @OneToMany(mappedBy = "eventsId")
    private List<CardTemplate> cardTemplateList;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "eventsId")
    private List<EventMap> eventMapList;
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "eventsId")
    private List<Role> roleList;
    @Version
    @Column(nullable = false)
    private int jpaVersionField;

    public Event() {
    }

    public Event(Integer eventsId) {
        this.id = eventsId;
    }

    public Event(Integer eventsId, String name) {
        this.id = eventsId;
        this.name = name;
    }

    public Date getStartTime() {
        return startTime;
    }

    public void setStartTime(Date startTime) {
        this.startTime = startTime;
    }

    public Date getEndTime() {
        return endTime;
    }

    public void setEndTime(Date endTime) {
        this.endTime = endTime;
    }

    public String getName() {
        return name;
    }

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

    public String getReferer() {
        return referer;
    }

    public void setReferer(String referer) {
        this.referer = referer;
    }

    public EventSettings getEventSettingsId() {
        return eventSettingsId;
    }

    public void setEventSettingsId(EventSettings eventSettingsId) {
        this.eventSettingsId = eventSettingsId;
    }

    public EventStatus getEventStatusId() {
        return eventStatusId;
    }

    public void setEventStatusId(EventStatus eventStatusId) {
        this.eventStatusId = eventStatusId;
    }

    public Role getDefaultRole() {
        return defaultRole;
    }

    public void setDefaultRole(Role defaultRole) {
        this.defaultRole = defaultRole;
    }

    public List<Compo> getCompoList() {
        return compoList;
    }

    public void setCompoList(List<Compo> compoList) {
        this.compoList = compoList;
    }

    public List<CardTemplate> getCardTemplateList() {
        return cardTemplateList;
    }

    public void setCardTemplateList(List<CardTemplate> cardTemplateList) {
        this.cardTemplateList = cardTemplateList;
    }

    public List<EventMap> getEventMapList() {
        return eventMapList;
    }

    public void setEventMapList(List<EventMap> eventMapList) {
        this.eventMapList = eventMapList;
    }

    public List<Role> getRoleList() {
        return roleList;
    }

    public void setRoleList(List<Role> roleList) {
        this.roleList = roleList;
    }

    @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 Event)) {
            return false;
        }
        Event other = (Event) 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.Event[eventsId=" + 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;
    }
}