summaryrefslogtreecommitdiffstats
path: root/modules/setting
diff options
context:
space:
mode:
authorUnknwon <u@gogs.io>2016-02-27 20:48:39 -0500
committerUnknwon <u@gogs.io>2016-02-27 20:48:39 -0500
commit8055a0bdac005189077df69870cd2ed0b7eebd56 (patch)
treebf3fa2bf419006ea846315eef48fb5e83378376c /modules/setting
parent83c74878df3f6edec4fca51e9cec299d2a1bb897 (diff)
downloadgitea-8055a0bdac005189077df69870cd2ed0b7eebd56.tar.gz
gitea-8055a0bdac005189077df69870cd2ed0b7eebd56.zip
Post work for #2637
Improve test cases, config settings, also show SSH config settings on admin config panel.
Diffstat (limited to 'modules/setting')
-rw-r--r--modules/setting/setting.go105
1 files changed, 46 insertions, 59 deletions
diff --git a/modules/setting/setting.go b/modules/setting/setting.go
index 2b1b553126..80d807f851 100644
--- a/modules/setting/setting.go
+++ b/modules/setting/setting.go
@@ -27,11 +27,6 @@ import (
"github.com/gogits/gogs/modules/user"
)
-const (
- SSH_PUBLICKEY_CHECK_NATIVE = "native"
- SSH_PUBLICKEY_CHECK_KEYGEN = "ssh-keygen"
-)
-
type Scheme string
const (
@@ -66,15 +61,6 @@ var (
Domain string
HttpAddr, HttpPort string
LocalURL string
- DisableSSH bool
- StartSSHServer bool
- SSHDomain string
- SSHPort int
- SSHListenPort int
- SSHRootPath string
- SSHPublicKeyCheck string
- SSHWorkPath string
- SSHKeyGenPath string
OfflineMode bool
DisableRouterLog bool
CertFile, KeyFile string
@@ -82,6 +68,19 @@ var (
EnableGzip bool
LandingPageUrl LandingPage
+ SSH struct {
+ Disabled bool `ini:"DISABLE_SSH"`
+ StartBuiltinServer bool `ini:"START_SSH_SERVER"`
+ Domain string `ini:"SSH_DOMAIN"`
+ Port int `ini:"SSH_PORT"`
+ ListenPort int `ini:"SSH_LISTEN_PORT"`
+ RootPath string `ini:"SSH_ROOT_PATH"`
+ KeyTestPath string `ini:"SSH_KEY_TEST_PATH"`
+ KeygenPath string `ini:"SSH_KEYGEN_PATH"`
+ MinimumKeySizeCheck bool `ini:"-"`
+ MinimumKeySizes map[string]int `ini:"-"`
+ }
+
// Security settings
InstallLock bool
SecretKey string
@@ -327,40 +326,6 @@ func NewContext() {
HttpAddr = sec.Key("HTTP_ADDR").MustString("0.0.0.0")
HttpPort = sec.Key("HTTP_PORT").MustString("3000")
LocalURL = sec.Key("LOCAL_ROOT_URL").MustString("http://localhost:" + HttpPort + "/")
- DisableSSH = sec.Key("DISABLE_SSH").MustBool()
- if !DisableSSH {
- StartSSHServer = sec.Key("START_SSH_SERVER").MustBool()
- }
- SSHDomain = sec.Key("SSH_DOMAIN").MustString(Domain)
- SSHPort = sec.Key("SSH_PORT").MustInt(22)
- SSHListenPort = sec.Key("SSH_LISTEN_PORT").MustInt(SSHPort)
- SSHRootPath = sec.Key("SSH_ROOT_PATH").MustString(path.Join(homeDir, ".ssh"))
- if err := os.MkdirAll(SSHRootPath, 0700); err != nil {
- log.Fatal(4, "Fail to create '%s': %v", SSHRootPath, err)
- }
- checkDefault := SSH_PUBLICKEY_CHECK_KEYGEN
- if StartSSHServer {
- checkDefault = SSH_PUBLICKEY_CHECK_NATIVE
- }
- SSHPublicKeyCheck = sec.Key("SSH_PUBLICKEY_CHECK").MustString(checkDefault)
- if SSHPublicKeyCheck != SSH_PUBLICKEY_CHECK_NATIVE &&
- SSHPublicKeyCheck != SSH_PUBLICKEY_CHECK_KEYGEN {
- log.Fatal(4, "SSH_PUBLICKEY_CHECK must be ssh-keygen or native")
- }
- SSHWorkPath = sec.Key("SSH_WORK_PATH").MustString(os.TempDir())
- if !DisableSSH && (!StartSSHServer || SSHPublicKeyCheck == SSH_PUBLICKEY_CHECK_KEYGEN) {
- if tmpDirStat, err := os.Stat(SSHWorkPath); err != nil || !tmpDirStat.IsDir() {
- log.Fatal(4, "directory '%s' set in SSHWorkPath is not a directory: %s", SSHWorkPath, err)
- }
- }
- SSHKeyGenPath = sec.Key("SSH_KEYGEN_PATH").MustString("")
- if !DisableSSH && !StartSSHServer &&
- SSHKeyGenPath == "" && SSHPublicKeyCheck == SSH_PUBLICKEY_CHECK_KEYGEN {
- SSHKeyGenPath, err = exec.LookPath("ssh-keygen")
- if err != nil {
- log.Fatal(4, "could not find ssh-keygen, maybe set DISABLE_SSH to use the internal ssh server")
- }
- }
OfflineMode = sec.Key("OFFLINE_MODE").MustBool()
DisableRouterLog = sec.Key("DISABLE_ROUTER_LOG").MustBool()
StaticRootPath = sec.Key("STATIC_ROOT_PATH").MustString(workDir)
@@ -373,6 +338,39 @@ func NewContext() {
LandingPageUrl = LANDING_PAGE_HOME
}
+ SSH.RootPath = path.Join(homeDir, ".ssh")
+ SSH.KeyTestPath = os.TempDir()
+ if err = Cfg.Section("server").MapTo(&SSH); err != nil {
+ log.Fatal(4, "Fail to map SSH settings: %v", err)
+ }
+ // When disable SSH, start builtin server value is ignored.
+ if SSH.Disabled {
+ SSH.StartBuiltinServer = false
+ }
+
+ if !SSH.Disabled && !SSH.StartBuiltinServer {
+ if err := os.MkdirAll(SSH.RootPath, 0700); err != nil {
+ log.Fatal(4, "Fail to create '%s': %v", SSH.RootPath, err)
+ } else if err = os.MkdirAll(SSH.KeyTestPath, 0644); err != nil {
+ log.Fatal(4, "Fail to create '%s': %v", SSH.KeyTestPath, err)
+ }
+
+ if !filepath.IsAbs(SSH.KeygenPath) {
+ if _, err := exec.LookPath(SSH.KeygenPath); err != nil {
+ log.Fatal(4, "Fail to test '%s' command: %v (forgotten install?)", SSH.KeygenPath, err)
+ }
+ }
+ }
+
+ SSH.MinimumKeySizeCheck = sec.Key("MINIMUM_KEY_SIZE_CHECK").MustBool()
+ SSH.MinimumKeySizes = map[string]int{}
+ minimumKeySizes := Cfg.Section("ssh.minimum_key_sizes").Keys()
+ for _, key := range minimumKeySizes {
+ if key.MustInt() != -1 {
+ SSH.MinimumKeySizes[strings.ToLower(key.Name())] = key.MustInt()
+ }
+ }
+
sec = Cfg.Section("security")
InstallLock = sec.Key("INSTALL_LOCK").MustBool()
SecretKey = sec.Key("SECRET_KEY").String()
@@ -492,8 +490,6 @@ var Service struct {
EnableReverseProxyAuth bool
EnableReverseProxyAutoRegister bool
EnableCaptcha bool
- EnableMinimumKeySizeCheck bool
- MinimumKeySizes map[string]int
}
func newService() {
@@ -506,15 +502,6 @@ func newService() {
Service.EnableReverseProxyAuth = sec.Key("ENABLE_REVERSE_PROXY_AUTHENTICATION").MustBool()
Service.EnableReverseProxyAutoRegister = sec.Key("ENABLE_REVERSE_PROXY_AUTO_REGISTRATION").MustBool()
Service.EnableCaptcha = sec.Key("ENABLE_CAPTCHA").MustBool()
- Service.EnableMinimumKeySizeCheck = sec.Key("ENABLE_MINIMUM_KEY_SIZE_CHECK").MustBool()
- Service.MinimumKeySizes = map[string]int{}
-
- minimumKeySizes := Cfg.Section("service.minimum_key_sizes").Keys()
- for _, key := range minimumKeySizes {
- if key.MustInt() != -1 {
- Service.MinimumKeySizes[strings.ToLower(key.Name())] = key.MustInt()
- }
- }
}
var logLevels = map[string]string{