/* * Copyright 2015 by Edi Weissmann (edi.weissmann@gmail.com) * * This file is part of the Sejda source code * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Affero General Public License as * published by the Free Software Foundation, either version 3 of the * License, or (at your option) any later version. * * This program 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 General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ package org.sejda.impl.sambox; import static org.sejda.common.ComponentsUtility.nullSafeCloseQuietly; import static org.sejda.core.notification.dsl.ApplicationEventsNotifier.notifyEvent; import static org.sejda.core.support.io.IOUtils.createTemporaryBuffer; import java.io.File; import java.util.Map.Entry; import org.sejda.core.support.io.OutputWriters; import org.sejda.core.support.io.SingleOutputWriter; import org.sejda.impl.sambox.component.DefaultPdfSourceOpener; import org.sejda.impl.sambox.component.PDDocumentHandler; import org.sejda.model.exception.TaskException; import org.sejda.model.input.PdfSource; import org.sejda.model.input.PdfSourceOpener; import org.sejda.model.parameter.SetMetadataParameters; import org.sejda.model.pdf.PdfMetadataKey; import org.sejda.model.task.BaseTask; import org.sejda.model.task.TaskExecutionContext; import org.sejda.sambox.pdmodel.PDDocumentInformation; import org.slf4j.Logger; import org.slf4j.LoggerFactory; /** * SAMBox implementation of a task setting metadata on an input {@link PdfSource}. * * @author Eduard Weissmann * */ public class SetMetadataTask extends BaseTask<SetMetadataParameters> { private static final Logger LOG = LoggerFactory.getLogger(SetMetadataTask.class); private PDDocumentHandler documentHandler = null; private SingleOutputWriter outputWriter; private PdfSourceOpener<PDDocumentHandler> documentLoader; @Override public void before(SetMetadataParameters parameters, TaskExecutionContext executionContext) throws TaskException { super.before(parameters, executionContext); documentLoader = new DefaultPdfSourceOpener(); outputWriter = OutputWriters.newSingleOutputWriter(parameters.getExistingOutputPolicy(), executionContext); } @Override public void execute(SetMetadataParameters parameters) throws TaskException { executionContext().assertTaskNotCancelled(); notifyEvent(executionContext().notifiableTaskMetadata()).progressUndetermined(); PdfSource<?> source = parameters.getSource(); LOG.debug("Opening {}", source); documentHandler = source.open(documentLoader); documentHandler.setCreatorOnPDDocument(); File tmpFile = createTemporaryBuffer(parameters.getOutput()); outputWriter.taskOutput(tmpFile); LOG.debug("Temporary output set to {}", tmpFile); LOG.debug("Setting metadata on temporary document."); PDDocumentInformation actualMeta = documentHandler.getUnderlyingPDDocument().getDocumentInformation(); for (Entry<PdfMetadataKey, String> meta : parameters.entrySet()) { LOG.trace("'{}' -> '{}'", meta.getKey().getKey(), meta.getValue()); actualMeta.setCustomMetadataValue(meta.getKey().getKey(), meta.getValue()); } documentHandler.setVersionOnPDDocument(parameters.getVersion()); documentHandler.setCompress(parameters.isCompress()); documentHandler.savePDDocument(tmpFile); nullSafeCloseQuietly(documentHandler); parameters.getOutput().accept(outputWriter); LOG.debug("Metadata set on {}", parameters.getOutput()); } @Override public void after() { nullSafeCloseQuietly(documentHandler); } }