forked from Realhedin/topjava02
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUser.java
More file actions
139 lines (110 loc) · 3.99 KB
/
User.java
File metadata and controls
139 lines (110 loc) · 3.99 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
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
package ru.javawebinar.topjava.model;
import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import ru.javawebinar.topjava.util.AbstractUser;
import javax.persistence.*;
import javax.validation.constraints.NotNull;
import java.util.*;
/**
* 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"),
})
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class User extends NamedEntity implements AbstractUser {
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)
protected String email;
@Column(name = "password", nullable = false)
protected String password;
@Column(name = "enabled", nullable = false)
protected boolean enabled = true;
@Column(name = "registered", columnDefinition = "timestamp default now()")
@NotNull
protected Date registered = new Date();
@Enumerated(EnumType.STRING)
@CollectionTable(name = "user_roles", joinColumns = @JoinColumn(name = "user_id"))
@Column(name = "role")
@ElementCollection(fetch = FetchType.EAGER)
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
// @JsonIgnore
protected Set<Role> roles;
@Column(name = "calories_per_day", nullable = false, columnDefinition = "default 2000")
protected int caloriesPerDay = 2000;
// @OneToMany(cascade = CascadeType.REMOVE, mappedBy = "user", fetch = FetchType.LAZY)
// private List<UserMeal> userMeals = new LinkedList<>();
public User() {
}
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, Role role, Role... roles) {
this(id, name, email, password, enabled, EnumSet.of(role, roles));
}
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;
}
@Override
public int getCaloriesPerDay() {
return caloriesPerDay;
}
@Override
public void setCaloriesPerDay(int caloriesPerDay) {
this.caloriesPerDay = caloriesPerDay;
}
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;
}
public void setRoles(Role... authorities) {
setRoles(Arrays.asList(authorities));
}
public void setRoles(Collection<Role> authorities) {
this.roles = EnumSet.copyOf(authorities);
}
@Override
public String toString() {
return "User (" +
"id=" + id +
", email=" + email +
", name=" + name +
", enabled=" + enabled +
", roles=" + roles +
')';
}
}