aboutsummaryrefslogtreecommitdiff
path: root/pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java
diff options
context:
space:
mode:
authorAndreas Fitzek <andreas.fitzek@iaik.tugraz.at>2014-12-01 12:23:47 +0100
committerAndreas Fitzek <andreas.fitzek@iaik.tugraz.at>2014-12-02 10:09:35 +0100
commite929b5f4c6d9351b29150e6c1843f06806ee7b00 (patch)
treec6ecc4e5f6c3da6ef381a3d852c0a2211ca060e2 /pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java
parent6398c85d80213f316dd0f9e4be10e34b54b1f5f9 (diff)
downloadpdf-as-4-e929b5f4c6d9351b29150e6c1843f06806ee7b00.tar.gz
pdf-as-4-e929b5f4c6d9351b29150e6c1843f06806ee7b00.tar.bz2
pdf-as-4-e929b5f4c6d9351b29150e6c1843f06806ee7b00.zip
added status servlet to pdf-as-web
Diffstat (limited to 'pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java')
-rw-r--r--pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java87
1 files changed, 87 insertions, 0 deletions
diff --git a/pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java b/pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java
new file mode 100644
index 00000000..f26c0885
--- /dev/null
+++ b/pdf-as-web-status/src/main/java/at/gv/egiz/status/content/JsonGenerator.java
@@ -0,0 +1,87 @@
+package at.gv.egiz.status.content;
+
+import java.io.IOException;
+import java.util.Iterator;
+import java.util.Map;
+import java.util.Map.Entry;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+
+import org.apache.commons.lang3.StringEscapeUtils;
+
+import at.gv.egiz.status.TestResult;
+import at.gv.egiz.status.TestStatus;
+import at.gv.egiz.status.impl.TestStatusString;
+
+public class JsonGenerator implements ContentGenerator {
+
+ @Override
+ public void generate(HttpServletRequest request,
+ HttpServletResponse response, Map<String, TestResult> results,
+ boolean details) throws IOException {
+ boolean allOk = true;
+
+ Iterator<TestResult> testIterator = results.values().iterator();
+ while(testIterator.hasNext()) {
+ TestResult result = testIterator.next();
+ if(!result.getStatus().equals(TestStatus.OK)){
+ allOk = false;
+ break;
+ }
+ }
+
+ if(!allOk) {
+ response.setStatus(HttpServletResponse.SC_INTERNAL_SERVER_ERROR);
+ } else {
+ response.setStatus(HttpServletResponse.SC_OK);
+ }
+
+ response.setContentType("application/json");
+
+ StringBuilder sb = new StringBuilder();
+
+ sb.append("{");
+
+ Iterator<Entry<String,TestResult>> testResultIterator = results.entrySet().iterator();
+ while(testResultIterator.hasNext()) {
+ Entry<String,TestResult> entry = testResultIterator.next();
+ TestResult result = entry.getValue();
+ String testName = entry.getKey();
+
+ sb.append("\"");
+ sb.append(StringEscapeUtils.escapeJson(testName));
+ sb.append("\": {\"Status\": \"");
+ sb.append(StringEscapeUtils.escapeJson(TestStatusString.getString(result.getStatus())));
+ sb.append("\"");
+
+ if(details) {
+ sb.append(", \"Detail\": \"");
+
+ StringBuilder detail = new StringBuilder();
+
+ Iterator<String> detailStringIt = result.getDetails().iterator();
+
+ while(detailStringIt.hasNext()) {
+ String detailString = detailStringIt.next();
+ detail.append(StringEscapeUtils.escapeJson(detailString));
+ detail.append(" ");
+ }
+
+ sb.append(detail.toString());
+ sb.append("\"");
+ }
+
+ sb.append("}");
+ if(testResultIterator.hasNext()) {
+ sb.append(", ");
+ }
+ }
+
+ sb.append("}");
+
+ response.getOutputStream().write(sb.toString().getBytes("UTF-8"));
+ response.getOutputStream().close();
+ }
+
+}