| 1 |  |  | 
            
  
    | 2 |  |  | 
            
  
    | 3 |  |  | 
            
  
    | 4 |  |  | 
            
  
    | 5 |  |  | 
            
  
    | 6 |  |  | 
            
  
    | 7 |  |  | 
            
  
    | 8 |  |  | 
            
  
    | 9 |  |  | 
            
  
    | 10 |  |  | 
            
  
    | 11 |  |  | 
            
  
    | 12 |  |  | 
            
  
    | 13 |  |  | 
            
  
    | 14 |  |  | 
            
  
    | 15 |  |  | 
            
  
    | 16 |  |  | 
            
  
    | 17 |  |  | 
            
  
    | 18 |  |  | 
            
  
    | 19 |  |  | 
            
  
    | 20 |  |  | 
            
  
    | 21 |  |  | 
            
  
    | 22 |  |  | 
            
  
    | 23 |  |  | 
            
  
    | 24 |  |  | 
            
  
    | 25 |  |  | 
            
  
    | 26 |  |  | 
            
  
    | 27 |  |  | 
            
  
    | 28 |  |  | 
            
  
    | 29 |  |  | 
            
  
    | 30 |  |  | 
            
  
    | 31 |  |  | 
            
  
    | 32 |  | package net.sourceforge.pebble.web.action; | 
            
  
    | 33 |  |  | 
            
  
    | 34 |  | import net.sourceforge.pebble.Constants; | 
            
  
    | 35 |  | import net.sourceforge.pebble.PebbleContext; | 
            
  
    | 36 |  | import net.sourceforge.pebble.security.PebbleUserDetails; | 
            
  
    | 37 |  | import net.sourceforge.pebble.security.SecurityRealm; | 
            
  
    | 38 |  | import net.sourceforge.pebble.security.SecurityRealmException; | 
            
  
    | 39 |  | import net.sourceforge.pebble.util.SecurityUtils; | 
            
  
    | 40 |  | import net.sourceforge.pebble.web.controller.RequireSecurityToken; | 
            
  
    | 41 |  | import net.sourceforge.pebble.web.validation.ValidationContext; | 
            
  
    | 42 |  | import net.sourceforge.pebble.web.view.ForbiddenView; | 
            
  
    | 43 |  | import net.sourceforge.pebble.web.view.View; | 
            
  
    | 44 |  | import net.sourceforge.pebble.web.view.impl.ChangePasswordView; | 
            
  
    | 45 |  | import net.sourceforge.pebble.web.view.impl.PasswordChangedView; | 
            
  
    | 46 |  | import org.apache.commons.logging.Log; | 
            
  
    | 47 |  | import org.apache.commons.logging.LogFactory; | 
            
  
    | 48 |  |  | 
            
  
    | 49 |  | import javax.servlet.ServletException; | 
            
  
    | 50 |  | import javax.servlet.http.HttpServletRequest; | 
            
  
    | 51 |  | import javax.servlet.http.HttpServletResponse; | 
            
  
    | 52 |  |  | 
            
  
    | 53 |  |  | 
            
  
    | 54 |  |  | 
            
  
    | 55 |  |  | 
            
  
    | 56 |  | @author | 
            
  
    | 57 |  |  | 
            
  
    | 58 |  | @RequireSecurityToken | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 34 (34) | Complexity: 10 | Complexity Density: 0,45 |  | 
  
  
    | 59 |  | public class ChangePasswordAction extends SecureAction { | 
            
  
    | 60 |  |  | 
            
  
    | 61 |  |  | 
            
  
    | 62 |  | private static final Log log = LogFactory.getLog(ChangePasswordAction.class); | 
            
  
    | 63 |  |  | 
            
  
    | 64 |  |  | 
            
  
    | 65 |  |  | 
            
  
    | 66 |  |  | 
            
  
    | 67 |  | @param | 
            
  
    | 68 |  | @param | 
            
  
    | 69 |  | @return | 
            
  
    | 70 |  |  | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 31 (31) | Complexity: 9 | Complexity Density: 0,43 |  | 
  
  
    | 71 | 0 |  public View process(HttpServletRequest request, HttpServletResponse response) throws ServletException {... | 
            
  
    | 72 | 0 | try { | 
            
  
    | 73 | 0 | SecurityRealm realm = PebbleContext.getInstance().getConfiguration().getSecurityRealm(); | 
            
  
    | 74 | 0 | PebbleUserDetails currentUserDetails = SecurityUtils.getUserDetails(); | 
            
  
    | 75 | 0 | String password1 = request.getParameter("password1"); | 
            
  
    | 76 | 0 | String password2 = request.getParameter("password2"); | 
            
  
    | 77 | 0 | String submit = request.getParameter("submit"); | 
            
  
    | 78 |  |  | 
            
  
    | 79 |  |  | 
            
  
    | 80 | 0 | if (!currentUserDetails.isDetailsUpdateable()) { | 
            
  
    | 81 | 0 | return new ForbiddenView(); | 
            
  
    | 82 |  | } | 
            
  
    | 83 |  |  | 
            
  
    | 84 | 0 | if (submit == null || submit.length() == 0) { | 
            
  
    | 85 | 0 | return new ChangePasswordView(); | 
            
  
    | 86 |  | } | 
            
  
    | 87 |  |  | 
            
  
    | 88 | 0 | ValidationContext validationContext = new ValidationContext(); | 
            
  
    | 89 |  |  | 
            
  
    | 90 | 0 | if (password1 == null || password1.length() == 0) { | 
            
  
    | 91 | 0 | validationContext.addError("Password can not be empty"); | 
            
  
    | 92 | 0 | } else if (!password1.equals(password2)) { | 
            
  
    | 93 | 0 | validationContext.addError("Passwords do not match"); | 
            
  
    | 94 |  | } | 
            
  
    | 95 |  |  | 
            
  
    | 96 | 0 | if (!validationContext.hasErrors()) { | 
            
  
    | 97 | 0 | realm.changePassword(currentUserDetails.getUsername(), password1); | 
            
  
    | 98 |  |  | 
            
  
    | 99 | 0 | return new PasswordChangedView(); | 
            
  
    | 100 |  | } | 
            
  
    | 101 |  |  | 
            
  
    | 102 | 0 | getModel().put("validationContext", validationContext); | 
            
  
    | 103 | 0 | return new ChangePasswordView(); | 
            
  
    | 104 |  | } catch (SecurityRealmException e) { | 
            
  
    | 105 | 0 | throw new ServletException(e); | 
            
  
    | 106 |  | } | 
            
  
    | 107 |  | } | 
            
  
    | 108 |  |  | 
            
  
    | 109 |  |  | 
            
  
    | 110 |  |  | 
            
  
    | 111 |  |  | 
            
  
    | 112 |  | @return | 
            
  
    | 113 |  | @param | 
            
  
    | 114 |  |  | 
               
        |  |  | 
           
           |  | 0% | Uncovered Elements: 1 (1) | Complexity: 1 | Complexity Density: 1 |  | 
  
  
    | 115 | 0 |  public String[] getRoles(HttpServletRequest request) {... | 
            
  
    | 116 | 0 | return new String[]{Constants.ANY_ROLE}; | 
            
  
    | 117 |  | } | 
            
  
    | 118 |  |  | 
            
  
    | 119 |  | } |