/*
WebBox - Dein Server.
Copyright (C) 2020 Ulrich Hilger, http://uhilger.de
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see .
*/
package de.uhilger.wbx.web;
import java.io.BufferedReader;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.Map;
import static org.asciidoctor.AttributesBuilder.attributes;
import static org.asciidoctor.OptionsBuilder.options;
import static org.asciidoctor.Asciidoctor.Factory.create;
import org.asciidoctor.Asciidoctor;
/**
* Das AdocServlet wandelt AsciiDoc-Inhalte (*.adoc)
* zu HTML-Seiten und PDF-Dokumenten
*/
public class AdocServlet extends HttpServlet {
private static final String DOT = ".";
private static final String HTMLEXT = ".html";
private static final String PDFEXT = ".pdf";
private static final String PDF = "pdf";
private static final String SERVLET_NAME = "AdocServlet";
/**
* Processes requests for both HTTP GET
and POST
* methods.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
protected void processRequest(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
response.setContentType("text/html;charset=UTF-8");
try (PrintWriter out = response.getWriter()) {
// Asciidoc-Quelldatei aus HTTP-Request ermitteln
String vPath = request.getServletPath();
String absname = getServletContext().getRealPath(vPath);
File adocfile = new File(absname);
// HTML-Datei ermitteln
String nameext = adocfile.getName();
String fname = nameext.substring(0, nameext.lastIndexOf(DOT));
File htmlfile = new File(adocfile.getParentFile(), fname + HTMLEXT);
/*
transformieren, wenn die Quelle sich geandert hat oder
die HTML-Datei noch nicht existiert
*/
if(!htmlfile.exists() || adocfile.lastModified() > htmlfile.lastModified()) {
transform(absname, htmlfile);
}
String pdf = request.getParameter(PDF);
if(null != pdf && pdf.length() > 0 && pdf.equalsIgnoreCase(Boolean.TRUE.toString())) {
File pdffile = new File(adocfile.getParentFile(), fname + PDFEXT);
if(!pdffile.exists() || adocfile.lastModified() > pdffile.lastModified()) {
transform(absname, pdffile);
}
}
// HTML-Datei ausgeben
FileInputStream in = new FileInputStream(htmlfile);
BufferedReader reader = new BufferedReader(new InputStreamReader(in));
String line;
while ((line = reader.readLine()) != null) {
out.println(line);
}
}
}
private void transform(String absoluteFileName, File target) {
Map options = null;
Map attributes;
Asciidoctor asciidoctor = create();
String fname = target.getName().toLowerCase();
if(fname.endsWith(HTMLEXT)) {
attributes = attributes().noFooter(false)
.sourceHighlighter("highlightjs")
//.tableOfContents(true)
//.sectionNumbers(true)
.asMap();
options = options().inPlace(false)
.attributes(attributes)
.asMap();
} else if(fname.endsWith(PDFEXT)) {
attributes = attributes().noFooter(false)
.asMap();
options = options().inPlace(false)
.attributes(attributes)
.backend("pdf")
.asMap();
}
asciidoctor.convertFile(new File(absoluteFileName), options);
}
/**
* Handles the HTTP GET
method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Handles the HTTP POST
method.
*
* @param request servlet request
* @param response servlet response
* @throws ServletException if a servlet-specific error occurs
* @throws IOException if an I/O error occurs
*/
@Override
protected void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
processRequest(request, response);
}
/**
* Returns a short description of the servlet.
*
* @return a String containing servlet description
*/
@Override
public String getServletInfo() {
return SERVLET_NAME;
}
}