AppUser.java
package com.codecool.bytebattlers.model;
import jakarta.persistence.*;
import lombok.Getter;
import lombok.Setter;
import org.hibernate.annotations.JdbcTypeCode;
import org.hibernate.type.SqlTypes;
import java.util.LinkedHashSet;
import java.util.Set;
import java.util.UUID;
@Getter
@Setter
@Entity
@Table(name = "app_user")
public class AppUser {
@Id
@GeneratedValue(strategy = GenerationType.SEQUENCE)
@Column(name = "id", nullable = false)
private Long id;
@Column(name = "public_id", insertable = false)
@JdbcTypeCode(SqlTypes.UUID)
private UUID publicID;
@Column(name = "user_name", nullable = false, unique = true)
@JdbcTypeCode(SqlTypes.VARCHAR)
private String name;
@Enumerated(EnumType.STRING)
private Role role;
@Column(name = "password", nullable = false)
@JdbcTypeCode(SqlTypes.VARCHAR)
private String password;
@Column(name = "email", nullable = false)
@JdbcTypeCode(SqlTypes.VARCHAR)
private String email;
@OneToMany(mappedBy = "appUser", cascade = CascadeType.ALL, orphanRemoval = true)
private Set<Review> reviews = new LinkedHashSet<>();
@ManyToMany(cascade = {CascadeType.PERSIST, CascadeType.MERGE, CascadeType.REFRESH, CascadeType.DETACH})
@JoinTable(name = "app_user_favorite_board_game",
joinColumns = @JoinColumn(name = "app_user_id"),
inverseJoinColumns = @JoinColumn(name = "favorite_board_game_id"))
private Set<BoardGame> favoriteBoardGames = new LinkedHashSet<>();
@OneToMany(mappedBy = "appUser", cascade = CascadeType.ALL, orphanRemoval = true)
private Set<Rating> ratings = new LinkedHashSet<>();
}