blob: 596a6f71946a12e1e8c7b59d295beebda90d7369 [file] [log] [blame]
package eu.mulk.mulkcms2.benki.generic;
import eu.mulk.mulkcms2.benki.users.User;
import io.quarkus.hibernate.orm.panache.PanacheEntityBase;
import java.time.OffsetDateTime;
import java.util.Set;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Inheritance;
import javax.persistence.InheritanceType;
import javax.persistence.JoinColumn;
import javax.persistence.JoinTable;
import javax.persistence.ManyToMany;
import javax.persistence.ManyToOne;
import javax.persistence.SequenceGenerator;
import javax.persistence.Table;
@Entity
@Table(name = "posts", schema = "benki")
@Inheritance(strategy = InheritanceType.TABLE_PER_CLASS)
public abstract class Post extends PanacheEntityBase {
@Id
@SequenceGenerator(
allocationSize = 1,
sequenceName = "posts_id_seq",
name = "posts_id_seq",
schema = "benki")
@GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "posts_id_seq")
@Column(name = "id", nullable = false)
public Integer id;
@Column(name = "date", nullable = true)
public OffsetDateTime date;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "owner", referencedColumnName = "id")
public User owner;
@ManyToMany(fetch = FetchType.LAZY)
@JoinTable(
name = "user_visible_posts",
schema = "benki",
joinColumns = @JoinColumn(name = "message"),
inverseJoinColumns = @JoinColumn(name = "user"))
public Set<User> visibleTo;
}