package org.opentosca.csarrepo.servlet;
import java.io.IOException;
import java.util.ArrayList;
import java.util.Map;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import org.opentosca.csarrepo.exception.AuthenticationException;
import org.opentosca.csarrepo.model.User;
import org.opentosca.csarrepo.model.WineryServer;
import org.opentosca.csarrepo.service.ListCsarService;
import org.opentosca.csarrepo.service.ListWineryServerService;
import freemarker.template.Template;
@SuppressWarnings("serial")
@WebServlet(ListCsarServlet.PATH)
public class ListCsarServlet extends AbstractServlet {
private static final Logger LOGGER = LogManager.getLogger(ListCsarServlet.class);
private static final String TEMPLATE_NAME = "listCsarServlet.ftl";
public static final String PATH = "/csarlist";
public ListCsarServlet() {
super();
}
@Override
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
try {
User user = checkUserAuthentication(request, response);
// setup output and template
Map<String, Object> root = getRoot(request);
Template template = getTemplate(this.getServletContext(), TEMPLATE_NAME);
// init title
root.put("title", "CSARs");
// invoke service
ListCsarService service = new ListCsarService(user.getId());
if (service.hasErrors()) {
throw new ServletException("errors occured generating csar list");
}
// load winery servers
ListWineryServerService wineryListService = new ListWineryServerService(user.getId());
if(wineryListService.hasErrors()) {
root.put("wineryList", new ArrayList<WineryServer>());
} else {
root.put("wineryList", wineryListService.getResult());
}
// pass result to template
root.put("csars", service.getResult());
// output
template.process(root, response.getWriter());
} catch (AuthenticationException e) {
return;
} catch (Exception e) {
AbstractServlet.addError(request, e.getMessage());
this.redirect(request, response, DashboardServlet.PATH);
LOGGER.error(e);
}
}
}