diff options
author | James Moger <james.moger@gitblit.com> | 2014-04-02 13:54:23 -0400 |
---|---|---|
committer | James Moger <james.moger@gitblit.com> | 2014-04-10 19:01:30 -0400 |
commit | a9be3d2fb5e69ce3c9ac7b3963853cb338a0ca10 (patch) | |
tree | b2e5bf785405162746d469c819572474a79feb42 /src | |
parent | d85bfb7c9bdfdffbe2c598e9a2f34b6d92cc99d1 (diff) | |
download | gitblit-a9be3d2fb5e69ce3c9ac7b3963853cb338a0ca10.tar.gz gitblit-a9be3d2fb5e69ce3c9ac7b3963853cb338a0ca10.zip |
Add hostname and ssh repo url methodso to SshCommand
Diffstat (limited to 'src')
-rw-r--r-- | src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java b/src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java index 67e2805f..7008b5eb 100644 --- a/src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java +++ b/src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java @@ -16,11 +16,19 @@ package com.gitblit.transport.ssh.commands; import java.io.IOException; import java.io.PrintWriter; +import java.net.MalformedURLException; +import java.net.URL; +import java.text.MessageFormat; import org.apache.sshd.server.Environment; +import org.eclipse.jgit.util.SystemReader; import org.slf4j.Logger; import org.slf4j.LoggerFactory; +import com.gitblit.Keys; +import com.gitblit.manager.IGitblit; +import com.gitblit.utils.StringUtils; + public abstract class SshCommand extends BaseCommand { protected Logger log = LoggerFactory.getLogger(getClass()); @@ -45,5 +53,35 @@ public abstract class SshCommand extends BaseCommand { }); } + protected String getHostname() { + IGitblit gitblit = getContext().getGitblit(); + String host = null; + String url = gitblit.getSettings().getString(Keys.web.canonicalUrl, "https://localhost:8443"); + if (url != null) { + try { + host = new URL(url).getHost(); + } catch (MalformedURLException e) { + } + } + if (StringUtils.isEmpty(host)) { + host = SystemReader.getInstance().getHostname(); + } + return host; + } + + protected String getRepositoryUrl(String repository) { + String username = getContext().getClient().getUsername(); + String hostname = getHostname(); + int port = getContext().getGitblit().getSettings().getInteger(Keys.git.sshPort, 0); + if (port == 22) { + // standard port + return MessageFormat.format("{0}@{1}/{2}.git", username, hostname, repository); + } else { + // non-standard port + return MessageFormat.format("ssh://{0}@{1}:{2,number,0}/{3}", + username, hostname, port, repository); + } + } + protected abstract void run() throws UnloggedFailure, Failure, Exception; } |