]> git.mxchange.org Git - jjobs-ejb.git/blob - src/java/org/mxchange/jphone/model/phonenumbers/mobile/JobsAdminMobileSessionBean.java
7cf55aae710bb3f2ed31f1ea69c6513b5ac9064d
[jjobs-ejb.git] / src / java / org / mxchange / jphone / model / phonenumbers / mobile / JobsAdminMobileSessionBean.java
1 /*
2  * Copyright (C) 2016 - 2024 Free Software Foundation
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.model.phonenumbers.mobile;
18
19 import java.text.MessageFormat;
20 import java.util.Date;
21 import javax.ejb.Stateless;
22 import org.mxchange.jjobs.enterprise.BaseJobsEnterpriseBean;
23 import org.mxchange.jphone.model.utils.MobileNumberUtils;
24
25 /**
26  * An EJB for administrative mobile number purposes
27  * <p>
28  * @author Roland Häder<roland@mxchange.org>
29  */
30 @Stateless (name = "adminMobile", description = "An administrative bean handling mobile number data")
31 public class JobsAdminMobileSessionBean extends BaseJobsEnterpriseBean implements AdminMobileSessionBeanRemote {
32
33         /**
34          * Serial number
35          */
36         private static final long serialVersionUID = 18_597_165_817_401_854L;
37
38         /**
39          * Default constructor
40          */
41         public JobsAdminMobileSessionBean () {
42                 // Call super constructor
43                 super();
44         }
45
46         @Override
47         public void deleteMobileData (final DialableMobileNumber mobileNumber) {
48                 // Trace message
49                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.deleteMobileData: mobileNumber={1} - CALLED!", this.getClass().getSimpleName(), mobileNumber));
50
51                 // Is all data set
52                 if (null == mobileNumber) {
53                         // Not set, throw NPE
54                         throw new NullPointerException("mobileNumber is null"); //NOI18N
55                 } else if (mobileNumber.getMobileId() == null) {
56                         // Throw NPE again
57                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
58                 } else if (mobileNumber.getMobileId() < 1) {
59                         // Invalid number
60                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getMobileId())); //NOI18N
61                 } else if (mobileNumber.getMobileProvider() == null) {
62                         // Throw NPE
63                         throw new NullPointerException("mobileNumber.cellphoneProvider is null"); //NOI18N
64                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
65                         // ... throw again
66                         throw new NullPointerException("mobileNumber.cellphoneProvider.providerId is null"); //NOI18N
67                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
68                         // Id not valid
69                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.cellphoneProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
70                 } else if (mobileNumber.getMobileNumber() == null) {
71                         // Throw NPE again
72                         throw new NullPointerException("mobileNumber.mobileNumber is null"); //NOI18N
73                 } else if (mobileNumber.getMobileNumber() < 1) {
74                         // Throw NPE again
75                         throw new NullPointerException(MessageFormat.format("mobileNumber.mobileNumber={0} is not valid.", mobileNumber.getMobileNumber())); //NOI18N
76                 }
77
78                 // Get a managed instance
79                 final DialableMobileNumber managedNumber = this.getEntityManager().getReference(mobileNumber.getClass(), mobileNumber.getMobileId());
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 DialableMobileNumber updateMobileData (final DialableMobileNumber mobileNumber) {
90                 // Trace message
91                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateMobileData: mobileNumber={1} - CALLED!", this.getClass().getSimpleName(), mobileNumber));
92
93                 // Is all data set
94                 if (null == mobileNumber) {
95                         // Not set, throw NPE
96                         throw new NullPointerException("mobileNumber is null"); //NOI18N
97                 } else if (mobileNumber.getMobileId() == null) {
98                         // Throw NPE again
99                         throw new NullPointerException("mobileNumber.phoneId is null"); //NOI18N
100                 } else if (mobileNumber.getMobileId() < 1) {
101                         // Invalid number
102                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.phoneId={0} is not valid", mobileNumber.getMobileId())); //NOI18N
103                 } else if (mobileNumber.getMobileProvider() == null) {
104                         // Throw NPE
105                         throw new NullPointerException("mobileNumber.cellphoneProvider is null"); //NOI18N
106                 } else if (mobileNumber.getMobileProvider().getProviderId() == null) {
107                         // ... throw again
108                         throw new NullPointerException("mobileNumber.cellphoneProvider.providerId is null"); //NOI18N
109                 } else if (mobileNumber.getMobileProvider().getProviderId() < 1) {
110                         // Id not valid
111                         throw new IllegalArgumentException(MessageFormat.format("mobileNumber.cellphoneProvider.providerId={0} is not valid.", mobileNumber.getMobileProvider().getProviderId())); //NOI18N
112                 } else if (mobileNumber.getMobileNumber() == null) {
113                         // Throw NPE again
114                         throw new NullPointerException("mobileNumber.mobileNumber is null"); //NOI18N
115                 } else if (mobileNumber.getMobileNumber() < 1) {
116                         // Throw NPE again
117                         throw new NullPointerException(MessageFormat.format("mobileNumber.mobileNumber={0} is not valid.", mobileNumber.getMobileNumber())); //NOI18N
118                 }
119
120                 // Get contact from it and find it
121                 final DialableMobileNumber managedNumber = this.getEntityManager().find(mobileNumber.getClass(), mobileNumber.getMobileId());
122
123                 // Should be found
124                 assert (managedNumber instanceof DialableMobileNumber) : MessageFormat.format("Cell phone number with id {0} not found, but should be.", mobileNumber.getMobileId()); //NOI18N
125
126                 // Debug message
127                 this.getLoggerBeanLocal().logDebug(MessageFormat.format("{0}.updateMobileData: managedNumber.phoneId={1}", this.getClass().getSimpleName(), managedNumber.getMobileId())); //NOI18N
128
129                 // Set updated timestamp
130                 MobileNumberUtils.copyMobileNumberData(mobileNumber, managedNumber);
131                 managedNumber.setMobileEntryUpdated(new Date());
132
133                 // Trace message
134                 this.getLoggerBeanLocal().logTrace(MessageFormat.format("{0}.updateMobileData: managedNumber={1} - EXIT!", this.getClass().getSimpleName(), managedNumber)); //NOI18N
135
136                 // Return it
137                 return managedNumber;
138         }
139
140 }