NewsGroup.java 3.57 KB
/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */
package fi.insomnia.bortal.model;

import java.util.List;

import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.JoinColumn;
import javax.persistence.JoinColumns;
import javax.persistence.JoinTable;
import javax.persistence.Lob;
import javax.persistence.ManyToMany;
import javax.persistence.ManyToOne;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.OrderBy;
import javax.persistence.Table;
import javax.persistence.UniqueConstraint;

/**
 * 
 * @author jkj
 */
@Entity
@Table(name = "news_groups", uniqueConstraints = @UniqueConstraint(columnNames = { "event_id", "group_name" }))
@NamedQueries({
        @NamedQuery(name = "NewsGroup.findAll", query = "SELECT n FROM NewsGroup n"),
        @NamedQuery(name = "NewsGroup.findByName", query = "SELECT n FROM NewsGroup n WHERE n.name = :name"),
        @NamedQuery(name = "NewsGroup.findByDescription", query = "SELECT n FROM NewsGroup n WHERE n.description = :description"),
        @NamedQuery(name = "NewsGroup.findByPriority", query = "SELECT n FROM NewsGroup n WHERE n.priority = :priority") })
public class NewsGroup extends GenericEventChild {

    /**
     * 
     */
    private static final long serialVersionUID = 4014463478275469802L;

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

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

    @Column(name = "priority", nullable = false)
    private int priority;

    @ManyToOne(optional = false)
    @JoinColumns({ @JoinColumn(name = "writer_role_id", referencedColumnName = Role.ID_COLUMN, nullable = false), })
    private Role writerRole;

    @OrderBy("priority")
    @OneToMany(cascade = CascadeType.ALL, mappedBy = "group")
    private List<News> news;

    @ManyToMany
    @JoinTable(name = "read_group_roles", joinColumns = {
                @JoinColumn(name = "read_group_id", referencedColumnName = ID_COLUMN),
                @JoinColumn(name = "event_id", referencedColumnName = EVENT_ID_COLUMN) }, inverseJoinColumns = {
                @JoinColumn(name = "role_id", referencedColumnName = Role.ID_COLUMN) })
    private List<Role> readerRoles;

    public NewsGroup() {
        super();
    }

    public NewsGroup(LanEvent event) {
        super(event);
    }

    public NewsGroup(LanEvent event, String groupName, int priority) {
        super(event);
        this.name = groupName;
        this.priority = priority;
    }

    public String getName() {
        return name;
    }

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

    public String getDescription() {
        return description;
    }

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

    public int getPriority() {
        return priority;
    }

    public void setPriority(int priority) {
        this.priority = priority;
    }

    @OrderBy("priority")
    public List<News> getNews() {
        return news;
    }

    public void setNews(List<News> newsList) {
        this.news = newsList;
    }

    public void setWriterRole(Role writerRole) {
        this.writerRole = writerRole;
    }

    public Role getWriterRole() {
        return writerRole;
    }

    public void setReaderRoles(List<Role> readerRoles) {
        this.readerRoles = readerRoles;
    }

    public List<Role> getReaderRoles() {
        return readerRoles;
    }
}