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