1
22
23 package com.liferay.portal.action;
24
25 import com.liferay.portal.NoSuchUserException;
26 import com.liferay.portal.UserPasswordException;
27 import com.liferay.portal.kernel.servlet.SessionErrors;
28 import com.liferay.portal.kernel.util.Constants;
29 import com.liferay.portal.kernel.util.ParamUtil;
30 import com.liferay.portal.kernel.util.Validator;
31 import com.liferay.portal.security.auth.PrincipalException;
32 import com.liferay.portal.service.UserServiceUtil;
33 import com.liferay.portal.struts.ActionConstants;
34 import com.liferay.portal.util.PortalUtil;
35 import com.liferay.portal.util.WebKeys;
36
37 import javax.servlet.http.HttpServletRequest;
38 import javax.servlet.http.HttpServletResponse;
39 import javax.servlet.http.HttpSession;
40
41 import org.apache.struts.action.Action;
42 import org.apache.struts.action.ActionForm;
43 import org.apache.struts.action.ActionForward;
44 import org.apache.struts.action.ActionMapping;
45
46
51 public class UpdatePasswordAction extends Action {
52
53 public ActionForward execute(
54 ActionMapping mapping, ActionForm form, HttpServletRequest request,
55 HttpServletResponse response)
56 throws Exception {
57
58 String cmd = ParamUtil.getString(request, Constants.CMD);
59
60 if (Validator.isNull(cmd)) {
61 return mapping.findForward("portal.update_password");
62 }
63
64 try {
65 updatePassword(request, response);
66
67 return mapping.findForward(ActionConstants.COMMON_REFERER);
68 }
69 catch (Exception e) {
70 if (e instanceof UserPasswordException) {
71 SessionErrors.add(request, e.getClass().getName(), e);
72
73 return mapping.findForward(ActionConstants.COMMON_REFERER);
74 }
75 else if (e instanceof NoSuchUserException ||
76 e instanceof PrincipalException) {
77
78 SessionErrors.add(request, e.getClass().getName());
79
80 return mapping.findForward("portal.error");
81 }
82 else {
83 PortalUtil.sendError(e, request, response);
84
85 return null;
86 }
87 }
88 }
89
90 protected void updatePassword(
91 HttpServletRequest request, HttpServletResponse response)
92 throws Exception {
93
94 HttpSession session = request.getSession();
95
96 long userId = PortalUtil.getUserId(request);
97 String password1 = ParamUtil.getString(request, "password1");
98 String password2 = ParamUtil.getString(request, "password2");
99 boolean passwordReset = false;
100
101 UserServiceUtil.updatePassword(
102 userId, password1, password2, passwordReset);
103
104 session.setAttribute(WebKeys.USER_PASSWORD, password1);
105 }
106
107 }