62 lines
4.7 KiB
HTML
62 lines
4.7 KiB
HTML
<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"><html xmlns="http://www.w3.org/1999/xhtml" lang="de"><head><meta http-equiv="Content-Type" content="text/html;charset=UTF-8"/><link rel="stylesheet" href="../jacoco-resources/report.css" type="text/css"/><link rel="shortcut icon" href="../jacoco-resources/report.gif" type="image/gif"/><title>GetUsers.java</title><link rel="stylesheet" href="../jacoco-resources/prettify.css" type="text/css"/><script type="text/javascript" src="../jacoco-resources/prettify.js"></script></head><body onload="window['PR_TAB_WIDTH']=4;prettyPrint()"><div class="breadcrumb" id="breadcrumb"><span class="info"><a href="../jacoco-sessions.html" class="el_session">Sessions</a></span><a href="../index.html" class="el_report">backend</a> > <a href="index.source.html" class="el_package">com.workbenchclassic</a> > <span class="el_source">GetUsers.java</span></div><h1>GetUsers.java</h1><pre class="source lang-java linenums">package com.workbenchclassic;
|
|
|
|
import java.sql.SQLException;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import javax.ws.rs.Consumes;
|
|
import javax.ws.rs.POST;
|
|
import javax.ws.rs.Path;
|
|
import javax.ws.rs.Produces;
|
|
import javax.ws.rs.core.MediaType;
|
|
import javax.ws.rs.core.Response;
|
|
import org.json.JSONException;
|
|
import org.json.JSONObject;
|
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
|
import java.util.logging.Level;
|
|
import java.util.logging.Logger;
|
|
|
|
@Path("/getUsers")
|
|
<span class="nc" id="L20">public class GetUsers { // Klassenname geändert</span>
|
|
|
|
<span class="nc" id="L22"> private static final DBService DB_SERVICE = new DBService("dsMesMiiNJTA");</span>
|
|
<span class="nc" id="L23"> private static final ObjectMapper MAPPER = new ObjectMapper();</span>
|
|
<span class="nc" id="L24"> private static final Logger LOGGER = Logger.getLogger(DBService.class.getName());</span>
|
|
|
|
@POST
|
|
@Consumes(MediaType.APPLICATION_JSON)
|
|
@Produces(MediaType.APPLICATION_JSON)
|
|
public Response getUserResponse(String jsonBody) {
|
|
String station;
|
|
try {
|
|
<span class="nc" id="L32"> JSONObject json = new JSONObject(jsonBody);</span>
|
|
<span class="nc" id="L33"> station = json.getString("station");</span>
|
|
<span class="nc" id="L34"> } catch (JSONException e) {</span>
|
|
<span class="nc" id="L35"> return Response.status(Response.Status.BAD_REQUEST)</span>
|
|
<span class="nc" id="L36"> .entity("{\"error\":\"Missing or invalid 'station' parameter\"}")</span>
|
|
<span class="nc" id="L37"> .build();</span>
|
|
<span class="nc" id="L38"> }</span>
|
|
|
|
<span class="nc" id="L40"> String query = "SELECT bde_userid AS USER_ID, geschlecht AS GENDER, name AS USER_NAME, vorname AS USER_FIRSTNAME "</span>
|
|
+ "FROM bde.pers_stamm "
|
|
+ "WHERE werk_id IN (SELECT werk_id FROM bde.kast WHERE kap_nr = '" + station + "')";
|
|
<span class="nc" id="L43"> LOGGER.log(Level.INFO, "Executing SQL query: {0}", query);</span>
|
|
|
|
try {
|
|
<span class="nc" id="L46"> List<Map<String, Object>> rows = DB_SERVICE.dbConnectAndGetRows(query); // Vorbereitetes Statement nutzen</span>
|
|
//
|
|
<span class="nc" id="L48"> return Response.ok(MAPPER.writeValueAsString(rows)).build();</span>
|
|
<span class="nc" id="L49"> } catch (SQLException e) {</span>
|
|
<span class="nc" id="L50"> LOGGER.log(Level.SEVERE, "Database error", e);</span>
|
|
<span class="nc" id="L51"> return Response.status(Response.Status.INTERNAL_SERVER_ERROR)</span>
|
|
<span class="nc" id="L52"> .entity(String.format("{\"error\":\"DB error: %s\"}", e.getMessage()))</span>
|
|
<span class="nc" id="L53"> .build();</span>
|
|
<span class="nc" id="L54"> } catch (JsonProcessingException e) {</span>
|
|
<span class="nc" id="L55"> LOGGER.log(Level.SEVERE, "JSON processing error", e);</span>
|
|
<span class="nc" id="L56"> return Response.status(Response.Status.INTERNAL_SERVER_ERROR)</span>
|
|
<span class="nc" id="L57"> .entity(String.format("{\"error\":\"JSON processing error: %s\"}", e.getMessage()))</span>
|
|
<span class="nc" id="L58"> .build();</span>
|
|
}
|
|
}
|
|
}
|
|
</pre><div class="footer"><span class="right">Created with <a href="http://www.jacoco.org/jacoco">JaCoCo</a> 0.8.4.201905082037</span></div></body></html> |