Paul Martin
2016-04-30 a502d96a860456ec5e8c96761db70f7cabb74751
src/main/java/com/gitblit/transport/ssh/commands/SshCommand.java
@@ -1,17 +1,19 @@
// Copyright (C) 2012 The Android Open Source Project
//
// 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.
/*
 * Copyright (C) 2012 The Android Open Source Project
 * 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.transport.ssh.commands;
import java.io.IOException;
@@ -25,6 +27,7 @@
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.gitblit.IStoredSettings;
import com.gitblit.Keys;
import com.gitblit.manager.IGitblit;
import com.gitblit.utils.StringUtils;
@@ -71,17 +74,22 @@
   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) {
      IStoredSettings settings = getContext().getGitblit().getSettings();
      String displayHostname = settings.getString(Keys.git.sshAdvertisedHost, "");
      if(displayHostname.isEmpty()) {
         displayHostname = getHostname();
      }
      int port = settings.getInteger(Keys.git.sshPort, 0);
      int displayPort = settings.getInteger(Keys.git.sshAdvertisedPort, port);
      if (displayPort == 22) {
         // standard port
         return MessageFormat.format("{0}@{1}/{2}.git", username, hostname, repository);
         return MessageFormat.format("{0}@{1}/{2}.git", username, displayHostname, repository);
      } else {
         // non-standard port
         return MessageFormat.format("ssh://{0}@{1}:{2,number,0}/{3}",
               username, hostname, port, repository);
               username, displayHostname, displayPort, repository);
      }
   }
   protected abstract void run() throws UnloggedFailure, Failure, Exception;
   protected abstract void run() throws Failure, Exception;
}