/** * Koya is an alfresco module that provides a corporate orientated dataroom. * * Copyright (C) Itl Developpement 2014 * * This program is free software: you can redistribute it and/or modify it 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. * * This program 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 GNU Affero General Public License for more * details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see `<http://www.gnu.org/licenses/>`. */ package fr.itldev.koya.webscript.security; import java.io.IOException; import java.util.Map; import org.alfresco.service.cmr.repository.NodeRef; import org.springframework.extensions.webscripts.AbstractWebScript; import org.springframework.extensions.webscripts.WebScriptException; import org.springframework.extensions.webscripts.WebScriptRequest; import org.springframework.extensions.webscripts.WebScriptResponse; import fr.itldev.koya.alfservice.KoyaNodeService; import fr.itldev.koya.alfservice.UserService; import fr.itldev.koya.alfservice.security.SpaceAclService; import fr.itldev.koya.exception.KoyaServiceException; import fr.itldev.koya.model.impl.Space; import fr.itldev.koya.model.impl.User; import fr.itldev.koya.model.json.RestConstants; import fr.itldev.koya.model.permissions.KoyaPermission; import fr.itldev.koya.webscript.KoyaWebscript; /** * * Add or Del user user membership on node * * if roleName = "any" with del method, removes on any rolename * */ public class ModifyMembership extends AbstractWebScript { private KoyaNodeService koyaNodeService; private SpaceAclService spaceAclService; private UserService userService; public void setKoyaNodeService(KoyaNodeService koyaNodeService) { this.koyaNodeService = koyaNodeService; } public void setSpaceAclService(SpaceAclService spaceAclService) { this.spaceAclService = spaceAclService; } public void setUserService(UserService userService) { this.userService = userService; } @Override public void execute(WebScriptRequest req, WebScriptResponse res) throws IOException { Map<String, String> urlParams = KoyaWebscript.getUrlParamsMap(req); Map<String, Object> postParams = KoyaWebscript.getJsonMap(req); String response = ""; try { NodeRef nodeRef = koyaNodeService.getNodeRef((String) urlParams.get(RestConstants.WSCONST_NODEREF)); Space space = koyaNodeService.getKoyaNode(nodeRef, Space.class); String roleName = (String) urlParams.get("rolename"); String method = (String) urlParams.get("method"); String userName = (String) postParams.get("userName"); User u = userService.getUserByUsername(userName); if (method.equals("add")) { spaceAclService.addKoyaAuthority(space, KoyaPermission.valueOf(roleName), u); } else if (method.equals("del")) { if ("any".equals(roleName)) { // Delete on any KOYA Group spaceAclService.removeAnyKoyaAuthority(space, u); } else { spaceAclService.removeKoyaAuthority(space, KoyaPermission.valueOf(roleName), u); } } else { // TODO error unknown method } } catch (KoyaServiceException ex) { throw new WebScriptException("KoyaError : " + ex.getErrorCode().toString()); } res.setContentType("application/json;charset=UTF-8"); res.getWriter().write(response); } }