Compo.java 5.5 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 = "compos")
@NamedQueries( {
	@NamedQuery(name = "Compo.findAll", query = "SELECT c FROM Compo c"),
	@NamedQuery(name = "Compo.findById", query = "SELECT c FROM Compo c WHERE c.id = :id"),
	@NamedQuery(name = "Compo.findByName", query = "SELECT c FROM Compo c WHERE c.name = :name"),
	@NamedQuery(name = "Compo.findByCompoStart", query = "SELECT c FROM Compo c WHERE c.compoStart = :startTime"),
	@NamedQuery(name = "Compo.findByVoteStart", query = "SELECT c FROM Compo c WHERE c.voteStart = :voteStart"),
	@NamedQuery(name = "Compo.findByVoteEnd", query = "SELECT c FROM Compo c WHERE c.voteEnd = :voteEnd"),
	@NamedQuery(name = "Compo.findBySubmitStart", query = "SELECT c FROM Compo c WHERE c.submitStart = :submitStart"),
	@NamedQuery(name = "Compo.findBySubmitEnd", query = "SELECT c FROM Compo c WHERE c.submitEnd = :submitEnd"),
	@NamedQuery(name = "Compo.findByHoldVoting", query = "SELECT c FROM Compo c WHERE c.holdVoting = :holdVoting"),
	@NamedQuery(name = "Compo.findByDescription", query = "SELECT c FROM Compo c WHERE c.description = :description") })
public class Compo implements ModelInterface {
    private static final long serialVersionUID = 1L;
    @Id
    @Column(name = "compos_id", nullable = false)
    private Integer id;

    @Column(name = "compo_name", nullable = false)
    private String name;

    @Column(name = "compo_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date startTime;

    @Column(name = "vote_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date voteStart;

    @Column(name = "vote_end")
    @Temporal(TemporalType.TIMESTAMP)
    private Date voteEnd;

    @Column(name = "submit_start")
    @Temporal(TemporalType.TIMESTAMP)
    private Date submitStart;

    @Column(name = "submit_end")
    @Temporal(TemporalType.TIMESTAMP)
    private Date submitEnd;

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

    @Column(name = "hold_voting", nullable = false, columnDefinition = "boolean default true")
    private boolean holdVoting;

    @OneToMany(cascade = CascadeType.ALL, mappedBy = "compo")
    private List<CompoEntry> compoEntries;

    @JoinColumn(name = "events_id", referencedColumnName = "events_id", nullable = false)
    @ManyToOne(optional = false)
    private Event event;

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

    public Integer getId() {
	return id;
    }

    public void setId(Integer id) {
	this.id = id;
    }

    public Compo() {
    }

    public Compo(Integer composId) {
	this.id = composId;
    }

    public Compo(Integer composId, String compoName, boolean holdVoting) {
	this.id = composId;
	this.name = compoName;
	this.holdVoting = holdVoting;
    }

    public String getName() {
	return name;
    }

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

    public Date getStartTime() {
	return startTime;
    }

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

    public Date getVoteStart() {
	return voteStart;
    }

    public void setVoteStart(Date voteStart) {
	this.voteStart = voteStart;
    }

    public Date getVoteEnd() {
	return voteEnd;
    }

    public void setVoteEnd(Date voteEnd) {
	this.voteEnd = voteEnd;
    }

    public Date getSubmitStart() {
	return submitStart;
    }

    public void setSubmitStart(Date submitStart) {
	this.submitStart = submitStart;
    }

    public Date getSubmitEnd() {
	return submitEnd;
    }

    public void setSubmitEnd(Date submitEnd) {
	this.submitEnd = submitEnd;
    }

    public boolean getHoldVoting() {
	return holdVoting;
    }

    public void setHoldVoting(boolean holdVoting) {
	this.holdVoting = holdVoting;
    }

    public List<CompoEntry> getCompoEntries() {
	return compoEntries;
    }

    public void setCompoEntries(List<CompoEntry> compoEntryList) {
	this.compoEntries = compoEntryList;
    }

    public Event getEvent() {
	return event;
    }

    public void setEvent(Event eventsId) {
	this.event = eventsId;
    }

    @Override
    public int hashCode() {
	int hash = 0;
	hash += (id != null ? id.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 Compo)) {
	    return false;
	}
	Compo other = (Compo) object;
	if ((this.id == null && other.id != null)
		|| (this.id != null && !this.id.equals(other.id))) {
	    return false;
	}
	return true;
    }

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

    public void setJpaVersionField(int jpaVersionField) {
	this.jpaVersionField = jpaVersionField;
    }

    public int getJpaVersionField() {
	return jpaVersionField;
    }

    public void setDescription(String description) {
	this.description = description;
    }

    public String getDescription() {
	return description;
    }

}