]> git.mxchange.org Git - addressbook-mailer-ejb.git/blob - src/java/org/mxchange/jphone/phonenumbers/phone/AddressbookAdminPhoneSessionBean.java
updated jar(s)
[addressbook-mailer-ejb.git] / src / java / org / mxchange / jphone / phonenumbers / phone / AddressbookAdminPhoneSessionBean.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.jphone.phonenumbers.phone;
18
19 import java.text.MessageFormat;
20 import java.util.GregorianCalendar;
21 import javax.ejb.Stateless;
22 import org.mxchange.addressbook.database.BaseAddressbookDatabaseBean;
23 import org.mxchange.jphone.phonenumbers.fax.DialableFaxNumber;
24 import org.mxchange.jphone.phonenumbers.landline.DialableLandLineNumber;
25 import org.mxchange.jphone.phonenumbers.mobile.DialableMobileNumber;
26
27 /**
28  * An EJB for administrative phone purposes
29  * <p>
30  * @author Roland Häder<roland@mxchange.org>
31  */
32 @Stateless (name = "adminPhone", description = "An administrative bean handling phone data")
33 public class AddressbookAdminPhoneSessionBean extends BaseAddressbookDatabaseBean implements AdminPhoneSessionBeanRemote {
34
35         /**
36          * Serial number
37          */
38         private static final long serialVersionUID = 18_597_165_817_401_853L;
39
40         @Override
41         public void deleteFaxData (final DialableFaxNumber faxNumber) {
42                 // Trace message
43                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteFaxData: faxNumber={1} - CALLED!", this.getClass().getSimpleName(), faxNumber));
44
45                 // Is all data set
46                 if (faxNumber == null) {
47                         // Not set, throw NPE
48                         throw new NullPointerException("faxNumber is null"); //NOI18N
49                 } else if (faxNumber.getPhoneId() == null) {
50                         // Throw NPE again
51                         throw new NullPointerException("faxNumber.phoneId is null"); //NOI18N
52                 } else if (faxNumber.getPhoneId() < 1) {
53                         // Invalid number
54                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneId={0} is not valid", faxNumber.getPhoneId())); //NOI18N
55                 } else if (faxNumber.getPhoneCountry() == null) {
56                         // Throw NPE
57                         throw new NullPointerException("faxNumber.phoneCountry is null"); //NOI18N
58                 } else if (faxNumber.getPhoneCountry().getCountryId() == null) {
59                         // Throw NPE
60                         throw new NullPointerException("faxNumber.phoneCountry.countryId is null"); //NOI18N
61                 } else if (faxNumber.getPhoneCountry().getCountryId() < 1) {
62                         // Throw NPE
63                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneCountry.countryId={0} is not valid", faxNumber.getPhoneCountry().getCountryId())); //NOI18N
64                 } else if (faxNumber.getPhoneAreaCode() == null) {
65                         // ... throw again
66                         throw new NullPointerException("faxNumber.phoneAreaCode is null"); //NOI18N
67                 } else if (faxNumber.getPhoneAreaCode() < 1) {
68                         // Id not valid
69                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneAreaCode={0} is not valid.", faxNumber.getPhoneAreaCode())); //NOI18N
70                 } else if (faxNumber.getPhoneNumber() == null) {
71                         // Throw NPE again
72                         throw new NullPointerException("faxNumber.phoneNumber is null"); //NOI18N
73                 } else if (faxNumber.getPhoneNumber() < 1) {
74                         // Throw NPE again
75                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneNumber={0} is not valid.", faxNumber.getPhoneNumber())); //NOI18N
76                 }
77
78                 // Get a managed instance
79                 DialableFaxNumber managedNumber = this.getEntityManager().getReference(faxNumber.getClass(), faxNumber.getPhoneId());
80
81                 // Remove it from database
82                 this.getEntityManager().remove(managedNumber);
83
84                 // Trace message
85                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteMobileData: EXIT!", this.getClass().getSimpleName()));
86         }
87
88         @Override
89         public void deleteLandLineData (final DialableLandLineNumber landLineNumber) {
90                 // Trace message
91                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteLandLineData: landLineNumber={1} - CALLED!", this.getClass().getSimpleName(), landLineNumber));
92
93                 // Is all data set
94                 if (landLineNumber == null) {
95                         // Not set, throw NPE
96                         throw new NullPointerException("landLineNumber is null"); //NOI18N
97                 } else if (landLineNumber.getPhoneId() == null) {
98                         // Throw NPE again
99                         throw new NullPointerException("landLineNumber.phoneId is null"); //NOI18N
100                 } else if (landLineNumber.getPhoneId() < 1) {
101                         // Invalid number
102                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneId={0} is not valid", landLineNumber.getPhoneId())); //NOI18N
103                 } else if (landLineNumber.getPhoneCountry() == null) {
104                         // Throw NPE
105                         throw new NullPointerException("landLineNumber.phoneCountry is null"); //NOI18N
106                 } else if (landLineNumber.getPhoneCountry().getCountryId() == null) {
107                         // Throw NPE
108                         throw new NullPointerException("landLineNumber.phoneCountry.countryId is null"); //NOI18N
109                 } else if (landLineNumber.getPhoneCountry().getCountryId() < 1) {
110                         // Throw NPE
111                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneCountry.countryId={0} is not valid", landLineNumber.getPhoneCountry().getCountryId())); //NOI18N
112                 } else if (landLineNumber.getPhoneAreaCode() == null) {
113                         // ... throw again
114                         throw new NullPointerException("landLineNumber.phoneAreaCode is null"); //NOI18N
115                 } else if (landLineNumber.getPhoneAreaCode() < 1) {
116                         // Id not valid
117                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneAreaCode={0} is not valid.", landLineNumber.getPhoneAreaCode())); //NOI18N
118                 } else if (landLineNumber.getPhoneNumber() == null) {
119                         // Throw NPE again
120                         throw new NullPointerException("landLineNumber.phoneNumber is null"); //NOI18N
121                 } else if (landLineNumber.getPhoneNumber() < 1) {
122                         // Throw NPE again
123                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneNumber={0} is not valid.", landLineNumber.getPhoneNumber())); //NOI18N
124                 }
125
126                 // Get a managed instance
127                 DialableLandLineNumber managedNumber = this.getEntityManager().getReference(landLineNumber.getClass(), landLineNumber.getPhoneId());
128
129                 // Remove it from database
130                 this.getEntityManager().remove(managedNumber);
131
132                 // Trace message
133                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteMobileData: EXIT!", this.getClass().getSimpleName()));
134         }
135
136         @Override
137         public void deleteMobileData (final DialableMobileNumber mobileNumber) {
138                 // Trace message
139                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteMobileData: mobileNumber={1} - CALLED!", this.getClass().getSimpleName(), mobileNumber));
140
141                 // Is all data set
142                 if (null == mobileNumber) {
143                         // Not set, throw NPE
144                         throw new NullPointerException("mobileNumber is null"); //NOI18N
145                 } else if (mobileNumber.getPhoneId() == null) {
146                         // Throw NPE again
147                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
148                 } else if (mobileNumber.getPhoneId() < 1) {
149                         // Invalid number
150                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getPhoneId())); //NOI18N
151                 } else if (mobileNumber.getMobileProvider() == null) {
152                         // Throw NPE
153                         throw new NullPointerException("mobileNumber.cellphoneProvider is null"); //NOI18N
154                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
155                         // ... throw again
156                         throw new NullPointerException("mobileNumber.cellphoneProvider.providerId is null"); //NOI18N
157                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
158                         // Id not valid
159                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.cellphoneProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
160                 } else if (mobileNumber.getPhoneNumber() == null) {
161                         // Throw NPE again
162                         throw new NullPointerException("mobileNumber.phoneNumber is null"); //NOI18N
163                 } else if (mobileNumber.getPhoneNumber() < 1) {
164                         // Throw NPE again
165                         throw new NullPointerException(MessageFormat.format("mobileNumber.phoneNumber={0} is not valid.", mobileNumber.getPhoneNumber())); //NOI18N
166                 }
167
168                 // Get a managed instance
169                 DialableMobileNumber managedNumber = this.getEntityManager().getReference(mobileNumber.getClass(), mobileNumber.getPhoneId());
170
171                 // Remove it from database
172                 this.getEntityManager().remove(managedNumber);
173
174                 // Trace message
175                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteMobileData: EXIT!", this.getClass().getSimpleName()));
176         }
177
178         @Override
179         public DialableFaxNumber updateFaxData (final DialableFaxNumber faxNumber) {
180                 // Trace message
181                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateFaxData: faxNumber={1} - CALLED!", this.getClass().getSimpleName(), faxNumber));
182
183                 // Is all data set
184                 if (faxNumber == null) {
185                         // Not set, throw NPE
186                         throw new NullPointerException("faxNumber is null"); //NOI18N
187                 } else if (faxNumber.getPhoneId() == null) {
188                         // Throw NPE again
189                         throw new NullPointerException("faxNumber.phoneId is null"); //NOI18N
190                 } else if (faxNumber.getPhoneId() < 1) {
191                         // Invalid number
192                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneId={0} is not valid", faxNumber.getPhoneId())); //NOI18N
193                 } else if (faxNumber.getPhoneCountry() == null) {
194                         // Throw NPE
195                         throw new NullPointerException("faxNumber.phoneCountry is null"); //NOI18N
196                 } else if (faxNumber.getPhoneCountry().getCountryId() == null) {
197                         // Throw NPE
198                         throw new NullPointerException("faxNumber.phoneCountry.countryId is null"); //NOI18N
199                 } else if (faxNumber.getPhoneCountry().getCountryId() < 1) {
200                         // Throw NPE
201                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneCountry.countryId={0} is not valid", faxNumber.getPhoneCountry().getCountryId())); //NOI18N
202                 } else if (faxNumber.getPhoneAreaCode() == null) {
203                         // ... throw again
204                         throw new NullPointerException("faxNumber.phoneAreaCode is null"); //NOI18N
205                 } else if (faxNumber.getPhoneAreaCode() < 1) {
206                         // Id not valid
207                         throw new IllegalArgumentException(MessageFormat.format("faxNumber.phoneAreaCode={0} is not valid.", faxNumber.getPhoneAreaCode())); //NOI18N
208                 } else if (faxNumber.getPhoneNumber() == null) {
209                         // Throw NPE again
210                         throw new NullPointerException("faxNumber.phoneNumber is null"); //NOI18N
211                 } else if (faxNumber.getPhoneNumber() < 1) {
212                         // Throw NPE again
213                         throw new NullPointerException(MessageFormat.format("faxNumber.phoneNumber={0} is not valid.", faxNumber.getPhoneNumber())); //NOI18N
214                 }
215
216                 // Get contact from it and find it
217                 DialableFaxNumber managedNumber = this.getEntityManager().find(faxNumber.getClass(), faxNumber.getPhoneId());
218
219                 // Should be found
220                 assert (managedNumber instanceof DialableFaxNumber) : MessageFormat.format("Cell phone number with id {0} not found, but should be.", faxNumber.getPhoneId()); //NOI18N
221
222                 // Debug message
223                 this.getLoggerBeanLocal().logDebug(MessageFormat.format("{0}.updateFaxData: managedNumber.phoneId={1}", this.getClass().getSimpleName(), managedNumber.getPhoneId())); //NOI18N
224
225                 // Set updated timestamp
226                 managedNumber.copyAll(faxNumber);
227                 managedNumber.setPhoneEntryUpdated(new GregorianCalendar());
228
229                 // Trace message
230                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateFaxData: managedNumber={1} - EXIT!", this.getClass().getSimpleName(), managedNumber)); //NOI18N
231
232                 // Return it
233                 return managedNumber;
234         }
235
236         @Override
237         public DialableLandLineNumber updateLandLineData (final DialableLandLineNumber landLineNumber) {
238                 // Trace message
239                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateLandLineData: landLineNumber={1} - CALLED!", this.getClass().getSimpleName(), landLineNumber));
240
241                 // Is all data set
242                 if (landLineNumber == null) {
243                         // Not set, throw NPE
244                         throw new NullPointerException("landLineNumber is null"); //NOI18N
245                 } else if (landLineNumber.getPhoneId() == null) {
246                         // Throw NPE again
247                         throw new NullPointerException("landLineNumber.phoneId is null"); //NOI18N
248                 } else if (landLineNumber.getPhoneId() < 1) {
249                         // Invalid number
250                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneId={0} is not valid", landLineNumber.getPhoneId())); //NOI18N
251                 } else if (landLineNumber.getPhoneCountry() == null) {
252                         // Throw NPE
253                         throw new NullPointerException("landLineNumber.phoneCountry is null"); //NOI18N
254                 } else if (landLineNumber.getPhoneCountry().getCountryId() == null) {
255                         // Throw NPE
256                         throw new NullPointerException("landLineNumber.phoneCountry.countryId is null"); //NOI18N
257                 } else if (landLineNumber.getPhoneCountry().getCountryId() < 1) {
258                         // Throw NPE
259                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneCountry.countryId={0} is not valid", landLineNumber.getPhoneCountry().getCountryId())); //NOI18N
260                 } else if (landLineNumber.getPhoneAreaCode() == null) {
261                         // ... throw again
262                         throw new NullPointerException("landLineNumber.phoneAreaCode is null"); //NOI18N
263                 } else if (landLineNumber.getPhoneAreaCode() < 1) {
264                         // Id not valid
265                         throw new IllegalArgumentException(MessageFormat.format("landLineNumber.phoneAreaCode={0} is not valid.", landLineNumber.getPhoneAreaCode())); //NOI18N
266                 } else if (landLineNumber.getPhoneNumber() == null) {
267                         // Throw NPE again
268                         throw new NullPointerException("landLineNumber.phoneNumber is null"); //NOI18N
269                 } else if (landLineNumber.getPhoneNumber() < 1) {
270                         // Throw NPE again
271                         throw new NullPointerException(MessageFormat.format("landLineNumber.phoneNumber={0} is not valid.", landLineNumber.getPhoneNumber())); //NOI18N
272                 }
273
274                 // Get contact from it and find it
275                 DialableLandLineNumber managedNumber = this.getEntityManager().find(landLineNumber.getClass(), landLineNumber.getPhoneId());
276
277                 // Should be found
278                 assert (managedNumber instanceof DialableLandLineNumber) : MessageFormat.format("Cell phone number with id {0} not found, but should be.", landLineNumber.getPhoneId()); //NOI18N
279
280                 // Debug message
281                 this.getLoggerBeanLocal().logDebug(MessageFormat.format("{0}.updateLandLineData: managedNumber.phoneId={1}", this.getClass().getSimpleName(), managedNumber.getPhoneId())); //NOI18N
282
283                 // Set updated timestamp
284                 managedNumber.copyAll(landLineNumber);
285                 managedNumber.setPhoneEntryUpdated(new GregorianCalendar());
286
287                 // Trace message
288                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateLandLineData: managedNumber={1} - EXIT!", this.getClass().getSimpleName(), managedNumber)); //NOI18N
289
290                 // Return it
291                 return managedNumber;
292         }
293
294         @Override
295         public DialableMobileNumber updateMobileData (final DialableMobileNumber mobileNumber) {
296                 // Trace message
297                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateMobileData: mobileNumber={1} - CALLED!", this.getClass().getSimpleName(), mobileNumber));
298
299                 // Is all data set
300                 if (null == mobileNumber) {
301                         // Not set, throw NPE
302                         throw new NullPointerException("mobileNumber is null"); //NOI18N
303                 } else if (mobileNumber.getPhoneId() == null) {
304                         // Throw NPE again
305                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
306                 } else if (mobileNumber.getPhoneId() < 1) {
307                         // Invalid number
308                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getPhoneId())); //NOI18N
309                 } else if (mobileNumber.getMobileProvider() == null) {
310                         // Throw NPE
311                         throw new NullPointerException("mobileNumber.cellphoneProvider is null"); //NOI18N
312                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
313                         // ... throw again
314                         throw new NullPointerException("mobileNumber.cellphoneProvider.providerId is null"); //NOI18N
315                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
316                         // Id not valid
317                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.cellphoneProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
318                 } else if (mobileNumber.getPhoneNumber() == null) {
319                         // Throw NPE again
320                         throw new NullPointerException("mobileNumber.phoneNumber is null"); //NOI18N
321                 } else if (mobileNumber.getPhoneNumber() < 1) {
322                         // Throw NPE again
323                         throw new NullPointerException(MessageFormat.format("mobileNumber.phoneNumber={0} is not valid.", mobileNumber.getPhoneNumber())); //NOI18N
324                 }
325
326                 // Get contact from it and find it
327                 DialableMobileNumber managedNumber = this.getEntityManager().find(mobileNumber.getClass(), mobileNumber.getPhoneId());
328
329                 // Should be found
330                 assert (managedNumber instanceof DialableMobileNumber) : MessageFormat.format("Cell phone number with id {0} not found, but should be.", mobileNumber.getPhoneId()); //NOI18N
331
332                 // Debug message
333                 this.getLoggerBeanLocal().logDebug(MessageFormat.format("{0}.updateMobileData: managedNumber.phoneId={1}", this.getClass().getSimpleName(), managedNumber.getPhoneId())); //NOI18N
334
335                 // Set updated timestamp
336                 managedNumber.copyAll(mobileNumber);
337                 managedNumber.setPhoneEntryUpdated(new GregorianCalendar());
338
339                 // Trace message
340                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateMobileData: managedNumber={1} - EXIT!", this.getClass().getSimpleName(), managedNumber)); //NOI18N
341
342                 // Return it
343                 return managedNumber;
344         }
345
346 }