mirror of
https://github.com/scm-manager/scm-manager.git
synced 2025-11-03 12:05:52 +01:00
Generalize servlet decorator structure
This commit is contained in:
@@ -0,0 +1,28 @@
|
||||
package sonia.scm.repository.spi;
|
||||
|
||||
import sonia.scm.repository.Repository;
|
||||
|
||||
import javax.servlet.ServletConfig;
|
||||
import javax.servlet.ServletException;
|
||||
import javax.servlet.http.HttpServletRequest;
|
||||
import javax.servlet.http.HttpServletResponse;
|
||||
import java.io.IOException;
|
||||
|
||||
public class ScmProviderHttpServletDecorator implements ScmProviderHttpServlet {
|
||||
|
||||
private final ScmProviderHttpServlet object;
|
||||
|
||||
public ScmProviderHttpServletDecorator(ScmProviderHttpServlet object) {
|
||||
this.object = object;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void service(HttpServletRequest request, HttpServletResponse response, Repository repository) throws ServletException, IOException {
|
||||
object.service(request, response, repository);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void init(ServletConfig config) throws ServletException {
|
||||
object.init(config);
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,15 @@
|
||||
package sonia.scm.repository.spi;
|
||||
|
||||
import sonia.scm.DecoratorFactory;
|
||||
import sonia.scm.plugin.ExtensionPoint;
|
||||
|
||||
@ExtensionPoint
|
||||
public interface ScmProviderHttpServletDecoratorFactory extends DecoratorFactory<ScmProviderHttpServlet> {
|
||||
/**
|
||||
* Has to return <code>true</code> if this factory provides a decorator for the given scm type (eg. "git", "hg" or
|
||||
* "svn").
|
||||
* @param type The current scm type this factory can provide a decorator for.
|
||||
* @return <code>true</code> when the provided decorator should be used for the given scm type.
|
||||
*/
|
||||
boolean handlesScmType(String type);
|
||||
}
|
||||
@@ -1,7 +0,0 @@
|
||||
package sonia.scm.repository.spi;
|
||||
|
||||
import sonia.scm.DecoratorFactory;
|
||||
import sonia.scm.plugin.ExtensionPoint;
|
||||
|
||||
@ExtensionPoint
|
||||
public interface ScmProviderHttpServletFactory extends DecoratorFactory<ScmProviderHttpServlet> {}
|
||||
@@ -1,22 +1,16 @@
|
||||
package sonia.scm.web;
|
||||
|
||||
import com.google.inject.Inject;
|
||||
import sonia.scm.repository.spi.ScmProviderHttpServlet;
|
||||
import sonia.scm.repository.spi.ScmProviderHttpServletFactory;
|
||||
import sonia.scm.util.Decorators;
|
||||
|
||||
import javax.inject.Provider;
|
||||
import java.util.Set;
|
||||
|
||||
public class ScmGitServletProvider implements Provider<ScmProviderHttpServlet> {
|
||||
public class ScmGitServletProvider extends ScmProviderHttpServletProvider {
|
||||
|
||||
@Inject
|
||||
private Provider<ScmGitServlet> scmGitServlet;
|
||||
@Inject(optional = true)
|
||||
private Set<ScmProviderHttpServletFactory> decoratorFactories;
|
||||
|
||||
@Override
|
||||
public ScmProviderHttpServlet get() {
|
||||
return Decorators.decorate(scmGitServlet.get(), decoratorFactories);
|
||||
protected ScmGitServlet getRootServlet() {
|
||||
return scmGitServlet.get();
|
||||
}
|
||||
}
|
||||
|
||||
@@ -0,0 +1,24 @@
|
||||
package sonia.scm.web;
|
||||
|
||||
import com.google.inject.Inject;
|
||||
import sonia.scm.repository.spi.ScmProviderHttpServlet;
|
||||
import sonia.scm.repository.spi.ScmProviderHttpServletDecoratorFactory;
|
||||
import sonia.scm.util.Decorators;
|
||||
|
||||
import javax.inject.Provider;
|
||||
import java.util.Set;
|
||||
|
||||
import static java.util.stream.Collectors.toList;
|
||||
|
||||
public abstract class ScmProviderHttpServletProvider implements Provider<ScmProviderHttpServlet> {
|
||||
|
||||
@Inject(optional = true)
|
||||
private Set<ScmProviderHttpServletDecoratorFactory> decoratorFactories;
|
||||
|
||||
@Override
|
||||
public ScmProviderHttpServlet get() {
|
||||
return Decorators.decorate(getRootServlet(), decoratorFactories.stream().filter(d -> d.handlesScmType("git")).collect(toList()));
|
||||
}
|
||||
|
||||
protected abstract ScmProviderHttpServlet getRootServlet();
|
||||
}
|
||||
Reference in New Issue
Block a user