User.java
1.83 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
package net.ziemers.swxercise.lg.model.user;
import javax.persistence.*;
import net.ziemers.swxercise.db.BaseEntity;
/**
* Stellt die Stammdaten eines Benutzers zur Verfügung. Nutzt hierbei verschiedene Subklassen.
*/
@Entity
@NamedQueries({
@NamedQuery(name = "User.findById", query = "SELECT u FROM User u WHERE u.id = :id"),
@NamedQuery(name = "User.findByUsername", query = "SELECT u FROM User u WHERE lower(u.profile.username) = lower(:username)")})
public class User extends BaseEntity {
private String firstname;
private String lastname;
private Profile profile;
private Address address;
public User() {
super();
}
public User(final String firstname, final String lastname) {
this.firstname = firstname;
this.lastname = lastname;
}
public String getFirstname() {
return firstname;
}
public void setFirstname(String firstname) {
this.firstname = firstname;
}
public String getLastname() {
return lastname;
}
public void setLastname(String lastname) {
this.lastname = lastname;
}
@Transient
public String getFullName() {
return String.format("%s %s", getFirstname(), getLastname());
}
@OneToOne(cascade = {CascadeType.ALL})
public Profile getProfile() {
return profile;
}
public void setProfile(Profile profile) {
this.profile = profile;
}
public User withProfile(final Profile profile) {
setProfile(profile);
return this;
}
@OneToOne(cascade = {CascadeType.ALL})
public Address getAddress() {
return address;
}
public void setAddress(Address address) {
this.address = address;
}
public User withAddress(final Address address) {
setAddress(address);
return this;
}
}