Author: indika
Date: Mon Feb 16 10:44:46 2009
New Revision: 744887
URL: http://svn.apache.org/viewvc?rev=744887&view=rev
Log:
fix for SYNAPSE-503
Modified:
synapse/trunk/java/modules/extensions/src/main/java/org/apache/synapse/mediators/xquery/XQueryMediator.java
Modified:
synapse/trunk/java/modules/extensions/src/main/java/org/apache/synapse/mediators/xquery/XQueryMediator.java
URL:
http://svn.apache.org/viewvc/synapse/trunk/java/modules/extensions/src/main/java/org/apache/synapse/mediators/xquery/XQueryMediator.java?rev=744887&r1=744886&r2=744887&view=diff
==============================================================================
---
synapse/trunk/java/modules/extensions/src/main/java/org/apache/synapse/mediators/xquery/XQueryMediator.java
(original)
+++
synapse/trunk/java/modules/extensions/src/main/java/org/apache/synapse/mediators/xquery/XQueryMediator.java
Mon Feb 16 10:44:46 2009
@@ -41,6 +41,7 @@
import javax.xml.namespace.QName;
import javax.xml.stream.XMLInputFactory;
import javax.xml.stream.XMLStreamException;
+import javax.xml.stream.XMLStreamReader;
import javax.xml.transform.dom.DOMSource;
import javax.activation.DataHandler;
import java.io.StringReader;
@@ -539,54 +540,15 @@
break;
}
case (XQItemType.XQITEMKIND_DOCUMENT): {
- if (value instanceof OMNode) {
- if (useDOMSource) {
- xqDynamicContext.
- bindObject(name,
- new DOMSource(((Element)
ElementHelper.
-
importOMElement((OMElement) value,
-
DOOMAbstractFactory.getOMFactory())).
- getOwnerDocument()),
null);
- } else {
- xqDynamicContext.bindDocument(name,
- new
InputSource(SynapseConfigUtils.getInputStream(
- value)));
- }
- }
+ bindOMNode(name, value, xqDynamicContext);
break;
}
case (XQItemType.XQITEMKIND_ELEMENT): {
- if (value instanceof OMNode) {
- if (useDOMSource) {
- xqDynamicContext.
- bindObject(name,
- new DOMSource(((Element)
ElementHelper.
-
importOMElement((OMElement) value,
-
DOOMAbstractFactory.getOMFactory())).
- getOwnerDocument()),
null);
- } else {
- xqDynamicContext.bindDocument(name,
- new InputSource(
-
SynapseConfigUtils.getInputStream(value)));
- }
- }
+ bindOMNode(name, value, xqDynamicContext);
break;
}
case (XQItemType.XQITEMKIND_DOCUMENT_ELEMENT): {
- if (value instanceof OMNode) {
- if (useDOMSource) {
- xqDynamicContext.
- bindObject(name,
- new DOMSource(((Element)
ElementHelper.
-
importOMElement((OMElement) value,
-
DOOMAbstractFactory.getOMFactory())).
- getOwnerDocument()),
null);
- } else {
- xqDynamicContext.bindDocument(name,
- new
InputSource(SynapseConfigUtils.getInputStream(
- value)));
- }
- }
+ bindOMNode(name, value, xqDynamicContext);
break;
}
default: {
@@ -600,6 +562,43 @@
}
+ private void bindOMNode(QName name, Object value, XQDynamicContext
xqDynamicContext) throws XQException {
+
+ OMElement varibleValue = null;
+ if (value instanceof String) {
+ varibleValue = createOMElement((String) value);
+ } else if (value instanceof OMElement) {
+ varibleValue = (OMElement) value;
+ }
+
+ if (varibleValue != null) {
+ if (useDOMSource) {
+ xqDynamicContext.
+ bindObject(name,
+ new DOMSource(((Element) ElementHelper.
+ importOMElement(varibleValue,
+
DOOMAbstractFactory.getOMFactory())).
+ getOwnerDocument()), null);
+ } else {
+ xqDynamicContext.bindDocument(name,
+ new InputSource(SynapseConfigUtils.getInputStream(
+ varibleValue)));
+ }
+ }
+ }
+
+ private OMElement createOMElement(String xml) {
+ try {
+ XMLStreamReader reader =
XMLInputFactory.newInstance().createXMLStreamReader(
+ new StringReader(xml));
+ StAXOMBuilder builder = new StAXOMBuilder(reader);
+ return builder.getDocumentElement();
+ } catch (XMLStreamException e) {
+ handleException("Malform XML : " + xml);
+ }
+ return null;
+ }
+
private void handleException(String msg, Exception e) {
log.error(msg, e);
throw new SynapseException(msg, e);