/* * Copyright (C) 2005-2011 Alfresco Software Limited. * * This file is part of Alfresco * * Alfresco is free software: you can redistribute it and/or modify * it under the terms of 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. * * Alfresco 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * along with Alfresco. If not, see . */ package org.alfresco.repo.publishing; import static org.alfresco.repo.publishing.PublishingModel.PROP_CHANNEL_TYPE_ID; import static org.alfresco.repo.publishing.PublishingModel.TYPE_DELIVERY_CHANNEL; import java.io.Serializable; import java.util.ArrayList; import java.util.Collections; import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.TreeMap; import org.alfresco.model.ContentModel; import org.alfresco.repo.node.encryption.MetadataEncryptor; import org.alfresco.service.cmr.dictionary.DictionaryService; import org.alfresco.service.cmr.publishing.channels.Channel; import org.alfresco.service.cmr.publishing.channels.ChannelService; import org.alfresco.service.cmr.publishing.channels.ChannelType; import org.alfresco.service.cmr.repository.NodeRef; import org.alfresco.service.cmr.repository.NodeService; import org.alfresco.service.namespace.NamespaceService; import org.alfresco.service.namespace.QName; import org.alfresco.util.ParameterCheck; import org.alfresco.util.collections.CollectionUtils; import org.alfresco.util.collections.Filter; /** * @author Nick Smith * @author Brian * @since 4.0 */ public class ChannelServiceImpl implements ChannelService { public static final String NAME = "ChannelService"; private final Map channelTypes = new TreeMap(); private NodeService nodeService; private DictionaryService dictionaryService; private ChannelHelper channelHelper; private PublishingRootObject rootObject; private MetadataEncryptor encryptor; /** * @param nodeService * the nodeService to set */ public void setNodeService(NodeService nodeService) { this.nodeService = nodeService; } /** * @param dictionaryService * the dictionaryService to set */ public void setDictionaryService(DictionaryService dictionaryService) { this.dictionaryService = dictionaryService; } /** * @param rootObject the rootObject to set */ public void setPublishingRootObject(PublishingRootObject rootObject) { this.rootObject = rootObject; } /** * @param channelHelper the channelHelper to set */ public void setChannelHelper(ChannelHelper channelHelper) { this.channelHelper = channelHelper; } public void setEncryptor(MetadataEncryptor encryptor) { this.encryptor = encryptor; } /** * {@inheritDoc} */ public void register(AbstractChannelType channelType) { ParameterCheck.mandatory("channelType", channelType); String id = channelType.getId(); if (channelTypes.containsKey(id)) { throw new IllegalArgumentException("Channel type " + id + " is already registered!"); } channelTypes.put(id, channelType); } /** * {@inheritDoc} */ public List getChannelTypes() { return new ArrayList(channelTypes.values()); } /** * {@inheritDoc} */ public Channel createChannel(String channelTypeId, String name, Map properties) { NodeRef channelContainer = getChannelContainer(); ChannelType channelType = channelTypes.get(channelTypeId); if (channelType == null) { String message = "Channel Type: " + channelTypeId + " does not exist!"; throw new IllegalArgumentException(message); } Map actualProps = new HashMap(); if (properties != null) { actualProps.putAll(properties); } actualProps.put(ContentModel.PROP_NAME, name); actualProps.put(PROP_CHANNEL_TYPE_ID, channelType.getId()); actualProps.put(PublishingModel.PROP_AUTHORISATION_COMPLETE, Boolean.FALSE); actualProps = encryptor.encrypt(actualProps); NodeRef channelNode = channelHelper.createChannelNode(channelContainer, channelType, name, actualProps); return channelHelper.buildChannelObject(channelNode, this); } /** * {@inheritDoc} */ public void deleteChannel(Channel channel) { nodeService.deleteNode(channel.getNodeRef()); } /** * {@inheritDoc} */ public List getChannels() { NodeRef channelContainer = getChannelContainer(); return channelHelper.getAllChannels(channelContainer, this); } /** * {@inheritDoc} */ @Override public Channel getChannelByName(String channelName) { NodeRef node = getChannelNodeByName(channelName); return channelHelper.buildChannelObject(node, this); } private NodeRef getChannelNodeByName(String channelName) { ParameterCheck.mandatory("channelName", channelName); NodeRef channelContainer = getChannelContainer(); if (channelContainer == null) { return null; } NodeRef child = nodeService.getChildByName(channelContainer, ContentModel.ASSOC_CONTAINS, channelName); if (child != null) { QName type = nodeService.getType(child); if (dictionaryService.isSubClass(type, TYPE_DELIVERY_CHANNEL)) { return child; } } return null; } /** * {@inheritDoc} */ public List getRelevantPublishingChannels(NodeRef nodeToPublish) { NodeRef containerNode = getChannelContainer(); List types = channelHelper.getReleventChannelTypes(nodeToPublish, channelTypes.values()); List channels = channelHelper.getChannelsForTypes(containerNode, types, this, true); return channelHelper.filterAuthorisedChannels(channels); } /** * {@inheritDoc} */ public List getPublishingChannels(boolean filterByPublishPermission) { final NodeRef containerNode = getChannelContainer(); if (containerNode != null) { List types = CollectionUtils.filter(channelTypes.values(), new Filter() { public Boolean apply(ChannelType type) { return type.canPublish(); } }); return channelHelper.getChannelsForTypes(containerNode, types, this, filterByPublishPermission); } return Collections.emptyList(); } /** * {@inheritDoc} */ public List getStatusUpdateChannels(boolean filterByPublishPermission) { final NodeRef containerNode = getChannelContainer(); if (containerNode != null) { List types = channelHelper.getStatusUpdateChannelTypes(channelTypes.values()); return channelHelper.getChannelsForTypes(containerNode, types, this, filterByPublishPermission); } return Collections.emptyList(); } /** * {@inheritDoc} */ public List getAuthorisedStatusUpdateChannels() { return channelHelper.filterAuthorisedChannels(getStatusUpdateChannels(false)); } private NodeRef getChannelContainer() { return rootObject.getChannelContainer(); } /** * {@inheritDoc} */ public ChannelType getChannelType(String id) { return channelTypes.get(id); } /** * {@inheritDoc} */ public void renameChannel(Channel channel, String newName) { NodeRef channelNode = channel.getNodeRef(); if (channelNode != null && nodeService.exists(channelNode)) { NodeRef channelContainer = getChannelContainer(); nodeService.setProperty(channelNode, ContentModel.PROP_NAME, newName); nodeService.moveNode(channelNode, channelContainer, ContentModel.ASSOC_CONTAINS, QName.createQName(NamespaceService.APP_MODEL_1_0_URI, newName)); } } /** * {@inheritDoc} */ public void updateChannel(Channel channel, Map properties) { Map actualProps = new HashMap(properties); actualProps.remove(ContentModel.PROP_NODE_UUID); NodeRef editorialNode = new NodeRef(channel.getId()); actualProps = encryptor.encrypt(actualProps); for (Map.Entry entry : actualProps.entrySet()) { nodeService.setProperty(editorialNode, entry.getKey(), entry.getValue()); } } /** * {@inheritDoc} */ public Channel getChannelById(String id) { if (id != null && NodeRef.isNodeRef(id)) { NodeRef node = new NodeRef(id); return channelHelper.buildChannelObject(node, this); } return null; } }