/* * Copyright 2008 Federal Chancellery Austria and * Graz University of Technology * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package at.gv.egiz.bku.slcommands.impl; import java.util.ArrayList; import java.util.Collections; import javax.xml.bind.JAXBElement; import javax.xml.bind.JAXBException; import javax.xml.bind.Marshaller; import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.ParserConfigurationException; import javax.xml.transform.Result; import javax.xml.transform.Templates; import javax.xml.transform.dom.DOMResult; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.w3c.dom.Document; import org.w3c.dom.Node; import org.w3c.dom.NodeList; import at.buergerkarte.namespaces.securitylayer._1.Base64XMLContentType; import at.buergerkarte.namespaces.securitylayer._1.InfoboxReadResponseType; import at.buergerkarte.namespaces.securitylayer._1.ObjectFactory; import at.buergerkarte.namespaces.securitylayer._1.XMLContentType; import at.gv.egiz.bku.slcommands.InfoboxReadResult; import at.gv.egiz.bku.slcommands.SLCommand; import at.gv.egiz.bku.slcommands.SLMarshallerFactory; import at.gv.egiz.bku.slexceptions.SLRuntimeException; /** * This class implements the result of the security layer command InfoboxReadRequest. * * @author mcentner */ public class InfoboxReadResultFileImpl extends SLResultImpl implements InfoboxReadResult { /** * Logging facility. */ protected final Logger log = LoggerFactory.getLogger(InfoboxReadResultFileImpl.class); /** * The XML document containing the infobox content. */ protected Document xmlDocument; /** * Binary content of the infobox (may be null). */ protected byte[] binaryContent; /** * Creates the response document from the given binaryContent. * * @param binaryContent the infobox content * @param preserveSpace the value of the preserveSpace parameter * * @return the created response document */ private Document createResponseDocument(byte[] binaryContent, boolean preserveSpace) { DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance(); Document doc; try { doc = dbf.newDocumentBuilder().newDocument(); } catch (ParserConfigurationException e) { // it should always be possible to create a new Document log.error("Failed to create XML document.", e); throw new SLRuntimeException(e); } ObjectFactory factory = new ObjectFactory(); Base64XMLContentType base64XMLContentType = factory.createBase64XMLContentType(); if (binaryContent == null) { XMLContentType xmlContentType = factory.createXMLContentType(); if (preserveSpace) { xmlContentType.setSpace("preserve"); } base64XMLContentType.setXMLContent(xmlContentType); } else { base64XMLContentType.setBase64Content(binaryContent); } InfoboxReadResponseType infoboxReadResponseType = factory.createInfoboxReadResponseType(); infoboxReadResponseType.setBinaryFileData(base64XMLContentType); JAXBElement infoboxReadResponse = factory.createInfoboxReadResponse(infoboxReadResponseType); Marshaller marshaller = SLMarshallerFactory.getInstance().createMarshaller(false); try { marshaller.marshal(infoboxReadResponse, doc); } catch (JAXBException e) { log.error("Failed to marshal 'InfoboxReadResponse' document.", e); throw new SLRuntimeException(e); } return doc; } /** * @return an XMLResult for marshalling the infobox to */ public Result getXmlResult(boolean preserveSpace) { xmlDocument = createResponseDocument(null, preserveSpace); NodeList nodeList = xmlDocument.getElementsByTagNameNS(SLCommand.NAMESPACE_URI, "XMLContent"); return new DOMResult(nodeList.item(0)); } /** * Creates a new InfoboxReadResponse document and appends * the given node as child node of the XMLContent element. * * @param node the node to be appended as child node of the XMLContnet element * @param preserveSpace if true the value of the XMLContent's space * attribute is set to preserve. */ public void setResultXMLContent(Node node, boolean preserveSpace) { xmlDocument = createResponseDocument(null, preserveSpace); NodeList nodeList = xmlDocument.getElementsByTagNameNS(SLCommand.NAMESPACE_URI, "XMLContent"); if (node.getOwnerDocument() != xmlDocument) { node = xmlDocument.importNode(node, true); } nodeList.item(0).appendChild(node); } /** * Creates a new result document for this InfoboxReadResult * and sets the given resultBytes as content. * * @param resultBytes */ public void setResultBytes(byte[] resultBytes) { this.binaryContent = resultBytes; } @Override public void writeTo(Result result, Templates templates, boolean fragment) { if (xmlDocument == null) { xmlDocument = createResponseDocument(binaryContent, false); } writeTo(xmlDocument, result, templates, fragment); } @Override public Object getContent() { if (xmlDocument != null) { NodeList nodes = xmlDocument.getElementsByTagNameNS(SLCommand.NAMESPACE_URI, "XMLContent"); if (nodes.getLength() > 0) { NodeList children = nodes.item(0).getChildNodes(); ArrayList content = new ArrayList(); for (int i = 0; i < children.getLength(); i++) { content.add(children.item(i)); } return Collections.unmodifiableList(content); } else { return null; } } else { return binaryContent; } } }