001/* 002 * Copyright 2016 Anyware Services 003 * 004 * Licensed under the Apache License, Version 2.0 (the "License"); 005 * you may not use this file except in compliance with the License. 006 * You may obtain a copy of the License at 007 * 008 * http://www.apache.org/licenses/LICENSE-2.0 009 * 010 * Unless required by applicable law or agreed to in writing, software 011 * distributed under the License is distributed on an "AS IS" BASIS, 012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 013 * See the License for the specific language governing permissions and 014 * limitations under the License. 015 */ 016package org.ametys.plugins.survey.right; 017 018import java.util.Collections; 019import java.util.Set; 020 021import org.apache.avalon.framework.context.Context; 022import org.apache.avalon.framework.context.ContextException; 023import org.apache.avalon.framework.context.Contextualizable; 024import org.apache.avalon.framework.service.ServiceException; 025import org.apache.avalon.framework.service.ServiceManager; 026import org.apache.cocoon.components.ContextHelper; 027import org.apache.cocoon.environment.Request; 028 029import org.ametys.core.right.AccessController; 030import org.ametys.plugins.core.impl.right.AbstractProfileStorageBasedAccessController; 031import org.ametys.plugins.repository.AmetysObject; 032import org.ametys.plugins.survey.repository.Survey; 033import org.ametys.web.repository.site.Site; 034import org.ametys.web.repository.site.SiteManager; 035 036/** 037 * {@link AccessController} for a {@link Survey} 038 */ 039public class SurveyAccessController extends AbstractProfileStorageBasedAccessController implements Contextualizable 040{ 041 /** The avalon context */ 042 protected Context _context; 043 /** The web site manager */ 044 protected SiteManager _siteManager; 045 046 public void contextualize(Context context) throws ContextException 047 { 048 _context = context; 049 } 050 051 @Override 052 public void service(ServiceManager manager) throws ServiceException 053 { 054 super.service(manager); 055 _siteManager = (SiteManager) manager.lookup(SiteManager.ROLE); 056 } 057 058 @Override 059 public boolean isSupported(Object object) 060 { 061 return object instanceof Survey; 062 } 063 064 @Override 065 protected Set< ? extends Object> _convertWorkspaceToRootRightContexts(Set<Object> workspacesContexts) 066 { 067 if (workspacesContexts.contains("/web")) 068 { 069 Request request = ContextHelper.getRequest(_context); 070 071 String siteName = request.getParameter("siteName"); 072 if (siteName == null) 073 { 074 siteName = (String) request.getAttribute("siteName"); 075 } 076 if (siteName == null) 077 { 078 siteName = (String) request.getAttribute("site"); 079 } 080 081 if (siteName != null) 082 { 083 Site site = _siteManager.getSite(siteName); 084 if (site != null && site.getRootPlugins().hasChild("survey/ametys:surveys")) 085 { 086 AmetysObject surveyNode = site.getRootPlugins().getChild("survey/ametys:surveys"); 087 return Collections.singleton(surveyNode); 088 } 089 } 090 091 getLogger().warn("Could not determine current site to obtain all permissions"); 092 } 093 return null; 094 } 095}