+++ /dev/null
-/*
- * Copyright (C) 2016 - 2020 Free Software Foundation
- *
- * This program is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License as
- * published by the Free Software Foundation, either version 3 of the
- * License, or (at your option) any later version.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License
- * along with this program. If not, see <http://www.gnu.org/licenses/>.
- */
-package org.mxchange.jjobs.beans.mobile;
-
-import java.text.MessageFormat;
-import java.util.Date;
-import java.util.List;
-import java.util.Objects;
-import javax.ejb.EJB;
-import javax.enterprise.context.RequestScoped;
-import javax.enterprise.event.Event;
-import javax.enterprise.event.Observes;
-import javax.enterprise.inject.Any;
-import javax.faces.application.FacesMessage;
-import javax.inject.Inject;
-import javax.inject.Named;
-import org.mxchange.jjobs.beans.BaseJobsBean;
-import org.mxchange.jjobs.beans.mobile.list.FinancialsMobileListWebViewController;
-import org.mxchange.jphone.events.mobile.created.ObservableCreatedMobileNumberEvent;
-import org.mxchange.jphone.events.mobile.deleted.AdminDeletedMobileNumberEvent;
-import org.mxchange.jphone.events.mobile.deleted.AdminMobileNumberDeletedEvent;
-import org.mxchange.jphone.events.mobile.remove.AdminMobileNumberRemovedFromListEvent;
-import org.mxchange.jphone.events.mobile.remove.AdminRemoveMobileNumberFromListEvent;
-import org.mxchange.jphone.events.mobile.updated.AdminMobileNumberUpdatedEvent;
-import org.mxchange.jphone.events.mobile.updated.AdminUpdatedMobileNumberEvent;
-import org.mxchange.jphone.model.phonenumbers.mobile.AdminMobileSessionBeanRemote;
-import org.mxchange.jphone.model.phonenumbers.mobile.DialableMobileNumber;
-import org.mxchange.jphone.model.phonenumbers.mobile.MobileNumber;
-import org.mxchange.jphone.model.phonenumbers.mobileprovider.MobileProvider;
-
-/**
- * Administrative bean (controller) for mobile numbers
- * <p>
- * @author Roland Häder<roland@mxchange.org>
- */
-@Named ("adminMobileController")
-@RequestScoped
-public class FinancialsAdminMobileWebRequestBean extends BaseJobsBean implements FinancialsAdminMobileWebRequestController {
-
- /**
- * Serial number
- */
- private static final long serialVersionUID = 184_598_175_371_269_017L;
-
- /**
- * Remote EJB for phone number (administrative)
- */
- @EJB (lookup = "java:global/jjobs-ejb/adminMobile!org.mxchange.jphone.model.phonenumbers.mobile.AdminMobileSessionBeanRemote")
- private AdminMobileSessionBeanRemote adminMobileBean;
-
- /**
- * When the phone entry has been created (persisted)
- */
- private Date mobileEntryCreated;
-
- /**
- * When the phone entry has been updated
- */
- private Date mobileEntryUpdated;
-
- /**
- * Mobile id (aka primary key)
- */
- private Long mobileId;
-
- /**
- * Generic hone controller
- */
- @Inject
- private FinancialsMobileListWebViewController mobileListController;
-
- /**
- * Mobile number
- */
- private Long mobileNumber;
-
- /**
- * Event being fired when an administrator has deleted mobile number
- */
- @Inject
- @Any
- private Event<AdminDeletedMobileNumberEvent> mobileNumberDeletedEvent;
-
- /**
- * Event being fired when an administrator has updated land-line number
- */
- @Inject
- @Any
- private Event<AdminUpdatedMobileNumberEvent> mobileNumberUpdatedEvent;
-
- /**
- * Mobile provider
- */
- private MobileProvider mobileProvider;
-
- /**
- * Event being fired when a list of all unused mobile numbers is being
- * created.
- */
- @Inject
- @Any
- private Event<AdminRemoveMobileNumberFromListEvent> removeLinkedMobileNumbersEvent;
-
- /**
- * Chosen mobile number
- */
- private DialableMobileNumber selectedMobileNumber;
-
- /**
- * Default constructor
- */
- public FinancialsAdminMobileWebRequestBean () {
- // Call super constructor
- super();
- }
-
- /**
- * Observes events being fired when a bean helper has successfully created a
- * mobile number instance.
- * <p>
- * @param event Event being fired
- */
- public void afterCreatedMobileNumberEvent (@Observes final ObservableCreatedMobileNumberEvent event) {
- // The event instance must be valid
- if (null == event) {
- // Throw NPE
- throw new NullPointerException("event is null"); //NOI18N
- } else if (event.getMobileNumber() == null) {
- // Throw NPE again
- throw new NullPointerException("event.mobileNumber is null"); //NOI18N
- } else if (event.getMobileNumber().getMobileId() == null) {
- // Throw NPE yet again
- throw new NullPointerException("event.mobileNumber.mobileId is null"); //NOI18N
- } else if (event.getMobileNumber().getMobileId() < 1) {
- // Throw NPE yet again
- throw new NullPointerException(MessageFormat.format("event.mobileNumber.mobileId={0} is invalid", event.getMobileNumber().getMobileId())); //NOI18N
- }
-
- // Get fax number from event
- final DialableMobileNumber number = event.getMobileNumber();
-
- // Copy all data to this bean
- this.setMobileId(number.getMobileId());
- this.setMobileProvider(number.getMobileProvider());
- this.setMobileNumber(number.getMobileNumber());
- this.setMobileEntryCreated(number.getMobileEntryCreated());
- this.setMobileEntryUpdated(number.getMobileEntryUpdated());
- }
-
- /**
- * Returns a list of all unused ("non-linked") mobile numbers
- * <p>
- * @return List with all unused mobile numbers
- */
- public List<DialableMobileNumber> allNonLinkedMobileNumbers () {
- // Get list of all mobile numbers
- final List<DialableMobileNumber> numbers = this.mobileListController.getAllMobileNumbers();
-
- // Visit all controllers to reduce the list
- this.removeLinkedMobileNumbersEvent.fire(new AdminMobileNumberRemovedFromListEvent(numbers));
-
- // Return it
- return numbers;
- }
-
- /**
- * Deletes given mobile entry data
- */
- public void deleteMobileData () {
- // Get mobile number from helper
- final DialableMobileNumber number = this.createMobileNumber();
-
- // Is all data set
- if (number == null) {
- // Not set, throw NPE
- throw new NullPointerException("mobileNumber is null"); //NOI18N
- } else if (number.getMobileId() == null) {
- // Throw NPE again
- throw new NullPointerException("mobileNumber.mobileId is null"); //NOI18N
- } else if (number.getMobileId() < 1) {
- // Invalid number
- throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileId={0} is not valid", number.getMobileId())); //NOI18N
- } else if (number.getMobileProvider() == null) {
- // Throw NPE
- throw new NullPointerException("mobileNumber.mobileProvider is null"); //NOI18N
- } else if (number.getMobileProvider().getProviderId() == null) {
- // ... throw again
- throw new NullPointerException("mobileNumber.mobileProvider.providerId is null"); //NOI18N
- } else if (number.getMobileProvider().getProviderId() < 1) {
- // Id not valid
- throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileProvider.providerId={0} is not valid.", number.getMobileProvider().getProviderId())); //NOI18N
- } else if (number.getMobileNumber() == null) {
- // Throw NPE again
- throw new NullPointerException("mobileNumber.mobileNumber is null"); //NOI18N
- } else if (number.getMobileNumber() < 1) {
- // Throw NPE again
- throw new NullPointerException(MessageFormat.format("mobileNumber.mobileNumber={0} is not valid.", number.getMobileNumber())); //NOI18N
- }
-
- // Call EJB
- this.adminMobileBean.deleteMobileData(number);
-
- // Fire event
- this.mobileNumberDeletedEvent.fire(new AdminMobileNumberDeletedEvent(number));
- }
-
- /**
- * Changes mobile entry data
- * <p>
- * @return Redirect outcome
- */
- public String doUpdateMobileNumber () {
- // Get mobile number from helper
- final DialableMobileNumber number = this.createMobileNumber();
-
- // Is all data set
- if (number == null) {
- // Not set, throw NPE
- throw new NullPointerException("mobileNumber is null"); //NOI18N
- } else if (number.getMobileId() == null) {
- // Throw NPE again
- throw new NullPointerException("mobileNumber.mobileId is null"); //NOI18N
- } else if (number.getMobileId() < 1) {
- // Invalid number
- throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileId={0} is not valid", number.getMobileId())); //NOI18N
- } else if (number.getMobileProvider() == null) {
- // Throw NPE
- throw new NullPointerException("mobileNumber.mobileProvider is null"); //NOI18N
- } else if (number.getMobileProvider().getProviderId() == null) {
- // ... throw again
- throw new NullPointerException("mobileNumber.mobileProvider.providerId is null"); //NOI18N
- } else if (number.getMobileProvider().getProviderId() < 1) {
- // Id not valid
- throw new IllegalArgumentException(MessageFormat.format("mobileNumber.mobileProvider.providerId={0} is not valid.", number.getMobileProvider().getProviderId())); //NOI18N
- } else if (number.getMobileNumber() == null) {
- // Throw NPE again
- throw new NullPointerException("mobileNumber.mobileNumber is null"); //NOI18N
- } else if (number.getMobileNumber() < 1) {
- // Throw NPE again
- throw new NullPointerException(MessageFormat.format("mobileNumber.mobileNumber={0} is not valid.", number.getMobileNumber())); //NOI18N
- } else if (this.getMobileProvider() == null) {
- // Throw NPE again
- throw new NullPointerException("this.mobileProvider is null"); //NOI18N
- } else if (this.getMobileProvider().getProviderId() == null) {
- // Throw NPE again ...
- throw new NullPointerException("this.mobileProvider.providerId is null"); //NOI18N
- } else if (this.getMobileProvider().getProviderId() < 0) {
- // Invalid id number
- throw new IllegalArgumentException(MessageFormat.format("this.mobileProvider.providerId={0} is not valid.", this.getMobileProvider().getProviderId())); //NOI18N
- } else if (this.getMobileNumber() == null) {
- // Throw NPE
- throw new NullPointerException("this.phoneNumber is null"); //NOI18N
- }
-
- // Is the mobile provider and number the same?
- if ((Objects.equals(this.getMobileProvider(), number.getMobileProvider())) && (Objects.equals(this.getMobileNumber(), number.getMobileNumber()))) {
- // Show message
- this.showFacesMessage("form_edit_mobile:mobileNumber", "ERROR_ADMIN_NO_CHANGE_ENTERED", FacesMessage.SEVERITY_WARN); //NOI18N
-
- // No difference in both together, no need to edit
- return ""; //NOI18N
- }
-
- // Set all data
- number.setMobileProvider(this.getMobileProvider());
- number.setMobileNumber(this.getMobileNumber());
-
- // Send to bean
- final DialableMobileNumber updatedNumber = this.adminMobileBean.updateMobileData(number);
-
- // Fire event
- this.mobileNumberUpdatedEvent.fire(new AdminMobileNumberUpdatedEvent(updatedNumber));
-
- // All fine, redirect
- return "admin_show_mobile"; //NOI18N
- }
-
- /**
- * Getter for phone entry created timestamp
- * <p>
- * @return Mobile entry created timestamp
- */
- @SuppressWarnings ("ReturnOfDateField")
- public Date getMobileEntryCreated () {
- return this.mobileEntryCreated;
- }
-
- /**
- * Setter for phone entry created timestamp
- * <p>
- * @param mobileEntryCreated Mobile entry created timestamp
- */
- @SuppressWarnings ("AssignmentToDateFieldFromParameter")
- public void setMobileEntryCreated (final Date mobileEntryCreated) {
- this.mobileEntryCreated = mobileEntryCreated;
- }
-
- /**
- * Getter for phone entry updated timestamp
- * <p>
- * @return Mobile entry updated timestamp
- */
- @SuppressWarnings ("ReturnOfDateField")
- public Date getMobileEntryUpdated () {
- return this.mobileEntryUpdated;
- }
-
- /**
- * Setter for phone entry updated timestamp
- * <p>
- * @param mobileEntryUpdated Mobile entry updated timestamp
- */
- @SuppressWarnings ("AssignmentToDateFieldFromParameter")
- public void setMobileEntryUpdated (final Date mobileEntryUpdated) {
- this.mobileEntryUpdated = mobileEntryUpdated;
- }
-
- /**
- * Getter for phone id
- * <p>
- * @return Mobile id
- */
- public Long getMobileId () {
- return this.mobileId;
- }
-
- /**
- * Setter for phone id
- * <p>
- * @param mobileId Mobile id
- */
- public void setMobileId (final Long mobileId) {
- this.mobileId = mobileId;
- }
-
- /**
- * Getter for dial number without prefix
- * <p>
- * @return Dial number without prefix
- */
- public Long getMobileNumber () {
- return this.mobileNumber;
- }
-
- /**
- * Setter for dial number without prefix
- * <p>
- * @param mobileNumber Dial number without prefix
- */
- public void setMobileNumber (final Long mobileNumber) {
- this.mobileNumber = mobileNumber;
- }
-
- /**
- * Getter for mobile provider
- * <p>
- * @return Mobile provider
- */
- public MobileProvider getMobileProvider () {
- return this.mobileProvider;
- }
-
- /**
- * Setter for mobile provider
- * <p>
- * @param mobileProvider Mobile provider
- */
- public void setMobileProvider (final MobileProvider mobileProvider) {
- this.mobileProvider = mobileProvider;
- }
-
- /**
- * Getter for chosen mobile number
- * <p>
- * @return mobile number
- */
- public DialableMobileNumber getSelectedMobileNumber () {
- return this.selectedMobileNumber;
- }
-
- /**
- * Setter for chosen mobile number
- * <p>
- * @param selectedMobileNumber mobile number
- */
- public void setSelectedMobileNumber (final DialableMobileNumber selectedMobileNumber) {
- this.selectedMobileNumber = selectedMobileNumber;
- }
-
- /**
- * Returns an instance of a DialableMobileNumber from all fields stored in
- * this bean.
- * <p>
- * @return An instance of a DialableMobileNumber class
- */
- private DialableMobileNumber createMobileNumber () {
- // Initialize it
- final DialableMobileNumber number = new MobileNumber(this.getMobileProvider(), this.getMobileNumber());
-
- // Add all other data
- number.setMobileEntryCreated(this.getMobileEntryCreated());
- number.setMobileEntryUpdated(this.getMobileEntryUpdated());
- number.setMobileId(this.getMobileId());
-
- // Return it
- return number;
- }
-
-}