1
14
15 package com.liferay.portlet.enterpriseadmin.action;
16
17 import com.liferay.portal.NoSuchPasswordPolicyException;
18 import com.liferay.portal.kernel.servlet.SessionErrors;
19 import com.liferay.portal.kernel.util.Constants;
20 import com.liferay.portal.kernel.util.ParamUtil;
21 import com.liferay.portal.kernel.util.StringUtil;
22 import com.liferay.portal.kernel.util.Validator;
23 import com.liferay.portal.security.auth.PrincipalException;
24 import com.liferay.portal.service.OrganizationServiceUtil;
25 import com.liferay.portal.service.UserServiceUtil;
26 import com.liferay.portal.struts.PortletAction;
27
28 import javax.portlet.ActionRequest;
29 import javax.portlet.ActionResponse;
30 import javax.portlet.PortletConfig;
31 import javax.portlet.RenderRequest;
32 import javax.portlet.RenderResponse;
33
34 import org.apache.struts.action.ActionForm;
35 import org.apache.struts.action.ActionForward;
36 import org.apache.struts.action.ActionMapping;
37
38
44 public class EditPasswordPolicyAssignmentsAction extends PortletAction {
45
46 public void processAction(
47 ActionMapping mapping, ActionForm form, PortletConfig portletConfig,
48 ActionRequest actionRequest, ActionResponse actionResponse)
49 throws Exception {
50
51 String cmd = ParamUtil.getString(actionRequest, Constants.CMD);
52
53 try {
54 if (cmd.equals("password_policy_organizations")) {
55 updatePasswordPolicyOrganizations(actionRequest);
56 }
57 else if (cmd.equals("password_policy_users")) {
58 updatePasswordPolicyUsers(actionRequest);
59 }
60
61 if (Validator.isNotNull(cmd)) {
62 String redirect = ParamUtil.getString(
63 actionRequest, "assignmentsRedirect");
64
65 sendRedirect(actionRequest, actionResponse, redirect);
66 }
67 }
68 catch (Exception e) {
69 if (e instanceof NoSuchPasswordPolicyException ||
70 e instanceof PrincipalException) {
71
72 SessionErrors.add(actionRequest, e.getClass().getName());
73
74 setForward(actionRequest, "portlet.enterprise_admin.error");
75 }
76 else {
77 throw e;
78 }
79 }
80 }
81
82 public ActionForward render(
83 ActionMapping mapping, ActionForm form, PortletConfig portletConfig,
84 RenderRequest renderRequest, RenderResponse renderResponse)
85 throws Exception {
86
87 try {
88 ActionUtil.getPasswordPolicy(renderRequest);
89 }
90 catch (Exception e) {
91 if (e instanceof NoSuchPasswordPolicyException ||
92 e instanceof PrincipalException) {
93
94 SessionErrors.add(renderRequest, e.getClass().getName());
95
96 return mapping.findForward("portlet.enterprise_admin.error");
97 }
98 else {
99 throw e;
100 }
101 }
102
103 return mapping.findForward(getForward(
104 renderRequest,
105 "portlet.enterprise_admin.edit_password_policy_assignments"));
106 }
107
108 protected void updatePasswordPolicyOrganizations(
109 ActionRequest actionRequest)
110 throws Exception {
111
112 long passwordPolicyId = ParamUtil.getLong(
113 actionRequest, "passwordPolicyId");
114
115 long[] addOrganizationIds = StringUtil.split(
116 ParamUtil.getString(actionRequest, "addOrganizationIds"), 0L);
117 long[] removeOrganizationIds = StringUtil.split(
118 ParamUtil.getString(actionRequest, "removeOrganizationIds"), 0L);
119
120 OrganizationServiceUtil.addPasswordPolicyOrganizations(
121 passwordPolicyId, addOrganizationIds);
122 OrganizationServiceUtil.unsetPasswordPolicyOrganizations(
123 passwordPolicyId, removeOrganizationIds);
124 }
125
126 protected void updatePasswordPolicyUsers(ActionRequest actionRequest)
127 throws Exception {
128
129 long passwordPolicyId = ParamUtil.getLong(
130 actionRequest, "passwordPolicyId");
131
132 long[] addUserIds = StringUtil.split(
133 ParamUtil.getString(actionRequest, "addUserIds"), 0L);
134 long[] removeUserIds = StringUtil.split(
135 ParamUtil.getString(actionRequest, "removeUserIds"), 0L);
136
137 UserServiceUtil.addPasswordPolicyUsers(passwordPolicyId, addUserIds);
138 UserServiceUtil.unsetPasswordPolicyUsers(
139 passwordPolicyId, removeUserIds);
140 }
141
142 }