All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.purl.sword.base.BasicContentElement Maven / Gradle / Ivy

The newest version!
/**
 * The contents of this file are subject to the license and copyright
 * detailed in the LICENSE and NOTICE files at the root of the source
 * tree and available online at
 *
 * http://www.dspace.org/license/
 */
package org.purl.sword.base;

import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

import nu.xom.Element;
import org.apache.logging.log4j.Logger;

/**
 * Represents a text construct in the ATOM elements. This is a superclass of
 * several elements within this implementation.
 *
 * @author Neil Taylor
 */
public abstract class BasicContentElement extends XmlElement
    implements SwordElementInterface {
    /**
     * The log.
     */
    private static Logger log = org.apache.logging.log4j.LogManager.getLogger(BasicContentElement.class);

    public BasicContentElement(String prefix, String name, String namespaceUri) {
        super(prefix, name, namespaceUri);
    }

    public BasicContentElement(XmlName name) {
        super(name);
    }

    /**
     * Marshal the data in this object to an Element object.
     *
     * @return The data expressed in an Element.
     */
    public Element marshall() {
        Element element = new Element(getQualifiedName(), xmlName.getNamespace());
        marshallContent(element);
        return element;
    }

    protected abstract void marshallContent(Element element);

    /**
     * Unmarshal the text element into this object.
     *
     * This unmarshaller only handles plain text content, although it can
     * recognise the three different type elements of text, html and xhtml. This
     * is an area that can be improved in a future implementation, if necessary.
     *
     * @param element              The text element.
     * @param validationProperties FIXME: PLEASE DOCUMENT.
     * @return object representing the text element
     * @throws UnmarshallException If the specified element is not of
     *                             the correct type, where the localname is used
     *                             to specify the valid name. Also thrown
     *                             if there is an issue accessing the data.
     */
    public SwordValidationInfo unmarshall(Element element, Properties validationProperties)
        throws UnmarshallException {
        if (!isInstanceOf(element, xmlName)) {
            return handleIncorrectElement(element, validationProperties);
        }

        ArrayList validationItems = new ArrayList();
        ArrayList attributeItems = new ArrayList();

        try {
            processUnexpectedAttributes(element, attributeItems);

            int length = element.getChildCount();
            if (length > 0) {
                try {
                    unmarshallContent(element);
                } catch (UnmarshallException ume) {
                    log.error("Error accessing the content of the " + xmlName.getQualifiedName() + "  element");
                    if (validationProperties == null) {
                        throw ume;
                    } else {
                        SwordValidationInfo info = new SwordValidationInfo(xmlName,
                                                                           SwordValidationInfo.ERROR_WITH_CONTENT,
                                                                           SwordValidationInfoType.ERROR);
                        info.setContentDescription(element.getValue());
                        validationItems.add(info);
                    }
                }
            }

        } catch (Exception ex) {
            log.error("Unable to parse an element in " + getQualifiedName() + ": " + ex.getMessage());
            if (validationProperties == null) {
                throw new UnmarshallException("Unable to parse an element in " + getQualifiedName(), ex);
            }
        }

        SwordValidationInfo result = null;
        if (validationProperties != null) {
            result = validate(validationItems, attributeItems, validationProperties);
        }
        return result;
    }

    public void unmarshall(Element element)
        throws UnmarshallException {

    }

    @Override
    public SwordValidationInfo validate(Properties validationContext) {
        return validate(null, null, validationContext);
    }

    /**
     * @param existing          add results to this.
     * @param attributeItems    FIXME: PLEASE DOCUMENT.
     * @param validationContext FIXME: PLEASE DOCUMENT.
     * @return SWORD validation info
     */
    protected SwordValidationInfo validate(List existing,
                                           List attributeItems,
                                           Properties validationContext) {
        SwordValidationInfo result = new SwordValidationInfo(xmlName);
        result.setContentDescription(getContentAsString());

        SwordValidationInfo contentResult = validateContent(validationContext);
        if (contentResult != null) {
            result.addValidationInfo(contentResult);
        }

        result.addUnmarshallValidationInfo(existing, attributeItems);
        return result;
    }


    protected abstract void unmarshallContent(Element element)
        throws UnmarshallException;


    protected abstract SwordValidationInfo validateContent(Properties validationContext);


    protected abstract String getContentAsString();

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy