2 * ============LICENSE_START=======================================================
4 * ================================================================================
5 * Copyright (C) 2017 AT&T Intellectual Property. All rights
7 * ================================================================================
8 * Licensed under the Apache License, Version 2.0 (the "License");
9 * you may not use this file except in compliance with the License.
10 * You may obtain a copy of the License at
12 * http://www.apache.org/licenses/LICENSE-2.0
14 * Unless required by applicable law or agreed to in writing, software
15 * distributed under the License is distributed on an "AS IS" BASIS,
16 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 * See the License for the specific language governing permissions and
18 * limitations under the License.
19 * ============LICENSE_END=========================================================
22 package org.onap.ccsdk.sli.plugins.restapicall;
24 import java.util.ArrayList;
25 import java.util.HashMap;
26 import java.util.List;
29 import org.slf4j.Logger;
30 import org.slf4j.LoggerFactory;
32 public final class XmlJsonUtil {
34 private static final Logger log = LoggerFactory.getLogger(XmlJsonUtil.class);
36 private XmlJsonUtil() {
37 // Preventing instantiation of the same.
40 public static String getXml(Map<String, String> varmap, String var) {
41 boolean escape = true;
42 if (var.startsWith("'")) {
43 var = var.substring(1);
47 Object o = createStructure(varmap, var);
48 return generateXml(o, 0, escape);
51 public static String getJson(Map<String, String> varmap, String var) {
52 boolean escape = true;
53 if (var.startsWith("'")) {
54 var = var.substring(1);
58 Object o = createStructure(varmap, var);
59 return generateJson(o, escape);
62 private static Object createStructure(Map<String, String> flatmap, String var) {
63 if (flatmap.containsKey(var)) {
64 if (var.endsWith("_length") || var.endsWith("].key"))
66 return flatmap.get(var);
69 Map<String, Object> mm = new HashMap<>();
70 for (String k : flatmap.keySet())
71 if (k.startsWith(var + ".")) {
72 int i1 = k.indexOf('.', var.length() + 1);
73 int i2 = k.indexOf('[', var.length() + 1);
75 if (i1 > 0 && i1 < i3)
77 if (i2 > 0 && i2 < i3)
79 String k1 = k.substring(var.length() + 1, i3);
80 String var1 = k.substring(0, i3);
81 if (!mm.containsKey(k1)) {
82 Object str = createStructure(flatmap, var1);
83 if (str != null && (!(str instanceof String) || ((String) str).trim().length() > 0))
90 boolean arrayFound = false;
91 for (String k : flatmap.keySet())
92 if (k.startsWith(var + "[")) {
98 List<Object> ll = new ArrayList<>();
100 int length = Integer.MAX_VALUE;
101 String lengthStr = flatmap.get(var + "_length");
102 if (lengthStr != null) {
104 length = Integer.parseInt(lengthStr);
105 } catch (Exception e) {
106 log.warn("Invalid number for {}_length:{}", var, lengthStr);
110 for (int i = 0; i < length; i++) {
111 Object v = createStructure(flatmap, var + '[' + i + ']');
124 @SuppressWarnings("unchecked")
125 private static String generateXml(Object o, int indent, boolean escape) {
129 if (o instanceof String)
130 return escape ? escapeXml((String) o) : (String) o;;
132 if (o instanceof Map) {
133 StringBuilder ss = new StringBuilder();
134 Map<String, Object> mm = (Map<String, Object>) o;
135 for (String k : mm.keySet()) {
136 Object v = mm.get(k);
137 if (v instanceof String) {
138 String s = escape ? escapeXml((String) v) : (String) v;
139 ss.append(pad(indent)).append('<').append(k).append('>');
141 ss.append("</").append(k).append('>').append('\n');
142 } else if (v instanceof Map) {
143 ss.append(pad(indent)).append('<').append(k).append('>').append('\n');
144 ss.append(generateXml(v, indent + 1, escape));
145 ss.append(pad(indent)).append("</").append(k).append('>').append('\n');
146 } else if (v instanceof List) {
147 List<Object> ll = (List<Object>) v;
148 for (Object o1 : ll) {
149 ss.append(pad(indent)).append('<').append(k).append('>').append('\n');
150 ss.append(generateXml(o1, indent + 1, escape));
151 ss.append(pad(indent)).append("</").append(k).append('>').append('\n');
155 return ss.toString();
161 private static String generateJson(Object o, boolean escape) {
165 StringBuilder ss = new StringBuilder();
166 generateJson(ss, o, 0, false, escape);
167 return ss.toString();
170 @SuppressWarnings("unchecked")
171 private static void generateJson(StringBuilder ss, Object o, int indent, boolean padFirst, boolean escape) {
172 if (o instanceof String) {
173 String s = escape ? escapeJson((String) o) : (String) o;
175 ss.append(pad(indent));
176 ss.append('"').append(s).append('"');
180 if (o instanceof Map) {
181 Map<String, Object> mm = (Map<String, Object>) o;
184 ss.append(pad(indent));
187 boolean first = true;
188 for (String k : mm.keySet()) {
193 Object v = mm.get(k);
194 ss.append(pad(indent + 1)).append('"').append(k).append("\": ");
195 generateJson(ss, v, indent + 1, false, escape);
199 ss.append(pad(indent)).append('}');
204 if (o instanceof List) {
205 List<Object> ll = (List<Object>) o;
208 ss.append(pad(indent));
211 boolean first = true;
212 for (Object o1 : ll) {
217 generateJson(ss, o1, indent + 1, true, escape);
221 ss.append(pad(indent)).append(']');
225 public static String removeLastCommaJson(String s) {
226 StringBuilder sb = new StringBuilder();
229 while (k < s.length()) {
230 int i11 = s.indexOf('}', k);
231 int i12 = s.indexOf(']', k);
238 i1 = i11 < i12 ? i11 : i12;
242 int i2 = s.lastIndexOf(',', i1);
248 String between = s.substring(i2 + 1, i1);
249 if (between.trim().length() > 0) {
254 sb.append(s.substring(start, i2));
259 sb.append(s.substring(start, s.length()));
261 return sb.toString();
264 public static String removeEmptyStructJson(String s) {
266 while (k < s.length()) {
267 boolean curly = true;
268 int i11 = s.indexOf('{', k);
269 int i12 = s.indexOf('[', k);
285 int i2 = curly ? s.indexOf('}', i1) : s.indexOf(']', i1);
287 String value = s.substring(i1 + 1, i2);
288 if (value.trim().length() == 0) {
289 int i4 = s.lastIndexOf('\n', i1);
292 int i5 = s.indexOf('\n', i2);
296 s = s.substring(0, i4) + s.substring(i5);
309 public static String removeEmptyStructXml(String s) {
311 while (k < s.length()) {
312 int i1 = s.indexOf('<', k);
313 if (i1 < 0 || i1 == s.length() - 1)
316 char c1 = s.charAt(i1 + 1);
317 if (c1 == '?' || c1 == '!') {
322 int i2 = s.indexOf('>', i1);
328 String closingTag = "</" + s.substring(i1 + 1, i2 + 1);
329 int i3 = s.indexOf(closingTag, i2 + 1);
335 String value = s.substring(i2 + 1, i3);
336 if (value.trim().length() > 0) {
341 int i4 = s.lastIndexOf('\n', i1);
344 int i5 = s.indexOf('\n', i3);
348 s = s.substring(0, i4) + s.substring(i5);
355 private static String escapeXml(String v) {
356 String s = v.replaceAll("&", "&");
357 s = s.replaceAll("<", "<");
358 s = s.replaceAll("'", "'");
359 s = s.replaceAll("\"", """);
360 s = s.replaceAll(">", ">");
364 private static String escapeJson(String v) {
365 String s = v.replaceAll("\\\\", "\\\\\\\\");
366 s = s.replaceAll("\"", "\\\\\"");
370 private static String pad(int n) {
371 StringBuilder s = new StringBuilder();
372 for (int i = 0; i < n; i++)
373 s.append(Character.toString('\t'));