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