/* * (C) Copyright 2006-2013 Nuxeo SA (http://nuxeo.com/) and others. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * * Contributors: * Vladimir Pasquier <vpasquier@nuxeo.com> * Laurent Doguin <ldoguin@nuxeo.com> * Nelson Silva <nsilva@nuxeo.com> */ package org.nuxeo.ecm.platform.thumbnail.listener; import static org.nuxeo.ecm.core.api.CoreSession.ALLOW_VERSION_WRITE; import java.io.IOException; import java.io.InputStream; import java.io.Serializable; import java.util.HashSet; import java.util.Set; import org.nuxeo.ecm.core.api.Blob; import org.nuxeo.ecm.core.api.Blobs; import org.nuxeo.ecm.core.api.CoreSession; import org.nuxeo.ecm.core.api.DocumentModel; import org.nuxeo.ecm.core.api.NuxeoException; import org.nuxeo.ecm.core.api.VersioningOption; import org.nuxeo.ecm.core.api.blobholder.BlobHolder; import org.nuxeo.ecm.core.api.thumbnail.ThumbnailAdapter; import org.nuxeo.ecm.core.blob.BlobManager; import org.nuxeo.ecm.core.event.DeletedDocumentModel; import org.nuxeo.ecm.core.event.Event; import org.nuxeo.ecm.core.event.EventBundle; import org.nuxeo.ecm.core.event.PostCommitEventListener; import org.nuxeo.ecm.core.event.impl.DocumentEventContext; import org.nuxeo.ecm.core.versioning.VersioningService; import org.nuxeo.ecm.platform.dublincore.listener.DublinCoreListener; import org.nuxeo.ecm.platform.ec.notification.NotificationConstants; import org.nuxeo.ecm.platform.thumbnail.ThumbnailConstants; import org.nuxeo.runtime.api.Framework; /** * Thumbnail listener handling creation and update document event to store doc thumbnail preview (only for DocType File) * * @since 5.7 */ public class UpdateThumbnailListener implements PostCommitEventListener { public static final String THUMBNAIL_UPDATED = "thumbnailUpdated"; protected void processDoc(CoreSession session, DocumentModel doc) { Blob thumbnailBlob = getManagedThumbnail(doc); if (thumbnailBlob == null) { ThumbnailAdapter thumbnailAdapter = doc.getAdapter(ThumbnailAdapter.class); if (thumbnailAdapter == null) { return; } thumbnailBlob = thumbnailAdapter.computeThumbnail(session); } if (thumbnailBlob != null) { if (!doc.hasFacet(ThumbnailConstants.THUMBNAIL_FACET)) { doc.addFacet(ThumbnailConstants.THUMBNAIL_FACET); } doc.setPropertyValue(ThumbnailConstants.THUMBNAIL_PROPERTY_NAME, (Serializable) thumbnailBlob); } else { if (doc.hasFacet(ThumbnailConstants.THUMBNAIL_FACET)) { doc.setPropertyValue(ThumbnailConstants.THUMBNAIL_PROPERTY_NAME, null); doc.removeFacet(ThumbnailConstants.THUMBNAIL_FACET); } } if (doc.isDirty()) { doc.putContextData(VersioningService.VERSIONING_OPTION, VersioningOption.NONE); doc.putContextData(VersioningService.DISABLE_AUTO_CHECKOUT, Boolean.TRUE); doc.putContextData(DublinCoreListener.DISABLE_DUBLINCORE_LISTENER, Boolean.TRUE); doc.putContextData(NotificationConstants.DISABLE_NOTIFICATION_SERVICE, Boolean.TRUE); doc.putContextData("disableAuditLogger", Boolean.TRUE); if (doc.isVersion()) { doc.putContextData(ALLOW_VERSION_WRITE, Boolean.TRUE); } doc.putContextData(THUMBNAIL_UPDATED, true); session.saveDocument(doc); } } private Blob getManagedThumbnail(DocumentModel doc) { BlobHolder bh = doc.getAdapter(BlobHolder.class); if (bh == null) { return null; } Blob blob = bh.getBlob(); if (blob == null) { return null; } BlobManager blobManager = Framework.getService(BlobManager.class); try { InputStream is = blobManager.getThumbnail(blob); if (is == null) { return null; } return Blobs.createBlob(is); } catch (IOException e) { throw new NuxeoException("Failed to get managed blob thumbnail", e); } } @Override public void handleEvent(EventBundle events) { if (!events.containsEventName(ThumbnailConstants.EventNames.scheduleThumbnailUpdate.name())) { return; } Set<String> processedDocs = new HashSet<String>(); for (Event event : events) { if (!ThumbnailConstants.EventNames.scheduleThumbnailUpdate.name().equals(event.getName())) { continue; } DocumentEventContext context = (DocumentEventContext) event.getContext(); DocumentModel doc = context.getSourceDocument(); if (doc instanceof DeletedDocumentModel) { continue; } if (doc.isProxy()) { continue; } if (processedDocs.contains(doc.getId())) { continue; } CoreSession repo = context.getCoreSession(); processDoc(repo, doc); processedDocs.add(doc.getId()); } } }