net.padaf.preflight.actions.HideAction.java Source code

Java tutorial

Introduction

Here is the source code for net.padaf.preflight.actions.HideAction.java

Source

/*******************************************************************************
 * Copyright 2010 Atos Worldline SAS
 * 
 * Licensed by Atos Worldline SAS under one or more
 * contributor license agreements.  See the NOTICE file distributed with
 * this work for additional information regarding copyright ownership.
 * Atos Worldline SAS licenses this file to You 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.
 ******************************************************************************/
/**
 * 
 */
package net.padaf.preflight.actions;

import static net.padaf.preflight.ValidationConstants.ACTION_DICTIONARY_KEY_H;
import static net.padaf.preflight.ValidationConstants.ACTION_DICTIONARY_KEY_T;
import static net.padaf.preflight.ValidationConstants.ERROR_ACTION_HIDE_H_INVALID;
import static net.padaf.preflight.ValidationConstants.ERROR_ACTION_INVALID_TYPE;
import static net.padaf.preflight.ValidationConstants.ERROR_ACTION_MISING_KEY;

import java.util.List;

import net.padaf.preflight.ValidationResult.ValidationError;
import net.padaf.preflight.utils.COSUtils;

import org.apache.pdfbox.cos.COSBase;
import org.apache.pdfbox.cos.COSDictionary;
import org.apache.pdfbox.cos.COSDocument;
import org.apache.pdfbox.cos.COSName;

/**
 * ActionManager for the Hide action. The Hide action isn't specifically
 * prohibited by PDF/A-1, but should have been. So this action manager isn't an
 * instance of InvalidAction but authorized only the H entry with the false
 * value.
 */
public class HideAction extends AbstractActionManager {

    /**
     * @param amFact
     *          Instance of ActionManagerFactory used to create ActionManager to
     *          check Next actions.
     * @param adict
     *          the COSDictionary of the action wrapped by this class.
     * @param cDoc
     *          the COSDocument from which the action comes from.
     * @param aaKey
     *          The name of the key which identify the action in a additional
     *          action dictionary.
     */
    public HideAction(ActionManagerFactory amFact, COSDictionary adict, COSDocument doc, String aaKey) {
        super(amFact, adict, doc, aaKey);
    }

    /*
     * (non-Javadoc)
     * 
     * @see
     * net.awl.edoc.pdfa.validation.actions.AbstractActionManager#valid(java.util
     * .List)
     */
    @Override
    protected boolean innerValid(List<ValidationError> error) {
        COSBase t = this.actionDictionnary.getItem(COSName.getPDFName(ACTION_DICTIONARY_KEY_T));
        // ---- T entry is mandatory
        if (t == null) {
            error.add(new ValidationError(ERROR_ACTION_MISING_KEY, "T entry is mandatory for the NamedActions"));
            return false;
        }

        if (!(COSUtils.isDictionary(t, cDoc) || COSUtils.isArray(t, cDoc) || COSUtils.isString(t, cDoc))) {
            error.add(new ValidationError(ERROR_ACTION_INVALID_TYPE, "T entry type is invalid"));
            return false;
        }

        /*
         * ---- H entry is optional but the default value is True (annotations of
         * the T entry will be hidden) according to the aim of a PDF/A it should be
         * false (annotations of the T entry will be shown).
         * 
         * We check the H value and we throw an error if it is true because of the
         * PDF/A Application Notes sentence :
         * 
         * The PDF Reference supports a concept whereby something will happen when
         * the user performs an explicit or implicit action in a PDF viewer - these
         * "things" are called Actions. PDF/A-1 permits a limited set of these
         * Actions, which are detailed in section 6.6.1. Specifically, any action
         * that could change the visual representation of the document or is not
         * documented in the PDF Reference is not permitted. This includes the /Hide
         * action which isn't specifically prohibited by PDF/A-1, but should have
         * been.
         */
        boolean h = this.actionDictionnary.getBoolean(COSName.getPDFName(ACTION_DICTIONARY_KEY_H), true);
        if (h) {
            error.add(new ValidationError(ERROR_ACTION_HIDE_H_INVALID, "H entry is \"true\""));
            return false;
        }

        return true;
    }
}