--- /dev/null
+/*******************************************************************************
+ * Copyright © Igor Barma, Alexandre Desoubeaux, Christian Martel, Eric Brun, Mathieu Amblard, Gwenael Gevet, Pierre Guillot, 2012
+ *
+ * This file is part of the work and learning management system Pentila Nero.
+ *
+ * Pentila Nero is free software. You can redistribute it and/or modify since
+ * you respect the terms of either (at least one of the both license) :
+ * - under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ * - the CeCILL-C as published by CeCILL-C; either version 1 of the
+ * License, or any later version
+ * - the GNU Lesser General Public License as published by the
+ * Free Software Foundation, either version 3 of the license,
+ * or (at your option) any later version.
+ *
+ * There are special exceptions to the terms and conditions of the
+ * licenses as they are applied to this software. View the full text of
+ * the exception in file LICENSE-PROJECT.txt in the directory of this software
+ * distribution.
+ *
+ * Pentila Nero is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * Licenses for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * and the CeCILL-C and the GNU Lesser General Public License along with
+ * Pentila Nero. If not, see :
+ * <http://www.gnu.org/licenses/> and
+ * <http://www.cecill.info/licences.fr.html>.
+ ******************************************************************************/
+package com.pentila.entSavoie.roleSelect;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+
+import org.apache.struts.action.Action;
+import org.apache.struts.action.ActionForm;
+import org.apache.struts.action.ActionForward;
+import org.apache.struts.action.ActionMapping;
+
+import com.liferay.portal.kernel.exception.PortalException;
+import com.liferay.portal.kernel.exception.SystemException;
+import com.liferay.portal.kernel.log.Log;
+import com.liferay.portal.kernel.log.LogFactoryUtil;
+import com.liferay.portal.kernel.util.ParamUtil;
+import com.liferay.portal.model.Layout;
+import com.liferay.portal.model.LayoutTypePortlet;
+import com.liferay.portal.model.Portlet;
+import com.liferay.portal.model.Role;
+import com.liferay.portal.model.User;
+import com.liferay.portal.service.LayoutLocalServiceUtil;
+import com.liferay.portal.service.RoleLocalServiceUtil;
+import com.liferay.portal.service.UserLocalServiceUtil;
+import com.liferay.portal.util.PortalUtil;
+
+public class SelectAction extends Action {
+ @Override
+ public ActionForward execute(ActionMapping mapping, ActionForm form,
+ HttpServletRequest request, HttpServletResponse response)
+ throws Exception {
+ final String cmd = ParamUtil.getString(request, "cmd");
+ if (_log.isDebugEnabled()) {
+ _log.debug("Command called: "+cmd);
+ }
+ if (cmd.equals("displaySelector")) {
+ if (PortalUtil.getUser(request) != null) {
+ return mapping.findForward("roleSelector");
+ }
+ } else if (cmd.equals("changeRole")) {
+ final User u = PortalUtil.getUser(request);
+ final long roleId = ParamUtil.getLong(request, "selectedRole");
+
+ updateUserRole(u, roleId);
+ updatePages(u);
+
+ if (_log.isDebugEnabled()) {
+ _log.debug("Role change for "+u.getScreenName()+" to role "+roleId);
+ }
+
+
+ }
+
+ return mapping.findForward("/common/referer_jsp.jsp");
+ }
+
+ private void updateUserRole(User user, long newRoleId) {
+ try {
+ Role userRole = RoleLocalServiceUtil.getRole(user.getCompanyId(), "User");
+ Role otherRole = RoleLocalServiceUtil.getRole(newRoleId);
+
+ //retire tous les roles globaux
+ for (Role r : user.getRoles()) {
+ if (r.getType()==1) {
+ UserLocalServiceUtil.deleteRoleUser(r.getRoleId(), user.getUserId());
+ }
+ }
+
+ UserLocalServiceUtil.addRoleUsers(userRole.getRoleId(), new long[]{user.getUserId()});
+ UserLocalServiceUtil.addRoleUsers(otherRole.getRoleId(), new long[]{user.getUserId()});
+
+ } catch (Exception e) {
+ if (_log.isErrorEnabled()) {
+ _log.error(e);
+ }
+ }
+ }
+
+ private void updatePages(User user) throws SystemException, PortalException {
+ for (Layout l : LayoutLocalServiceUtil.getLayouts(
+ user.getGroup().getGroupId(), true)) {
+ LayoutTypePortlet lt = (LayoutTypePortlet) l.getLayoutType();
+ // la page ne serait à cacher que si un seul portlet est dessus
+ // comme c'est le cas pour les portlets de l'entsavoie
+ if (lt.getAllPortlets().size() == 1 ) {
+ final Portlet p = lt.getAllPortlets().get(0);
+ boolean hasPermission = false;
+ for (final String role : p.getRolesArray()) {
+ if (_log.isDebugEnabled()) {
+ _log.debug("Portlet role: "+role);
+ }
+ for (Role r : user.getRoles()) {
+ if (_log.isDebugEnabled()) {
+ _log.debug("User role: "+r.getName());
+ }
+ if (r.getName().equals(role)) {
+ if (_log.isDebugEnabled()) {
+ _log.debug("match, has permission.");
+ }
+ hasPermission = true;
+ }
+ }
+ }
+ l.setHidden(!hasPermission);
+ LayoutLocalServiceUtil.updateLayout(l);
+ }
+ }
+ }
+
+ private Log _log = LogFactoryUtil.getLog(this.getClass());
+
+}