/*
- * Copyright (C) 2015 Roland Haeder
+ * Copyright (C) 2016 Roland Haeder
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
import javax.persistence.Id;
import javax.persistence.Index;
import javax.persistence.JoinColumn;
+import javax.persistence.Lob;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToOne;
import javax.persistence.TemporalType;
import org.mxchange.jcontacts.contact.Contact;
import org.mxchange.jcontacts.contact.UserContact;
+import org.mxchange.jusercore.model.user.profilemodes.ProfileMode;
import org.mxchange.jusercore.model.user.status.UserAccountStatus;
/**
@NamedQuery (name = "SearchUserId", query = "SELECT u FROM users AS u WHERE u.userId = :id"),
@NamedQuery (name = "SearchEmailAddress", query = "SELECT u FROM users AS u INNER JOIN contacts AS c ON u.userContact = c WHERE LOWER(c.contactEmailAddress) LIKE LOWER(:param)"),
@NamedQuery (name = "SearchAllUsersExcept", query = "SELECT u FROM users AS u WHERE u != :user ORDER BY u.userId ASC"),
- @NamedQuery (name = "AllPublicUsers", query = "SELECT u FROM users AS u WHERE u.userAccountStatus = :param AND u.userPublicProfile = TRUE")
+ @NamedQuery (name = "AllUsers", query = "SELECT u FROM users AS u ORDER BY u.userId ASC"),
+ @NamedQuery (name = "AllPublicUsers", query = "SELECT u FROM users AS u WHERE u.userAccountStatus = :status AND u.userProfileMode = :mode ORDER BY u.userId ASC"),
+ @NamedQuery (name = "AllMemberPublicUsers", query = "SELECT u FROM users AS u WHERE u.userAccountStatus = :status AND u.userProfileMode IN (:public, :members) ORDER BY u.userId ASC")
}
)
+@SuppressWarnings ("PersistenceUnitPresent")
public class LoginUser implements User {
/**
*/
private static final long serialVersionUID = 4_328_454_581_751L;
+ /**
+ * Last locked reason
+ */
+ @Lob
+ @Column (name = "user_last_locked_reason")
+ private String lastLockedReason;
+
/**
* Account status
*/
/**
* Id number from "contacts" table
*/
- @JoinColumn (name = "user_contact_id", nullable = false, updatable = false)
+ @JoinColumn (name = "user_contact_id", referencedColumnName = "contact_id", nullable = false, updatable = false, unique = true)
@OneToOne (targetEntity = UserContact.class, cascade = CascadeType.ALL, optional = false)
private Contact userContact;
/**
* Encrypted password
*/
+ @Basic (optional = false)
@Column (name = "user_encrypted_password", nullable = false)
private String userEncryptedPassword;
private Long userId;
/**
- * "locked" timestamp
+ * Last "locked" timestamp
*/
@Temporal (TemporalType.TIMESTAMP)
- @Column (name = "user_locked")
- private Calendar userLocked;
+ @Column (name = "user_last_locked_timestamp")
+ private Calendar userLastLocked;
/**
* User name
*/
+ @Basic (optional = false)
@Column (name = "user_name", nullable = false, length = 20)
private String userName;
/**
- * Whether the user wants a public profile. This means that it can be viewed
- * from the Internet by everyone (only profile, no personal data, this needs
- * explicit agreement) and it can be found for sharing addresses with.
+ * Profile mode of this user
*/
@Basic (optional = false)
- @Column (name = "user_public_profile_flag", nullable = false)
- private Boolean userPublicProfile;
+ @Enumerated (EnumType.STRING)
+ @Column (name = "user_profile_mode", nullable = false)
+ private ProfileMode userProfileMode;
+
+ /**
+ * When this user has been updated
+ */
+ @Temporal (TemporalType.TIMESTAMP)
+ @Column (name = "user_updated")
+ private Calendar userUpdated;
/**
* Default constructor
*/
public LoginUser () {
- // Default is not public
- this.userPublicProfile = Boolean.FALSE;
+ // Default is invisible
+ this.userProfileMode = ProfileMode.INVISIBLE;
}
@Override
public void copyAll (final User user) {
- // Copy also contact data
- this.getUserContact().copyAll(user.getUserContact());
+ // Is contact set?
+ if (user.getUserContact() instanceof Contact) {
+ // Copy also contact data
+ this.getUserContact().copyAll(user.getUserContact());
+ }
// Copy other data
this.setUserConfirmKey(user.getUserConfirmKey());
this.setUserEncryptedPassword(user.getUserEncryptedPassword());
this.setUserAccountStatus(user.getUserAccountStatus());
this.setUserCreated(user.getUserCreated());
- this.setUserLocked(user.getUserLocked());
+ this.setUserLastLocked(user.getUserLastLocked());
}
@Override
public boolean equals (final Object object) {
- if (object == null) {
+ if (null == object) {
return false;
}
- if (getClass() != object.getClass()) {
+ if (this.getClass() != object.getClass()) {
return false;
}
final User other = (User) object;
- return ((Objects.equals(this.getUserName(), other.getUserName()))
- && (Objects.equals(this.getUserId(), other.getUserId())));
+ return ((Objects.equals(this.getUserName(), other.getUserName())) &&
+ (Objects.equals(this.getUserId(), other.getUserId())));
+ }
+
+ @Override
+ public int hashCode () {
+ int hash = 5;
+ hash = 83 * hash + Objects.hashCode(this.getUserName());
+ hash = 83 * hash + Objects.hashCode(this.getUserId());
+ return hash;
+ }
+
+ @Override
+ public String getLastLockedReason () {
+ return this.lastLockedReason;
+ }
+
+ @Override
+ public void setLastLockedReason (final String lastLockedReason) {
+ this.lastLockedReason = lastLockedReason;
}
@Override
}
@Override
- public Calendar getUserLocked () {
- return this.userLocked;
+ public Calendar getUserLastLocked () {
+ return this.userLastLocked;
}
@Override
- public void setUserLocked (final Calendar userLocked) {
- this.userLocked = userLocked;
+ public void setUserLastLocked (final Calendar userLastLocked) {
+ this.userLastLocked = userLastLocked;
}
@Override
}
@Override
- public Boolean getUserPublicProfile () {
- return this.userPublicProfile;
+ public ProfileMode getUserProfileMode () {
+ return this.userProfileMode;
}
@Override
- public void setUserPublicProfile (final Boolean userPublicProfile) {
- this.userPublicProfile = userPublicProfile;
+ public void setUserProfileMode (final ProfileMode userProfileMode) {
+ this.userProfileMode = userProfileMode;
}
@Override
- public int hashCode () {
- int hash = 5;
- hash = 83 * hash + Objects.hashCode(this.getUserName());
- hash = 83 * hash + Objects.hashCode(this.getUserId());
- return hash;
+ public Calendar getUserUpdated () {
+ return this.userUpdated;
}
+
+ @Override
+ public void setUserUpdated (final Calendar userUpdated) {
+ this.userUpdated = userUpdated;
+ }
+
}