/*
* Copyright 2015-Present Entando Inc. (http://www.entando.com) All rights reserved.
*
* This library is free software; you can redistribute it and/or modify it under
* the terms of the GNU Lesser General Public License as published by the Free
* Software Foundation; either version 2.1 of the License, or (at your option)
* any later version.
*
* This library 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 Lesser General Public License for more
* details.
*/
package org.entando.entando.aps.system.services.controller.executor;
import com.agiletec.aps.system.RequestContext;
import com.agiletec.aps.system.SystemConstants;
import com.agiletec.aps.system.services.page.IPage;
import com.agiletec.aps.system.services.pagemodel.PageModel;
import freemarker.template.Template;
import java.io.IOException;
import java.io.StringReader;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang.StringUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @author E.Santoboni
*/
public class PageExecutorService implements ExecutorServiceInterface {
private static final Logger _logger = LoggerFactory.getLogger(PageExecutorService.class);
@Override
public void afterPropertiesSet() throws Exception {
//nothing to do
}
@Override
public void service(RequestContext reqCtx) {
HttpServletRequest request = reqCtx.getRequest();
HttpServletResponse response = reqCtx.getResponse();
try {
if (response.isCommitted()) {
return;
}
IPage page = (IPage) reqCtx.getExtraParam(SystemConstants.EXTRAPAR_CURRENT_PAGE);
PageModel model = page.getModel();
if (StringUtils.isBlank(model.getTemplate())) {
String jspPath = model.getPageModelJspPath();
RequestDispatcher dispatcher = request.getSession().getServletContext().getRequestDispatcher(jspPath);
dispatcher.forward(request, response);
} else {
ExecutorBeanContainer ebc = (ExecutorBeanContainer) reqCtx.getExtraParam(SystemConstants.EXTRAPAR_EXECUTOR_BEAN_CONTAINER);
Template template = new Template(page.getCode(), new StringReader(model.getTemplate()), ebc.getConfiguration());
try {
template.process(ebc.getTemplateModel(), response.getWriter());
} catch (Throwable t) {
String msg = "Error detected while including a page model " + model.getCode();
_logger.error(msg, t);
throw new RuntimeException(msg, t);
}
}
} catch (ServletException e) {
String msg = "Error detected while including a page model";
_logger.error(msg, e);
throw new RuntimeException(msg, e);
} catch (IOException e) {
String msg = "IO error detected while including the page model";
_logger.error(msg, e);
throw new RuntimeException(msg, e);
}
}
}