/**
* A POJO for user addressbooks
* <p>
- * @author Roland Haeder
+ * @author Roland Haeder<roland@mxchange.org>
*/
@Entity (name = "addressbooks")
@Table (name = "addressbooks")
@NamedQuery (name = "SearchAddressbookById", query = "SELECT a FROM addressbooks AS a WHERE a.addressbookId = :id")
}
)
-public class UserAddressbook implements Addressbook, Comparable<Addressbook> {
+public class UserAddressbook implements Addressbook {
/**
* Serial number
*/
@Id
@GeneratedValue (strategy = GenerationType.IDENTITY)
- @Column (name = "addressbook_id", length = 20, nullable = false, updatable = false)
+ @Column (name = "addressbook_id", nullable = false, updatable = false)
private Long addressbookId;
+ /**
+ * Last locked timestamp
+ */
+ @Temporal (TemporalType.TIMESTAMP)
+ @Column (name = "addressbook_last_locked")
+ private Calendar addressbookLastLocked;
+
+ /**
+ * Last locked timestamp
+ */
+ @Lob
+ @Column (name = "addressbook_last_locked_reason")
+ private String addressbookLastLockedReason;
+
/**
* Name for this address book
*/
* Connection to "users" table
*/
@JoinColumn (name = "addressbook_user_id", nullable = false)
- @OneToOne (targetEntity = LoginUser.class, optional = false, cascade = CascadeType.MERGE)
+ @OneToOne (targetEntity = LoginUser.class, cascade = CascadeType.REFRESH, optional = false)
private User addressbookUser;
- /**
- * Last locked timestamp
- */
- @Temporal (TemporalType.TIMESTAMP)
- @Column (name = "addressbook_last_locked")
- private Calendar addressbookLastLocked;
-
- /**
- * Last locked timestamp
- */
- @Lob
- @Column (name = "addressbook_last_locked_reason")
- private String addressbookLastLockedReason;
-
/**
* Public constructor with address book name
* <p>
* @param addressbookName Address book name
* @param addressbookUser User instance
- * @param addressbookCreated When this entry has been created
*/
- public UserAddressbook (final String addressbookName, final User addressbookUser, final Calendar addressbookCreated) {
+ public UserAddressbook (final String addressbookName, final User addressbookUser) {
// Call default constructor
this();
- // Set name, user instance and creation timestamp
+ // Set name, user instance
this.addressbookName = addressbookName;
this.addressbookUser = addressbookUser;
- this.addressbookCreated = addressbookCreated;
}
/**
- * Default protected constructor
+ * Default constructor
*/
- protected UserAddressbook () {
+ public UserAddressbook () {
// Set status to UNLOCKED
this.addressbookStatus = AddressbokStatus.UNLOCKED;
}
+ @Override
+ public boolean equals (final Object object) {
+ if (this == object) {
+ return true;
+ } else if (null == object) {
+ return false;
+ } else if (this.getClass() != object.getClass()) {
+ return false;
+ }
+
+ final Addressbook other = (Addressbook) object;
+
+ if (!Objects.equals(this.getAddressbookName(), other.getAddressbookName())) {
+ return false;
+ } else if (!Objects.equals(this.getAddressbookUser(), other.getAddressbookUser())) {
+ return false;
+ }
+
+ return true;
+ }
+
+ @Override
+ public int hashCode () {
+ int hash = 7;
+ hash = 59 * hash + Objects.hashCode(this.getAddressbookName());
+ hash = 59 * hash + Objects.hashCode(this.getAddressbookUser());
+ return hash;
+ }
+
@Override
public Calendar getAddressbookCreated () {
return this.addressbookCreated;
this.addressbookUser = addressbookUser;
}
- @Override
- public int compareTo (final Addressbook addressbook) {
- throw new UnsupportedOperationException("Not supported yet."); //To change body of generated methods, choose Tools | Templates.
- }
-
- @Override
- public boolean equals (final Object object) {
- if (object == null) {
- return false;
- } else if (getClass() != object.getClass()) {
- return false;
- }
-
- final Addressbook other = (Addressbook) object;
-
- if (!Objects.equals(this.getAddressbookName(), other.getAddressbookName())) {
- return false;
- } else if (!Objects.equals(this.getAddressbookUser(), other.getAddressbookUser())) {
- return false;
- }
-
- return true;
- }
-
- @Override
- public int hashCode () {
- int hash = 7;
- hash = 59 * hash + Objects.hashCode(this.getAddressbookName());
- hash = 59 * hash + Objects.hashCode(this.getAddressbookUser());
- return hash;
- }
}