Author: doll
Date: Thu Apr 17 06:19:42 2008
New Revision: 649085

URL: http://svn.apache.org/viewvc?rev=649085&view=rev
Log:
Removed the gadgets guice dependency on the social directories by creating a 
new social specific guice module.


Added:
    
incubator/shindig/trunk/java/social-api/src/main/java/org/apache/shindig/social/SocialApiGuiceModule.java
Modified:
    
incubator/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/DefaultGuiceModule.java
    incubator/shindig/trunk/java/social-api/src/main/webapp/WEB-INF/web.xml

Modified: 
incubator/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/DefaultGuiceModule.java
URL: 
http://svn.apache.org/viewvc/incubator/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/DefaultGuiceModule.java?rev=649085&r1=649084&r2=649085&view=diff
==============================================================================
--- 
incubator/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/DefaultGuiceModule.java
 (original)
+++ 
incubator/shindig/trunk/java/gadgets/src/main/java/org/apache/shindig/gadgets/DefaultGuiceModule.java
 Thu Apr 17 06:19:42 2008
@@ -21,28 +21,15 @@
 import com.google.inject.AbstractModule;
 import com.google.inject.CreationException;
 import com.google.inject.Inject;
-import com.google.inject.Provider;
 import com.google.inject.Scopes;
-import com.google.inject.TypeLiteral;
 import com.google.inject.name.Names;
 import com.google.inject.spi.Message;
 import org.apache.shindig.gadgets.oauth.OAuthFetcherFactory;
-import org.apache.shindig.social.GadgetDataHandler;
-import org.apache.shindig.social.opensocial.ActivitiesService;
-import org.apache.shindig.social.opensocial.DataService;
-import org.apache.shindig.social.opensocial.OpenSocialDataHandler;
-import org.apache.shindig.social.opensocial.PeopleService;
-import org.apache.shindig.social.samplecontainer.BasicActivitiesService;
-import org.apache.shindig.social.samplecontainer.BasicDataService;
-import org.apache.shindig.social.samplecontainer.BasicPeopleService;
-import org.apache.shindig.social.samplecontainer.StateFileDataHandler;
 import org.apache.shindig.util.ResourceLoader;
 
 import java.io.IOException;
 import java.io.InputStream;
-import java.util.ArrayList;
 import java.util.Arrays;
-import java.util.List;
 import java.util.Properties;
 import java.util.concurrent.Executor;
 import java.util.concurrent.Executors;
@@ -77,15 +64,6 @@
     bind(ContainerConfig.class).in(Scopes.SINGLETON);
     bind(GadgetFeatureRegistry.class).in(Scopes.SINGLETON);
     bind(GadgetServer.class).in(Scopes.SINGLETON);
-
-    // Social guice
-    bind(PeopleService.class).to(BasicPeopleService.class);
-    bind(DataService.class).to(BasicDataService.class);
-    bind(ActivitiesService.class).to(BasicActivitiesService.class);
-
-    bind(new TypeLiteral<List<GadgetDataHandler>>() {})
-        .toProvider(GadgetDataHandlersProvider.class);
-
   }
 
   public DefaultGuiceModule(Properties properties) {
@@ -106,22 +84,5 @@
           new Message("Unable to load properties: " + DEFAULT_PROPERTIES)));
     }
     this.properties = properties;
-  }
-
-  public static class GadgetDataHandlersProvider
-      implements Provider<List<GadgetDataHandler>> {
-    List<GadgetDataHandler> handlers;
-
-    @Inject
-    public GadgetDataHandlersProvider(OpenSocialDataHandler
-        openSocialDataHandler, StateFileDataHandler stateFileHandler) {
-      handlers = new ArrayList<GadgetDataHandler>();
-      handlers.add(openSocialDataHandler);
-      handlers.add(stateFileHandler);
-    }
-
-    public List<GadgetDataHandler> get() {
-      return handlers;
-    }
   }
 }

Added: 
incubator/shindig/trunk/java/social-api/src/main/java/org/apache/shindig/social/SocialApiGuiceModule.java
URL: 
http://svn.apache.org/viewvc/incubator/shindig/trunk/java/social-api/src/main/java/org/apache/shindig/social/SocialApiGuiceModule.java?rev=649085&view=auto
==============================================================================
--- 
incubator/shindig/trunk/java/social-api/src/main/java/org/apache/shindig/social/SocialApiGuiceModule.java
 (added)
+++ 
incubator/shindig/trunk/java/social-api/src/main/java/org/apache/shindig/social/SocialApiGuiceModule.java
 Thu Apr 17 06:19:42 2008
@@ -0,0 +1,77 @@
+/*
+ * Licensed to the Apache Software Foundation (ASF) under one
+ * or more contributor license agreements.  See the NOTICE file
+ * distributed with this work for additional information
+ * regarding copyright ownership.  The ASF licenses this file
+ * to you under the Apache 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.apache.org/licenses/LICENSE-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.apache.shindig.social;
+
+import com.google.inject.AbstractModule;
+import com.google.inject.Inject;
+import com.google.inject.Provider;
+import com.google.inject.TypeLiteral;
+import org.apache.shindig.social.opensocial.ActivitiesService;
+import org.apache.shindig.social.opensocial.PeopleService;
+import org.apache.shindig.social.opensocial.DataService;
+import org.apache.shindig.social.opensocial.OpenSocialDataHandler;
+import org.apache.shindig.social.samplecontainer.BasicActivitiesService;
+import org.apache.shindig.social.samplecontainer.BasicPeopleService;
+import org.apache.shindig.social.samplecontainer.BasicDataService;
+import org.apache.shindig.social.samplecontainer.StateFileDataHandler;
+import org.apache.shindig.gadgets.RemoteContentFetcher;
+import org.apache.shindig.gadgets.BasicRemoteContentFetcher;
+import org.apache.shindig.gadgets.GadgetTokenDecoder;
+import org.apache.shindig.gadgets.BasicGadgetTokenDecoder;
+
+import java.util.Properties;
+import java.util.List;
+import java.util.ArrayList;
+
+/**
+ * Provides http component injection on top of existing components.
+ */
+public class SocialApiGuiceModule extends AbstractModule {
+
+  /** [EMAIL PROTECTED] */
+  @Override
+  protected void configure() {
+    bind(RemoteContentFetcher.class).to(BasicRemoteContentFetcher.class);
+    bind(GadgetTokenDecoder.class).to(BasicGadgetTokenDecoder.class);
+
+    bind(PeopleService.class).to(BasicPeopleService.class);
+    bind(DataService.class).to(BasicDataService.class);
+    bind(ActivitiesService.class).to(BasicActivitiesService.class);
+
+    bind(new TypeLiteral<List<GadgetDataHandler>>() {})
+        .toProvider(GadgetDataHandlersProvider.class);
+  }
+
+  public static class GadgetDataHandlersProvider
+      implements Provider<List<GadgetDataHandler>> {
+    List<GadgetDataHandler> handlers;
+
+    @Inject
+    public GadgetDataHandlersProvider(OpenSocialDataHandler
+        openSocialDataHandler, StateFileDataHandler stateFileHandler) {
+      handlers = new ArrayList<GadgetDataHandler>();
+      handlers.add(openSocialDataHandler);
+      handlers.add(stateFileHandler);
+    }
+
+    public List<GadgetDataHandler> get() {
+      return handlers;
+    }
+  }
+}

Modified: 
incubator/shindig/trunk/java/social-api/src/main/webapp/WEB-INF/web.xml
URL: 
http://svn.apache.org/viewvc/incubator/shindig/trunk/java/social-api/src/main/webapp/WEB-INF/web.xml?rev=649085&r1=649084&r2=649085&view=diff
==============================================================================
--- incubator/shindig/trunk/java/social-api/src/main/webapp/WEB-INF/web.xml 
(original)
+++ incubator/shindig/trunk/java/social-api/src/main/webapp/WEB-INF/web.xml Thu 
Apr 17 06:19:42 2008
@@ -26,7 +26,7 @@
   <!-- If you have your own Guice module(s), put them here as a 
colon-separated list. -->
   <context-param>
     <param-name>guice-modules</param-name>
-    <param-value>org.apache.shindig.gadgets.http.HttpGuiceModule</param-value>
+    <param-value>org.apache.shindig.social.SocialApiGuiceModule</param-value>
   </context-param>
 
   <listener>


Reply via email to