David Ostrovsky
2014-03-11 b799d545f37f7123aaa1ee1d0ff3b61f1f3cc8c2
src/main/java/com/gitblit/git/RepositoryResolver.java
@@ -27,9 +27,11 @@
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.git.GitDaemonClient;
import com.gitblit.transport.ssh.SshSession;
/**
 * Resolves repositories and grants export access.
@@ -41,9 +43,9 @@
   private final Logger logger = LoggerFactory.getLogger(RepositoryResolver.class);
   private final GitBlit gitblit;
   private final IGitblit gitblit;
   public RepositoryResolver(GitBlit gitblit) {
   public RepositoryResolver(IGitblit gitblit) {
      super(gitblit.getRepositoriesFolder(), true);
      this.gitblit = gitblit;
   }
@@ -67,6 +69,9 @@
         // git request
         GitDaemonClient client = (GitDaemonClient) req;
         client.setRepositoryName(name);
      } else if (req instanceof SshSession) {
         SshSession s = (SshSession)req;
         s.setRepositoryName(name);
      }
      return repo;
   }
@@ -98,6 +103,12 @@
         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)) {