]> git.mxchange.org Git - jjobs-war.git/blob - src/java/org/mxchange/jjobs/beans/phone/JobsPhoneWebApplicationBean.java
Continued a bit:
[jjobs-war.git] / src / java / org / mxchange / jjobs / beans / phone / JobsPhoneWebApplicationBean.java
1 /*
2  * Copyright (C) 2016, 2017 Roland Häder
3  *
4  * This program is free software: you can redistribute it and/or modify
5  * it under the terms of the GNU Affero General Public License as
6  * published by the Free Software Foundation, either version 3 of the
7  * License, or (at your option) any later version.
8  *
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 Affero General Public License for more details.
13  *
14  * You should have received a copy of the GNU Affero General Public License
15  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
16  */
17 package org.mxchange.jjobs.beans.phone;
18
19 import java.text.MessageFormat;
20 import java.util.LinkedList;
21 import java.util.List;
22 import java.util.Objects;
23 import javax.annotation.PostConstruct;
24 import javax.enterprise.context.ApplicationScoped;
25 import javax.enterprise.event.Observes;
26 import javax.faces.view.facelets.FaceletException;
27 import javax.inject.Named;
28 import javax.naming.Context;
29 import javax.naming.InitialContext;
30 import javax.naming.NamingException;
31 import org.mxchange.jcontacts.contact.Contact;
32 import org.mxchange.jcontacts.events.contact.add.ObservableAdminAddedContactEvent;
33 import org.mxchange.jcontacts.events.contact.update.ObservableAdminUpdatedContactEvent;
34 import org.mxchange.jcontacts.events.fax.linked.ObservableAdminLinkedFaxNumberEvent;
35 import org.mxchange.jcontacts.events.landline.linked.ObservableAdminLinkedLandLineNumberEvent;
36 import org.mxchange.jcontacts.events.mobile.linked.ObservableAdminLinkedMobileNumberEvent;
37 import org.mxchange.jjobs.beans.BaseJobsController;
38 import org.mxchange.jphone.events.fax.deleted.AdminDeletedFaxNumberEvent;
39 import org.mxchange.jphone.events.fax.updated.AdminUpdatedFaxNumberEvent;
40 import org.mxchange.jphone.events.landline.deleted.AdminDeletedLandLineNumberEvent;
41 import org.mxchange.jphone.events.landline.updated.AdminUpdatedLandLineNumberEvent;
42 import org.mxchange.jphone.events.mobile.deleted.AdminDeletedMobileNumberEvent;
43 import org.mxchange.jphone.events.mobile.updated.AdminUpdatedMobileNumberEvent;
44 import org.mxchange.jphone.phonenumbers.fax.DialableFaxNumber;
45 import org.mxchange.jphone.phonenumbers.landline.DialableLandLineNumber;
46 import org.mxchange.jphone.phonenumbers.mobile.DialableMobileNumber;
47 import org.mxchange.jphone.phonenumbers.phone.PhoneSessionBeanRemote;
48 import org.mxchange.jusercore.events.user.add.ObservableAdminAddedUserEvent;
49
50 /**
51  * Regular controller (bean) for phone numbers
52  * <p>
53  * @author Roland Häder<roland@mxchange.org>
54  */
55 @Named ("phoneController")
56 @ApplicationScoped
57 public class JobsPhoneWebApplicationBean extends BaseJobsController implements JobsPhoneWebApplicationController {
58
59         /**
60          * Serial number
61          */
62         private static final long serialVersionUID = 491_058_674_675_690_105L;
63
64         /**
65          * All fax numbers
66          */
67         private final List<DialableFaxNumber> faxNumbers;
68
69         /**
70          * All land-line numbers
71          */
72         private final List<DialableLandLineNumber> landLineNumbers;
73
74         /**
75          * All mobile numbers
76          */
77         private final List<DialableMobileNumber> mobileNumbers;
78
79         /**
80          * General EJB for phone numbers
81          */
82         private PhoneSessionBeanRemote phoneBean;
83
84         /**
85          * Default constructor
86          */
87         public JobsPhoneWebApplicationBean () {
88                 // Call super constructor
89                 super();
90
91                 // Init all lists
92                 this.mobileNumbers = new LinkedList<>();
93                 this.faxNumbers = new LinkedList<>();
94                 this.landLineNumbers = new LinkedList<>();
95         }
96
97         @Override
98         public void afterAdminAddedContactEvent (@Observes final ObservableAdminAddedContactEvent event) {
99                 // The event must be valid
100                 if (null == event) {
101                         // Throw NPE
102                         throw new NullPointerException("event is null"); //NOI18N
103                 } else if (event.getAddedContact() == null) {
104                         // Throw again ...
105                         throw new NullPointerException("event.addedContact is null"); //NOI18N
106                 } else if (event.getAddedContact().getContactId() == null) {
107                         // ... and again
108                         throw new NullPointerException("event.addedContact.contactId is null"); //NOI18N
109                 } else if (event.getAddedContact().getContactId() < 1) {
110                         // Not valid
111                         throw new IllegalArgumentException(MessageFormat.format("event.addedContact.contactId={0} is not valid", event.getAddedContact().getContactId())); //NOI18N
112                 }
113
114                 // Update contact's mobile, land-line and fax number
115                 this.updateContactPhoneNumbers(event.getAddedContact());
116
117                 // Clear this bean
118                 this.clear();
119         }
120
121         @Override
122         public void afterAdminAddedUserEvent (@Observes final ObservableAdminAddedUserEvent event) {
123                 // event should not be null
124                 if (null == event) {
125                         // Throw NPE
126                         throw new NullPointerException("event is null"); //NOI18N
127                 } else if (event.getAddedUser() == null) {
128                         // Throw NPE again
129                         throw new NullPointerException("event.addedUser is null"); //NOI18N
130                 } else if (event.getAddedUser().getUserId() == null) {
131                         // userId is null
132                         throw new NullPointerException("event.addedUser.userId is null"); //NOI18N
133                 } else if (event.getAddedUser().getUserId() < 1) {
134                         // Not avalid id
135                         throw new IllegalArgumentException(MessageFormat.format("userId of user={0} is not valid: {1}", event.getAddedUser(), event.getAddedUser().getUserId())); //NOI18N
136                 }
137
138                 // Update contact's mobile, land-line and fax number
139                 this.updateContactPhoneNumbers(event.getAddedUser().getUserContact());
140
141                 // Clear all data
142                 this.clear();
143         }
144
145         @Override
146         public void afterAdminDeletedFaxNumberEvent (@Observes final AdminDeletedFaxNumberEvent event) {
147                 // event should not be null
148                 if (null == event) {
149                         // Throw NPE
150                         throw new NullPointerException("event is null"); //NOI18N
151                 } else if (event.getDeletedFaxNumber()== null) {
152                         // Throw NPE again
153                         throw new NullPointerException("event.deletedFaxNumber is null"); //NOI18N
154                 } else if (event.getDeletedFaxNumber().getPhoneId() == null) {
155                         // userId is null
156                         throw new NullPointerException("event.deletedFaxNumber.phoneId is null"); //NOI18N
157                 } else if (event.getDeletedFaxNumber().getPhoneId() < 1) {
158                         // Not avalid id
159                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getDeletedFaxNumber(), event.getDeletedFaxNumber().getPhoneId())); //NOI18N
160                 }
161
162                 // Update contact's mobile, land-line and fax number
163                 this.allFaxNumbers().remove(event.getDeletedFaxNumber());
164
165                 // Clear all data
166                 this.clear();
167         }
168
169         @Override
170         public void afterAdminDeletedLandLineNumberEvent (@Observes final AdminDeletedLandLineNumberEvent event) {
171                 // event should not be null
172                 if (null == event) {
173                         // Throw NPE
174                         throw new NullPointerException("event is null"); //NOI18N
175                 } else if (event.getDeletedLandLineNumber()== null) {
176                         // Throw NPE again
177                         throw new NullPointerException("event.deletedLandLineNumber is null"); //NOI18N
178                 } else if (event.getDeletedLandLineNumber().getPhoneId() == null) {
179                         // userId is null
180                         throw new NullPointerException("event.deletedLandLineNumber.phoneId is null"); //NOI18N
181                 } else if (event.getDeletedLandLineNumber().getPhoneId() < 1) {
182                         // Not avalid id
183                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getDeletedLandLineNumber(), event.getDeletedLandLineNumber().getPhoneId())); //NOI18N
184                 }
185
186                 // Update contact's mobile, land-line and fax number
187                 this.allLandLineNumbers().remove(event.getDeletedLandLineNumber());
188
189                 // Clear all data
190                 this.clear();
191         }
192
193         @Override
194         public void afterAdminDeletedMobileNumberEvent (@Observes final AdminDeletedMobileNumberEvent event) {
195                 // event should not be null
196                 if (null == event) {
197                         // Throw NPE
198                         throw new NullPointerException("event is null"); //NOI18N
199                 } else if (event.getDeletedMobileNumber()== null) {
200                         // Throw NPE again
201                         throw new NullPointerException("event.deletedMobileNumber is null"); //NOI18N
202                 } else if (event.getDeletedMobileNumber().getPhoneId() == null) {
203                         // userId is null
204                         throw new NullPointerException("event.deletedMobileNumber.phoneId is null"); //NOI18N
205                 } else if (event.getDeletedMobileNumber().getPhoneId() < 1) {
206                         // Not avalid id
207                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getDeletedMobileNumber(), event.getDeletedMobileNumber().getPhoneId())); //NOI18N
208                 }
209
210                 // Update contact's mobile, land-line and fax number
211                 this.allMobileNumbers().remove(event.getDeletedMobileNumber());
212
213                 // Clear all data
214                 this.clear();
215         }
216
217         @Override
218         public void afterAdminLinkedFaxNumberEvent (@Observes final ObservableAdminLinkedFaxNumberEvent event) {
219                 // Is the event fine?
220                 if (event == null) {
221                         // Throw NPE
222                         throw new NullPointerException("event is null"); //NOI18N
223                 } else if (event.getContact() == null) {
224                         // Throw again ...
225                         throw new NullPointerException("event.contact is null");
226                 } else if (event.getContact().getContactId() == null) {
227                         // Throw again ...
228                         throw new NullPointerException("event.contact.contactId is null");
229                 } else if (event.getContact().getContactId() < 1) {
230                         // Throw again ...
231                         throw new NullPointerException("event.contact.contactId="+ event.getContact().getContactId() + " is invalid");
232                 } else if (event.getContact().getContactFaxNumber() == null) {
233                         // Throw again ...
234                         throw new NullPointerException("event.contact.contactFaxNumber is null");
235                 } else if (event.getContact().getContactFaxNumber().getPhoneId() == null) {
236                         // Throw again ...
237                         throw new NullPointerException("event.contact.contactFaxNumber.phoneId is null");
238                 } else if (event.getContact().getContactFaxNumber().getPhoneId() < 1) {
239                         // Throw again ...
240                         throw new NullPointerException("event.contact.contactFaxNumber.phoneId="+event.getContact().getContactFaxNumber().getPhoneId() + " is invalid");
241                 } else if (event.getLinkedFaxNumber() == null) {
242                         // Throw again ...
243                         throw new NullPointerException("event.linkedFaxNumer is null");
244                 }
245
246                 // Is the id number in linked number not set?
247                 if (event.getLinkedFaxNumber().getPhoneId() == null) {
248                         // Then it is a new number, so add it from contact as there the id number has been set
249                         this.uniqueAddFaxNumber(event.getContact().getContactFaxNumber());
250                 }
251         }
252
253         @Override
254         public void afterAdminLinkedLandLineNumberEvent (@Observes final ObservableAdminLinkedLandLineNumberEvent event) {
255                 // Is the event fine?
256                 if (event == null) {
257                         // Throw NPE
258                         throw new NullPointerException("event is null"); //NOI18N
259                 } else if (event.getContact() == null) {
260                         // Throw again ...
261                         throw new NullPointerException("event.contact is null");
262                 } else if (event.getContact().getContactId() == null) {
263                         // Throw again ...
264                         throw new NullPointerException("event.contact.contactId is null");
265                 } else if (event.getContact().getContactId() < 1) {
266                         // Throw again ...
267                         throw new NullPointerException("event.contact.contactId="+ event.getContact().getContactId() + " is invalid");
268                 } else if (event.getContact().getContactLandLineNumber() == null) {
269                         // Throw again ...
270                         throw new NullPointerException("event.contact.contactLandLineNumber is null");
271                 } else if (event.getContact().getContactLandLineNumber().getPhoneId() == null) {
272                         // Throw again ...
273                         throw new NullPointerException("event.contact.contactLandLineNumber.phoneId is null");
274                 } else if (event.getContact().getContactLandLineNumber().getPhoneId() < 1) {
275                         // Throw again ...
276                         throw new NullPointerException("event.contact.contactLandLineNumber.phoneId="+event.getContact().getContactLandLineNumber().getPhoneId() + " is invalid");
277                 } else if (event.getLinkedLandLineNumber() == null) {
278                         // Throw again ...
279                         throw new NullPointerException("event.linkedLandLineNumer is null");
280                 }
281
282                 // Is the id number in linked number not set?
283                 if (event.getLinkedLandLineNumber().getPhoneId() == null) {
284                         // Then it is a new number, so add it from contact as there the id number has been set
285                         this.uniqueAddLandLineNumber(event.getContact().getContactLandLineNumber());
286                 }
287         }
288
289         @Override
290         public void afterAdminLinkedMobileNumberEvent (@Observes final ObservableAdminLinkedMobileNumberEvent event) {
291                 // Is the event fine?
292                 if (event == null) {
293                         // Throw NPE
294                         throw new NullPointerException("event is null"); //NOI18N
295                 } else if (event.getContact() == null) {
296                         // Throw again ...
297                         throw new NullPointerException("event.contact is null");
298                 } else if (event.getContact().getContactId() == null) {
299                         // Throw again ...
300                         throw new NullPointerException("event.contact.contactId is null");
301                 } else if (event.getContact().getContactId() < 1) {
302                         // Throw again ...
303                         throw new NullPointerException("event.contact.contactId="+ event.getContact().getContactId() + " is invalid");
304                 } else if (event.getContact().getContactMobileNumber() == null) {
305                         // Throw again ...
306                         throw new NullPointerException("event.contact.contactMobileNumber is null");
307                 } else if (event.getContact().getContactMobileNumber().getPhoneId() == null) {
308                         // Throw again ...
309                         throw new NullPointerException("event.contact.contactMobileNumber.phoneId is null");
310                 } else if (event.getContact().getContactMobileNumber().getPhoneId() < 1) {
311                         // Throw again ...
312                         throw new NullPointerException("event.contact.contactMobileNumber.phoneId="+event.getContact().getContactMobileNumber().getPhoneId() + " is invalid");
313                 } else if (event.getLinkedMobileNumber() == null) {
314                         // Throw again ...
315                         throw new NullPointerException("event.linkedMobileNumer is null");
316                 }
317
318                 // Is the id number in linked number not set?
319                 if (event.getLinkedMobileNumber().getPhoneId() == null) {
320                         // Then it is a new number, so add it from contact as there the id number has been set
321                         this.uniqueAddMobileNumber(event.getContact().getContactMobileNumber());
322                 }
323         }
324
325         @Override
326         public void afterAdminUpdatedContactDataEvent (@Observes final ObservableAdminUpdatedContactEvent event) {
327                 // event should not be null
328                 if (null == event) {
329                         // Throw NPE
330                         throw new NullPointerException("event is null"); //NOI18N
331                 } else if (event.getUpdatedContact() == null) {
332                         // Throw NPE again
333                         throw new NullPointerException("event.updatedContact is null"); //NOI18N
334                 } else if (event.getUpdatedContact().getContactId() == null) {
335                         // userId is null
336                         throw new NullPointerException("event.updatedContact.contactId is null"); //NOI18N
337                 } else if (event.getUpdatedContact().getContactId() < 1) {
338                         // Not avalid id
339                         throw new IllegalArgumentException(MessageFormat.format("contactId of contact={0} is not valid: {1}", event.getUpdatedContact(), event.getUpdatedContact().getContactId())); //NOI18N
340                 }
341
342                 // Update contact's mobile, land-line and fax number
343                 this.updateContactPhoneNumbers(event.getUpdatedContact());
344
345                 // Clear all data
346                 this.clear();
347         }
348
349         @Override
350         public void afterAdminUpdatedFaxNumberEvent (@Observes final AdminUpdatedFaxNumberEvent event) {
351                 // event should not be null
352                 if (null == event) {
353                         // Throw NPE
354                         throw new NullPointerException("event is null"); //NOI18N
355                 } else if (event.getUpdatedFaxNumber()== null) {
356                         // Throw NPE again
357                         throw new NullPointerException("event.updatedFaxNumber is null"); //NOI18N
358                 } else if (event.getUpdatedFaxNumber().getPhoneId() == null) {
359                         // userId is null
360                         throw new NullPointerException("event.updatedFaxNumber.phoneId is null"); //NOI18N
361                 } else if (event.getUpdatedFaxNumber().getPhoneId() < 1) {
362                         // Not avalid id
363                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getUpdatedFaxNumber(), event.getUpdatedFaxNumber().getPhoneId())); //NOI18N
364                 }
365
366                 // Uniquely add it
367                 this.uniqueAddFaxNumber(event.getUpdatedFaxNumber());
368
369                 // Clear it
370                 this.clear();
371         }
372
373         @Override
374         public void afterAdminUpdatedLandLineNumberEvent (@Observes final AdminUpdatedLandLineNumberEvent event) {
375                 // event should not be null
376                 if (null == event) {
377                         // Throw NPE
378                         throw new NullPointerException("event is null"); //NOI18N
379                 } else if (event.getUpdatedLandLineNumber()== null) {
380                         // Throw NPE again
381                         throw new NullPointerException("event.updatedLandLineNumber is null"); //NOI18N
382                 } else if (event.getUpdatedLandLineNumber().getPhoneId() == null) {
383                         // userId is null
384                         throw new NullPointerException("event.updatedLandLineNumber.phoneId is null"); //NOI18N
385                 } else if (event.getUpdatedLandLineNumber().getPhoneId() < 1) {
386                         // Not avalid id
387                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getUpdatedLandLineNumber(), event.getUpdatedLandLineNumber().getPhoneId())); //NOI18N
388                 }
389
390                 // Uniquely add it
391                 this.uniqueAddLandLineNumber(event.getUpdatedLandLineNumber());
392
393                 // Clear it
394                 this.clear();
395         }
396
397         @Override
398         public void afterAdminUpdatedMobileNumberEvent (@Observes final AdminUpdatedMobileNumberEvent event) {
399                 // event should not be null
400                 if (null == event) {
401                         // Throw NPE
402                         throw new NullPointerException("event is null"); //NOI18N
403                 } else if (event.getUpdatedMobileNumber()== null) {
404                         // Throw NPE again
405                         throw new NullPointerException("event.updatedMobileNumber is null"); //NOI18N
406                 } else if (event.getUpdatedMobileNumber().getPhoneId() == null) {
407                         // userId is null
408                         throw new NullPointerException("event.updatedMobileNumber.phoneId is null"); //NOI18N
409                 } else if (event.getUpdatedMobileNumber().getPhoneId() < 1) {
410                         // Not avalid id
411                         throw new IllegalArgumentException(MessageFormat.format("phoneId of contact={0} is not valid: {1}", event.getUpdatedMobileNumber(), event.getUpdatedMobileNumber().getPhoneId())); //NOI18N
412                 }
413
414                 // Uniquely add it
415                 this.uniqueAddMobileNumber(event.getUpdatedMobileNumber());
416
417                 // Clear it
418                 this.clear();
419         }
420
421         @Override
422         @SuppressWarnings ("ReturnOfCollectionOrArrayField")
423         public List<DialableFaxNumber> allFaxNumbers () {
424                 return this.faxNumbers;
425         }
426
427         @Override
428         @SuppressWarnings ("ReturnOfCollectionOrArrayField")
429         public List<DialableLandLineNumber> allLandLineNumbers () {
430                 return this.landLineNumbers;
431         }
432
433         @Override
434         @SuppressWarnings ("ReturnOfCollectionOrArrayField")
435         public List<DialableMobileNumber> allMobileNumbers () {
436                 return this.mobileNumbers;
437         }
438
439         /**
440          * Post-construction method
441          */
442         @PostConstruct
443         public void init () {
444                 // Try it
445                 try {
446                         // Get initial context
447                         Context context = new InitialContext();
448
449                         // Try to lookup the beans
450                         this.phoneBean = (PhoneSessionBeanRemote) context.lookup("java:global/jjobs-ejb/phone!org.mxchange.jphone.phonenumbers.phone.PhoneSessionBeanRemote"); //NOI18N
451                 } catch (final NamingException e) {
452                         // Throw it again
453                         throw new FaceletException(e);
454                 }
455
456                 // All phone numbers
457                 this.allMobileNumbers().addAll(this.phoneBean.allMobileNumbers());
458                 this.allFaxNumbers().addAll(this.phoneBean.allFaxNumbers());
459                 this.allLandLineNumbers().addAll(this.phoneBean.allLandLineNumbers());
460         }
461
462         /**
463          * Clears this bean
464          */
465         private void clear () {
466                 // Clear all data
467         }
468
469         /**
470          * Uniquely add given fax number to this bean's list. First remove the old
471          * instance (by id number), then re-add it again.
472          * <p>
473          * @param faxNumber number to add
474          */
475         private void uniqueAddFaxNumber (final DialableFaxNumber faxNumber) {
476                 // Make sure the parameter is valid
477                 if (null == faxNumber) {
478                         // Throw NPE
479                         throw new NullPointerException("faxNumber is null");
480                 } else if (faxNumber.getPhoneId() == null) {
481                         // Throw again ...
482                         throw new NullPointerException("faxNumber.phoneId is null");
483                 } else if (faxNumber.getPhoneId() < 1) {
484                         // Not valid
485                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneId={0} is not valid.", faxNumber.getPhoneId()));
486                 }
487
488                 // First remove it
489                 if (!this.allFaxNumbers().remove(faxNumber)) {
490                         // Did not work, try by id number
491                         for (final DialableFaxNumber fax : this.allFaxNumbers()) {
492                                 // Is id number the same?
493                                 if (Objects.equals(fax.getPhoneId(), faxNumber.getPhoneId())) {
494                                         // Found it
495                                         this.allFaxNumbers().remove(fax);
496                                         break;
497                                 }
498                         }
499                 }
500
501                 // ... then add it
502                 this.allFaxNumbers().add(faxNumber);
503         }
504
505         /**
506          * Uniquely add given land-line number to this bean's list. First remove the
507          * old instance (by id number), then re-add it again.
508          * <p>
509          * @param landLineNumber Land-line number to add
510          */
511         private void uniqueAddLandLineNumber (final DialableLandLineNumber landLineNumber) {
512                 // Make sure the parameter is valid
513                 if (null == landLineNumber) {
514                         // Throw NPE
515                         throw new NullPointerException("landLineNumber is null");
516                 } else if (landLineNumber.getPhoneId() == null) {
517                         // Throw again ...
518                         throw new NullPointerException("landLineNumber.phoneId is null");
519                 } else if (landLineNumber.getPhoneId() < 1) {
520                         // Not valid
521                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneId={0} is not valid.", landLineNumber.getPhoneId()));
522                 }
523
524                 // First remove it
525                 if (!this.allLandLineNumbers().remove(landLineNumber)) {
526                         // Did not work, try by id number
527                         for (final DialableLandLineNumber landLine : this.allLandLineNumbers()) {
528                                 // Is id number the same?
529                                 if (Objects.equals(landLine.getPhoneId(), landLineNumber.getPhoneId())) {
530                                         // Found it
531                                         this.allLandLineNumbers().remove(landLine);
532                                         break;
533                                 }
534                         }
535                 }
536
537                 // ... then add it
538                 this.allLandLineNumbers().add(landLineNumber);
539         }
540
541         /**
542          * Uniquely add given mobile number to this bean's list. First remove the
543          * old instance (by id number), then re-add it again.
544          * <p>
545          * @param mobileNumber Mobile number to add
546          */
547         private void uniqueAddMobileNumber (final DialableMobileNumber mobileNumber) {
548                 // Make sure the parameter is valid
549                 if (null == mobileNumber) {
550                         // Throw NPE
551                         throw new NullPointerException("mobileNumber is null");
552                 } else if (mobileNumber.getPhoneId() == null) {
553                         // Throw again ...
554                         throw new NullPointerException("mobileNumber.phoneId is null");
555                 } else if (mobileNumber.getPhoneId() < 1) {
556                         // Not valid
557                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid.", mobileNumber.getPhoneId()));
558                 }
559
560                 // First remove it by object
561                 if (!this.allMobileNumbers().remove(mobileNumber)) {
562                         // Did not work, try by id number
563                         for (final DialableMobileNumber cell : this.allMobileNumbers()) {
564                                 // Is id number the same?
565                                 if (Objects.equals(cell.getPhoneId(), mobileNumber.getPhoneId())) {
566                                         // Found it
567                                         this.allMobileNumbers().remove(cell);
568                                         break;
569                                 }
570                         }
571                 }
572
573                 // ... then add it
574                 this.allMobileNumbers().add(mobileNumber);
575         }
576
577         /**
578          * Updates given contact's mobile, land-line and fax number
579          * <p>
580          * @param contact Contact instance
581          */
582         private void updateContactPhoneNumbers (final Contact contact) {
583                 // Parameter must be valid
584                 if (null == contact) {
585                         // Throw NPE
586                         throw new NullPointerException("contact is null");
587                 } else if (contact.getContactId() == null) {
588                         // Throw again
589                         throw new NullPointerException("contact.contactId is null");
590                 } else if (contact.getContactId() < 1) {
591                         // Id number is not valid
592                 }
593
594                 // Is mobile set?
595                 if (contact.getContactMobileNumber() instanceof DialableMobileNumber) {
596                         // Unique-add it
597                         this.uniqueAddMobileNumber(contact.getContactMobileNumber());
598                 }
599
600                 // Is land-line set?
601                 if (contact.getContactLandLineNumber() instanceof DialableLandLineNumber) {
602                         // Unique-add it
603                         this.uniqueAddLandLineNumber(contact.getContactLandLineNumber());
604                 }
605
606                 // Is fax set?
607                 if (contact.getContactFaxNumber() instanceof DialableFaxNumber) {
608                         // Unique-add it
609                         this.uniqueAddFaxNumber(contact.getContactFaxNumber());
610                 }
611         }
612
613 }