/branches/ZCrawl/ZCrawlSources/src/org/zonales/ZGram/services/SetZGram.java
Java | 72 lines | 57 code | 6 blank | 9 comment | 4 complexity | cb8db839d8b0d05aba6b0aa6d7278906 MD5 | raw file
Possible License(s): BSD-3-Clause
- /*
- * To change this template, choose Tools | Templates
- * and open the template in the editor.
- */
- package org.zonales.ZGram.services;
- import com.google.gson.Gson;
- import org.zonales.BaseService;
- import com.mongodb.MongoException;
- import java.io.IOException;
- import java.io.PrintWriter;
- import java.util.Date;
- import java.util.Properties;
- import java.util.logging.Level;
- import java.util.logging.Logger;
- import javax.servlet.ServletException;
- import javax.servlet.http.HttpServletRequest;
- import javax.servlet.http.HttpServletResponse;
- import org.zonales.ZGram.ZGram;
- import org.zonales.ZGram.daos.ZGramDao;
- import org.zonales.crawlConfig.objets.State;
- import org.zonales.errors.ZMessages;
- import org.zonales.errors.ZMessage;
- /**
- *
- * @author nacho
- */
- public class SetZGram extends BaseService {
- @Override
- public void serve(HttpServletRequest request, HttpServletResponse response, Properties props) throws ServletException, IOException, Exception {
- response.setCharacterEncoding("UTF-8");
- response.setContentType("text/html");
- PrintWriter out = response.getWriter();
- int cod = Integer.valueOf(request.getParameter("cod"));
- String msg = request.getParameter("msg");
- String metadataJson = request.getParameter("metadata");
- String verbatim = request.getParameter("verbatim");
- String state = request.getParameter("state");
- String creadoPor = request.getParameter("creadoPor");
- ZGram zgram = new ZGram();
- Gson metadataGson = new Gson();
- ZMessage zMessage = new ZMessage(cod, msg);
- //Mapeo en un objeto ZCrawling la metadata que vienen en formato JSON en el request
- zgram = metadataGson.fromJson(metadataJson.replace("\\\"", "\"").replace("\\'", "\""), ZGram.class);
- zgram.setVerbatim(verbatim);
- zgram.setEstado(state != null && state.length() > 0 ? state : State.GENERATED);
- zgram.setCreado((new Date()).getTime());
- zgram.setZmessage(zMessage);
- zgram.setPeriodicidad(20); //TODO: correfir, por ahora está duro por defecto
-
- if (creadoPor != null) {
- zgram.setCreadoPor(creadoPor);
- }
- try {
- Logger.getLogger(this.getClass().getName()).log(Level.INFO, "Se intentará guardar: {0}", new Object[]{zgram});
- ZGramDao zGramDao = new ZGramDao(props.getProperty("db_host"), Integer.valueOf(props.getProperty("db_port")), props.getProperty("db_name"));
- String id = zGramDao.save(zgram);
- Logger.getLogger(this.getClass().getName()).log(Level.INFO, "Extracción guardada {0}", new Object[]{zgram});
- out.print(ZMessages.SUCCESS.toString().replace("}", "") + ", \"id\": \"" + id + "\"}");
- } catch (MongoException ex) {
- Logger.getLogger(this.getClass().getName()).log(Level.INFO, "Error guardando extracción {0}: {1}", new Object[]{zgram,ex.getMessage()});
- out.print(ZMessages.SAVE_FAILED);
- } catch (Exception ex) {
- Logger.getLogger(this.getClass().getName()).log(Level.SEVERE, "Base de datos no disponible {0}", new Object[]{ex.getMessage()});
- out.print(ZMessages.NO_DB_FAILED);
- }
- }
- }