/*******************************************************************************
* Copyright (c) 2011, 2015 Oracle and/or its affiliates. All rights reserved.
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 and Eclipse Distribution License v. 1.0
* which accompanies this distribution.
* The Eclipse Public License is available at http://www.eclipse.org/legal/epl-v10.html
* and the Eclipse Distribution License is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* Contributors:
* Blaise Doughan - 2.3 - initial implementation
* Praba Vijayaratnam - 2.3 - test automation
******************************************************************************/
package org.eclipse.persistence.testing.jaxrs.model;
import org.eclipse.persistence.oxm.annotations.XmlPath;
import javax.persistence.CascadeType;
import javax.persistence.Column;
import javax.persistence.Entity;
import javax.persistence.FetchType;
import javax.persistence.Id;
import javax.persistence.NamedQueries;
import javax.persistence.NamedQuery;
import javax.persistence.OneToMany;
import javax.persistence.OneToOne;
import javax.persistence.Table;
import javax.xml.bind.annotation.XmlRootElement;
import java.io.Serializable;
import java.util.List;
@NamedQueries({
@NamedQuery(name = "findCustomerById", query = "SELECT c "
+ "FROM Customer c " + "WHERE c.id = :id"),
@NamedQuery(name = "findCustomerByName", query = "SELECT c "
+ "FROM Customer c " + "WHERE c.firstName = :firstName AND "
+ " c.lastName = :lastName"),
@NamedQuery(name = "findCustomerByCity", query = "SELECT c "
+ "FROM Customer c " + "WHERE c.address.city = :city ") })
@Entity
@XmlRootElement
@Table(name = "CUSTOMER")
public class Customer implements Serializable {
private static final long serialVersionUID = 1L;
@Id
private long id;
@Column(name = "FIRST_NAME")
private String firstName;
@Column(name = "LAST_NAME")
private String lastName;
@OneToMany(mappedBy = "customer", cascade = { CascadeType.ALL })
private List<PhoneNumber> phoneNumbers;
@OneToOne(mappedBy = "customer", cascade = { CascadeType.ALL }, fetch = FetchType.LAZY)
private Address address;
public Customer() {
}
public long getId() {
return this.id;
}
public void setId(long id) {
this.id = id;
}
@XmlPath("moxy/firstName/text()")
public String getFirstName() {
return this.firstName;
}
public void setFirstName(String firstName) {
this.firstName = firstName;
}
public String getLastName() {
return this.lastName;
}
public void setLastName(String lastName) {
this.lastName = lastName;
}
public List<PhoneNumber> getPhoneNumbers() {
return this.phoneNumbers;
}
public void setPhoneNumbers(List<PhoneNumber> phoneNumbers) {
this.phoneNumbers = phoneNumbers;
}
public Address getAddress() {
return this.address;
}
public void setAddress(Address address) {
this.address = address;
}
public boolean equals(Object object) {
if (null == object || object.getClass() != this.getClass()) {
return false;
}
Customer test = (Customer) object;
if (!equals(id, test.getId())) {
return false;
}
if (!equals(firstName, test.getFirstName())) {
return false;
}
if (!equals(lastName, test.getLastName())) {
return false;
}
if (null == test.getAddress() && null != address) {
return false;
}
if (null != test.getPhoneNumbers() && null == phoneNumbers) {
return false;
}
return true;
}
private boolean equals(Object control, Object test) {
if (null == control) {
return null == test;
}
return control.equals(test);
}
}