/* * Copyright (c) 2006-2011 Nuxeo SA (http://nuxeo.com/) and others. * * All rights reserved. This program and the accompanying materials * are made available under the terms of the Eclipse Public License v1.0 * which accompanies this distribution, and is available at * http://www.eclipse.org/legal/epl-v10.html * * Contributors: * bstefanescu * * $Id: DocumentModelUpdater.java 29029 2008-01-14 18:38:14Z ldoguin $ */ package org.eclipse.ecr.core.io.impl.plugins; import java.io.IOException; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; import org.eclipse.ecr.core.api.ClientException; import org.eclipse.ecr.core.api.CoreSession; import org.eclipse.ecr.core.api.DocumentLocation; import org.eclipse.ecr.core.api.DocumentModel; import org.eclipse.ecr.core.api.IdRef; import org.eclipse.ecr.core.io.DocumentTranslationMap; import org.eclipse.ecr.core.io.ExportedDocument; import org.eclipse.ecr.core.io.impl.AbstractDocumentModelWriter; import org.eclipse.ecr.core.io.impl.DocumentTranslationMapImpl; /** * A writer that only updates existing documents. The doc ID is used to identity documents. * The imported tree structure is ignored. * * @author <a href="mailto:bs@nuxeo.com">Bogdan Stefanescu</a> */ // TODO: improve it -> // modify core session to add a batch create method and use it public class DocumentModelUpdater extends AbstractDocumentModelWriter { private static final Log log = LogFactory.getLog(DocumentModelUpdater.class); /** * @param session the session to the repository where to write * @param parentPath where to write the tree. this document will be used as * the parent of all top level documents passed as input. Note * that you may have */ public DocumentModelUpdater(CoreSession session, String parentPath) { super(session, parentPath); } public DocumentModelUpdater(CoreSession session, String parentPath, int saveInterval) { super(session, parentPath, saveInterval); } @SuppressWarnings({"ThrowableInstanceNeverThrown"}) @Override public DocumentTranslationMap write(ExportedDocument xdoc) throws IOException { if (xdoc.getDocument() == null) { // not a valid doc -> this may be a regular folder for example the // root of the tree return null; } DocumentModel doc = null; String id = xdoc.getId(); try { doc = session.getDocument(new IdRef(id)); } catch (Exception e) { log.error("Cannot update document. No such document: " + id); return null; } try { doc = updateDocument(xdoc, doc); DocumentLocation source = xdoc.getSourceLocation(); DocumentTranslationMap map = new DocumentTranslationMapImpl( source.getServerName(), doc.getRepositoryName()); map.put(source.getDocRef(), doc.getRef()); return map; } catch (ClientException e) { IOException ioe = new IOException( "Failed to import document in repository: " + e.getMessage()); ioe.setStackTrace(e.getStackTrace()); log.error(e); return null; } } }