1   /**
2    * Copyright (c) 2000-2009 Liferay, Inc. All rights reserved.
3    *
4    * The contents of this file are subject to the terms of the Liferay Enterprise
5    * Subscription License ("License"). You may not use this file except in
6    * compliance with the License. You can obtain a copy of the License by
7    * contacting Liferay, Inc. See the License for the specific language governing
8    * permissions and limitations under the License, including but not limited to
9    * distribution rights of the Software.
10   *
11   * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
12   * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
13   * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
14   * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
15   * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
16   * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
17   * SOFTWARE.
18   */
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  /**
44   * <a href="EditPasswordPolicyAssignmentsAction.java.html"><b><i>View Source</i>
45   * </b></a>
46   *
47   * @author Scott Lee
48   *
49   */
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 }