forked from VolodymyrPortianko/topjava03
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUser.java
More file actions
116 lines (93 loc) · 3.16 KB
/
User.java
File metadata and controls
116 lines (93 loc) · 3.16 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
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
package ru.javawebinar.topjava.model;
import org.hibernate.validator.constraints.Email;
import org.hibernate.validator.constraints.Length;
import org.hibernate.validator.constraints.NotEmpty;
import javax.persistence.*;
import java.util.Date;
import java.util.EnumSet;
import java.util.Set;
/**
* User: gkislin
* Date: 22.08.2014
*/
@Entity
@Table(name = "users", uniqueConstraints = {@UniqueConstraint(columnNames = "email", name = "unique_email")})
@NamedQueries({
@NamedQuery(name = User.DELETE, query = "DELETE FROM User u WHERE u.id=:id"),
@NamedQuery(name = User.BY_EMAIL, query = "SELECT u FROM User u LEFT JOIN FETCH u.roles WHERE u.email=?1"),
@NamedQuery(name = User.ALL_SORTED, query = "SELECT u FROM User u LEFT JOIN FETCH u.roles ORDER BY u.name, u.email"),
})
public class User extends NamedEntity {
public static final String DELETE = "User.delete";
public static final String ALL_SORTED = "User.getAllSorted";
public static final String BY_EMAIL = "User.getByEmail";
@Column(name = "email", nullable = false, unique = true)
@Email
@NotEmpty
protected String email;
@Column(name = "password", nullable = false)
@NotEmpty
@Length(min = 5)
protected String password;
@Column(name = "enabled", nullable = false)
protected boolean enabled = true;
@Column(name = "registered", columnDefinition = "timestamp default now()")
protected Date registered = new Date();
@Enumerated(EnumType.STRING)
@CollectionTable(name = "user_roles", joinColumns = @JoinColumn(name = "user_id"))
@Column(name = "role")
@ElementCollection(fetch = FetchType.EAGER)
protected Set<Role> roles;
public User() {
}
public User(Integer id, String name, String email, String password, Role role, Role... roles) {
this(id, name, email, password, true, EnumSet.of(role, roles));
}
public User(User u) {
this(u.getId(), u.getName(), u.getEmail(), u.getPassword(), u.isEnabled(), u.getRoles());
}
public User(Integer id, String name, String email, String password, boolean enabled, Set<Role> roles) {
super(id, name);
this.email = email;
this.password = password;
this.enabled = enabled;
this.roles = roles;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public void setPassword(String password) {
this.password = password;
}
public Date getRegistered() {
return registered;
}
public void setRegistered(Date registered) {
this.registered = registered;
}
public void setEnabled(boolean enabled) {
this.enabled = enabled;
}
public boolean isEnabled() {
return enabled;
}
public Set<Role> getRoles() {
return roles;
}
public String getPassword() {
return password;
}
@Override
public String toString() {
return "User (" +
"id=" + id +
", email=" + email +
", name=" + name +
", enabled=" + enabled +
", roles=" + roles +
')';
}
}