/** * Copyright (c) 2011-2014, OpenIoT * * This file is part of OpenIoT. * * OpenIoT 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, version 3 of the License. * * OpenIoT 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. * * You should have received a copy of the GNU Lesser General Public License * along with OpenIoT. If not, see <http://www.gnu.org/licenses/>. * * Contact: OpenIoT mailto: info@openiot.eu * @author Behnaz Bostanipour * @author Timotee Maret * @author Julien Eberle */ package org.openiot.gsn.http.ac; import org.openiot.gsn.Main; import org.openiot.gsn.http.WebConstants; import javax.servlet.ServletException; import javax.servlet.http.*; import java.io.IOException; import java.io.PrintWriter; /** * Created by IntelliJ IDEA. * User: Behnaz Bostanipour * Date: Apr 15, 2010 * Time: 7:57:45 PM * To change this template use File | Settings | File Templates. */ public class MyDisplayACTablesContentServlet extends HttpServlet { /****************************************** Servlet Methods*******************************************/ /******************************************************************************************************/ public void doGet(HttpServletRequest req, HttpServletResponse res)throws ServletException, IOException { res.setContentType("text/html"); PrintWriter out = res.getWriter(); // Get the session HttpSession session = req.getSession(); User user = (User) session.getAttribute("user"); if (user == null) { this.redirectToLogin(req,res); } else { this.checkSessionScheme(req,res); if(user.isAdmin()== false) { res.sendError( WebConstants.ACCESS_DENIED , "Access denied." ); } else { this.printHeader(out); this.printLayoutMastHead(out, user ); this.printLayoutContent(out); printBody(out); this.printLayoutFooter(out); } } } public void doPost(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException { this.doGet(req,res); } /****************************************** HTML Printing Methods*******************************************/ /***********************************************************************************************************/ private void printHeader(PrintWriter out) { out.println("<HTML>"); out.println("<HEAD>"); out.println("<TITLE>Display AC Tables Content</TITLE>"); out.println(" <link rel=\"stylesheet\" media=\"screen\" type=\"text/css\" href=\"/style/acstyle.css\"/>"); //printStyle(out); out.println("</HEAD>"); out.println("<body>"); out.println("<div id=\"container\">"); out.println("<div class=box>"); } private void printLayoutMastHead(PrintWriter out, User user) { out.println("<div id=\"masthead\">"); out.println("<div class=\"image_float\"><img src=\"/style/gsn-mark.png\" alt=\"GSN logo\" /></div><br>"); out.println("<h1>Display AC Tables Content </h1>"); out.println("<div class=\"spacer\"></div>"); out.println("</div>"); out.println("<div id=\"mastheadborder\">"); this.printLinks(out); this.printUserName(out, user); out.println("<br><br>"); out.println("</div>"); } private void printLayoutContent(PrintWriter out) { out.println("<div id=\"content\">"); } private void printLayoutFooter(PrintWriter out) { out.println("</div>"); out.println("<div id=\"footer\">"); out.println(" <p align=\"center\"><FONT COLOR=\"#000000\"/>Powered by <a class=\"nonedecolink\" href=\"http://globalsn.sourceforge.net/\">GSN</a>, Distributed Information Systems Lab, EPFL 2010</p>"); out.println("</div>");//footer out.println("</div>");//box out.println("</div>");//container out.println("</body>"); out.println("</html>"); } private void printLinks(PrintWriter out) { //out.println("<a class=linkclass href=\"/gsn/MyLoginHandlerServlet\">login</a>"); //out.println("<a class=linkclass href=/gsn/MyAccessRightsManagementServlet>access rights management</a>"); out.println("<a class=linkclass href=\"/gsn/MyAdminManagementServlet\">admin only</a>"); out.println("<a class=linkclass href=\"/gsn/MyLogoutHandlerServlet\">logout</a>"); //out.println("<a class=linkclass href=\"/\">GSN home</a>"); } private void printUserName(PrintWriter out, User user) { //String username=user.getUserName(); out.println("<p id=\"login\">logged in as : "+user.getUserName()+"</p>"); } private void printBody(PrintWriter out) throws ServletException { ConnectToDB ctdb = null; HtmlResultSet hrs=new HtmlResultSet(); try { ctdb = new ConnectToDB(); this.createFormSubmitButtons(out,ctdb); } catch(Exception e) { out.println("Exception caught : "+e.getMessage()); } finally { if(ctdb!=null) { ctdb.closeStatement(); ctdb.closeConnection(); } } } public void createFormSubmitButtons(PrintWriter out, ConnectToDB ctdb) { out.println("<p>Please click on the appropriate table to see its content:</p>"); out.println("<ul class=tablelinkul>"); for(int i=ctdb.getACTables().size()-1;i>=0;i--) { String tbname=(String)ctdb.getACTables().get(i); out.println("<FORM ACTION=/gsn/MyHtmlResultSetServlet METHOD=POST>"); out.println("<INPUT TYPE=HIDDEN NAME=tablename VALUE= "+tbname+">"); out.println("<LI><INPUT TYPE=SUBMIT VALUE= "+tbname+"></LI>"); out.println("</FORM>"); } out.println("</ul>"); } /****************************************** Client Session related Methods*******************************************/ /********************************************************************************************************************/ private void checkSessionScheme(HttpServletRequest req, HttpServletResponse res)throws IOException { if(req.getScheme().equals("https")== true) { if((req.getSession().getAttribute("scheme")==null)) { req.getSession().setAttribute("scheme","https"); } } else if(req.getScheme().equals("http")== true ) { if((req.getSession().getAttribute("scheme")==null)) { req.getSession().setAttribute("scheme","http"); } res.sendRedirect("https://"+req.getServerName()+":"+ Main.getContainerConfig().getSSLPort()+"/gsn/MyDisplayACTablesContentServlet"); } } private void redirectToLogin(HttpServletRequest req, HttpServletResponse res)throws IOException { req.getSession().setAttribute("login.target", HttpUtils.getRequestURL(req).toString()); res.sendRedirect("/gsn/MyLoginHandlerServlet"); } }