blob: f9ed05c71fb7c56908703bcd446f5d5ccd689bfe [file] [log] [blame]
package eu.mulk.mulkcms2.entity;
import io.quarkus.hibernate.orm.panache.PanacheEntityBase;
import java.sql.Timestamp;
import java.util.Collection;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.ManyToOne;
import javax.persistence.OneToMany;
import javax.persistence.Table;
@Entity
@Table(name = "article_revisions", schema = "public", catalog = "mulkcms")
public class ArticleRevision extends PanacheEntityBase {
@Id
@Column(name = "id", nullable = false)
public int id;
@Column(name = "date", nullable = true)
public Timestamp date;
@Column(name = "title", nullable = false, length = -1)
public String title;
@Column(name = "content", nullable = false, length = -1)
public String content;
@Column(name = "format", nullable = false, length = -1)
public String format;
@Column(name = "status", nullable = false, length = -1)
public String status;
@Column(name = "global_id", nullable = true, length = -1)
public String globalId;
@OneToMany(mappedBy = "articleRevision", fetch = FetchType.LAZY)
public Collection<ArticleRevisionCharacteristic> characteristics;
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(
name = "article_revision_parenthood",
joinColumns = @JoinColumn(name = "parent"),
inverseJoinColumns = @JoinColumn(name = "child"))
public Set<ArticleRevision> children;
@ManyToMany(mappedBy = "children")
public Set<ArticleRevision> parents;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "article", referencedColumnName = "id", nullable = false)
public Article article;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "author", referencedColumnName = "id")
public User authors;
}