X-Git-Url: http://wamblee.org/gitweb/?a=blobdiff_plain;f=impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fxmlrouter%2Fimpl%2FRobustTransformation.java;fp=impl%2Fsrc%2Fmain%2Fjava%2Forg%2Fwamblee%2Fxmlrouter%2Fimpl%2FRobustTransformation.java;h=fb028aed98100066fae78e4b885ce4a3b7313c84;hb=f7f3bbbc63a9e177f56064d821dc5f502dee378e;hp=0000000000000000000000000000000000000000;hpb=9dbda773fb0f33b7022a044f0e4cbc0e64f1929e;p=xmlrouter diff --git a/impl/src/main/java/org/wamblee/xmlrouter/impl/RobustTransformation.java b/impl/src/main/java/org/wamblee/xmlrouter/impl/RobustTransformation.java new file mode 100644 index 0000000..fb028ae --- /dev/null +++ b/impl/src/main/java/org/wamblee/xmlrouter/impl/RobustTransformation.java @@ -0,0 +1,94 @@ +package org.wamblee.xmlrouter.impl; + +import java.util.logging.Level; +import java.util.logging.Logger; + +import javax.xml.transform.dom.DOMSource; + +import org.wamblee.xml.XMLDocument; +import org.wamblee.xmlrouter.common.Id; +import org.wamblee.xmlrouter.config.Transformation; + +public class RobustTransformation implements Transformation { + + private static final Logger LOGGER = Logger + .getLogger(RobustTransformation.class.getName()); + + private Id id; + private Transformation transformation; + + public RobustTransformation(Id aId, + Transformation aTransformation) { + id = aId; + transformation = aTransformation; + } + + @Override + public String getFromType() { + try { + String from = transformation.getFromType(); + if (from == null) { + logTypeReturnedNull("from"); + return Constants.UNKNOWN_DOCUMENT_TYPE.toString(); + } + return from; + } catch (Exception e) { + logTypeThrewException("from", e); + return Constants.UNKNOWN_DOCUMENT_TYPE.toString(); + } + } + + @Override + public String getToType() { + try { + String to = transformation.getToType(); + if (to == null) { + logTypeReturnedNull("to"); + return Constants.UNKNOWN_DOCUMENT_TYPE.toString(); + } + return to; + } catch (Exception e) { + logTypeThrewException("to", e); + return Constants.UNKNOWN_DOCUMENT_TYPE.toString(); + } + } + + @Override + public DOMSource transform(DOMSource aDocument) { + try { + DOMSource res = transformation.transform(aDocument); + if (res == null) { + logTransformationReturnedNull(aDocument); + return null; + } + return res; + } catch (Exception e) { + logTranformationThrewException(aDocument, e); + return null; + } + } + + private void logTypeThrewException(String aFromTo, Exception aE) { + LOGGER.log(Level.WARNING, "get" + aFromTo + + " threw exception, returning default value " + + Constants.UNKNOWN_DOCUMENT_TYPE, aE); + } + + private void logTypeReturnedNull(String aFromTo) { + LOGGER.log(Level.WARNING, "get" + aFromTo + + " returned null, returning default value " + + Constants.UNKNOWN_DOCUMENT_TYPE); + } + + private void logTranformationThrewException(DOMSource aEvent, Exception aE) { + LOGGER.log(Level.WARNING, + "transformation " + id + " threw exception for event " + + new XMLDocument(aEvent).print(true), aE); + } + + private void logTransformationReturnedNull(DOMSource aEvent) { + LOGGER.log(Level.WARNING, "transformation " + id + + " returned null for event " + new XMLDocument(aEvent).print(true)); + } + +}