2 * Copyright (C) 2016, 2017 Roland Häder
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.jphone.phonenumbers.mobile;
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.GeneratedValue;
26 import javax.persistence.GenerationType;
27 import javax.persistence.Id;
28 import javax.persistence.JoinColumn;
29 import javax.persistence.NamedQueries;
30 import javax.persistence.NamedQuery;
31 import javax.persistence.OneToOne;
32 import javax.persistence.Table;
33 import javax.persistence.Temporal;
34 import javax.persistence.TemporalType;
35 import javax.persistence.Transient;
36 import org.mxchange.jcountry.data.Country;
37 import org.mxchange.jphone.phonenumbers.mobileprovider.CellphoneProvider;
38 import org.mxchange.jphone.phonenumbers.mobileprovider.MobileProvider;
41 * A POJO for dialable cellphone numbers
43 * @author Roland Häder<roland@mxchange.org>
45 @Entity (name = "mobile_numbers")
46 @Table (name = "mobile_numbers")
49 @NamedQuery (name = "AllMobileNumbers", query = "SELECT c FROM mobile_numbers AS c ORDER BY c.phoneId ASC"),
50 @NamedQuery (name = "SearchMobileNumberId", query = "SELECT c FROM mobile_numbers AS c WHERE c.phoneId = :mobileNumberId")
53 @SuppressWarnings ("PersistenceUnitPresent")
54 public class MobileNumber implements DialableMobileNumber {
60 private static final long serialVersionUID = 13_859_879_482_106L;
63 * Connection to table "mobile_provider" (for dial prefix and more data)
65 @JoinColumn (name = "mobile_provider_id", nullable = false)
66 @OneToOne (targetEntity = CellphoneProvider.class, cascade = CascadeType.REFRESH, optional = false)
67 private MobileProvider mobileProvider;
70 * Timestamp when this entry has been created
72 @Basic (optional = false)
73 @Temporal (TemporalType.TIMESTAMP)
74 @Column (name = "mobile_entry_created", nullable = false, updatable = false)
75 private Calendar phoneEntryCreated;
78 * Timestamp when this entry has been created
80 @Temporal (TemporalType.TIMESTAMP)
81 @Column (name = "mobile_entry_updated", updatable = false)
82 private Calendar phoneEntryUpdated;
88 @GeneratedValue (strategy = GenerationType.IDENTITY)
89 @Column (name = "mobile_id", nullable = false, updatable = false)
93 * Number without prefix to dial
95 @Basic (optional = false)
96 @Column (name = "mobile_number", nullable = false)
97 private Long phoneNumber;
100 * Default constructor
102 public MobileNumber () {
106 * Constructor with cellphone provider and number
108 * @param mobileProvider Mobile provider
109 * @param mobileNumber Mobile number
111 public MobileNumber (final MobileProvider mobileProvider, final Long mobileNumber) {
112 // Call default constructor
116 this.mobileProvider = mobileProvider;
117 this.phoneNumber = mobileNumber;
121 public boolean equals (final Object object) {
122 if (null == object) {
124 } else if (this.getClass() != object.getClass()) {
128 final DialableMobileNumber other = (DialableMobileNumber) object;
130 if (!Objects.equals(this.getPhoneId(), other.getPhoneId())) {
132 } else if (!Objects.equals(this.getMobileProvider(), other.getMobileProvider())) {
134 } else if (!Objects.equals(this.getPhoneNumber(), other.getPhoneNumber())) {
142 public MobileProvider getMobileProvider () {
143 return this.mobileProvider;
147 public void setMobileProvider (final MobileProvider mobileProvider) {
148 this.mobileProvider = mobileProvider;
153 public Integer getPhoneAreaCode () {
154 throw new UnsupportedOperationException("Mobile numbers don't have area codes. Please fix your code."); //NOI18N
159 public void setPhoneAreaCode (final Integer phoneAreaCode) {
160 throw new UnsupportedOperationException("Mobile numbers don't have area codes. Please fix your code."); //NOI18N
165 public Country getPhoneCountry () {
166 throw new UnsupportedOperationException("The country code is provided by MobileProvider."); //To change body of generated methods, choose Tools | Templates.
171 public void setPhoneCountry (final Country country) {
172 throw new UnsupportedOperationException("The country code is provided by MobileProvider."); //To change body of generated methods, choose Tools | Templates.
176 @SuppressWarnings ("ReturnOfDateField")
177 public Calendar getPhoneEntryCreated () {
178 return this.phoneEntryCreated;
182 @SuppressWarnings ("AssignmentToDateFieldFromParameter")
183 public void setPhoneEntryCreated (final Calendar phoneEntryCreated) {
184 this.phoneEntryCreated = phoneEntryCreated;
188 @SuppressWarnings ("ReturnOfDateField")
189 public Calendar getPhoneEntryUpdated () {
190 return this.phoneEntryUpdated;
194 @SuppressWarnings ("AssignmentToDateFieldFromParameter")
195 public void setPhoneEntryUpdated (final Calendar phoneEntryUpdated) {
196 this.phoneEntryUpdated = phoneEntryUpdated;
200 public Long getPhoneId () {
205 public void setPhoneId (final Long phoneId) {
206 this.phoneId = phoneId;
210 public Long getPhoneNumber () {
211 return this.phoneNumber;
215 public void setPhoneNumber (final Long phoneNumber) {
216 this.phoneNumber = phoneNumber;
220 public int hashCode () {
223 hash = 97 * hash + Objects.hashCode(this.getPhoneId());
224 hash = 97 * hash + Objects.hashCode(this.getMobileProvider());
225 hash = 97 * hash + Objects.hashCode(this.getPhoneNumber());