/******************************************************************************* * Copyright 2014 by E-Government Innovation Center EGIZ, Graz, Austria * PDF-AS has been contracted by the E-Government Innovation Center EGIZ, a * joint initiative of the Federal Chancellery Austria and Graz University of * Technology. * * Licensed under the EUPL, Version 1.1 or - as soon they will be approved by * the European Commission - subsequent versions of the EUPL (the "Licence"); * You may not use this work except in compliance with the Licence. * You may obtain a copy of the Licence at: * http://www.osor.eu/eupl/ * * Unless required by applicable law or agreed to in writing, software * distributed under the Licence is distributed on an "AS IS" basis, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the Licence for the specific language governing permissions and * limitations under the Licence. * * This product combines work with different licenses. See the "NOTICE" text * file for details on the various modules and licenses. * The "NOTICE" text file is part of the distribution. Any derivative works * that you distribute must include a readable copy of the "NOTICE" text file. ******************************************************************************/ package at.gv.egiz.pdfas.web.servlets; import at.gv.egiz.pdfas.api.ws.PDFASVerificationResponse; import at.gv.egiz.pdfas.web.config.WebConfiguration; import at.gv.egiz.pdfas.web.helper.PdfAsHelper; import at.gv.egiz.pdfas.web.helper.PdfAsParameterExtractor; import at.gv.egiz.pdfas.web.stats.StatisticEvent; import at.gv.egiz.pdfas.web.stats.StatisticEvent.Status; import at.gv.egiz.pdfas.web.stats.StatisticFrontend; import org.slf4j.Logger; import org.slf4j.LoggerFactory; 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.OutputStream; /** * Servlet implementation class PDFData */ public class PDFData extends HttpServlet { private static final long serialVersionUID = 1L; private static final Logger logger = LoggerFactory.getLogger(PDFData.class); /** * @see HttpServlet#HttpServlet() */ public PDFData() { super(); } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse * response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.process(request, response); } /** * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse * response) */ protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { this.process(request, response); } protected void process(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { byte[] signedData = PdfAsHelper.getSignedPdf(request, response); StatisticEvent statisticEvent = PdfAsHelper.getStatisticEvent(request, response); String plainPDFDigest = PdfAsParameterExtractor.getOrigDigest(request); if (signedData != null) { if(WebConfiguration.isKeepSignedDocument()) { if(PdfAsHelper.isSignedDataExpired(request, response)) { logger.info("Destroying expired signed data in session"); request.getSession().invalidate(); PdfAsHelper.setSessionException(request, response, "No signed pdf document available.", null); PdfAsHelper.gotoError(getServletContext(), request, response); return; } } if (plainPDFDigest != null) { String signatureDataHash = PdfAsHelper .getSignatureDataHash(request); if (!plainPDFDigest.equalsIgnoreCase(signatureDataHash)) { logger.warn("Digest Hash mismatch!"); logger.warn("Requested digest: " + plainPDFDigest); logger.warn("Saved digest: " + signatureDataHash); PdfAsHelper.setSessionException(request, response, "Signature Data digest do not match!", null); PdfAsHelper.gotoError(getServletContext(), request, response); return; } } response.setHeader("Content-Disposition", "inline;filename=" + PdfAsHelper.getPDFFileName(request)); String pdfCert = PdfAsHelper.getSignerCertificate(request); if (pdfCert != null) { response.setHeader("Signer-Certificate", pdfCert); } if (statisticEvent != null) { if (!statisticEvent.isLogged()) { statisticEvent.setStatus(Status.OK); statisticEvent.setEndNow(); statisticEvent.setTimestampNow(); StatisticFrontend.getInstance().storeEvent(statisticEvent); statisticEvent.setLogged(true); } } PDFASVerificationResponse resp = PdfAsHelper .getPDFASVerificationResponse(request); if (resp != null) { response.setHeader("CertificateCheckCode", String.valueOf(resp.getCertificateCode())); response.setHeader("ValueCheckCode", String.valueOf(resp.getValueCode())); } response.setContentType("application/pdf"); OutputStream os = response.getOutputStream(); os.write(signedData); os.close(); // When data is collected destroy session! if(!WebConfiguration.isKeepSignedDocument()) { logger.debug("Destroying signed data in session : {}", request.getSession().getId()); request.getSession().invalidate(); } else { logger.debug("Keeping signed data in session : {}", request.getSession().getId()); } } else { PdfAsHelper.setSessionException(request, response, "No signed pdf document available.", null); PdfAsHelper.gotoError(getServletContext(), request, response); } } }