Sebastian Sdorra avatar Sebastian Sdorra committed 2dcede7

bind new security api

Comments (0)

Files changed (2)

scm-webapp/src/main/java/sonia/scm/ScmContextListener.java

 
 //~--- non-JDK imports --------------------------------------------------------
 
+import com.google.common.collect.Lists;
 import com.google.inject.Guice;
 import com.google.inject.Injector;
 import com.google.inject.Module;
 
 //~--- JDK imports ------------------------------------------------------------
 
-import java.util.ArrayList;
 import java.util.List;
 
+import javax.servlet.ServletContext;
 import javax.servlet.ServletContextEvent;
+import org.apache.shiro.guice.web.ShiroWebModule;
 
 /**
  *
 
       // call destroy event
       globalInjector.getInstance(
-          ServletContextListenerHolder.class).contextDestroyed(
-          servletContextEvent);
+        ServletContextListenerHolder.class).contextDestroyed(
+        servletContextEvent);
     }
 
     super.contextDestroyed(servletContextEvent);
   @Override
   public void contextInitialized(ServletContextEvent servletContextEvent)
   {
+    this.servletContext = servletContextEvent.getServletContext();
+
     if (SCMContext.getContext().getStartupError() == null)
     {
       ScmUpgradeHandler upgradeHandler = new ScmUpgradeHandler();
     if ((globalInjector != null) &&!startupError)
     {
       globalInjector.getInstance(
-          ServletContextListenerHolder.class).contextInitialized(
-          servletContextEvent);
+        ServletContextListenerHolder.class).contextInitialized(
+        servletContextEvent);
     }
   }
 
     }
     else
     {
-      globalInjector = getDefaultInjector();
+      globalInjector = getDefaultInjector(servletContext);
     }
 
     return globalInjector;
    * Method description
    *
    *
+   *
+   * @param servletContext
    * @return
    */
-  private Injector getDefaultInjector()
+  private Injector getDefaultInjector(ServletContext servletContext)
   {
     PluginLoader pluginLoader = new DefaultPluginLoader();
     BindingExtensionProcessor bindExtProcessor =
     ClassOverrides overrides = ClassOverrides.findOverrides();
     ScmServletModule main = new ScmServletModule(pluginLoader,
                               bindExtProcessor, overrides);
-    List<Module> moduleList = new ArrayList<Module>();
+    List<Module> moduleList = Lists.newArrayList();
 
+    moduleList.add(ShiroWebModule.guiceFilterModule());
+    moduleList.add(main);
+    moduleList.add(new ScmSecurityModule(servletContext));
     moduleList.addAll(bindExtProcessor.getModuleSet());
     moduleList.addAll(overrides.getModules());
-    moduleList.add(0, main);
+    
 
     Injector injector = Guice.createInjector(moduleList);
     SCMContextProvider context = SCMContext.getContext();
   private Injector globalInjector;
 
   /** Field description */
+  private ServletContext servletContext;
+
+  /** Field description */
   private boolean startupError = false;
 }

scm-webapp/src/main/java/sonia/scm/ScmSecurityModule.java

+/**
+ * Copyright (c) 2010, Sebastian Sdorra All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ *
+ * 1. Redistributions of source code must retain the above copyright notice,
+ * this list of conditions and the following disclaimer. 2. Redistributions in
+ * binary form must reproduce the above copyright notice, this list of
+ * conditions and the following disclaimer in the documentation and/or other
+ * materials provided with the distribution. 3. Neither the name of SCM-Manager;
+ * nor the names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE FOR
+ * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
+ * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
+ * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
+ * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ * http://bitbucket.org/sdorra/scm-manager
+ *
+ */
+
+
+
+package sonia.scm;
+
+//~--- non-JDK imports --------------------------------------------------------
+
+import org.apache.shiro.guice.web.ShiroWebModule;
+
+import sonia.scm.security.ScmRealm;
+
+//~--- JDK imports ------------------------------------------------------------
+
+import javax.servlet.ServletContext;
+
+/**
+ *
+ * @author Sebastian Sdorra
+ */
+public class ScmSecurityModule extends ShiroWebModule
+{
+
+  /**
+   * Constructs ...
+   *
+   *
+   * @param servletContext
+   */
+  ScmSecurityModule(ServletContext servletContext)
+  {
+    super(servletContext);
+  }
+
+  //~--- methods --------------------------------------------------------------
+
+  /**
+   * Method description
+   *
+   */
+  @Override
+  protected void configureShiroWeb()
+  {
+    bindRealm().to(ScmRealm.class);
+  }
+}
Tip: Filter by directory path e.g. /media app.js to search for public/media/app.js.
Tip: Use camelCasing e.g. ProjME to search for ProjectModifiedEvent.java.
Tip: Filter by extension type e.g. /repo .js to search for all .js files in the /repo directory.
Tip: Separate your search with spaces e.g. /ssh pom.xml to search for src/ssh/pom.xml.
Tip: Use ↑ and ↓ arrow keys to navigate and return to view the file.
Tip: You can also navigate files with Ctrl+j (next) and Ctrl+k (previous) and view the file with Ctrl+o.
Tip: You can also navigate files with Alt+j (next) and Alt+k (previous) and view the file with Alt+o.