One way of doing this is to use the standard Java transform and use the standard javax.xml.transform API to perform the transformation.
To do this add a Java Transform to your flow
data:image/s3,"s3://crabby-images/92e82/92e82ec2b4758422cf038a5a351b1133ad846212" alt="enter image description here"
In the Import Packages pane, import the required java packages
data:image/s3,"s3://crabby-images/7c5f1/7c5f184df3a0d0f64eabb885228f13c7a40d25b0" alt="enter image description here"
import java.io.*;
import javax.xml.transform.*;
import javax.xml.transform.stream.*;
In the Helper Code pane we construct a transformer object. As I understand non static fields are created per instance, so there should be no concurrency issues. (comments?)
data:image/s3,"s3://crabby-images/06fb3/06fb320b976f21ba1af58448bf5807c59d279364" alt="enter image description here"
private final Transformer transformer = getNewTransformer();
public Transformer getNewTransformer()
{
// /opt/informatica/infadev/DataTransformation
final String IFCMPath = System.getenv("IFCONTENTMASTER_HOME");
final String xslt = IFCMPath + "/ServiceDB/xst/mytransform.xslt";
logInfo("Using XSLT File" + xslt);
try{
return TransformerFactory.newInstance().newTransformer(new StreamSource(xslt));
} catch(TransformerConfigurationException ex) {
logError("Could not create TransformerFactory with xslt " + xslt );
}
return null;
}
Finally we execute the transform on the incoming xml document by executing the transform method on the transformer object.
data:image/s3,"s3://crabby-images/9edd9/9edd9644f35457ace70a6b320f035c80624bac8d" alt="enter image description here"
if( transformer == null ) {
failSession("Transformer was null");
}
//final long startTime = System.nanoTime();
//final long endTime;
try {
//logInfo("Recieved xml with size " + xmlin.length() );
// logInfo("Recieved xml " + xmlin );
final StringReader reader = new StringReader(xmlin);
final StringWriter writer = new StringWriter();
transformer.transform(new StreamSource(reader),new StreamResult(writer));
xmlout = writer.toString();
// logInfo("xmlout " + xmlout );
} catch (Exception e) {
incrementErrorCount(1);
logError(e.getMessage());
logError(xmlin);
}
//finally {
// endTime = System.nanoTime();
//}
//final long duration = endTime - startTime;
//logInfo("Duration " + duration / **********.0 );