2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights reserved.
6 * ================================================================================
7 * Licensed under the Apache License, Version 2.0 (the "License");
8 * you may not use this file except in compliance with the License.
9 * You may obtain a copy of the License at
11 * http://www.apache.org/licenses/LICENSE-2.0
13 * Unless required by applicable law or agreed to in writing, software
14 * distributed under the License is distributed on an "AS IS" BASIS,
15 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
16 * See the License for the specific language governing permissions and
17 * limitations under the License.
18 * ============LICENSE_END=========================================================
21 package org.onap.so.adapters.sdnc.impl;
24 import java.io.StringWriter;
26 import javax.xml.XMLConstants;
27 import javax.xml.parsers.DocumentBuilder;
28 import javax.xml.parsers.DocumentBuilderFactory;
29 import javax.xml.transform.Transformer;
30 import javax.xml.transform.TransformerFactory;
31 import javax.xml.transform.dom.DOMSource;
32 import javax.xml.transform.stream.StreamResult;
34 import org.onap.so.logger.MessageEnum;
35 import org.onap.so.logger.MsoLogger;
36 import org.w3c.dom.Document;
37 import org.w3c.dom.Element;
38 import org.w3c.dom.Node;
39 import org.w3c.dom.NodeList;
42 private static MsoLogger msoLogger = MsoLogger.getMsoLogger(MsoLogger.Catalog.RA, Utils.class);
47 public static String genSdncReq(Document reqDoc, RequestTunables rt) {
50 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
51 DocumentBuilder db = dbf.newDocumentBuilder();
55 Document newdoc = db.newDocument();
56 Element root = newdoc.createElementNS(rt.getNamespace(), "input");
57 newdoc.appendChild(root);
60 Element hdr = newdoc.createElement(rt.getHeaderName());
61 root.appendChild(hdr);
63 String elemData = rt.getReqId();
65 if (elemData != null && elemData.length() > 0)
67 hdrChild = newdoc.createElement("svc-request-id");
68 hdrChild.appendChild(newdoc.createTextNode(elemData));
69 hdr.appendChild(hdrChild);
72 elemData = rt.getAction();
73 if (elemData != null && elemData.length() > 0)
75 hdrChild = newdoc.createElement("svc-action");
76 hdrChild.appendChild(newdoc.createTextNode(elemData));
77 hdr.appendChild(hdrChild);
80 elemData = rt.getSdncaNotificationUrl();
81 if (elemData != null && elemData.length() > 0)
83 hdrChild = newdoc.createElement("svc-notification-url");
84 hdrChild.appendChild(newdoc.createTextNode(elemData));
85 hdr.appendChild(hdrChild);
89 NodeList nodes = reqDoc.getDocumentElement().getChildNodes();
90 for (int i = 0; i < nodes.getLength(); i++) {
91 Node n = nodes.item(i);
92 Node newNode = newdoc.importNode(n, true);
93 root.appendChild(newNode);
96 String s = domToStr(newdoc);
97 msoLogger.debug("Formatted SdncReq:\n" + s);
100 } catch (Exception e) {
101 msoLogger.error(MessageEnum.RA_ERROR_CREATE_SDNC_REQUEST, "SDNC", "", MsoLogger.ErrorCode.BusinessProcesssError, "Exception in genSdncReq", e);
106 public static String genSdncPutReq(Document reqDoc, RequestTunables rt) {
109 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
110 DocumentBuilder db = dbf.newDocumentBuilder();
114 Document newdoc = db.newDocument();
117 NodeList nodes = reqDoc.getDocumentElement().getChildNodes();
119 Element root = newdoc.createElementNS(nodes.item(0).getNamespaceURI(), nodes.item(0).getNodeName());
120 newdoc.appendChild(root);
122 NodeList childNodes = nodes.item(0).getChildNodes();
123 for (int i = 0; i < childNodes.getLength(); i++) {
124 Node n = childNodes.item(i);
125 Node newNode = newdoc.importNode(n, true);
126 root.appendChild(newNode);
129 String s = domToStr(newdoc);
130 msoLogger.debug("Formatted SdncPutReq:\n" + s);
133 } catch (Exception e) {
134 msoLogger.error(MessageEnum.RA_ERROR_CREATE_SDNC_REQUEST, "SDNC", "", MsoLogger.ErrorCode.DataError, "Exception in genSdncPutReq", e);
139 public static String genMsoFailResp(SDNCResponse resp) {
142 DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
143 DocumentBuilder db = dbf.newDocumentBuilder();
147 Document newdoc = db.newDocument();
148 Element root = newdoc.createElement("output");
149 newdoc.appendChild(root);
151 Element elem1 = newdoc.createElement("svc-request-id");
152 elem1.appendChild(newdoc.createTextNode(resp.getReqId()));
153 root.appendChild(elem1);
155 Element elem2 = newdoc.createElement("response-code");
156 elem2.appendChild(newdoc.createTextNode(String.valueOf(resp.getRespCode())));
157 root.appendChild(elem2);
159 Element elem3 = newdoc.createElement("response-message");
160 elem3.appendChild(newdoc.createTextNode(String.valueOf(resp.getRespMsg())));
161 root.appendChild(elem3);
163 String s = domToStr(newdoc);
164 msoLogger.debug("Formatted SdncReq:" + s);
167 } catch (Exception e) {
168 msoLogger.error(MessageEnum.RA_ERROR_CREATE_SDNC_RESPONSE, "SDNC", "", MsoLogger.ErrorCode.DataError, "Exception in genMsoFailResp", e);
174 public static String domToStr(Document doc)
179 DOMSource ds = new DOMSource(doc);
180 StringWriter sw = new StringWriter();
181 StreamResult sr = new StreamResult(sw);
182 TransformerFactory tf = TransformerFactory.newInstance();
183 tf.setAttribute(XMLConstants.ACCESS_EXTERNAL_DTD, "");
184 tf.setAttribute(XMLConstants.ACCESS_EXTERNAL_STYLESHEET, "");
185 Transformer t = tf.newTransformer();
186 //t.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");//<?xml version="1.0" encoding="UTF-8"?>
188 String s = sw.toString();
190 // This is an awful fix for now but we don't want that xmlns="" to be generated
191 s = s.replaceAll("xmlns=\"\"", "");
193 } catch (Exception e) {
194 msoLogger.error(MessageEnum.RA_ERROR_CONVERT_XML2STR, "", "", MsoLogger.ErrorCode.DataError, "Exception - domToStr", e);