]> git.mxchange.org Git - jjobs-war.git/blob - src/java/org/mxchange/jjobs/beans/helper/JobsWebRequestHelperBean.java
Please cherry-pick:
[jjobs-war.git] / src / java / org / mxchange / jjobs / beans / helper / JobsWebRequestHelperBean.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.helper;
18
19 import java.text.MessageFormat;
20 import javax.enterprise.context.RequestScoped;
21 import javax.enterprise.event.Event;
22 import javax.enterprise.inject.Any;
23 import javax.inject.Inject;
24 import javax.inject.Named;
25 import org.mxchange.jcontacts.contact.Contact;
26 import org.mxchange.jjobs.beans.BaseJobsController;
27 import org.mxchange.jjobs.beans.contact.JobsAdminContactWebRequestController;
28 import org.mxchange.jjobs.beans.phone.JobsAdminPhoneWebRequestController;
29 import org.mxchange.jjobs.beans.user.JobsAdminUserWebRequestController;
30 import org.mxchange.jjobs.beans.user.JobsUserWebSessionController;
31 import org.mxchange.jphone.events.helper.fax.created.HelperCreatedFaxNumberEvent;
32 import org.mxchange.jphone.events.helper.fax.created.ObservableHelperCreatedFaxNumberEvent;
33 import org.mxchange.jphone.events.helper.landline.created.HelperCreatedLandLineNumberEvent;
34 import org.mxchange.jphone.events.helper.landline.created.ObservableHelperCreatedLandLineNumberEvent;
35 import org.mxchange.jphone.events.helper.mobile.created.HelperCreatedMobileNumberEvent;
36 import org.mxchange.jphone.events.helper.mobile.created.ObservableHelperCreatedMobileNumberEvent;
37 import org.mxchange.jphone.phonenumbers.fax.DialableFaxNumber;
38 import org.mxchange.jphone.phonenumbers.landline.DialableLandLineNumber;
39 import org.mxchange.jphone.phonenumbers.mobile.DialableMobileNumber;
40 import org.mxchange.jusercore.events.user.helper.created.HelperCreatedUserEvent;
41 import org.mxchange.jusercore.events.user.helper.created.ObservableHelperCreatedUserEvent;
42 import org.mxchange.jusercore.model.user.User;
43
44 /**
45  * A general helper for beans
46  * <p>
47  * @author Roland Häder<roland@mxchange.org>
48  */
49 @Named ("beanHelper")
50 @RequestScoped
51 public class JobsWebRequestHelperBean extends BaseJobsController implements JobsWebRequestHelperController {
52
53         /**
54          * Call-stack instance (5 may show BeanELResolver.getValue as caller)
55          */
56         private static final short THREAD_STACK = 5;
57
58         /**
59          * Serial number
60          */
61         private static final long serialVersionUID = 17_258_793_567_145_701L;
62
63         /**
64          * Administrative contact controller
65          */
66         @Inject
67         private JobsAdminContactWebRequestController adminContactController;
68
69         /**
70          * Administrative phone controller
71          */
72         @Inject
73         private JobsAdminPhoneWebRequestController adminPhoneController;
74
75         /**
76          * Administrative user controller
77          */
78         @Inject
79         private JobsAdminUserWebRequestController adminUserController;
80
81         /**
82          * Contact instance
83          */
84         private Contact contact;
85
86         /**
87          * Fax number
88          */
89         private DialableFaxNumber faxNumber;
90
91         /**
92          * Land-line number
93          */
94         private DialableLandLineNumber landLineNumber;
95
96         /**
97          * Mobile number
98          */
99         private DialableMobileNumber mobileNumber;
100
101         /**
102          * User instance
103          */
104         private User user;
105
106         /**
107          * Regular user controller
108          */
109         @Inject
110         private JobsUserWebSessionController userController;
111
112         /**
113          * Event for when a user instance was created
114          */
115         @Any
116         @Inject
117         private Event<ObservableHelperCreatedUserEvent> userCreatedEvent;
118
119         /**
120          * Event for when a fax number instance was created
121          */
122         @Any
123         @Inject
124         private Event<ObservableHelperCreatedFaxNumberEvent> faxNumberCreatedEvent;
125
126         /**
127          * Event for when a land-line number instance was created
128          */
129         @Any
130         @Inject
131         private Event<ObservableHelperCreatedLandLineNumberEvent> landLineNumberCreatedEvent;
132
133         /**
134          * Event for when a mobile number instance was created
135          */
136         @Any
137         @Inject
138         private Event<ObservableHelperCreatedMobileNumberEvent> mobileNumberCreatedEvent;
139
140         /**
141          * Default constructor
142          */
143         public JobsWebRequestHelperBean () {
144                 // Call super constructor
145                 super();
146
147                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[3].getClassName(), Thread.currentThread().getStackTrace()[3].getMethodName());
148                 // System.out.println(MessageFormat.format("{0}: Constructed, caller: {1}", this.getClass().getSimpleName(), caller));
149         }
150
151         @Override
152         public void copyContactToController () {
153                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[THREAD_STACK].getClassName(), Thread.currentThread().getStackTrace()[THREAD_STACK].getMethodName());
154                 // System.out.println(MessageFormat.format("{0}.copyContactToController: CALLED, caller: {2}", this.getClass().getSimpleName(), this.contact, caller));
155
156                 // Validate contact instance
157                 if (this.getContact() == null) {
158                         // Throw NPE
159                         throw new NullPointerException("this.contact is null"); //NOI18N
160                 } else if (this.getContact().getContactId() == null) {
161                         // Throw NPE again
162                         throw new NullPointerException("this.contact.contactId is null"); //NOI18N
163                 } else if (this.getContact().getContactId() < 1) {
164                         // Not valid
165                         throw new IllegalStateException(MessageFormat.format("this.contact.contactId={0} is not valid.", this.getContact().getContactId())); //NOI18N
166                 }
167
168                 // Set all phone instances
169                 this.setPhoneInstances(this.getContact());
170
171                 // Set all fields: user
172                 this.adminContactController.copyContactToController(this.getContact());
173         }
174
175         @Override
176         public void copyFaxNumberToController () {
177                 // Validate fax instance
178                 if (this.getFaxNumber() == null) {
179                         // Throw NPE
180                         throw new NullPointerException("this.faxNumber is null"); //NOI18N
181                 } else if (this.getFaxNumber().getPhoneId() == null) {
182                         // Throw again
183                         throw new NullPointerException("this.faxNumber.phoneId is null"); //NOI18N
184                 } else if (this.getFaxNumber().getPhoneId() < 1) {
185                         // Invalid id number
186                         throw new IllegalArgumentException(MessageFormat.format("this.faxNumber.phoneId={0} is not valid", this.getFaxNumber().getPhoneId())); //NOI18N
187                 } else if (this.getFaxNumber().getPhoneAreaCode() == null) {
188                         // Throw again
189                         throw new NullPointerException("this.faxNumber.phoneAreaCode is null"); //NOI18N
190                 } else if (this.getFaxNumber().getPhoneAreaCode() < 1) {
191                         // Invalid id number
192                         throw new IllegalArgumentException(MessageFormat.format("this.faxNumber.phoneAreaCode={0} is not valid", this.getFaxNumber().getPhoneAreaCode())); //NOI18N
193                 } else if (this.getFaxNumber().getPhoneCountry() == null) {
194                         // Throw NPE again
195                         throw new NullPointerException("this.faxNumber.phoneCountry is null"); //NOI18N
196                 } else if (this.getFaxNumber().getPhoneCountry().getCountryId() == null) {
197                         // ... throw again
198                         throw new NullPointerException("this.faxNumber.phoneCountry.countryId is null"); //NOI18N
199                 } else if (this.getFaxNumber().getPhoneCountry().getCountryId() < 1) {
200                         // Invalid id
201                         throw new IllegalArgumentException(MessageFormat.format("this.faxNumber.phoneCountry.countryId={0} is invalid", this.getFaxNumber().getPhoneCountry().getCountryId())); //NOI18N
202                 } else if (this.getFaxNumber().getPhoneNumber() == null) {
203                         // Throw NPE again ...
204                         throw new NullPointerException("this.faxNumber.phoneNumber is null"); //NOI18N
205                 } else if (this.getFaxNumber().getPhoneNumber() < 1) {
206                         // Invalid id number
207                         throw new IllegalArgumentException(MessageFormat.format("this.faxNumber.phoneNumber={0} is not valid", this.getFaxNumber().getPhoneNumber())); //NOI18N
208                 }
209
210                 // Fire event
211                 this.faxNumberCreatedEvent.fire(new HelperCreatedFaxNumberEvent(this.getFaxNumber()));
212         }
213
214         @Override
215         public void copyLandLineNumberToController () {
216                 // Validate land-line instance
217                 if (this.getLandLineNumber() == null) {
218                         // Throw NPE
219                         throw new NullPointerException("this.landLineNumber is null"); //NOI18N
220                 } else if (this.getLandLineNumber().getPhoneId() == null) {
221                         // Throw again
222                         throw new NullPointerException("this.landLineNumber.phoneId is null"); //NOI18N
223                 } else if (this.getLandLineNumber().getPhoneId() < 1) {
224                         // Invalid id number
225                         throw new IllegalArgumentException(MessageFormat.format("this.landLineNumber.phoneId={0} is not valid", this.getLandLineNumber().getPhoneId())); //NOI18N
226                 } else if (this.getLandLineNumber().getPhoneAreaCode() == null) {
227                         // Throw again
228                         throw new NullPointerException("this.landLineNumber.phoneAreaCode is null"); //NOI18N
229                 } else if (this.getLandLineNumber().getPhoneAreaCode() < 1) {
230                         // Invalid id number
231                         throw new IllegalArgumentException(MessageFormat.format("this.landLineNumber.phoneAreaCode={0} is not valid", this.getFaxNumber().getPhoneAreaCode())); //NOI18N
232                 } else if (this.getLandLineNumber().getPhoneCountry() == null) {
233                         // Throw NPE again
234                         throw new NullPointerException("this.landLineNumber.phoneCountry is null"); //NOI18N
235                 } else if (this.getLandLineNumber().getPhoneCountry().getCountryId() == null) {
236                         // ... throw again
237                         throw new NullPointerException("this.landLineNumber.phoneCountry.countryId is null"); //NOI18N
238                 } else if (this.getLandLineNumber().getPhoneCountry().getCountryId() < 1) {
239                         // Invalid id
240                         throw new IllegalArgumentException(MessageFormat.format("this.landLineNumber.phoneCountry.countryId={0} is invalid", this.getLandLineNumber().getPhoneCountry().getCountryId())); //NOI18N
241                 } else if (this.getLandLineNumber().getPhoneNumber() == null) {
242                         // Throw NPE again ...
243                         throw new NullPointerException("this.landLineNumber.phoneNumber is null"); //NOI18N
244                 } else if (this.getLandLineNumber().getPhoneNumber() < 1) {
245                         // Invalid id number
246                         throw new IllegalArgumentException(MessageFormat.format("this.landLineNumber.phoneNumber={0} is not valid", this.getLandLineNumber().getPhoneNumber())); //NOI18N
247                 }
248
249                 // Fire event
250                 this.landLineNumberCreatedEvent.fire(new HelperCreatedLandLineNumberEvent(this.getLandLineNumber()));
251         }
252
253         @Override
254         public void copyMobileNumberToController () {
255                 // Validate mobile instance
256                 if (this.getMobileNumber() == null) {
257                         // Throw NPE
258                         throw new NullPointerException("this.mobileNumber is null"); //NOI18N
259                 } else if (this.getMobileNumber().getPhoneId() == null) {
260                         // Throw again
261                         throw new NullPointerException("this.mobileNumber.phoneId is null"); //NOI18N
262                 } else if (this.getMobileNumber().getPhoneId() < 1) {
263                         // Invalid id number
264                         throw new IllegalArgumentException(MessageFormat.format("this.mobileNumber.phoneId={0} is not valid", this.getMobileNumber().getPhoneId())); //NOI18N
265                 } else if (this.getMobileNumber().getMobileProvider() == null) {
266                         // Throw NPE again
267                         throw new NullPointerException("this.mobileNumber.mobileProvider is null"); //NOI18N
268                 } else if (this.getMobileNumber().getMobileProvider().getProviderId() == null) {
269                         // ... throw again
270                         throw new NullPointerException("this.mobileNumber.mobileProvider.providerId is null"); //NOI18N
271                 } else if (this.getMobileNumber().getMobileProvider().getProviderId() < 1) {
272                         // Invalid id
273                         throw new IllegalArgumentException(MessageFormat.format("this.mobileNumber.mobileProvider.providerId={0} is invalid", this.getMobileNumber().getMobileProvider().getProviderId())); //NOI18N
274                 } else if (this.getMobileNumber().getPhoneNumber() == null) {
275                         // Throw NPE again ...
276                         throw new NullPointerException("this.mobileNumber.phoneNumber is null"); //NOI18N
277                 } else if (this.getMobileNumber().getPhoneNumber() < 1) {
278                         // Invalid id number
279                         throw new IllegalArgumentException(MessageFormat.format("this.mobileNumber.phoneNumber={0} is not valid", this.getMobileNumber().getPhoneNumber())); //NOI18N
280                 }
281
282                 // Fire event
283                 this.mobileNumberCreatedEvent.fire(new HelperCreatedMobileNumberEvent(this.getMobileNumber()));
284         }
285
286         @Override
287         public void copyUserToController () {
288                 // Log message
289                 //* NOISY-DEBUG: */ System.out.println("AdminHelper::copyUserToController - CALLED!"); //NOI18N
290
291                 // Validate user instance
292                 if (this.getUser() == null) {
293                         // Throw NPE
294                         throw new NullPointerException("this.user is null"); //NOI18N
295                 } else if (this.getUser().getUserId() == null) {
296                         // Throw NPE again
297                         throw new NullPointerException("this.user.userId is null"); //NOI18N
298                 } else if (this.getUser().getUserId() < 1) {
299                         // Not valid
300                         throw new IllegalStateException(MessageFormat.format("this.user.userId={0} is not valid.", this.getUser().getUserId())); //NOI18N
301                 }
302
303                 // Get contact
304                 Contact userContact = this.getUser().getUserContact();
305
306                 // Set contact here, too. This avoids parameters that cannot auto-complete in IDEs.
307                 this.setContact(userContact);
308
309                 // Set all phone instances
310                 this.setPhoneInstances(userContact);
311
312                 // Fire event
313                 this.userCreatedEvent.fire(new HelperCreatedUserEvent(this.getUser()));
314         }
315
316         @Override
317         public Contact getContact () {
318                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[THREAD_STACK].getClassName(), Thread.currentThread().getStackTrace()[THREAD_STACK].getMethodName());
319                 // System.out.println(MessageFormat.format("{0}: Returning this.contact={1}, caller: {2}", this.getClass().getSimpleName(), this.contact, caller));
320                 return this.contact;
321         }
322
323         @Override
324         public void setContact (final Contact contact) {
325                 // String caller = MessageFormat.format("{0}.{1}", Thread.currentThread().getStackTrace()[THREAD_STACK].getClassName(), Thread.currentThread().getStackTrace()[THREAD_STACK].getMethodName());
326                 // System.out.println(MessageFormat.format("{0}: Setting contact={1}, previous: {2}, caller: {3}", this.getClass().getSimpleName(), contact, this.contact, caller));
327                 this.contact = contact;
328         }
329
330         @Override
331         public String getContactUsageMessageKey (final Contact contact) {
332                 // The contact must be valid
333                 if (null == contact) {
334                         // Throw NPE
335                         throw new NullPointerException("contact is null"); //NOI18N
336                 } else if (contact.getContactId() == null) {
337                         // Throw again ...
338                         throw new NullPointerException("contact.contactId is null"); //NOI18N
339                 } else if (contact.getContactId() < 1) {
340                         // Not valid
341                         throw new IllegalArgumentException(MessageFormat.format("contact.contactId={0} is not valid", contact.getContactId())); //NOI18N
342                 }
343
344                 // Default key is "unused"
345                 String messageKey = "CONTACT_IS_UNUSED"; //NOI18N
346
347                 // Check user contact
348                 boolean isUserContact = this.userController.isContactFound(contact);
349
350                 // Check user first
351                 if (isUserContact) {
352                         // Only user
353                         messageKey = "CONTACT_IS_USER"; //NOI18N
354                 }
355
356                 // Return message key
357                 return messageKey;
358         }
359
360         @Override
361         public DialableFaxNumber getFaxNumber () {
362                 return this.faxNumber;
363         }
364
365         @Override
366         public void setFaxNumber (final DialableFaxNumber faxNumber) {
367                 this.faxNumber = faxNumber;
368         }
369
370         @Override
371         public DialableLandLineNumber getLandLineNumber () {
372                 return this.landLineNumber;
373         }
374
375         @Override
376         public void setLandLineNumber (final DialableLandLineNumber landLineNumber) {
377                 this.landLineNumber = landLineNumber;
378         }
379
380         @Override
381         public DialableMobileNumber getMobileNumber () {
382                 return this.mobileNumber;
383         }
384
385         @Override
386         public void setMobileNumber (final DialableMobileNumber mobileNumber) {
387                 this.mobileNumber = mobileNumber;
388         }
389
390         @Override
391         public User getUser () {
392                 return this.user;
393         }
394
395         @Override
396         public void setUser (final User user) {
397                 this.user = user;
398         }
399
400         /**
401          * Set's all given contact's phone instances: land-line, mobile and
402          * faxNumber
403          * <p>
404          * @param contact Contact to set phone instances for
405          */
406         private void setPhoneInstances (final Contact contact) {
407                 // The contact must be valid
408                 if (null == contact) {
409                         // Throw NPE
410                         throw new NullPointerException("contact is null"); //NOI18N
411                 } else if (contact.getContactId() == null) {
412                         // Throw again ...
413                         throw new NullPointerException("contact.contactId is null"); //NOI18N
414                 } else if (contact.getContactId() < 1) {
415                         // Not valid
416                         throw new IllegalArgumentException(MessageFormat.format("contact.contactId={0} is not valid", contact.getContactId())); //NOI18N
417                 }
418
419                 // Is mobile set?
420                 if (contact.getContactMobileNumber() instanceof DialableMobileNumber) {
421                         // Yes, then set it in admin controller
422                         this.setMobileNumber(contact.getContactMobileNumber());
423                 }
424
425                 // Is land-line set?
426                 if (contact.getContactLandLineNumber() instanceof DialableLandLineNumber) {
427                         // Yes, then set it in admin controller
428                         this.setLandLineNumber(contact.getContactLandLineNumber());
429                 }
430
431                 // Is faxNumber set?
432                 if (contact.getContactFaxNumber() instanceof DialableFaxNumber) {
433                         // Yes, then set it in admin controller
434                         this.setFaxNumber(contact.getContactFaxNumber());
435                 }
436         }
437
438 }