root / trunk / src / java / org / lidar / LogServlet.java @ 13
History | View | Annotate | Download (3.76 KB)
| 1 | 9 | andrej.cim | package org.lidar; |
|---|---|---|---|
| 2 | |||
| 3 | import com.google.gson.Gson; |
||
| 4 | import java.io.IOException; |
||
| 5 | import java.io.PrintWriter; |
||
| 6 | import java.util.ArrayList; |
||
| 7 | import javax.servlet.ServletException; |
||
| 8 | import javax.servlet.http.HttpServlet; |
||
| 9 | import javax.servlet.http.HttpServletRequest; |
||
| 10 | import javax.servlet.http.HttpServletResponse; |
||
| 11 | import org.hibernate.Query; |
||
| 12 | import org.hibernate.Session; |
||
| 13 | import org.hibernate.Transaction; |
||
| 14 | import org.lidar.HibernateUtil; |
||
| 15 | |||
| 16 | /**
|
||
| 17 | 11 | andrej.cim | * Log Servlet
|
| 18 | 9 | andrej.cim | * @author Andrej Cimpersek
|
| 19 | */
|
||
| 20 | public class LogServlet extends HttpServlet { |
||
| 21 | 11 | andrej.cim | |
| 22 | /**
|
||
| 23 | 9 | andrej.cim | * Processes requests for both HTTP <code>GET</code> and <code>POST</code> methods.
|
| 24 | * @param request servlet request
|
||
| 25 | * @param response servlet response
|
||
| 26 | * @throws ServletException if a servlet-specific error occurs
|
||
| 27 | * @throws IOException if an I/O error occurs
|
||
| 28 | */
|
||
| 29 | protected void processRequest(HttpServletRequest request, HttpServletResponse response) |
||
| 30 | 11 | andrej.cim | throws ServletException, IOException { |
| 31 | 9 | andrej.cim | response.setContentType("application/json;charset=UTF-8");
|
| 32 | PrintWriter out = response.getWriter();
|
||
| 33 | Gson gson = new Gson();
|
||
| 34 | try {
|
||
| 35 | int start = 0; |
||
| 36 | int limit = 15; |
||
| 37 | 11 | andrej.cim | if (request.getParameter("limit") != null) { |
| 38 | 9 | andrej.cim | limit = Integer.parseInt(request.getParameter("limit")); |
| 39 | } |
||
| 40 | 11 | andrej.cim | if (request.getParameter("start") != null) { |
| 41 | 9 | andrej.cim | start = Integer.parseInt(request.getParameter("start")); |
| 42 | } |
||
| 43 | |||
| 44 | Session session = HibernateUtil.getSessionFactory().getCurrentSession(); |
||
| 45 | Transaction tx = session.beginTransaction(); |
||
| 46 | |||
| 47 | // FIX: use COUNT instead
|
||
| 48 | int total = session.createQuery("from Log as log").list().size(); |
||
| 49 | Query query = session.createQuery("from Log as log order by log.date desc"); |
||
| 50 | query.setFirstResult(start); |
||
| 51 | query.setMaxResults(limit); |
||
| 52 | 11 | andrej.cim | JSONResponse resp = new JSONResponse(true, total, (ArrayList) query.list()); |
| 53 | 9 | andrej.cim | out.write(gson.toJson(resp)); |
| 54 | tx.commit(); |
||
| 55 | } catch (Exception e) { |
||
| 56 | response.setContentType("text/plain;charset=UTF-8");
|
||
| 57 | out.write(e.getMessage()); |
||
| 58 | } finally {
|
||
| 59 | out.close(); |
||
| 60 | } |
||
| 61 | } |
||
| 62 | |||
| 63 | class JSONResponse { |
||
| 64 | 11 | andrej.cim | |
| 65 | 9 | andrej.cim | private boolean success = true; |
| 66 | private int total; |
||
| 67 | private ArrayList rows; |
||
| 68 | |||
| 69 | 11 | andrej.cim | public JSONResponse(boolean success, int total, ArrayList rows) { |
| 70 | 9 | andrej.cim | this.success = success;
|
| 71 | this.total = total;
|
||
| 72 | this.rows = rows;
|
||
| 73 | } |
||
| 74 | } |
||
| 75 | |||
| 76 | // <editor-fold defaultstate="collapsed" desc="HttpServlet methods. Click on the + sign on the left to edit the code.">
|
||
| 77 | 11 | andrej.cim | /**
|
| 78 | 9 | andrej.cim | * Handles the HTTP <code>GET</code> method.
|
| 79 | * @param request servlet request
|
||
| 80 | * @param response servlet response
|
||
| 81 | * @throws ServletException if a servlet-specific error occurs
|
||
| 82 | * @throws IOException if an I/O error occurs
|
||
| 83 | */
|
||
| 84 | @Override
|
||
| 85 | protected void doGet(HttpServletRequest request, HttpServletResponse response) |
||
| 86 | 11 | andrej.cim | throws ServletException, IOException { |
| 87 | 9 | andrej.cim | processRequest(request, response); |
| 88 | 11 | andrej.cim | } |
| 89 | 9 | andrej.cim | |
| 90 | 11 | andrej.cim | /**
|
| 91 | 9 | andrej.cim | * Handles the HTTP <code>POST</code> method.
|
| 92 | * @param request servlet request
|
||
| 93 | * @param response servlet response
|
||
| 94 | * @throws ServletException if a servlet-specific error occurs
|
||
| 95 | * @throws IOException if an I/O error occurs
|
||
| 96 | */
|
||
| 97 | @Override
|
||
| 98 | protected void doPost(HttpServletRequest request, HttpServletResponse response) |
||
| 99 | 11 | andrej.cim | throws ServletException, IOException { |
| 100 | 9 | andrej.cim | processRequest(request, response); |
| 101 | } |
||
| 102 | |||
| 103 | 11 | andrej.cim | /**
|
| 104 | 9 | andrej.cim | * Returns a short description of the servlet.
|
| 105 | * @return a String containing servlet description
|
||
| 106 | */
|
||
| 107 | @Override
|
||
| 108 | public String getServletInfo() { |
||
| 109 | return "Short description"; |
||
| 110 | }// </editor-fold>
|
||
| 111 | } |