summaryrefslogtreecommitdiffstats
path: root/modules
diff options
context:
space:
mode:
authorLunny Xiao <xiaolunwen@gmail.com>2016-12-22 20:26:43 +0800
committerThomas Boerger <thomas@webhippie.de>2016-12-22 13:26:43 +0100
commit65b1875d2bba97130f2796fe915f2a342ef7869c (patch)
tree07169fa476e103ccb10811be072d2368b9c474fe /modules
parent11df7ebfc5013ce6acc302fa7808f9c7cbe684de (diff)
downloadgitea-65b1875d2bba97130f2796fe915f2a342ef7869c.tar.gz
gitea-65b1875d2bba97130f2796fe915f2a342ef7869c.zip
New settings option for a custom SSH host (#3763) (#446)
* New settings option for a custom SSH host (#3763) * let default ssh listen addr empty
Diffstat (limited to 'modules')
-rw-r--r--modules/setting/setting.go1
-rw-r--r--modules/ssh/ssh.go10
2 files changed, 6 insertions, 5 deletions
diff --git a/modules/setting/setting.go b/modules/setting/setting.go
index d78b22c484..9c00eb7437 100644
--- a/modules/setting/setting.go
+++ b/modules/setting/setting.go
@@ -82,6 +82,7 @@ var (
StartBuiltinServer bool `ini:"START_SSH_SERVER"`
Domain string `ini:"SSH_DOMAIN"`
Port int `ini:"SSH_PORT"`
+ ListenHost string `ini:"SSH_LISTEN_HOST"`
ListenPort int `ini:"SSH_LISTEN_PORT"`
RootPath string `ini:"SSH_ROOT_PATH"`
KeyTestPath string `ini:"SSH_KEY_TEST_PATH"`
diff --git a/modules/ssh/ssh.go b/modules/ssh/ssh.go
index b35973cc32..056ef084ef 100644
--- a/modules/ssh/ssh.go
+++ b/modules/ssh/ssh.go
@@ -110,10 +110,10 @@ func handleServerConn(keyID string, chans <-chan ssh.NewChannel) {
}
}
-func listen(config *ssh.ServerConfig, port int) {
- listener, err := net.Listen("tcp", "0.0.0.0:"+com.ToStr(port))
+func listen(config *ssh.ServerConfig, host string, port int) {
+ listener, err := net.Listen("tcp", host+":"+com.ToStr(port))
if err != nil {
- panic(err)
+ log.Fatal(4, "Fail to start SSH server: %v", err)
}
for {
// Once a ServerConfig has been configured, connections can be accepted.
@@ -148,7 +148,7 @@ func listen(config *ssh.ServerConfig, port int) {
}
// Listen starts a SSH server listens on given port.
-func Listen(port int) {
+func Listen(host string, port int) {
config := &ssh.ServerConfig{
PublicKeyCallback: func(conn ssh.ConnMetadata, key ssh.PublicKey) (*ssh.Permissions, error) {
pkey, err := models.SearchPublicKeyByContent(strings.TrimSpace(string(ssh.MarshalAuthorizedKey(key))))
@@ -185,5 +185,5 @@ func Listen(port int) {
}
config.AddHostKey(private)
- go listen(config, port)
+ go listen(config, host, port)
}