--- /dev/null
+/*
+ * Copyright (C) 2016 quix0r
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU 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 General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+package org.mxchange.jjobs.beans.email_address;
+
+import java.text.MessageFormat;
+import java.util.Objects;
+import javax.enterprise.context.SessionScoped;
+import javax.faces.view.facelets.FaceletException;
+import javax.inject.Inject;
+import javax.inject.Named;
+import javax.naming.Context;
+import javax.naming.InitialContext;
+import javax.naming.NamingException;
+import org.mxchange.jcontacts.contact.Contact;
+import org.mxchange.jjobs.beans.login.UserLoginWebSessionController;
+import org.mxchange.jusercore.exceptions.UserPasswordMismatchException;
+import org.mxchange.jusercore.model.email_address.EmailChangeSessionBeanRemote;
+import org.mxchange.jusercore.model.user.User;
+
+/**
+ * A web session bean for changing email addresses
+ * <p>
+ * @author Roland Haeder<roland@mxchange.org>
+ */
+@Named ("emailChangeController")
+@SessionScoped
+public class EmailChangeWebSessionBean implements EmailChangeWebSessionController {
+
+ /**
+ * Serial number
+ */
+ private static final long serialVersionUID = 186_078_724_659_153L;
+
+ /**
+ * Email address 1 (changing)
+ */
+ private String emailAddress1;
+
+ /**
+ * Email address 2 (repeat in changing)
+ */
+ private String emailAddress2;
+
+ /**
+ * Remote email change bean
+ */
+ private final EmailChangeSessionBeanRemote emailBean;
+
+ /**
+ * Login bean (controller)
+ */
+ @Inject
+ private UserLoginWebSessionController loginController;
+
+ /**
+ * Default constructor
+ */
+ public EmailChangeWebSessionBean () {
+ // Try it
+ try {
+ // Get initial context
+ Context context = new InitialContext();
+
+ // Try to lookup
+ this.emailBean = (EmailChangeSessionBeanRemote) context.lookup("ejb/stateless-jjobs-email-change"); //NOI18N
+ } catch (final NamingException e) {
+ // Throw again
+ throw new FaceletException(e);
+ }
+ }
+
+ @Override
+ public String doChangeEmailAddress () {
+ // This method shall only be called if the user is logged-in
+ if (!this.loginController.isUserLoggedIn()) {
+ // Not logged-in
+ throw new IllegalStateException("User is not logged-in"); //NOI18N
+ } else if (!this.isRequiredChangeEmailAddressSet()) {
+ // Not all required fields are set
+ throw new FaceletException("Not all required fields are set."); //NOI18N
+ } else if (!Objects.equals(this.getEmailAddress1(), this.getEmailAddress2())) {
+ // Email address 1+2 mismatch
+ throw new FaceletException("Email address 1/2 are mismatching."); //NOI18N
+ } else if (!this.loginController.ifCurrentPasswordMatches()) {
+ // Password not matching
+ throw new FaceletException(new UserPasswordMismatchException(this.loginController.getLoggedInUser()));
+ }
+
+ // Get user instance
+ User user = this.loginController.getLoggedInUser();
+
+ // It should be there, so run some tests on it
+ assert (user instanceof User) : "Instance loginController.loggedInUser is null";
+ assert (user.getUserId() instanceof Long) : "Instance loginController.loggedInUser.userId is null";
+ assert (user.getUserId() > 0) : MessageFormat.format("loginController.loggedInUser.userId={0} is invalid", user.getUserId());
+ assert (user.getUserContact() instanceof Contact) : "Instance loginController.loggedInUser.userContact is null";
+ assert (user.getUserContact().getContactId() instanceof Long) : "Instance loginController.userContact.contactId is null";
+ assert (user.getUserContact().getContactId() > 0) : MessageFormat.format("Instance loginController.userContact.contactId={0} is invalid", user.getUserContact().getContactId());
+
+ // Update email address
+ user.getUserContact().setContactEmailAddress(this.getEmailAddress1());
+
+ // Call EJB
+ this.emailBean.enqueueEmailAddressForChange(user);
+
+ // All fine
+ return "login_email_change_queued"; //NOI18N
+ }
+
+ @Override
+ public String getEmailAddress1 () {
+ return this.emailAddress1;
+ }
+
+ @Override
+ public void setEmailAddress1 (final String emailAddress1) {
+ this.emailAddress1 = emailAddress1;
+ }
+
+ @Override
+ public String getEmailAddress2 () {
+ return this.emailAddress2;
+ }
+
+ @Override
+ public void setEmailAddress2 (final String emailAddress2) {
+ this.emailAddress2 = emailAddress2;
+ }
+
+ @Override
+ public boolean isRequiredChangeEmailAddressSet () {
+ return ((this.getEmailAddress1() != null) &&
+ (this.getEmailAddress2() != null));
+ }
+
+}
import org.mxchange.jusercore.events.registration.UserRegisteredEvent;
import org.mxchange.jusercore.exceptions.UserNotFoundException;
import org.mxchange.jusercore.exceptions.UserPasswordMismatchException;
-import org.mxchange.jusercore.model.email_address.EmailChangeSessionBeanRemote;
import org.mxchange.jusercore.model.user.LoginUser;
import org.mxchange.jusercore.model.user.User;
import org.mxchange.jusercore.model.user.UserSessionBeanRemote;
*/
private String emailAddress;
- /**
- * Email address 1 (changing)
- */
- private String emailAddress1;
-
- /**
- * Email address 2 (repeat in changing)
- */
- private String emailAddress2;
-
/**
* Email address list
*/
*/
private final UserSessionBeanRemote userBean;
- /**
- * Remote email change bean
- */
- private final EmailChangeSessionBeanRemote emailBean;
-
/**
* User id
*/
// Try to lookup
this.userBean = (UserSessionBeanRemote) context.lookup("ejb/stateless-jjobs-user"); //NOI18N
-
- // Try to lookup
- this.emailBean = (EmailChangeSessionBeanRemote) context.lookup("ejb/stateless-jjobs-email-change"); //NOI18N
} catch (final NamingException e) {
// Throw again
throw new FaceletException(e);
}
}
- @Override
- public String doChangePersonalData () {
- // This method shall only be called if the user is logged-in
- if (!this.loginController.isUserLoggedIn()) {
- // Not logged-in
- throw new IllegalStateException("User is not logged-in"); //NOI18N
- } else if (!this.isRequiredChangePersonalDataSet()) {
- // Not all required fields are set
- throw new FaceletException("Not all required fields are set."); //NOI18N
- } else if (!this.loginController.ifCurrentPasswordMatches()) {
- // Password not matching
- throw new FaceletException(new UserPasswordMismatchException(this.loginController.getLoggedInUser()));
- }
-
- // Get user instance
- User user = this.loginController.getLoggedInUser();
-
- // It should be there, so run some tests on it
- assert (user instanceof User) : "Instance loginController.loggedInUser is null";
- assert (user.getUserId() instanceof Long) : "Instance loginController.loggedInUser.userId is null";
- assert (user.getUserId() > 0) : MessageFormat.format("loginController.loggedInUser.userId={0} is invalid", user.getUserId());
- assert (user.getUserContact() instanceof Contact) : "Instance loginController.loggedInUser.userContact is null";
- assert (user.getUserContact().getContactId() instanceof Long) : "Instance loginController.userContact.contactId is null";
- assert (user.getUserContact().getContactId() > 0) : MessageFormat.format("Instance loginController.userContact.contactId={0} is invalid", user.getUserContact().getContactId());
-
- // Update all fields
- user.setUserProfileMode(this.getUserProfileMode());
- user.getUserContact().setContactGender(this.getGender());
- user.getUserContact().setContactFirstName(this.getFirstName());
- user.getUserContact().setContactFamilyName(this.getFamilyName());
- user.getUserContact().setContactStreet(this.getStreet());
- user.getUserContact().setContactHouseNumber(this.getHouseNumber());
- user.getUserContact().setContactZipCode(this.getZipCode());
- user.getUserContact().setContactCity(this.getCity());
- user.getUserContact().setContactCountry(this.getCountry());
-
- // Is there a phone number?
- if (user.getUserContact().getContactLandLineNumber() instanceof DialableLandLineNumber) {
- // Debug message
- System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: phoneId={0}", user.getUserContact().getContactLandLineNumber().getPhoneId())); //NOI18N
-
- // Yes, then update as well
- user.getUserContact().getContactLandLineNumber().setPhoneAreaCode(this.getPhoneAreaCode());
- user.getUserContact().getContactLandLineNumber().setPhoneNumber(this.getPhoneNumber());
- }
-
- // Is there a fax number?
- if (user.getUserContact().getContactFaxNumber() instanceof DialableFaxNumber) {
- // Debug message
- System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: faxId={0}", user.getUserContact().getContactFaxNumber().getPhoneId())); //NOI18N
-
- // Yes, then update as well
- user.getUserContact().getContactFaxNumber().setPhoneAreaCode(this.getFaxAreaCode());
- user.getUserContact().getContactFaxNumber().setPhoneNumber(this.getFaxNumber());
- }
-
- // Is there a cellphone number?
- if (user.getUserContact().getContactCellphoneNumber() instanceof DialableCellphoneNumber) {
- // Debug message
- System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: cellPhoneId={0}", user.getUserContact().getContactCellphoneNumber().getPhoneId())); //NOI18N
-
- // Yes, then update as well
- user.getUserContact().getContactCellphoneNumber().setCellphoneProvider(this.getCellphoneCarrier());
- user.getUserContact().getContactCellphoneNumber().setPhoneNumber(this.getCellphoneNumber());
- }
-
- // Send it to the EJB
- this.userBean.updateUserPersonalData(user);
-
- // All fine
- return "login_data_saved"; //NOI18N
- }
-
- @Override
- public String doChangeEmailAddress () {
- // This method shall only be called if the user is logged-in
- if (!this.loginController.isUserLoggedIn()) {
- // Not logged-in
- throw new IllegalStateException("User is not logged-in"); //NOI18N
- } else if (!this.isRequiredChangeEmailAddressSet()) {
- // Not all required fields are set
- throw new FaceletException("Not all required fields are set."); //NOI18N
- } else if (!Objects.equals(this.getEmailAddress1(), this.getEmailAddress2())) {
- // Email address 1+2 mismatch
- throw new FaceletException("Email address 1/2 are mismatching."); //NOI18N
- } else if (!this.loginController.ifCurrentPasswordMatches()) {
- // Password not matching
- throw new FaceletException(new UserPasswordMismatchException(this.loginController.getLoggedInUser()));
- }
-
- // Get user instance
- User user = this.loginController.getLoggedInUser();
-
- // It should be there, so run some tests on it
- assert (user instanceof User) : "Instance loginController.loggedInUser is null";
- assert (user.getUserId() instanceof Long) : "Instance loginController.loggedInUser.userId is null";
- assert (user.getUserId() > 0) : MessageFormat.format("loginController.loggedInUser.userId={0} is invalid", user.getUserId());
- assert (user.getUserContact() instanceof Contact) : "Instance loginController.loggedInUser.userContact is null";
- assert (user.getUserContact().getContactId() instanceof Long) : "Instance loginController.userContact.contactId is null";
- assert (user.getUserContact().getContactId() > 0) : MessageFormat.format("Instance loginController.userContact.contactId={0} is invalid", user.getUserContact().getContactId());
-
- // Update email address
- user.getUserContact().setContactEmailAddress(this.getEmailAddress1());
-
- // Call EJB
- this.emailBean.enqueueEmailAddressForChange(user);
-
- // All fine
- return "login_data_saved"; //NOI18N
- }
-
@Override
public void afterRegistrationEvent (final @Observes UserRegisteredEvent event) {
// Trace message
return user;
}
+ @Override
+ public String doChangePersonalData () {
+ // This method shall only be called if the user is logged-in
+ if (!this.loginController.isUserLoggedIn()) {
+ // Not logged-in
+ throw new IllegalStateException("User is not logged-in"); //NOI18N
+ } else if (!this.isRequiredChangePersonalDataSet()) {
+ // Not all required fields are set
+ throw new FaceletException("Not all required fields are set."); //NOI18N
+ } else if (!this.loginController.ifCurrentPasswordMatches()) {
+ // Password not matching
+ throw new FaceletException(new UserPasswordMismatchException(this.loginController.getLoggedInUser()));
+ }
+
+ // Get user instance
+ User user = this.loginController.getLoggedInUser();
+
+ // It should be there, so run some tests on it
+ assert (user instanceof User) : "Instance loginController.loggedInUser is null";
+ assert (user.getUserId() instanceof Long) : "Instance loginController.loggedInUser.userId is null";
+ assert (user.getUserId() > 0) : MessageFormat.format("loginController.loggedInUser.userId={0} is invalid", user.getUserId());
+ assert (user.getUserContact() instanceof Contact) : "Instance loginController.loggedInUser.userContact is null";
+ assert (user.getUserContact().getContactId() instanceof Long) : "Instance loginController.userContact.contactId is null";
+ assert (user.getUserContact().getContactId() > 0) : MessageFormat.format("Instance loginController.userContact.contactId={0} is invalid", user.getUserContact().getContactId());
+
+ // Update all fields
+ user.setUserProfileMode(this.getUserProfileMode());
+ user.getUserContact().setContactGender(this.getGender());
+ user.getUserContact().setContactFirstName(this.getFirstName());
+ user.getUserContact().setContactFamilyName(this.getFamilyName());
+ user.getUserContact().setContactStreet(this.getStreet());
+ user.getUserContact().setContactHouseNumber(this.getHouseNumber());
+ user.getUserContact().setContactZipCode(this.getZipCode());
+ user.getUserContact().setContactCity(this.getCity());
+ user.getUserContact().setContactCountry(this.getCountry());
+
+ // Is there a phone number?
+ if (user.getUserContact().getContactLandLineNumber() instanceof DialableLandLineNumber) {
+ // Debug message
+ System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: phoneId={0}", user.getUserContact().getContactLandLineNumber().getPhoneId())); //NOI18N
+
+ // Yes, then update as well
+ user.getUserContact().getContactLandLineNumber().setPhoneAreaCode(this.getPhoneAreaCode());
+ user.getUserContact().getContactLandLineNumber().setPhoneNumber(this.getPhoneNumber());
+ }
+
+ // Is there a fax number?
+ if (user.getUserContact().getContactFaxNumber() instanceof DialableFaxNumber) {
+ // Debug message
+ System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: faxId={0}", user.getUserContact().getContactFaxNumber().getPhoneId())); //NOI18N
+
+ // Yes, then update as well
+ user.getUserContact().getContactFaxNumber().setPhoneAreaCode(this.getFaxAreaCode());
+ user.getUserContact().getContactFaxNumber().setPhoneNumber(this.getFaxNumber());
+ }
+
+ // Is there a cellphone number?
+ if (user.getUserContact().getContactCellphoneNumber() instanceof DialableCellphoneNumber) {
+ // Debug message
+ System.out.println(MessageFormat.format("UserWebBean:doChangePersonalData: cellPhoneId={0}", user.getUserContact().getContactCellphoneNumber().getPhoneId())); //NOI18N
+
+ // Yes, then update as well
+ user.getUserContact().getContactCellphoneNumber().setCellphoneProvider(this.getCellphoneCarrier());
+ user.getUserContact().getContactCellphoneNumber().setPhoneNumber(this.getCellphoneNumber());
+ }
+
+ // Send it to the EJB
+ this.userBean.updateUserPersonalData(user);
+
+ // All fine
+ return "login_data_saved"; //NOI18N
+ }
+
@Override
public Date getBirthday () {
return this.birthday;
this.emailAddress = emailAddress;
}
- @Override
- public String getEmailAddress1 () {
- return this.emailAddress1;
- }
-
- @Override
- public void setEmailAddress1 (final String emailAddress1) {
- this.emailAddress1 = emailAddress1;
- }
-
- @Override
- public String getEmailAddress2 () {
- return this.emailAddress2;
- }
-
- @Override
- public void setEmailAddress2 (final String emailAddress2) {
- this.emailAddress2 = emailAddress2;
- }
-
@Override
public String getEmailAddressRepeat () {
return this.emailAddressRepeat;
}
@Override
- public boolean isRequiredPersonalDataSet () {
- return ((this.getUserName() != null) &&
- (this.getUserProfileMode() != null) &&
+ public boolean isRequiredChangePersonalDataSet () {
+ return ((this.getUserProfileMode() != null) &&
(this.getGender() != null) &&
(this.getFirstName() != null) &&
(this.getFamilyName() != null) &&
(this.getStreet() != null) &&
(this.getHouseNumber() != null) &&
(this.getZipCode() != null) &&
- (this.getCity() != null) &&
- (this.getEmailAddress() != null) &&
- (this.getEmailAddressRepeat() != null) &&
- (this.getUserPassword() != null) &&
- (this.getUserPasswordRepeat() != null));
+ (this.getCity() != null));
}
@Override
- public boolean isRequiredChangePersonalDataSet () {
- return ((this.getUserProfileMode() != null) &&
+ public boolean isRequiredPersonalDataSet () {
+ return ((this.getUserName() != null) &&
+ (this.getUserProfileMode() != null) &&
(this.getGender() != null) &&
(this.getFirstName() != null) &&
(this.getFamilyName() != null) &&
(this.getStreet() != null) &&
(this.getHouseNumber() != null) &&
(this.getZipCode() != null) &&
- (this.getCity() != null));
- }
-
- @Override
- public boolean isRequiredChangeEmailAddressSet () {
- return ((this.getEmailAddress1() != null) &&
- (this.getEmailAddress2() != null));
+ (this.getCity() != null) &&
+ (this.getEmailAddress() != null) &&
+ (this.getEmailAddressRepeat() != null) &&
+ (this.getUserPassword() != null) &&
+ (this.getUserPasswordRepeat() != null));
}
@Override