2 * Copyright (C) 2016 - 2020 Free Software Foundation
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.
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.
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/>.
17 package org.mxchange.jfinancials.beans.mobileprovider;
19 import java.util.Objects;
21 import javax.enterprise.context.RequestScoped;
22 import javax.enterprise.event.Event;
23 import javax.enterprise.inject.Any;
24 import javax.faces.application.FacesMessage;
25 import javax.faces.view.facelets.FaceletException;
26 import javax.inject.Inject;
27 import javax.inject.Named;
28 import org.mxchange.jcountry.model.data.Country;
29 import org.mxchange.jfinancials.beans.BaseFinancialsBean;
30 import org.mxchange.jphone.events.mobileprovider.added.AdminAddedMobileProviderEvent;
31 import org.mxchange.jphone.events.mobileprovider.added.AdminMobileProviderAddedEvent;
32 import org.mxchange.jphone.exceptions.mobileprovider.MobileProviderAlreadyAddedException;
33 import org.mxchange.jphone.model.phonenumbers.mobileprovider.AdminMobileProviderSessionBeanRemote;
34 import org.mxchange.jphone.model.phonenumbers.mobileprovider.CellphoneProvider;
35 import org.mxchange.jphone.model.phonenumbers.mobileprovider.MobileProvider;
38 * Administrative bean (controller) for mobile provider
40 * @author Roland Häder<roland@mxchange.org>
42 @Named ("adminMobileProviderController")
44 public class FinancialsAdminMobileProviderWebRequestBean extends BaseFinancialsBean implements FinancialsAdminMobileProviderWebRequestController {
49 private static final long serialVersionUID = 184_598_175_371_269_016L;
52 * Remote EJB for mobile providers (administrative)
54 @EJB (lookup = "java:global/jfinancials-ejb/adminMobileProvider!org.mxchange.jphone.model.phonenumbers.mobileprovider.AdminMobileProviderSessionBeanRemote")
55 private AdminMobileProviderSessionBeanRemote adminRemoteBean;
61 private FinancialsMobileProviderWebRequestController mobileController;
64 * Event being fired when the mobile provider was added
68 private Event<AdminAddedMobileProviderEvent> providerAddedEvent;
71 * Country instance ('s dial data)
73 private Country providerCountry;
76 * Provider dial prefix (example: 0177 for German E+)
78 private Long providerDialPrefix;
81 * Pattern for mail gateway
83 private String providerMailPattern;
86 * Name of the provider
88 private String providerName;
93 public FinancialsAdminMobileProviderWebRequestBean () {
94 // Call super constructor
99 * Adds a mobile provider to database by calling the EJB. A pre-check on
100 * dial-prefix and country combination is done, if found, an exception is
101 * thrown. A redirect should take place after successfull creation.
103 * @todo Add field validation
105 public void addMobileProvider () {
106 // Create mobile provider instance
107 final MobileProvider mobileProvider = new CellphoneProvider(this.getProviderDialPrefix(), this.getProviderName(), this.getProviderCountry(), this.getProviderMailPattern());
109 // Is the provider already created?
110 if (this.isMobileProviderCreated(mobileProvider)) {
111 // Then throw exception
112 this.showFacesMessage("form_add_mobile_provider:providerDialPrefix", new MobileProviderAlreadyAddedException(mobileProvider), FacesMessage.SEVERITY_WARN); //NOI18N
117 final MobileProvider updatedProvider;
120 // Call remote EJB and get back an updated instance
121 updatedProvider = this.adminRemoteBean.addMobileProvider(mobileProvider);
122 } catch (final MobileProviderAlreadyAddedException ex) {
124 throw new FaceletException(ex);
128 this.providerAddedEvent.fire(new AdminMobileProviderAddedEvent(updatedProvider));
132 * Getter for country instance ('s dial data)
134 * @return Country instance
136 public Country getProviderCountry () {
137 return this.providerCountry;
141 * Setter for country instance ('s dial data)
143 * @param providerCountry Country instance
145 public void setProviderCountry (final Country providerCountry) {
146 this.providerCountry = providerCountry;
150 * Getter for provider dial prefix
152 * @return Provider dial prefix
154 public Long getProviderDialPrefix () {
155 return this.providerDialPrefix;
159 * Setter for provider dial prefix
161 * @param providerDialPrefix Provider dial prefix
163 public void setProviderDialPrefix (final Long providerDialPrefix) {
164 this.providerDialPrefix = providerDialPrefix;
168 * Getter for pattern for mail gateway
170 * @return Pattern for mail gateway
172 public String getProviderMailPattern () {
173 return this.providerMailPattern;
177 * Setter for pattern for mail gateway
179 * @param providerMailPattern Pattern for mail gateway
181 public void setProviderMailPattern (final String providerMailPattern) {
182 this.providerMailPattern = providerMailPattern;
186 * Getter for provider name
188 * @return Provider name
190 public String getProviderName () {
191 return this.providerName;
195 * Setter for provider name
197 * @param providerName Provider name
199 public void setProviderName (final String providerName) {
200 this.providerName = providerName;
204 * Checks whether if the given mobile provider is already created by
205 * checking both dial prefix and country.
207 * @param mobileProvider Mobile provider instance to check
209 * @return Whether the given mobile provider instance is found
211 private boolean isMobileProviderCreated (final MobileProvider mobileProvider) {
212 // Default is not found
213 boolean isFound = false;
216 for (final MobileProvider currentMobileProvider : this.mobileController.allMobileProviders()) {
217 // Is the provider's dial prefix and country the same?
218 if (Objects.equals(mobileProvider, currentMobileProvider)) {
219 // Is the same, abort loop