package servlets.admin.moduleManagement;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.Cookie;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;
import org.apache.log4j.Logger;
import dbProcs.Setter;
import utils.ShepherdLogManager;
import utils.Validate;
public class SetModuleStatus extends HttpServlet
{
private static final long serialVersionUID = 1L;
private static org.apache.log4j.Logger log = Logger.getLogger(SetModuleStatus.class);
/**
* Controller class used to specify what modules to mark as closed/open
* @param toOpen Array of moduleId's to open
* @param toClose Array of moduleId's to close
* @param csrfToken The csrf protection token for this function
*/
public void doPost (HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
//Setting IpAddress To Log and taking header for original IP if forwarded from proxy
ShepherdLogManager.setRequestIp(request.getRemoteAddr(), request.getHeader("X-Forwarded-For"));
log.debug("&&& servlets.module.SetModuleStatus &&&");
PrintWriter out = response.getWriter();
out.print(getServletInfo());
HttpSession ses = request.getSession(true);
Cookie tokenCookie = Validate.getToken(request.getCookies());
Object tokenParmeter = request.getParameter("csrfToken");
if(Validate.validateAdminSession(ses, tokenCookie, tokenParmeter))
{
ShepherdLogManager.setRequestIp(request.getRemoteAddr(), request.getHeader("X-Forwarded-For"), ses.getAttribute("userName").toString());
if(Validate.validateTokens(tokenCookie, tokenParmeter))
{
String ApplicationRoot = getServletContext().getRealPath("");
//ToDo - Itterate through input and run open/Close functions on them
if(request.getParameterValues("toOpen[]") != null)
{
String[] toOpen = request.getParameterValues("toOpen[]");;
log.debug("toOpen = " + toOpen.toString());
for(int i = 0; i < toOpen.length; i++)
Setter.setModuleStatusOpen(ApplicationRoot, toOpen[i]);
log.debug("Modules Opened");
}
else
{
log.debug("Nothing to Open");
}
if(request.getParameterValues("toClose[]") != null)
{
String[] toClose = request.getParameterValues("toClose[]");;
log.debug("toClose = " + toClose.toString());
for(int i = 0; i < toClose.length; i++)
Setter.setModuleStatusClosed(ApplicationRoot, toClose[i]);
log.debug("Modules Closed");
}
else
{
log.debug("Nothing to Close");
}
out.write("<h3 class='title'>Modules Updated</h3><p>The modules you selected have been updated accordingly</p>");
}
else
{
log.debug("CSRF Tokens did not match");
out.write("<h3 class='title'>Error Occurred</h3><p>Please Refresh Your Browser</p>");
}
}
else
{
log.error("Invalid Session Detected");
out.write("css/images/loggedOutSheep.jpg");
}
log.debug("&&& END SetModuleStatus &&&");
}
}