package it.agilis.mens.azzeroCO2.server.services;
import it.agilis.mens.azzeroCO2.client.services.AzzerroCO2UtilsClientHelper;
import it.agilis.mens.azzeroCO2.core.criteria.OrdineCriteria;
import it.agilis.mens.azzeroCO2.core.criteria.SellaRicevutaDiPagamentoCriteria;
import it.agilis.mens.azzeroCO2.core.entity.Esito;
import it.agilis.mens.azzeroCO2.core.entity.Ordine;
import it.agilis.mens.azzeroCO2.core.entity.SellaRicevutaDiPagamento;
import it.agilis.mens.azzeroCO2.core.register.impl.AzzeroCO2Register;
import it.agilis.mens.azzeroCO2.shared.model.pagamento.PagamentoModel;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.beans.factory.config.AutowireCapableBeanFactory;
import org.springframework.web.context.WebApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
import javax.servlet.ServletConfig;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* Created by IntelliJ IDEA.
* User: Giovanni La Torre
* Date: 22/09/11
* Time: 15.02
* To change this template use File | Settings | File Templates.
*/
public class RispostaBancaServiceOK extends HttpServlet {
@Autowired
@Qualifier("azzeroCO2Register")
private AzzeroCO2Register azzeroCO2Register;
@Override
public void init(ServletConfig config) throws ServletException {
super.init(config);
WebApplicationContext ctx = WebApplicationContextUtils
.getRequiredWebApplicationContext(config.getServletContext());
AutowireCapableBeanFactory beanFactory = ctx
.getAutowireCapableBeanFactory();
beanFactory.autowireBean(this);
}
private static final String PAGE_TOP = ""
+ "<html>"
+ "<head>"
+ "<title>AzzeroCO2</title>"
+ "</head>"
+ "<body onLoad='document.calcdata.submit()'>";
/* + "<h3>AzzeroCO2</h3>" ;*/
private static final String PAGE_BOTTOM =
/* "< a href='javascript:window.opener='x';window.close();'>Close< /a> + "*/
"</body>"
+ "</html>";
public AzzeroCO2Register getAzzeroCO2Register() {
return azzeroCO2Register;
}
public void setAzzeroCO2Register(AzzeroCO2Register azzeroCO2Register) {
this.azzeroCO2Register = azzeroCO2Register;
}
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String TRANSACTION_ID = request.getParameter("TRANSACTION_ID");//(id della transazione fornito dalla banca)
String MERCHANT_ID = request.getParameter("MERCHANT_ID"); //(id del merchant, dove il merchant AzzeroCO2 e l'id sempre 396870600001
String ORDER_ID = request.getParameter("ORDER_ID"); //(id dell'ordine)
String COD_AUT = request.getParameter("COD_AUT"); //(codice di autorizzazione fornito dalla banca)
String IMPORTO = request.getParameter("IMPORTO"); //
String DIVISA = request.getParameter("DIVISA"); //(nel nostro caso "EUR")
String MAC = request.getParameter("MAC"); //(codice di controllo da usare tra poco)
// String PROG_ID = request.getParameter("PROG_ID"); //(il codice dell'oggetto, nel nostro esempio mi pare "pagamentoCalcolatore"
response.setContentType("text/html");
PrintWriter out = response.getWriter();
if (ORDER_ID != null && ORDER_ID.length() > 0) {
SellaRicevutaDiPagamentoCriteria criteria = new SellaRicevutaDiPagamentoCriteria();
criteria.setOrderId(ORDER_ID);
SellaRicevutaDiPagamento ricevuta = azzeroCO2Register.getSellaRicevutaDiPagamento(criteria);
if (ricevuta != null) {
ricevuta.setTRANSACTION_ID(TRANSACTION_ID);
ricevuta.setCOD_AUT(COD_AUT);
ricevuta.setUpdateFromBanca(new Date());
try {
MessageDigest algorithm = MessageDigest.getInstance("MD5");
algorithm.reset();
String theMd5 = AzzerroCO2UtilsClientHelper.getMAC_MD5((TRANSACTION_ID + MERCHANT_ID + ORDER_ID + COD_AUT + IMPORTO + DIVISA + PagamentoModel.key).toUpperCase());
if (theMd5.equalsIgnoreCase(MAC)) {
ricevuta.setEsito(Esito.PAGATO);
azzeroCO2Register.saveRicevuta(ricevuta);
OrdineCriteria ordineCriteria = new OrdineCriteria();
ordineCriteria.setRicevuta(ricevuta);
Ordine ordine = azzeroCO2Register.getOrdine(ordineCriteria);
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
NumberFormat formatter = new DecimalFormat("#0.00");
String tonnellate = "" + formatter.format(ricevuta.getKgCO2() / 1000);
String importoinEuro = ricevuta.getIMPORTO().replace(",", ".");
out.println(PAGE_TOP +
"<form name='calcdata' id='calcdata' method='post' action='http://www.azzeroco2.it/onlinereg/agents/calc_receiver.php'>\n" +
"<input type='hidden' name='nome' id='nome' value='" + ordine.getUtente().getNome() + "' />\n" +
"<input type='hidden' name='cognome' id='cognome' value='" + ordine.getUtente().getCognome() + "' />\n" +
"<input type='hidden' name='societa' id='societa' value='" + ordine.getUtente().getRagSociale() + "' />\n" +
"<input type='hidden' name='email' id='email' value='" + ordine.getUtente().getEmail() + "' />\n" +
"<input type='hidden' name='indirizzo' id='indirizzo' value='" + ordine.getUtente().getIndirizzo() + "|" + ordine.getUtente().getCap() + "' />\n" +
"<input type='hidden' name='luogo' id='luogo' value='" + ordine.getUtente().getCitta() + "|" + ordine.getUtente().getProvincia() + "' />\n" +
"<input type='hidden' name='cfisc' id='cfisc' value='" + ordine.getUtente().getpIvaCF() + "' />\n" +
"<input type='hidden' name='piva' id='piva' value='" + ordine.getUtente().getpIvaCF() + "' />\n" +
"<input type='hidden' name='data' id='data' value='" + format.format(ricevuta.getUpdateFromBanca()) + "' />\n" +
"<input type='hidden' name='tonnellate' id='tonnellate' value='" + tonnellate + "' />\n" +
"<input type='hidden' name='crediti' id='crediti' value='" + tonnellate + "' />\n" +
"<input type='hidden' name='euro' id='euro' value='" + importoinEuro + "' />\n" +
"<input type='hidden' name='idprogetto' id='idprogetto' value='" + ordine.getProgettoCompensazione().getId() + "' />\n" +
"</form>" +
PAGE_BOTTOM
);
} else {
out.println(PAGE_TOP + "<table><tr><td>MD5 non corrispondente.+3</td></tr></table>" + PAGE_BOTTOM);
}
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
out.println(PAGE_TOP + "<table><tr><td>Errore nella ricezione dei dati.+0</td></tr></table>" + PAGE_BOTTOM);
} catch (Exception e) {
e.printStackTrace();
out.println(PAGE_TOP + "<table><tr><td>Errore nella ricezione dei dati.+1</td></tr></table>" + PAGE_BOTTOM);
}
} else {
out.println(PAGE_TOP + "<tr><td>Errore nella ricezione dei dati.+2</td></tr>" + PAGE_BOTTOM);
}
} else {
out.println(PAGE_TOP + "<tr><td>Errore nella ricezione dei dati.+3</td></tr>" + PAGE_BOTTOM);
}
}
}