2 * Copyright (C) 2016 quix0r
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 package org.mxchange.jusercore.model.email_address;
19 import java.util.Calendar;
20 import java.util.Objects;
21 import javax.persistence.Basic;
22 import javax.persistence.CascadeType;
23 import javax.persistence.Column;
24 import javax.persistence.Entity;
25 import javax.persistence.EnumType;
26 import javax.persistence.Enumerated;
27 import javax.persistence.GeneratedValue;
28 import javax.persistence.GenerationType;
29 import javax.persistence.Id;
30 import javax.persistence.JoinColumn;
31 import javax.persistence.NamedQueries;
32 import javax.persistence.NamedQuery;
33 import javax.persistence.OneToOne;
34 import javax.persistence.Table;
35 import javax.persistence.Temporal;
36 import javax.persistence.TemporalType;
37 import org.mxchange.jusercore.model.email_address.status.EmailChangeStatus;
38 import org.mxchange.jusercore.model.user.LoginUser;
39 import org.mxchange.jusercore.model.user.User;
42 * A POJO for changing email addresses.
44 * @author Roland Haeder<roland@mxchange.org>
46 @Entity (name = "email_changes")
47 @Table (name = "email_changes")
50 @NamedQuery (name = "SearchEmailChangeByEmail", query = "SELECT e FROM email_changes AS e WHERE LOWER(e.emailAddress) LIKE LOWER(:email)"),
51 @NamedQuery (name = "AllEmailAddressChanges", query = "SELECT e.emailAddress FROM email_changes AS e ORDER BY e.emailChangeId ASC")
54 public class EmailAddressChange implements ChangeableEmailAddress {
59 private static final long serialVersionUID = 398_459_287_176_139L;
62 * Email address to change to
64 @Basic (optional = false)
65 @Column (name = "email_address", length = 100, nullable = false, updatable = false)
66 private String emailAddress;
69 * Timestamp when this change has been added
71 @Basic (optional = false)
72 @Temporal (TemporalType.TIMESTAMP)
73 @Column (name = "email_change_created", nullable = false, updatable = false)
74 private Calendar emailChangeCreated;
77 * Timestamp when this change has been done or undone
79 @Basic (optional = false)
80 @Temporal (TemporalType.TIMESTAMP)
81 @Column (name = "email_change_done", nullable = false, updatable = false)
82 private Calendar emailChangeDone;
85 * Email change hash the user has to click
87 @Basic (optional = false)
88 @Column (name = "email_change_hash", unique = true)
89 private String emailChangeHash;
95 @GeneratedValue (strategy = GenerationType.IDENTITY)
96 @Column (name = "email_change_id", length = 20, nullable = false, updatable = false)
97 private Long emailChangeId;
100 * Email change status
102 @Basic (optional = false)
103 @Column (name = "email_change_status", nullable = false, updatable = false)
104 @Enumerated (EnumType.STRING)
105 private EmailChangeStatus emailChangeStatus;
108 * User initiating the email change
110 @JoinColumn (name = "email_change_user_id", nullable = false, updatable = false)
111 @OneToOne (targetEntity = LoginUser.class, cascade = CascadeType.REFRESH, optional = false)
112 private User emailChangeUser;
115 * Default constructor
117 public EmailAddressChange () {
118 // Set default email change status
119 this.emailChangeStatus = EmailChangeStatus.NEW;
123 * Constructor with all fields to set
125 * @param emailChangeId Email change id
126 * @param user User instance
127 * @param emailAddress Email address
128 * @param emailChangeCreated Timestamp for creation
129 * @param emailChangeStatus Email change status
130 * @param emailChangeDone When this entry has been done
131 * @param emailChangeHash Email change hash
133 public EmailAddressChange (final Long emailChangeId, final User user, final String emailAddress, final Calendar emailChangeCreated, final EmailChangeStatus emailChangeStatus, final Calendar emailChangeDone, final String emailChangeHash) {
134 // Call other constructor
135 this(user, emailAddress);
138 this.emailChangeId = emailChangeId;
139 this.emailChangeCreated = emailChangeCreated;
140 this.emailChangeStatus = emailChangeStatus;
141 this.emailChangeDone = emailChangeDone;
142 this.emailChangeHash = emailChangeHash;
146 * Constructor with user and email address
148 * @param user User instance
149 * @param emailAddress Email address
151 public EmailAddressChange (final User user, final String emailAddress) {
152 // Call other constructor
156 this.emailChangeUser = user;
157 this.emailAddress = emailAddress;
161 public boolean equals (final Object object) {
162 if (this == object) {
164 } else if (null == object) {
166 } else if (this.getClass() != object.getClass()) {
170 final ChangeableEmailAddress otherEmail = (ChangeableEmailAddress) object;
172 if (!Objects.equals(this.getEmailAddress(), otherEmail.getEmailAddress())) {
176 return Objects.equals(this.getEmailChangeUser(), otherEmail.getEmailChangeUser());
180 public int hashCode () {
182 hash = 71 * hash + Objects.hashCode(this.getEmailAddress());
183 hash = 71 * hash + Objects.hashCode(this.getEmailChangeUser());
188 public String getEmailAddress () {
189 return this.emailAddress;
193 public void setEmailAddress (final String emailAddress) {
194 this.emailAddress = emailAddress;
198 public Calendar getEmailChangeCreated () {
199 return this.emailChangeCreated;
203 public void setEmailChangeCreated (final Calendar emailChangeCreated) {
204 this.emailChangeCreated = emailChangeCreated;
208 public Calendar getEmailChangeDone () {
209 return this.emailChangeDone;
213 public void setEmailChangeDone (final Calendar emailChangeDone) {
214 this.emailChangeDone = emailChangeDone;
218 public String getEmailChangeHash () {
219 return this.emailChangeHash;
223 public void setEmailChangeHash (final String emailChangeHash) {
224 this.emailChangeHash = emailChangeHash;
228 public Long getEmailChangeId () {
229 return this.emailChangeId;
233 public void setEmailChangeId (final Long emailChangeId) {
234 this.emailChangeId = emailChangeId;
238 public EmailChangeStatus getEmailChangeStatus () {
239 return this.emailChangeStatus;
243 public void setEmailChangeStatus (final EmailChangeStatus emailChangeStatus) {
244 this.emailChangeStatus = emailChangeStatus;
248 public User getEmailChangeUser () {
249 return this.emailChangeUser;
253 public void setEmailChangeUser (final User emailChangeUser) {
254 this.emailChangeUser = emailChangeUser;