-
Notifications
You must be signed in to change notification settings - Fork 6
Expand file tree
/
Copy pathUser.java
More file actions
91 lines (77 loc) · 2.97 KB
/
User.java
File metadata and controls
91 lines (77 loc) · 2.97 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package ru.javaops.topjava2.model;
import com.fasterxml.jackson.annotation.JsonProperty;
import jakarta.persistence.*;
import jakarta.validation.constraints.Email;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;
import jakarta.validation.constraints.Size;
import lombok.AccessLevel;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;
import org.hibernate.annotations.OnDelete;
import org.hibernate.annotations.OnDeleteAction;
import org.springframework.util.CollectionUtils;
import ru.javaops.topjava2.HasIdAndEmail;
import ru.javaops.topjava2.util.validation.NoHtml;
import java.io.Serial;
import java.io.Serializable;
import java.util.*;
@Entity
@Table(name = "users")
@Getter
@Setter
@NoArgsConstructor(access = AccessLevel.PROTECTED)
public class User extends NamedEntity implements HasIdAndEmail {
@Column(name = "email", nullable = false, unique = true)
@Email
@NotBlank
@Size(max = 128)
@NoHtml // https://stackoverflow.com/questions/17480809
private String email;
@Column(name = "password", nullable = false)
@NotBlank
@Size(max = 128)
// https://stackoverflow.com/a/12505165/548473
@JsonProperty(access = JsonProperty.Access.WRITE_ONLY)
private String password;
@Column(name = "enabled", nullable = false, columnDefinition = "bool default true")
private boolean enabled = true;
@Column(name = "registered", nullable = false, columnDefinition = "timestamp default now()", updatable = false)
@NotNull
@JsonProperty(access = JsonProperty.Access.READ_ONLY)
private Date registered = new Date();
@Enumerated(EnumType.STRING)
@CollectionTable(name = "user_role",
joinColumns = @JoinColumn(name = "user_id"),
uniqueConstraints = @UniqueConstraint(columnNames = {"user_id", "role"}, name = "uk_user_role"))
@Column(name = "role")
@ElementCollection(fetch = FetchType.EAGER)
@JoinColumn
@OnDelete(action = OnDeleteAction.CASCADE)
private Set<Role> roles;
public User(User u) {
this(u.id, u.name, u.email, u.password, u.enabled, u.registered, u.roles);
}
public User(Integer id, String name, String email, String password, Role... roles) {
this(id, name, email, password, true, new Date(), Arrays.asList(roles));
}
public User(Integer id, String name, String email, String password, boolean enabled, Date registered, Collection<Role> roles) {
super(id, name);
this.email = email;
this.password = password;
this.enabled = enabled;
this.registered = registered;
setRoles(roles);
}
public void setRoles(Collection<Role> roles) {
this.roles = CollectionUtils.isEmpty(roles) ? EnumSet.noneOf(Role.class) : EnumSet.copyOf(roles);
}
public boolean hasRole(Role role) {
return roles != null && roles.contains(role);
}
@Override
public String toString() {
return "User:" + id + '[' + email + ']';
}
}