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.cms.rights; 017 018import java.util.Collections; 019import java.util.Map; 020import java.util.Set; 021 022import org.apache.avalon.framework.context.Context; 023import org.apache.avalon.framework.context.ContextException; 024import org.apache.avalon.framework.context.Contextualizable; 025import org.apache.avalon.framework.service.ServiceException; 026import org.apache.avalon.framework.service.ServiceManager; 027import org.apache.cocoon.components.ContextHelper; 028import org.apache.cocoon.environment.Request; 029 030import org.ametys.cms.content.ContentHelper; 031import org.ametys.cms.content.RootContentHelper; 032import org.ametys.cms.content.archive.ArchiveConstants; 033import org.ametys.cms.repository.Content; 034import org.ametys.core.right.AccessController; 035import org.ametys.core.right.RightsException; 036import org.ametys.plugins.core.impl.right.AbstractHierarchicalAccessController; 037import org.ametys.plugins.repository.AmetysObject; 038import org.ametys.plugins.repository.AmetysObjectResolver; 039import org.ametys.plugins.repository.AmetysRepositoryException; 040import org.ametys.plugins.repository.RepositoryConstants; 041import org.ametys.plugins.repository.collection.AmetysObjectCollection; 042import org.ametys.plugins.repository.provider.RequestAttributeWorkspaceSelector; 043import org.ametys.runtime.i18n.I18nizableText; 044 045/** 046 * {@link AccessController} for a {@link Content} 047 */ 048public class ContentAccessController extends AbstractHierarchicalAccessController<AmetysObject> implements Contextualizable 049{ 050 /** The content context category */ 051 public static final I18nizableText CONTENT_CONTEXT_CATEGORY = new I18nizableText("plugin.cms", "PLUGINS_CMS_RIGHT_ASSIGNMENT_CONTEXT_CONTENTS_LABEL"); 052 053 /** The helper for root content */ 054 protected RootContentHelper _rootContentHelper; 055 /** The helper for contents */ 056 protected ContentHelper _contentHelper; 057 /** Ametys Object Resolver */ 058 protected AmetysObjectResolver _resolver; 059 /** The avalon context */ 060 protected Context _context; 061 062 @Override 063 public void service(ServiceManager manager) throws ServiceException 064 { 065 super.service(manager); 066 _rootContentHelper = (RootContentHelper) manager.lookup(RootContentHelper.ROLE); 067 _contentHelper = (ContentHelper) manager.lookup(ContentHelper.ROLE); 068 _resolver = (AmetysObjectResolver) manager.lookup(AmetysObjectResolver.ROLE); 069 } 070 071 public void contextualize(Context context) throws ContextException 072 { 073 _context = context; 074 } 075 076 public boolean supports(Object object) 077 { 078 try 079 { 080 return object instanceof Content && _rootContentHelper.isChildOfRootContent((Content) object) 081 || object != null && object.equals(_rootContentHelper.getRootContent()); 082 } 083 catch (AmetysRepositoryException e) 084 { 085 getLogger().info("The contents root cannot be retrieved.", e); 086 return false; 087 } 088 } 089 090 @Override 091 protected Set<AmetysObject> _getParents(AmetysObject object) 092 { 093 if (object instanceof Content) 094 { 095 AmetysObject parent = object.getParent(); 096 if (parent instanceof AmetysObjectCollection && (RepositoryConstants.NAMESPACE_PREFIX_INTERNAL + ":contents").equals(((AmetysObjectCollection) parent).getName())) 097 { 098 Request request = ContextHelper.getRequest(_context); 099 String originalWorkspace = RequestAttributeWorkspaceSelector.getForcedWorkspace(request); 100 if (ArchiveConstants.ARCHIVE_WORKSPACE.equals(originalWorkspace)) 101 { 102 try 103 { 104 RequestAttributeWorkspaceSelector.setForcedWorkspace(request, RepositoryConstants.DEFAULT_WORKSPACE); 105 AmetysObject parentFromDefault = _resolver.resolveByPath(parent.getPath()); 106 return Collections.singleton(parentFromDefault); 107 108 } 109 finally 110 { 111 RequestAttributeWorkspaceSelector.setForcedWorkspace(request, originalWorkspace); 112 } 113 } 114 } 115 116 return Collections.singleton(parent); 117 } 118 else 119 { 120 return null; 121 } 122 } 123 124 @Override 125 protected Set< ? extends Object> _convertWorkspaceToRootRightContexts(Set<Object> workspacesContexts) 126 { 127 if (workspacesContexts.contains("/cms")) 128 { 129 return Collections.singleton(_rootContentHelper.getRootContent()); 130 } 131 return null; 132 } 133 134 @Override 135 protected I18nizableText getObjectLabelForExplanation(Object object) throws RightsException 136 { 137 if (object instanceof Content) 138 { 139 return new I18nizableText("plugin.cms", "PLUGINS_CMS_CONTENT_ACCESS_CONTROLLER_CONTENT_CONTEXT_EXPLANATION_LABEL", 140 Map.of("title", getObjectLabel(object))); 141 } 142 else if (object instanceof AmetysObjectCollection) 143 { 144 return new I18nizableText("plugin.cms", "PLUGINS_CMS_CONTENT_ACCESS_CONTROLLER_CONTENT_CONTEXT_EXPLANATION_LABEL"); 145 } 146 throw new RightsException("Unsupported context " + object.toString()); 147 } 148 149 @Override 150 public I18nizableText getObjectLabel(Object object) throws RightsException 151 { 152 if (object instanceof Content content) 153 { 154 return new I18nizableText(content.getTitle()); 155 } 156 else if (object instanceof AmetysObjectCollection) 157 { 158 return new I18nizableText("plugin.cms", "PLUGINS_CMS_CONTENT_ACCESS_CONTROLLER_ROOT_CONTEXT_LABEL"); 159 } 160 throw new RightsException("Unsupported context " + object.toString()); 161 } 162 163 public I18nizableText getObjectCategory(Object object) 164 { 165 return CONTENT_CONTEXT_CATEGORY; 166 } 167 168 public int getObjectPriority(Object object) 169 { 170 if (object instanceof AmetysObjectCollection) 171 { 172 return 10; 173 } 174 return super.getObjectPriority(object); 175 } 176}