/********************************************************************************** * $URL: https://source.sakaiproject.org/svn/velocity/trunk/tool/src/java/org/sakaiproject/vm/ComponentServlet.java $ * $Id: ComponentServlet.java 105080 2012-02-24 23:10:31Z ottenhoff@longsight.com $ *********************************************************************************** * * Copyright (c) 2003, 2004, 2005, 2006, 2007, 2008 The Sakai Foundation * * Licensed under the Educational Community License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.opensource.org/licenses/ECL-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * **********************************************************************************/ package org.sakaiproject.vm; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.sakaiproject.util.ParameterParser; /** * <p> * ComponentServlet does some setup and provides some support for (mostly legacy) Sakai servlets and tools. * <p> */ public abstract class ComponentServlet extends HttpServlet { /** This request's parsed parameters */ protected final static String ATTR_PARAMS = "sakai.wrapper.params"; /** * Override service, adding the setup for legacy. */ protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, java.io.IOException { // parse the parameters of the request, considering Unicode issues, into a ParameterParser ParameterParser parser = new ParameterParser(req); // make this available from the req as an attribute req.setAttribute(ATTR_PARAMS, parser); // Setup.setup(req, resp); super.service(req, resp); } /** * Send a redirect so our parent ends up at the url, via javascript. * * @param url * The redirect url */ protected void sendParentRedirect(HttpServletResponse resp, String url) { try { resp.setContentType("text/html; charset=UTF-8"); PrintWriter out = resp.getWriter(); out .println("<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Transitional//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd\">"); out.println("<html><head></head><body>"); out.println("<script type=\"text/javascript\" language=\"JavaScript\">"); out.println("if (parent)\n" + "{\n\tparent.location.replace('" + url + "');\n}\n"); out.println("else\n" + "{\n\tlocation.replace('" + url + "');\n}\n"); out.println("</script>"); out.println("</body></html>"); resp.flushBuffer(); } catch (IOException e) { } } // set standard no-cache headers protected void setNoCacheHeaders(HttpServletResponse resp) { resp.setContentType("text/html; charset=UTF-8"); // some old date resp.addHeader("Expires", "Mon, 01 Jan 2001 00:00:00 GMT"); // TODO: do we need this? adding a date header is expensive contention for the date formatter, ours or Tomcats. // resp.addDateHeader("Last-Modified", System.currentTimeMillis()); resp.addHeader("Cache-Control", "no-store, no-cache, must-revalidate, max-age=0, post-check=0, pre-check=0"); resp.addHeader("Pragma", "no-cache"); } }