]> WPIA git - gigi.git/commitdiff
add: login ticket into the devel launcher
authorFelix Dörre <felix@dogcraft.de>
Thu, 4 Jun 2015 15:18:34 +0000 (17:18 +0200)
committerFelix Dörre <felix@dogcraft.de>
Thu, 4 Jun 2015 17:19:58 +0000 (19:19 +0200)
util-testing/org/cacert/gigi/DevelLauncher.java
util-testing/org/cacert/gigi/TestLauncher.java

index 2f28757de7c644fecb9a0aa20354f6b321bd6987..44f9903a2bdade3b734619835e0add8fe86f3441 100644 (file)
@@ -1,5 +1,8 @@
 package org.cacert.gigi;
 
+import static org.cacert.gigi.Gigi.*;
+
+import java.awt.Desktop;
 import java.io.BufferedReader;
 import java.io.ByteArrayInputStream;
 import java.io.ByteArrayOutputStream;
@@ -20,9 +23,14 @@ import java.util.Properties;
 
 import javax.servlet.http.HttpServletRequest;
 import javax.servlet.http.HttpServletResponse;
+import javax.servlet.http.HttpSession;
 
 import org.cacert.gigi.dbObjects.ObjectCache;
+import org.cacert.gigi.dbObjects.User;
+import org.cacert.gigi.localisation.Language;
 import org.cacert.gigi.pages.Page;
+import org.cacert.gigi.util.RandomToken;
+import org.cacert.gigi.util.ServerConstants;
 import org.kamranzafar.jtar.TarEntry;
 import org.kamranzafar.jtar.TarHeader;
 import org.kamranzafar.jtar.TarOutputStream;
@@ -52,7 +60,9 @@ public class DevelLauncher {
         InputStream oldin = System.in;
         System.setIn(new ByteArrayInputStream(chunkConfig.toByteArray()));
         new Launcher().boot();
-        addDevelPage();
+        final String token = RandomToken.generateToken(32);
+        addDevelPage(token);
+        Desktop.getDesktop().browse(new URL("http://" + ServerConstants.getWwwHostNamePort() + "/ticket?token=" + token).toURI());
         System.setIn(oldin);
         BufferedReader br = new BufferedReader(new InputStreamReader(System.in, "UTF-8"));
         System.out.println("Cacert-gigi system sucessfully started.");
@@ -71,7 +81,7 @@ public class DevelLauncher {
         }
     }
 
-    public static void addDevelPage() {
+    public static void addDevelPage(String token) {
         try {
             Field instF = Gigi.class.getDeclaredField("instance");
             Field pageF = Gigi.class.getDeclaredField("pages");
@@ -122,12 +132,41 @@ public class DevelLauncher {
                 }
             });
 
+            if (token != null) {
+                addTicketPage(pages, token);
+            }
+
             pageF.set(gigi, Collections.unmodifiableMap(pages));
         } catch (ReflectiveOperationException e) {
             e.printStackTrace();
         }
     }
 
+    private static void addTicketPage(HashMap<String, Page> pages, final String token) {
+        pages.put("/ticket", new Page("ticket") {
+
+            boolean used = false;
+
+            @Override
+            public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
+                if ( !used && token.equals(req.getParameter("token"))) {
+                    HttpSession sess = req.getSession();
+                    User user = User.getById(1);
+                    sess.setAttribute(LOGGEDIN, true);
+                    sess.setAttribute(Language.SESSION_ATTRIB_NAME, user.getPreferredLocale());
+                    sess.setAttribute(USER, user);
+                    req.getSession().setAttribute(LOGIN_METHOD, "Ticket");
+                    resp.sendRedirect("/");
+                }
+            }
+
+            @Override
+            public boolean needsLogin() {
+                return false;
+            }
+        });
+    }
+
     public static void writeGigiConfig(OutputStream target, byte[] keystorepw, byte[] truststorepw, Properties mainprop, byte[] cacerts, byte[] keystore) throws IOException {
         TarOutputStream tos = new TarOutputStream(target);
         ByteArrayOutputStream baos = new ByteArrayOutputStream();
index 0181de7ab599fce26d768c71c53341b288ac582e..16d6a152bf1749ce73be0ef1b05215b347bfff39 100644 (file)
@@ -5,7 +5,7 @@ public class TestLauncher {
     public static void main(String[] args) throws Exception {
         // As clean as possible
         Launcher.main(args);
-        DevelLauncher.addDevelPage();
+        DevelLauncher.addDevelPage(null);
         System.err.println("System successfully started.");
 
     }