]> git.mxchange.org Git - jjobs-war.git/blob - src/java/org/mxchange/jjobs/beans/phone/JobsAdminPhoneWebRequestBean.java
Rewrite continued:
[jjobs-war.git] / src / java / org / mxchange / jjobs / beans / phone / JobsAdminPhoneWebRequestBean.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.List;
21 import java.util.Locale;
22 import java.util.MissingResourceException;
23 import java.util.Objects;
24 import java.util.ResourceBundle;
25 import javax.annotation.PostConstruct;
26 import javax.enterprise.context.RequestScoped;
27 import javax.enterprise.event.Event;
28 import javax.enterprise.inject.Any;
29 import javax.faces.application.FacesMessage;
30 import javax.faces.context.FacesContext;
31 import javax.faces.view.facelets.FaceletException;
32 import javax.inject.Inject;
33 import javax.inject.Named;
34 import javax.naming.Context;
35 import javax.naming.InitialContext;
36 import javax.naming.NamingException;
37 import org.mxchange.jcountry.data.Country;
38 import org.mxchange.jjobs.beans.BaseJobsController;
39 import org.mxchange.jjobs.beans.helper.JobsWebRequestHelperController;
40 import org.mxchange.jphone.events.fax.deleted.AdminDeletedFaxNumberEvent;
41 import org.mxchange.jphone.events.fax.deleted.AdminFaxNumberDeletedEvent;
42 import org.mxchange.jphone.events.fax.removed.AdminFaxNumberRemovedFromListEvent;
43 import org.mxchange.jphone.events.fax.removed.AdminRemoveFaxNumberFromListEvent;
44 import org.mxchange.jphone.events.fax.updated.AdminFaxNumberUpdatedEvent;
45 import org.mxchange.jphone.events.fax.updated.AdminUpdatedFaxNumberEvent;
46 import org.mxchange.jphone.events.landline.deleted.AdminDeletedLandLineNumberEvent;
47 import org.mxchange.jphone.events.landline.deleted.AdminLandLineNumberDeletedEvent;
48 import org.mxchange.jphone.events.landline.removed.AdminLandLineNumberRemovedFromListEvent;
49 import org.mxchange.jphone.events.landline.removed.AdminRemoveLandLineNumberFromListEvent;
50 import org.mxchange.jphone.events.landline.updated.AdminLandLineNumberUpdatedEvent;
51 import org.mxchange.jphone.events.landline.updated.AdminUpdatedLandLineNumberEvent;
52 import org.mxchange.jphone.events.mobile.deleted.AdminDeletedMobileNumberEvent;
53 import org.mxchange.jphone.events.mobile.deleted.AdminMobileNumberDeletedEvent;
54 import org.mxchange.jphone.events.mobile.remove.AdminMobileNumberRemovedFromListEvent;
55 import org.mxchange.jphone.events.mobile.remove.AdminRemoveMobileNumberFromListEvent;
56 import org.mxchange.jphone.events.mobile.updated.AdminMobileNumberUpdatedEvent;
57 import org.mxchange.jphone.events.mobile.updated.AdminUpdatedMobileNumberEvent;
58 import org.mxchange.jphone.phonenumbers.fax.DialableFaxNumber;
59 import org.mxchange.jphone.phonenumbers.landline.DialableLandLineNumber;
60 import org.mxchange.jphone.phonenumbers.mobile.DialableMobileNumber;
61 import org.mxchange.jphone.phonenumbers.mobileprovider.MobileProvider;
62 import org.mxchange.jphone.phonenumbers.phone.AdminPhoneSessionBeanRemote;
63
64 /**
65  * Administrative controller (bean) for phone numbers
66  * <p>
67  * @author Roland Häder<roland@mxchange.org>
68  */
69 @Named ("adminPhoneController")
70 @RequestScoped
71 public abstract class JobsAdminPhoneWebRequestBean extends BaseJobsController implements JobsAdminPhoneWebRequestController {
72
73         /**
74          * Call-stack position
75          */
76         private static final short THREAD_STACK = 5;
77
78         /**
79          * Serial number
80          */
81         private static final long serialVersionUID = 184_598_175_371_269_016L;
82
83         /**
84          * Remote EJB for phone number (administrative)
85          */
86         private AdminPhoneSessionBeanRemote adminPhoneBean;
87
88         /**
89          * Bean helper
90          */
91         @Inject
92         private JobsWebRequestHelperController beanHelper;
93
94         /**
95          * fax number
96          */
97         private DialableFaxNumber faxNumber;
98
99         /**
100          * land-line number
101          */
102         private DialableLandLineNumber landLineNumber;
103
104         /**
105          * mobile number
106          */
107         private DialableMobileNumber mobileNumber;
108
109         /**
110          * Event being fired when an administrator has deleted fax number
111          */
112         @Inject
113         @Any
114         private Event<AdminDeletedFaxNumberEvent> faxNumberDeletedEvent;
115
116         /**
117          * Event being fired when an administrator has updated fax number
118          */
119         @Inject
120         @Any
121         private Event<AdminUpdatedFaxNumberEvent> faxNumberUpdatedEvent;
122
123         /**
124          * Event being fired when an administrator has deleted land-line number
125          */
126         @Inject
127         @Any
128         private Event<AdminDeletedLandLineNumberEvent> landLineNumberDeletedEvent;
129
130         /**
131          * Event being fired when an administrator has updated fax number
132          */
133         @Inject
134         @Any
135         private Event<AdminUpdatedLandLineNumberEvent> landLineNumberUpdatedEvent;
136
137         /**
138          * Event being fired when an administrator has deleted mobile number
139          */
140         @Inject
141         @Any
142         private Event<AdminDeletedMobileNumberEvent> mobileNumberDeletedEvent;
143
144         /**
145          * Event being fired when an administrator has updated land-line number
146          */
147         @Inject
148         @Any
149         private Event<AdminUpdatedMobileNumberEvent> mobileNumberUpdatedEvent;
150
151         /**
152          * Mobile provider
153          */
154         private MobileProvider mobileProvider;
155
156         /**
157          * Area code (city dial prefix)
158          */
159         private Integer phoneAreaCode;
160
161         /**
162          * Generic hone controller
163          */
164         @Inject
165         private JobsPhoneWebApplicationController phoneController;
166
167         /**
168          * Country (for dial prefix)
169          */
170         private Country phoneCountry;
171
172         /**
173          * Phone number
174          */
175         private Long phoneNumber;
176
177         /**
178          * Event being fired when a list of all unsed fax numbers is being created.
179          */
180         @Inject
181         @Any
182         private Event<AdminRemoveFaxNumberFromListEvent> removeLinkedFaxNumbersEvent;
183
184         /**
185          * Event being fired when a list of all unsed land-line numbers is being
186          * created.
187          */
188         @Inject
189         @Any
190         private Event<AdminRemoveLandLineNumberFromListEvent> removeLinkedLandLineNumbersEvent;
191
192         /**
193          * Event being fired when a list of all unsed mobile numbers is being
194          * created.
195          */
196         @Inject
197         @Any
198         private Event<AdminRemoveMobileNumberFromListEvent> removeLinkedMobileNumbersEvent;
199
200         /**
201          * Default constructor
202          */
203         public JobsAdminPhoneWebRequestBean () {
204                 // Call super constructor
205                 super();
206
207                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[3].getClassName(), Thread.currentThread().getStackTrace()[3].getMethodName());
208                 // System.out.println(MessageFormat.format("{0}: Constructed, caller: {1}", this.getClass().getSimpleName(), caller));
209         }
210
211         @Override
212         public List<DialableFaxNumber> allNonLinkedFaxNumbers () {
213                 // Get list of all mobile numbers
214                 List<DialableFaxNumber> list = this.phoneController.allFaxNumbers();
215
216                 // Visit all controllers to reduce the list
217                 this.removeLinkedFaxNumbersEvent.fire(new AdminFaxNumberRemovedFromListEvent(list));
218
219                 // Return it
220                 return list;
221         }
222
223         @Override
224         public List<DialableLandLineNumber> allNonLinkedLandLineNumbers () {
225                 // Get list of all mobile numbers
226                 List<DialableLandLineNumber> list = this.phoneController.allLandLineNumbers();
227
228                 // Visit all controllers to reduce the list
229                 this.removeLinkedLandLineNumbersEvent.fire(new AdminLandLineNumberRemovedFromListEvent(list));
230
231                 // Return it
232                 return list;
233         }
234
235         @Override
236         public List<DialableMobileNumber> allNonLinkedMobileNumbers () {
237                 // Get list of all mobile numbers
238                 List<DialableMobileNumber> list = this.phoneController.allMobileNumbers();
239
240                 // Visit all controllers to reduce the list
241                 this.removeLinkedMobileNumbersEvent.fire(new AdminMobileNumberRemovedFromListEvent(list));
242
243                 // Return it
244                 return list;
245         }
246
247         @Override
248         public String deleteFaxData (final DialableFaxNumber faxNumber) {
249                 // Is all data set
250                 if (faxNumber == null) {
251                         // Not set, throw NPE
252                         throw new NullPointerException("faxNumber is null"); //NOI18N
253                 } else if (faxNumber.getPhoneId() == null) {
254                         // Throw NPE again
255                         throw new NullPointerException("faxNumber.phoneId is null"); //NOI18N
256                 } else if (faxNumber.getPhoneId() < 1) {
257                         // Invalid number
258                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneId={0} is not valid", faxNumber.getPhoneId())); //NOI18N
259                 } else if (faxNumber.getPhoneCountry() == null) {
260                         // Throw NPE
261                         throw new NullPointerException("faxNumber.phoneCountry is null"); //NOI18N
262                 } else if (faxNumber.getPhoneCountry().getCountryId() == null) {
263                         // Throw NPE
264                         throw new NullPointerException("faxNumber.phoneCountry.countryId is null"); //NOI18N
265                 } else if (faxNumber.getPhoneCountry().getCountryId() < 1) {
266                         // Throw NPE
267                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneCountry.countryId={0} is not valid", faxNumber.getPhoneCountry().getCountryId())); //NOI18N
268                 } else if (faxNumber.getPhoneAreaCode() == null) {
269                         // ... throw again
270                         throw new NullPointerException("faxNumber.phoneAreaCode is null"); //NOI18N
271                 } else if (faxNumber.getPhoneAreaCode() < 1) {
272                         // Id not valid
273                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneAreaCode={0} is not valid.", faxNumber.getPhoneAreaCode())); //NOI18N
274                 } else if (faxNumber.getPhoneNumber() == null) {
275                         // Throw NPE again
276                         throw new NullPointerException("faxNumber.phoneNumber is null"); //NOI18N
277                 } else if (faxNumber.getPhoneNumber() < 1) {
278                         // Throw NPE again
279                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneNumber={0} is not valid.", faxNumber.getPhoneNumber())); //NOI18N
280                 }
281
282                 // Call EJB
283                 this.adminPhoneBean.deleteFaxData(faxNumber);
284
285                 // Fire event
286                 this.faxNumberDeletedEvent.fire(new AdminFaxNumberDeletedEvent(faxNumber));
287
288                 // All fine, redirect
289                 return "admin_list_fax"; //NOI18N
290         }
291
292         @Override
293         public String deleteLandLineData (final DialableLandLineNumber landLineNumber) {
294                 // Is all data set
295                 if (landLineNumber == null) {
296                         // Not set, throw NPE
297                         throw new NullPointerException("landLineNumber is null"); //NOI18N
298                 } else if (landLineNumber.getPhoneId() == null) {
299                         // Throw NPE again
300                         throw new NullPointerException("landLineNumber.phoneId is null"); //NOI18N
301                 } else if (landLineNumber.getPhoneId() < 1) {
302                         // Invalid number
303                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneId={0} is not valid", landLineNumber.getPhoneId())); //NOI18N
304                 } else if (landLineNumber.getPhoneCountry() == null) {
305                         // Throw NPE
306                         throw new NullPointerException("landLineNumber.phoneCountry is null"); //NOI18N
307                 } else if (landLineNumber.getPhoneCountry().getCountryId() == null) {
308                         // Throw NPE
309                         throw new NullPointerException("landLineNumber.phoneCountry.countryId is null"); //NOI18N
310                 } else if (landLineNumber.getPhoneCountry().getCountryId() < 1) {
311                         // Throw NPE
312                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneCountry.countryId={0} is not valid", landLineNumber.getPhoneCountry().getCountryId())); //NOI18N
313                 } else if (landLineNumber.getPhoneAreaCode() == null) {
314                         // ... throw again
315                         throw new NullPointerException("landLineNumber.phoneAreaCode is null"); //NOI18N
316                 } else if (landLineNumber.getPhoneAreaCode() < 1) {
317                         // Id not valid
318                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneAreaCode={0} is not valid.", landLineNumber.getPhoneAreaCode())); //NOI18N
319                 } else if (landLineNumber.getPhoneNumber() == null) {
320                         // Throw NPE again
321                         throw new NullPointerException("landLineNumber.phoneNumber is null"); //NOI18N
322                 } else if (landLineNumber.getPhoneNumber() < 1) {
323                         // Throw NPE again
324                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneNumber={0} is not valid.", landLineNumber.getPhoneNumber())); //NOI18N
325                 }
326
327                 // Call EJB
328                 this.adminPhoneBean.deleteLandLineData(landLineNumber);
329
330                 // Fire event
331                 this.landLineNumberDeletedEvent.fire(new AdminLandLineNumberDeletedEvent(landLineNumber));
332
333                 // All fine, redirect
334                 return "admin_list_landline"; //NOI18N
335         }
336
337         @Override
338         public String deleteMobileData (final DialableMobileNumber mobileNumber) {
339                 // Is all data set
340                 if (mobileNumber == null) {
341                         // Not set, throw NPE
342                         throw new NullPointerException("mobileNumber is null"); //NOI18N
343                 } else if (mobileNumber.getPhoneId() == null) {
344                         // Throw NPE again
345                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
346                 } else if (mobileNumber.getPhoneId() < 1) {
347                         // Invalid number
348                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getPhoneId())); //NOI18N
349                 } else if (mobileNumber.getMobileProvider() == null) {
350                         // Throw NPE
351                         throw new NullPointerException("mobileNumber.mobileProvider is null"); //NOI18N
352                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
353                         // ... throw again
354                         throw new NullPointerException("mobileNumber.mobileProvider.providerId is null"); //NOI18N
355                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
356                         // Id not valid
357                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
358                 } else if (mobileNumber.getPhoneNumber() == null) {
359                         // Throw NPE again
360                         throw new NullPointerException("mobileNumber.phoneNumber is null"); //NOI18N
361                 } else if (mobileNumber.getPhoneNumber() < 1) {
362                         // Throw NPE again
363                         throw new NullPointerException(MessageFormat.format("mobileNumber.phoneNumber={0} is not valid.", mobileNumber.getPhoneNumber())); //NOI18N
364                 }
365
366                 // Call EJB
367                 this.adminPhoneBean.deleteMobileData(mobileNumber);
368
369                 // Fire event
370                 this.mobileNumberDeletedEvent.fire(new AdminMobileNumberDeletedEvent(mobileNumber));
371
372                 // All fine, redirect
373                 return "admin_list_mobile"; //NOI18N
374         }
375
376         @Override
377         public String editFaxData (final DialableFaxNumber faxNumber) {
378                 // Is all data set
379                 if (faxNumber == null) {
380                         // Not set, throw NPE
381                         throw new NullPointerException("faxNumber is null"); //NOI18N
382                 } else if (faxNumber.getPhoneId() == null) {
383                         // Throw NPE again
384                         throw new NullPointerException("faxNumber.phoneId is null"); //NOI18N
385                 } else if (faxNumber.getPhoneId() < 1) {
386                         // Invalid number
387                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneId={0} is not valid", faxNumber.getPhoneId())); //NOI18N
388                 } else if (faxNumber.getPhoneCountry() == null) {
389                         // Throw NPE
390                         throw new NullPointerException("faxNumber.phoneCountry is null"); //NOI18N
391                 } else if (faxNumber.getPhoneCountry().getCountryId() == null) {
392                         // Throw NPE
393                         throw new NullPointerException("faxNumber.phoneCountry.countryId is null"); //NOI18N
394                 } else if (faxNumber.getPhoneCountry().getCountryId() < 1) {
395                         // Throw NPE
396                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneCountry.countryId={0} is not valid", faxNumber.getPhoneCountry().getCountryId())); //NOI18N
397                 } else if (faxNumber.getPhoneAreaCode() == null) {
398                         // ... throw again
399                         throw new NullPointerException("faxNumber.phoneAreaCode is null"); //NOI18N
400                 } else if (faxNumber.getPhoneAreaCode() < 1) {
401                         // Id not valid
402                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneAreaCode={0} is not valid.", faxNumber.getPhoneAreaCode())); //NOI18N
403                 } else if (faxNumber.getPhoneNumber() == null) {
404                         // Throw NPE again
405                         throw new NullPointerException("faxNumber.phoneNumber is null"); //NOI18N
406                 } else if (faxNumber.getPhoneNumber() < 1) {
407                         // Throw NPE again
408                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneNumber={0} is not valid.", faxNumber.getPhoneNumber())); //NOI18N
409                 }
410
411                 // Is the mobile provider and number the same?
412                 if ((Objects.equals(this.getPhoneCountry(), faxNumber.getPhoneCountry())) && (Objects.equals(this.getPhoneAreaCode(), faxNumber.getPhoneAreaCode())) && (Objects.equals(this.getPhoneNumber(), faxNumber.getPhoneNumber()))) {
413                         // Show message
414                         this.showFacesMessage("form_edit_fax:faxNumber", "ERROR_ADMIN_NO_CHANGE_ENTERED"); //NOI18N
415
416                         // No difference in both together, no need to edit
417                         return ""; //NOI18N
418                 }
419
420                 // Set all data
421                 faxNumber.setPhoneCountry(this.getPhoneCountry());
422                 faxNumber.setPhoneAreaCode(this.getPhoneAreaCode());
423                 faxNumber.setPhoneNumber(this.getPhoneNumber());
424
425                 // Send to bean
426                 DialableFaxNumber updatedNumber = this.adminPhoneBean.updateFaxData(faxNumber);
427
428                 // Fire event
429                 this.faxNumberUpdatedEvent.fire(new AdminFaxNumberUpdatedEvent(updatedNumber));
430
431                 // All fine, redirect
432                 return "admin_show_fax"; //NOI18N
433         }
434
435         @Override
436         public String editLandLineData (final DialableLandLineNumber landLineNumber) {
437                 // Is all data set
438                 if (landLineNumber == null) {
439                         // Not set, throw NPE
440                         throw new NullPointerException("landLineNumber is null"); //NOI18N
441                 } else if (landLineNumber.getPhoneId() == null) {
442                         // Throw NPE again
443                         throw new NullPointerException("landLineNumber.phoneId is null"); //NOI18N
444                 } else if (landLineNumber.getPhoneId() < 1) {
445                         // Invalid number
446                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneId={0} is not valid", landLineNumber.getPhoneId())); //NOI18N
447                 } else if (landLineNumber.getPhoneCountry() == null) {
448                         // Throw NPE
449                         throw new NullPointerException("landLineNumber.phoneCountry is null"); //NOI18N
450                 } else if (landLineNumber.getPhoneCountry().getCountryId() == null) {
451                         // Throw NPE
452                         throw new NullPointerException("landLineNumber.phoneCountry.countryId is null"); //NOI18N
453                 } else if (landLineNumber.getPhoneCountry().getCountryId() < 1) {
454                         // Throw NPE
455                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneCountry.countryId={0} is not valid", landLineNumber.getPhoneCountry().getCountryId())); //NOI18N
456                 } else if (landLineNumber.getPhoneAreaCode() == null) {
457                         // ... throw again
458                         throw new NullPointerException("landLineNumber.phoneAreaCode is null"); //NOI18N
459                 } else if (landLineNumber.getPhoneAreaCode() < 1) {
460                         // Id not valid
461                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneAreaCode={0} is not valid.", landLineNumber.getPhoneAreaCode())); //NOI18N
462                 } else if (landLineNumber.getPhoneNumber() == null) {
463                         // Throw NPE again
464                         throw new NullPointerException("landLineNumber.phoneNumber is null"); //NOI18N
465                 } else if (landLineNumber.getPhoneNumber() < 1) {
466                         // Throw NPE again
467                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneNumber={0} is not valid.", landLineNumber.getPhoneNumber())); //NOI18N
468                 }
469
470                 // Is the mobile provider and number the same?
471                 if ((Objects.equals(this.getPhoneCountry(), landLineNumber.getPhoneCountry())) && (Objects.equals(this.getPhoneAreaCode(), landLineNumber.getPhoneAreaCode())) && (Objects.equals(this.getPhoneNumber(), landLineNumber.getPhoneNumber()))) {
472                         // Show message
473                         this.showFacesMessage("form_edit_landline:landLineNumber", "ERROR_ADMIN_NO_CHANGE_ENTERED"); //NOI18N
474
475                         // No difference in both together, no need to edit
476                         return ""; //NOI18N
477                 }
478
479                 // Set all data
480                 landLineNumber.setPhoneCountry(this.getPhoneCountry());
481                 landLineNumber.setPhoneAreaCode(this.getPhoneAreaCode());
482                 landLineNumber.setPhoneNumber(this.getPhoneNumber());
483
484                 // Send to bean
485                 DialableLandLineNumber updatedNumber = this.adminPhoneBean.updateLandLineData(landLineNumber);
486
487                 // Fire event
488                 this.landLineNumberUpdatedEvent.fire(new AdminLandLineNumberUpdatedEvent(updatedNumber));
489
490                 // All fine, redirect
491                 return "admin_show_landline"; //NOI18N
492         }
493
494         @Override
495         public String editMobileData (final DialableMobileNumber mobileNumber) {
496                 // Is all data set
497                 if (mobileNumber == null) {
498                         // Not set, throw NPE
499                         throw new NullPointerException("mobileNumber is null"); //NOI18N
500                 } else if (mobileNumber.getPhoneId() == null) {
501                         // Throw NPE again
502                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
503                 } else if (mobileNumber.getPhoneId() < 1) {
504                         // Invalid number
505                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getPhoneId())); //NOI18N
506                 } else if (mobileNumber.getMobileProvider() == null) {
507                         // Throw NPE
508                         throw new NullPointerException("mobileNumber.mobileProvider is null"); //NOI18N
509                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
510                         // ... throw again
511                         throw new NullPointerException("mobileNumber.mobileProvider.providerId is null"); //NOI18N
512                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
513                         // Id not valid
514                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
515                 } else if (mobileNumber.getPhoneNumber() == null) {
516                         // Throw NPE again
517                         throw new NullPointerException("mobileNumber.phoneNumber is null"); //NOI18N
518                 } else if (mobileNumber.getPhoneNumber() < 1) {
519                         // Throw NPE again
520                         throw new NullPointerException(MessageFormat.format("mobileNumber.phoneNumber={0} is not valid.", mobileNumber.getPhoneNumber())); //NOI18N
521                 } else if (this.getMobileProvider() == null) {
522                         // Not provided
523                         this.showFacesMessage("form_edit_mobile:mobileProvider", "ERROR_ADMIN_NO_MOBILE_PROVIDER_SELECTED"); //NOI18N
524                         return ""; //NOI18N
525                 } else if (this.getMobileProvider().getProviderId() == null) {
526                         // Throw NPE again ...
527                         throw new NullPointerException("this.mobileProvider.providerId is null"); //NOI18N
528                 } else if (this.getMobileProvider().getProviderId() < 0) {
529                         // Invalid id number
530                         throw new IllegalArgumentException(MessageFormat.format("this.mobileProvider.providerId={0} is not valid.", this.getMobileProvider().getProviderId())); //NOI18N
531                 } else if (this.getPhoneNumber() == null) {
532                         // Not provided
533                         this.showFacesMessage("form_edit_mobile:mobileNumber", "ERROR_ADMIN_EMPTY_MOBILE_NUMBER"); //NOI18N
534                         return ""; //NOI18N
535                 }
536
537                 // Is the mobile provider and number the same?
538                 if ((Objects.equals(this.getMobileProvider(), mobileNumber.getMobileProvider())) && (Objects.equals(this.getPhoneNumber(), mobileNumber.getPhoneNumber()))) {
539                         // Show message
540                         this.showFacesMessage("form_edit_mobile:mobileNumber", "ERROR_ADMIN_NO_CHANGE_ENTERED"); //NOI18N
541
542                         // No difference in both together, no need to edit
543                         return ""; //NOI18N
544                 }
545
546                 // Set all data
547                 mobileNumber.setMobileProvider(this.getMobileProvider());
548                 mobileNumber.setPhoneNumber(this.getPhoneNumber());
549
550                 // Send to bean
551                 DialableMobileNumber updatedNumber = this.adminPhoneBean.updateMobileData(mobileNumber);
552
553                 // Fire event
554                 this.mobileNumberUpdatedEvent.fire(new AdminMobileNumberUpdatedEvent(updatedNumber));
555
556                 // All fine, redirect
557                 return "admin_show_mobile"; //NOI18N
558         }
559
560         @Override
561         public DialableFaxNumber getFaxNumber () {
562                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[THREAD_STACK].getClassName(), Thread.currentThread().getStackTrace()[THREAD_STACK].getMethodName());
563                 // System.out.println(MessageFormat.format("{0}: Returning this.faxNumber={1}, caller: {2}", this.getClass().getSimpleName(), this.faxNumber, caller));
564                 return this.faxNumber;
565         }
566
567         @Override
568         public void setFaxNumber (final DialableFaxNumber faxNumber) {
569                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[THREAD_STACK].getClassName(), Thread.currentThread().getStackTrace()[THREAD_STACK].getMethodName());
570                 // System.out.println(MessageFormat.format("{0}: Settin faxNumber={1}, previous: this.faxNumber={2}, caller: {3}", this.getClass().getSimpleName(), faxNumber, this.faxNumber, caller));
571                 this.faxNumber = faxNumber;
572         }
573
574         @Override
575         public DialableLandLineNumber getLandLineNumber () {
576                 return this.landLineNumber;
577         }
578
579         @Override
580         public void setLandLineNumber (final DialableLandLineNumber landLineNumber) {
581                 this.landLineNumber = landLineNumber;
582         }
583
584         @Override
585         public DialableMobileNumber getMobileNumber () {
586                 return this.mobileNumber;
587         }
588
589         @Override
590         public void setMobileNumber (final DialableMobileNumber mobileNumber) {
591                 this.mobileNumber = mobileNumber;
592         }
593
594         @Override
595         public MobileProvider getMobileProvider () {
596                 return this.mobileProvider;
597         }
598
599         @Override
600         public void setMobileProvider (final MobileProvider mobileProvider) {
601                 this.mobileProvider = mobileProvider;
602         }
603
604         @Override
605         public Integer getPhoneAreaCode () {
606                 return this.phoneAreaCode;
607         }
608
609         @Override
610         public void setPhoneAreaCode (final Integer phoneAreaCode) {
611                 this.phoneAreaCode = phoneAreaCode;
612         }
613
614         @Override
615         public Country getPhoneCountry () {
616                 return this.phoneCountry;
617         }
618
619         @Override
620         public void setPhoneCountry (final Country phoneCountry) {
621                 this.phoneCountry = phoneCountry;
622         }
623
624         @Override
625         public Long getPhoneNumber () {
626                 return this.phoneNumber;
627         }
628
629         @Override
630         public void setPhoneNumber (final Long phoneNumber) {
631                 this.phoneNumber = phoneNumber;
632         }
633
634         /**
635          * Post-construction method
636          */
637         @PostConstruct
638         public void init () {
639                 // Try it
640                 try {
641                         // Get initial context
642                         Context context = new InitialContext();
643
644                         // Try to lookup the beans
645                         this.adminPhoneBean = (AdminPhoneSessionBeanRemote) context.lookup("java:global/jjobs-ejb/adminPhone!org.mxchange.jphone.phonenumbers.phone.AdminPhoneSessionBeanRemote"); //NOI18N
646                 } catch (final NamingException e) {
647                         // Throw it again
648                         throw new FaceletException(e);
649                 }
650         }
651
652         /**
653          * Returns given property key or throws an exception if not found.
654          * <p>
655          * @param parameterKey Property key
656          * <p>
657          * @return Property value
658          * <p>
659          * @throws NullPointerException If given key is not found
660          * @throws NumberFormatException If no number is given in context parameter
661          */
662         protected int getIntegerContextParameter (final String parameterKey) throws NullPointerException, NumberFormatException {
663                 // Get context parameter
664                 Integer contextValue = Integer.parseInt(this.getStringContextParameter(parameterKey));
665                 // Return it
666                 return contextValue;
667         }
668
669         /**
670          * Returns given property key or throws an exception if not found.
671          * <p>
672          * @param parameterKey Property key
673          * <p>
674          * @return Property value
675          * <p>
676          * @throws NullPointerException If given key is not found
677          */
678         protected String getStringContextParameter (final String parameterKey) throws NullPointerException {
679                 // Get context parameter
680                 String contextValue = FacesContext.getCurrentInstance().getExternalContext().getInitParameter(parameterKey);
681                 // Is it null?
682                 if (null == contextValue) {
683                         // Throw NPE
684                         throw new NullPointerException(MessageFormat.format("parameterKey={0} is not set.", parameterKey)); //NOI18N
685                 }
686                 // Return it
687                 return contextValue;
688         }
689
690         /**
691          * Checks whether debug mode is enabled for given controller
692          * <p>
693          * @param controllerName Name of controller
694          * <p>
695          * @return Whether debug mode is enabled
696          */
697         protected boolean isDebugModeEnabled (final String controllerName) {
698                 // Parameters should be valid
699                 if (null == controllerName) {
700                         // Throw NPE
701                         throw new NullPointerException("controllerName is null"); //NOI18N
702                 } else if (controllerName.isEmpty()) {
703                         // Is empty
704                         throw new IllegalArgumentException("controllerName is empty"); //NOI18N
705                 }
706                 // Try to get context parameter
707                 String contextParameter = this.getStringContextParameter(String.format("is_debug_%s_enabled", controllerName)); //NOI18N
708                 // Is it set and true?
709                 boolean isEnabled = Boolean.parseBoolean(contextParameter) == Boolean.TRUE;
710                 // Return it
711                 return isEnabled;
712         }
713
714         /**
715          * Loads resource bundle for given locale. This must be implemented per
716          * project so all projects can still customize their methods. Calling
717          * ResourceBundleloadBundle() in this class means that also the bundle files
718          * must be present here.
719          * <p>
720          * @param locale Locale from e.g. FacesContext
721          * <p>
722          * @return Initialized and loaded resource bundle
723          */
724         protected abstract ResourceBundle loadResourceBundle (final Locale locale);
725
726         /**
727          * Shows a faces message for given causing exception. The message from the
728          * exception is being inserted into the message.
729          * <p>
730          * @param clientId Client id to send message to
731          * @param cause    Causing exception
732          */
733         protected void showFacesMessage (final String clientId, final Throwable cause) {
734                 // Get context and add message
735                 this.showFacesMessage(clientId, cause.getMessage());
736         }
737
738         /**
739          * Shows a faces message with given message (i18n) key.
740          * <p>
741          * @param clientId Client id to send message to
742          * @param i18nKey  Message key
743          * <p>
744          * @throws NullPointerException If clientId or i18nKey is null
745          * @throws IllegalArgumentException If clientId or i18nKey is empty
746          */
747         protected void showFacesMessage (final String clientId, final String i18nKey) throws NullPointerException, IllegalArgumentException {
748                 // Both parameter must be valid
749                 if (null == clientId) {
750                         // Throw NPE
751                         throw new NullPointerException("clientId is null"); //NOI18N
752                 } else if (clientId.isEmpty()) {
753                         // Is empty
754                         throw new IllegalArgumentException("clientId is null"); //NOI18N
755                 } else if (null == i18nKey) {
756                         // Throw NPE
757                         throw new NullPointerException("i18nKey is null"); //NOI18N
758                 } else if (i18nKey.isEmpty()) {
759                         // Is empty
760                         throw new IllegalArgumentException("i18nKey is null"); //NOI18N
761                 }
762                 // Get current locale
763                 Locale locale = FacesContext.getCurrentInstance().getViewRoot().getLocale();
764                 // Get bundle bundle
765                 ResourceBundle bundle = this.loadResourceBundle(locale);
766                 // Default is i18nKey
767                 String message = MessageFormat.format("!{0}!", i18nKey); //NOI18N
768                 // Try it
769                 try {
770                         // Get message
771                         message = bundle.getString(i18nKey);
772                 } catch (final MissingResourceException ex) {
773                         // Did not find it, ignored
774                 }
775                 // Get context and add message
776                 FacesContext.getCurrentInstance().addMessage(clientId, new FacesMessage(message));
777         }
778
779 }