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

org.javabeanstack.xml.XmlCache Maven / Gradle / Ivy

There is a newer version: 1.4.0
Show newest version
/*
* JavaBeanStack FrameWork
*
* Copyright (C) 2017 Jorge Enciso
* Email: [email protected]
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This library 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
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301  USA
*/
package org.javabeanstack.xml;

import java.io.IOException;
import java.util.Date;
import javax.xml.parsers.ParserConfigurationException;
import org.apache.log4j.Logger;
import org.xml.sax.SAXException;
import org.javabeanstack.error.ErrorManager;

/**
 * Clase que almacena un objeto DOM o texto xml con el fin de utilizarlos
 * posteriormente para no volver a procesarlos.
 *
 * @author Jorge Enciso
 * @param  es el tipo DOM clase org.jdom2.Document or org.w3c.dom.Document
 */
public class XmlCache implements IXmlCache {

    private static final Logger LOGGER = Logger.getLogger(XmlCache.class);

    private Date processTime;
    private T domObject;
    private String xmlText;
    private Long referenceTimes = 0L;
    private Date lastReference;
    private boolean compiled=false;

    public XmlCache() {
    }

    public XmlCache(T dom) {
        domObject = dom;
        processTime = new Date();
    }

    public XmlCache(String xmlText) {
        this.xmlText = xmlText;
        processTime = new Date();
    }

    public XmlCache(T dom, Date processTime) {
        this.domObject = dom;
        this.processTime = processTime;
    }

    public XmlCache(String xmlText, Date processTime) {
        this.xmlText = xmlText;
        this.processTime = processTime;
    }

    /**
     * Es la cantidad de veces que se hizo referencia a este elemento
     *
     * @return cantidad de referencias hechas a este elemento.
     */
    @Override
    public Long getReferenceTimes() {
        return referenceTimes;
    }

    /**
     * Es la ultima fecha y hora que se hizo referencia a este objeto
     *
     * @return fecha y hora de la ultima referencia
     */
    @Override
    public Date getLastReference() {
        return lastReference;
    }

    /**
     * Es la fecha y hora del procesamiento del objeto DOM.
     *
     * @return fecha y hora del procesamiento del objeto DOM.
     */
    @Override
    public Date getProcessTime() {
        return processTime;
    }

    /**
     * Asignación manual de la fecha de procesamiento del objeto DOM.
     * Normalmente se asigna en el constructor de esta clase.
     *
     * @param date fecha de procesamiento del DOM.
     */
    @Override
    public void setProcessTime(Date date) {
        this.processTime = date;
    }

    /**
     * Devuelve el objeto DOM de este elemento
     *
     * @return objeto DOM.
     */
    @Override
    public T getDom() {
        if (domObject == null) {
            try {
                DomW3cParser.loadXml(xmlText);
            } catch (IOException | ParserConfigurationException | SAXException ex) {
                ErrorManager.showError(ex, LOGGER);
            }
        }
        lastReference = new Date();
        referenceTimes++;
        return domObject;
    }

    /**
     * Devuelve el objeto DOM de este elemento.
     *
     * @param date debe ser menor a la fecha de procesamiento o de lo contrario
     * se considera el DOM invalido u obsoleto.
     * @return objeto DOM.
     */
    @Override
    public T getDom(Date date) {
        if (!isValid(date)) {
            return null;
        }
        if (domObject == null) {
            try {
                DomW3cParser.loadXml(xmlText);
            } catch (IOException | ParserConfigurationException | SAXException ex) {
                ErrorManager.showError(ex, LOGGER);
            }
        }
        lastReference = new Date();
        referenceTimes++;
        return domObject;
    }

    /**
     * Asignación manual de un objeto DOM
     *
     * @param dom objeto DOM.
     */
    @Override
    public void setDom(T dom) {
        this.domObject = dom;
        processTime = new Date();
        referenceTimes = 0L;
        lastReference = null;
        xmlText = "";
    }

    /**
     * Devuelve el texto xml si lo hubiera.
     *
     * @return texto xml
     */
    @Override
    public String getXmlText() {
        return xmlText;
    }

    /**
     * Asignación manual del texto xml
     *
     * @param xmlText texto xml
     */
    @Override
    public void setXmlText(String xmlText) {
        this.xmlText = xmlText;
        domObject = null;
        processTime = new Date();
        referenceTimes = 0L;
        lastReference = null;
    }

    /**
     * Verifica la válidez del elemento, lastModified debe ser menor a la fecha
     * de procesamiento del DOM.
     *
     * @param lastModified fecha de modificación del archivo/objeto desde donde
     * fue procesado el dom.
     * @return verdadero es válido y falso es invalido.
     */
    @Override
    public boolean isValid(Date lastModified) {
        return !getProcessTime().before(lastModified);
    }


    /**
     * Devuelve si el objeto fue procesado con sus clases derivadas.
     * 
     * @return verdadero si fue compilado, falso si no.
     */
    @Override
    public boolean isCompiled() {
        return compiled;
    }

    /**
     * Asigna verdadero si el elemento fue procesado con sus clases derivadas.
     * @param isCompiled 
     */
    @Override
    public void setCompiled(boolean isCompiled) {
        this.compiled = isCompiled;
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy