diff options
Diffstat (limited to 'src/main/java/com/gitblit')
-rw-r--r-- | src/main/java/com/gitblit/DaggerModule.java | 13 | ||||
-rw-r--r-- | src/main/java/com/gitblit/FederationClient.java | 2 | ||||
-rw-r--r-- | src/main/java/com/gitblit/GitBlit.java | 7 | ||||
-rw-r--r-- | src/main/java/com/gitblit/dagger/DaggerFilter.java | 2 | ||||
-rw-r--r-- | src/main/java/com/gitblit/manager/GitblitManager.java | 18 | ||||
-rw-r--r-- | src/main/java/com/gitblit/manager/IGitblit.java | 3 | ||||
-rw-r--r-- | src/main/java/com/gitblit/manager/IPluginManager.java | 39 | ||||
-rw-r--r-- | src/main/java/com/gitblit/manager/PluginManager.java | 56 | ||||
-rw-r--r-- | src/main/java/com/gitblit/servlet/GitblitContext.java | 2 | ||||
-rw-r--r-- | src/main/java/com/gitblit/servlet/SyndicationFilter.java | 1 |
10 files changed, 135 insertions, 8 deletions
diff --git a/src/main/java/com/gitblit/DaggerModule.java b/src/main/java/com/gitblit/DaggerModule.java index b109f1db..1805c4ec 100644 --- a/src/main/java/com/gitblit/DaggerModule.java +++ b/src/main/java/com/gitblit/DaggerModule.java @@ -19,9 +19,11 @@ import javax.inject.Singleton; import com.gitblit.manager.AuthenticationManager; import com.gitblit.manager.FederationManager; +import com.gitblit.manager.PluginManager; import com.gitblit.manager.IAuthenticationManager; import com.gitblit.manager.IFederationManager; import com.gitblit.manager.IGitblit; +import com.gitblit.manager.IPluginManager; import com.gitblit.manager.INotificationManager; import com.gitblit.manager.IProjectManager; import com.gitblit.manager.IRepositoryManager; @@ -62,6 +64,7 @@ import dagger.Provides; IRepositoryManager.class, IProjectManager.class, IFederationManager.class, + IPluginManager.class, // the monolithic manager IGitblit.class, @@ -88,6 +91,10 @@ public class DaggerModule { return new UserManager(runtimeManager); } + @Provides @Singleton IPluginManager providePluginManager(IRuntimeManager runtimeManager) { + return new PluginManager(runtimeManager); + } + @Provides @Singleton IAuthenticationManager provideAuthenticationManager( IRuntimeManager runtimeManager, IUserManager userManager) { @@ -161,7 +168,8 @@ public class DaggerModule { IPublicKeyManager publicKeyManager, IRepositoryManager repositoryManager, IProjectManager projectManager, - IFederationManager federationManager) { + IFederationManager federationManager, + IPluginManager pluginManager) { return new GitBlit( runtimeManager, @@ -171,7 +179,8 @@ public class DaggerModule { publicKeyManager, repositoryManager, projectManager, - federationManager); + federationManager, + pluginManager); } @Provides @Singleton GitBlitWebApp provideWebApplication( diff --git a/src/main/java/com/gitblit/FederationClient.java b/src/main/java/com/gitblit/FederationClient.java index d20025f0..67a68654 100644 --- a/src/main/java/com/gitblit/FederationClient.java +++ b/src/main/java/com/gitblit/FederationClient.java @@ -97,7 +97,7 @@ public class FederationClient { UserManager users = new UserManager(runtime).start();
RepositoryManager repositories = new RepositoryManager(runtime, users).start();
FederationManager federation = new FederationManager(runtime, notifications, repositories).start();
- IGitblit gitblit = new GitblitManager(runtime, notifications, users, null, null, repositories, null, federation);
+ IGitblit gitblit = new GitblitManager(runtime, notifications, users, null, null, repositories, null, federation, null);
FederationPullService puller = new FederationPullService(gitblit, federation.getFederationRegistrations()) {
@Override
diff --git a/src/main/java/com/gitblit/GitBlit.java b/src/main/java/com/gitblit/GitBlit.java index b223d03c..147b2e16 100644 --- a/src/main/java/com/gitblit/GitBlit.java +++ b/src/main/java/com/gitblit/GitBlit.java @@ -28,6 +28,7 @@ import com.gitblit.manager.IAuthenticationManager; import com.gitblit.manager.IFederationManager; import com.gitblit.manager.IGitblit; import com.gitblit.manager.INotificationManager; +import com.gitblit.manager.IPluginManager; import com.gitblit.manager.IProjectManager; import com.gitblit.manager.IRepositoryManager; import com.gitblit.manager.IRuntimeManager; @@ -71,7 +72,8 @@ public class GitBlit extends GitblitManager { IPublicKeyManager publicKeyManager, IRepositoryManager repositoryManager, IProjectManager projectManager, - IFederationManager federationManager) { + IFederationManager federationManager, + IPluginManager pluginManager) { super(runtimeManager, notificationManager, @@ -80,7 +82,8 @@ public class GitBlit extends GitblitManager { publicKeyManager, repositoryManager, projectManager, - federationManager); + federationManager, + pluginManager); this.injector = ObjectGraph.create(getModules()); diff --git a/src/main/java/com/gitblit/dagger/DaggerFilter.java b/src/main/java/com/gitblit/dagger/DaggerFilter.java index 1c73d4b7..68fe6058 100644 --- a/src/main/java/com/gitblit/dagger/DaggerFilter.java +++ b/src/main/java/com/gitblit/dagger/DaggerFilter.java @@ -39,7 +39,7 @@ public abstract class DaggerFilter implements Filter { inject(objectGraph);
}
- protected abstract void inject(ObjectGraph dagger);
+ protected abstract void inject(ObjectGraph dagger) throws ServletException;
@Override
public void destroy() {
diff --git a/src/main/java/com/gitblit/manager/GitblitManager.java b/src/main/java/com/gitblit/manager/GitblitManager.java index 8856715a..34c101e2 100644 --- a/src/main/java/com/gitblit/manager/GitblitManager.java +++ b/src/main/java/com/gitblit/manager/GitblitManager.java @@ -43,6 +43,8 @@ import org.eclipse.jgit.transport.RefSpec; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import ro.fortsoft.pf4j.PluginWrapper; + import com.gitblit.Constants; import com.gitblit.Constants.AccessPermission; import com.gitblit.Constants.AccessRestrictionType; @@ -116,6 +118,8 @@ public class GitblitManager implements IGitblit { protected final IFederationManager federationManager; + protected final IPluginManager pluginManager; + public GitblitManager( IRuntimeManager runtimeManager, INotificationManager notificationManager, @@ -124,7 +128,8 @@ public class GitblitManager implements IGitblit { IPublicKeyManager publicKeyManager, IRepositoryManager repositoryManager, IProjectManager projectManager, - IFederationManager federationManager) { + IFederationManager federationManager, + IPluginManager pluginManager) { this.settings = runtimeManager.getSettings(); this.runtimeManager = runtimeManager; @@ -135,6 +140,7 @@ public class GitblitManager implements IGitblit { this.repositoryManager = repositoryManager; this.projectManager = projectManager; this.federationManager = federationManager; + this.pluginManager = pluginManager; } @Override @@ -1171,4 +1177,14 @@ public class GitblitManager implements IGitblit { public boolean isIdle(Repository repository) { return repositoryManager.isIdle(repository); } + + @Override + public <T> List<T> getExtensions(Class<T> clazz) { + return pluginManager.getExtensions(clazz); + } + + @Override + public PluginWrapper whichPlugin(Class<?> clazz) { + return pluginManager.whichPlugin(clazz); + } } diff --git a/src/main/java/com/gitblit/manager/IGitblit.java b/src/main/java/com/gitblit/manager/IGitblit.java index f4221cf9..7961a06b 100644 --- a/src/main/java/com/gitblit/manager/IGitblit.java +++ b/src/main/java/com/gitblit/manager/IGitblit.java @@ -36,7 +36,8 @@ public interface IGitblit extends IManager, IAuthenticationManager, IRepositoryManager, IProjectManager, - IFederationManager { + IFederationManager, + IPluginManager { /** * Returns a list of repository URLs and the user access permission. diff --git a/src/main/java/com/gitblit/manager/IPluginManager.java b/src/main/java/com/gitblit/manager/IPluginManager.java new file mode 100644 index 00000000..670e9769 --- /dev/null +++ b/src/main/java/com/gitblit/manager/IPluginManager.java @@ -0,0 +1,39 @@ +/* + * Copyright 2014 gitblit.com. + * + * Licensed 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 com.gitblit.manager; + +import java.util.List; + +import ro.fortsoft.pf4j.PluginWrapper; + +public interface IPluginManager extends IManager { + + /** + * Retrieves the extension for given class 'clazz'. + * + * @param clazz extension point class to retrieve extension for + * @return list of extensions + */ + public <T> List<T> getExtensions(Class<T> clazz); + + /** + * Retrieves the {@link PluginWrapper} that loaded the given class 'clazz'. + * + * @param clazz extension point class to retrieve extension for + * @return PluginWrapper that loaded the given class + */ + public PluginWrapper whichPlugin(Class<?> clazz); +} diff --git a/src/main/java/com/gitblit/manager/PluginManager.java b/src/main/java/com/gitblit/manager/PluginManager.java new file mode 100644 index 00000000..5eb00e92 --- /dev/null +++ b/src/main/java/com/gitblit/manager/PluginManager.java @@ -0,0 +1,56 @@ +/* + * Copyright 2014 gitblit.com. + * + * Licensed 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 com.gitblit.manager; + +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; + +import ro.fortsoft.pf4j.DefaultPluginManager; + +import com.gitblit.Keys; + +/** + * The plugin manager maintains the lifecycle of plugins. It is exposed as + * Dagger bean. The extension consumers supposed to retrieve plugin manager + * from the Dagger DI and retrieve extensions provided by active plugins. + * + * @author David Ostrovsky + * + */ +public class PluginManager extends DefaultPluginManager implements + IPluginManager { + + private final Logger logger = LoggerFactory.getLogger(getClass()); + + public PluginManager(IRuntimeManager runtimeManager) { + super(runtimeManager.getFileOrFolder(Keys.plugins.folder, + "${baseFolder}/plugins")); + } + + @Override + public PluginManager start() { + logger.info("Plugin manager started"); + loadPlugins(); + startPlugins(); + return this; + } + + @Override + public PluginManager stop() { + stopPlugins(); + return null; + } +} diff --git a/src/main/java/com/gitblit/servlet/GitblitContext.java b/src/main/java/com/gitblit/servlet/GitblitContext.java index cf8bba01..a98fe192 100644 --- a/src/main/java/com/gitblit/servlet/GitblitContext.java +++ b/src/main/java/com/gitblit/servlet/GitblitContext.java @@ -41,6 +41,7 @@ import com.gitblit.dagger.DaggerContext; import com.gitblit.manager.IAuthenticationManager; import com.gitblit.manager.IFederationManager; import com.gitblit.manager.IGitblit; +import com.gitblit.manager.IPluginManager; import com.gitblit.manager.IManager; import com.gitblit.manager.INotificationManager; import com.gitblit.manager.IProjectManager; @@ -184,6 +185,7 @@ public class GitblitContext extends DaggerContext { startManager(injector, IProjectManager.class); startManager(injector, IFederationManager.class); startManager(injector, IGitblit.class); + startManager(injector, IPluginManager.class); logger.info(""); logger.info("All managers started."); diff --git a/src/main/java/com/gitblit/servlet/SyndicationFilter.java b/src/main/java/com/gitblit/servlet/SyndicationFilter.java index 67a845ea..b399588b 100644 --- a/src/main/java/com/gitblit/servlet/SyndicationFilter.java +++ b/src/main/java/com/gitblit/servlet/SyndicationFilter.java @@ -19,6 +19,7 @@ import java.io.IOException; import java.text.MessageFormat;
import javax.servlet.FilterChain;
+import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
|