public class Gigi extends HttpServlet {
private HashMap<String, Page> pages = new HashMap<String, Page>();
+
@Override
public void init() throws ServletException {
- pages.put("login", new LoginPage());
+ pages.put("/login", new LoginPage());
+ pages.put("/", new MainPage());
super.init();
}
hs = req.getSession(false);
}
}
+ if (hs != null && ((Boolean) hs.getAttribute("loggedin"))
+ && req.getPathInfo().equals("/login")) {
+ resp.sendRedirect("/");
+ return;
+ }
if (req.getMethod().equals("POST") && req.getPathInfo() != null
&& req.getPathInfo().equals("/login")) {
authWithUnpw(req);
return;
}
- if (hs == null || !((Boolean) hs.getAttribute("loggedin"))) {
- resp.getWriter().println("Access denied. Sending login form.");
- pages.get("login").doGet(req, resp);
+ if ((hs == null || !((Boolean) hs.getAttribute("loggedin")))
+ && !"/login".equals(req.getPathInfo())) {
+ System.out.println(req.getPathInfo());
+ resp.sendRedirect("/login");
return;
}
- resp.getWriter().println("Access granted.");
+ System.out.println(req.getPathInfo());
+ if (pages.containsKey(req.getPathInfo())) {
+ Page p = pages.get(req.getPathInfo());
+ p.doGet(req, resp);
+ } else {
+ resp.sendError(404, "Page not found.");
+ }
}
+
private void authWithUnpw(HttpServletRequest req) {
String un = req.getParameter("username");
String pw = req.getParameter("password");
HttpSession hs = req.getSession();
hs.setAttribute("loggedin", true);
}
+
private void tryAuthWithCertificate(HttpServletRequest req,
X509Certificate x509Certificate) {
// TODO ckeck if certificate is valid
--- /dev/null
+package org.cacert.gigi;
+
+import java.io.IOException;
+
+import javax.servlet.ServletRequest;
+import javax.servlet.ServletResponse;
+
+public class MainPage extends Page {
+ @Override
+ public void doGet(ServletRequest req, ServletResponse resp)
+ throws IOException {
+ super.doGet(req, resp);
+ resp.getWriter().println("Access granted.");
+ }
+}