David Ostrovsky
2014-02-22 e3b636e7fa2a823cfe90ea75e88034a60f7e59e6
src/main/java/com/gitblit/git/RepositoryResolver.java
@@ -15,7 +15,6 @@
 */
package com.gitblit.git;
import java.io.File;
import java.io.IOException;
import java.text.MessageFormat;
@@ -28,9 +27,10 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.gitblit.GitBlit;
import com.gitblit.manager.IGitblit;
import com.gitblit.models.RepositoryModel;
import com.gitblit.models.UserModel;
import com.gitblit.transport.ssh.SshSession;
/**
 * Resolves repositories and grants export access.
@@ -42,8 +42,11 @@
   private final Logger logger = LoggerFactory.getLogger(RepositoryResolver.class);
   public RepositoryResolver(File repositoriesFolder) {
      super(repositoriesFolder, true);
   private final IGitblit gitblit;
   public RepositoryResolver(IGitblit gitblit) {
      super(gitblit.getRepositoriesFolder(), true);
      this.gitblit = gitblit;
   }
   /**
@@ -65,6 +68,9 @@
         // git request
         GitDaemonClient client = (GitDaemonClient) req;
         client.setRepositoryName(name);
      } else if (req instanceof SshSession) {
         SshSession s = (SshSession)req;
         s.setRepositoryName(name);
      }
      return repo;
   }
@@ -74,7 +80,7 @@
    */
   @Override
   protected boolean isExportOk(X req, String repositoryName, Repository db) throws IOException {
      RepositoryModel model = GitBlit.self().getRepositoryModel(repositoryName);
      RepositoryModel model = gitblit.getRepositoryModel(repositoryName);
      String scheme = null;
      UserModel user = null;
@@ -92,10 +98,16 @@
         HttpServletRequest httpRequest = (HttpServletRequest) req;
         scheme = httpRequest.getScheme();
         origin = httpRequest.getRemoteAddr();
         user = GitBlit.self().authenticate(httpRequest);
         user = gitblit.authenticate(httpRequest);
         if (user == null) {
            user = UserModel.ANONYMOUS;
         }
      } else if (req instanceof SshSession) {
         SshSession s = (SshSession) req;
         user = gitblit.authenticate(s);
         if (user == null) {
            throw new IOException(String.format("User %s not found",  s.getRemoteUser()));
         }
      }
      if (user.canClone(model)) {