/** * *************************************************************************** * Copyright (c) 2010 Qcadoo Limited * Project: Qcadoo Framework * Version: 1.4 * * This file is part of Qcadoo. * * Qcadoo 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, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA * *************************************************************************** */ package com.qcadoo.view.internal.controllers; import com.qcadoo.localization.api.TranslationService; import com.qcadoo.mail.api.InvalidMailAddressException; import com.qcadoo.security.api.PasswordReminderService; import org.apache.commons.lang3.StringUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.mail.MailException; import org.springframework.security.core.userdetails.UsernameNotFoundException; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import org.springframework.web.servlet.ModelAndView; import java.util.Locale; @Controller public final class PasswordResetController { private static final String FALSE = "false"; @Autowired private TranslationService translationService; @Autowired private PasswordReminderService passwordReminderService; @Autowired private ViewParametersAppender viewParametersAppender; @RequestMapping(value = "passwordReset", method = RequestMethod.GET) public ModelAndView getForgotPasswordFormView(@RequestParam(required = false, defaultValue = FALSE) final Boolean iframe, @RequestParam(required = false, defaultValue = FALSE) final Boolean popup, final Locale locale) { ModelAndView mav = new ModelAndView(); viewParametersAppender.appendCommonViewObjects(mav); mav.setViewName("qcadooView/passwordReset"); mav.addObject("translation", translationService.getMessagesGroup("security", locale)); mav.addObject("currentLanguage", locale.getLanguage()); mav.addObject("locales", translationService.getLocales()); mav.addObject("iframe", iframe); mav.addObject("popup", popup); return mav; } @RequestMapping(value = "passwordReset", method = RequestMethod.POST) @ResponseBody public String processForgotPasswordFormView(@RequestParam final String login) { if (StringUtils.isBlank(login)) { return "loginIsBlank"; } return performPasswordReseting(login); } private String performPasswordReseting(final String login) { try { passwordReminderService.generateAndSendNewPassword(login); } catch (UsernameNotFoundException e) { return "userNotFound"; } catch (InvalidMailAddressException e) { return "invalidMailAddress"; } catch (MailException e) { return "invalidMailConfig"; } catch (Exception e) { return "error"; } return "success"; } }