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