forked from mrigor87/CalorieManager
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathUser.java
More file actions
153 lines (123 loc) · 4.57 KB
/
User.java
File metadata and controls
153 lines (123 loc) · 4.57 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
140
141
142
143
144
145
146
147
148
149
150
151
152
153
package ru.javawebinar.topjava.model;
import org.hibernate.annotations.BatchSize;
import org.hibernate.annotations.Cache;
import org.hibernate.annotations.CacheConcurrencyStrategy;
import org.hibernate.validator.constraints.Email;
import org.hibernate.validator.constraints.Length;
import org.hibernate.validator.constraints.NotEmpty;
import org.springframework.util.CollectionUtils;
import ru.javawebinar.topjava.util.UserUtil;
import javax.persistence.*;
import javax.validation.constraints.Digits;
import java.util.*;
/**
* User: gkislin
* Date: 22.08.2014
*/
@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 WHERE u.email=?1"),
@NamedQuery(name = User.ALL_SORTED, query = "SELECT u FROM User u ORDER BY u.name, u.email"),
})
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
@Entity
@NamedEntityGraph(name = User.GRAPH_WITH_MEALS, attributeNodes = {@NamedAttributeNode("meals")})
@Table(name = "users", uniqueConstraints = {@UniqueConstraint(columnNames = "email", name = "users_unique_email_idx")})
public class User extends NamedEntity {
public static final String GRAPH_WITH_MEALS = "User.withMeals";
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
private String email;
@Column(name = "password", nullable = false)
@NotEmpty
@Length(min = 5)
private String password;
@Column(name = "enabled", nullable = false)
private boolean enabled = true;
@Column(name = "registered", columnDefinition = "timestamp default now()")
private Date registered = new Date();
@Enumerated(EnumType.STRING)
@CollectionTable(name = "user_roles", joinColumns = @JoinColumn(name = "user_id"))
@Column(name = "role")
@ElementCollection(fetch = FetchType.EAGER)
@BatchSize(size = 200)
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
private Set<Role> roles;
@Column(name = "calories_per_day", columnDefinition = "default 2000")
@Digits(fraction = 0, integer = 4)
private int caloriesPerDay = UserUtil.DEFAULT_CALORIES_PER_DAY;
@OneToMany(cascade = CascadeType.REMOVE, fetch = FetchType.LAZY, mappedBy = "user")
@OrderBy("dateTime DESC")
// @JsonIgnore
protected List<Meal> meals;
public User() {
}
public User(User u) {
this(u.getId(), u.getName(), u.getEmail(), u.getPassword(), u.getCaloriesPerDay(), u.isEnabled(), u.getRoles());
}
public User(Integer id, String name, String email, String password, Role role, Role... roles) {
this(id, name, email, password, UserUtil.DEFAULT_CALORIES_PER_DAY, true, EnumSet.of(role, roles));
}
public User(Integer id, String name, String email, String password, int caloriesPerDay, boolean enabled, Set<Role> roles) {
super(id, name);
this.email = email;
this.password = password;
this.caloriesPerDay = caloriesPerDay;
this.enabled = enabled;
setRoles(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 int getCaloriesPerDay() {
return caloriesPerDay;
}
public void setCaloriesPerDay(int caloriesPerDay) {
this.caloriesPerDay = caloriesPerDay;
}
public boolean isEnabled() {
return enabled;
}
public Set<Role> getRoles() {
return roles;
}
public void setRoles(Collection<Role> roles) {
this.roles = CollectionUtils.isEmpty(roles) ? Collections.emptySet() : EnumSet.copyOf(roles);
}
public String getPassword() {
return password;
}
public List<Meal> getMeals() {
return meals;
}
@Override
public String toString() {
return "User (" +
"id=" + id +
", email=" + email +
", name=" + name +
", enabled=" + enabled +
", roles=" + roles +
", caloriesPerDay=" + caloriesPerDay +
')';
}
}