diff options
author | Don Bowman <don.waterloo@gmail.com> | 2015-08-12 21:10:00 +0000 |
---|---|---|
committer | Don Bowman <don.waterloo@gmail.com> | 2015-08-12 21:10:00 +0000 |
commit | 1cb46ede1acf4f8527e64fcae7e92672cad764b2 (patch) | |
tree | fabb54ee5f040be2a4ee5c95f87cb3e9fbf7bdea /routers/install.go | |
parent | 9e6bd31d76aa6d6495a2144466af78773f34d07c (diff) | |
parent | aede5cdb04fdbf74d9c602062fdece9f408e90f4 (diff) |
Merge branch 'master' of https://github.com/gogits/gogs
Conflicts:
routers/repo/download.go
Diffstat (limited to 'routers/install.go')
-rw-r--r-- | routers/install.go | 85 |
1 files changed, 68 insertions, 17 deletions
diff --git a/routers/install.go b/routers/install.go index f5dc0c58..3d3e8997 100644 --- a/routers/install.go +++ b/routers/install.go @@ -36,6 +36,7 @@ func checkRunMode() { switch setting.Cfg.Section("").Key("RUN_MODE").String() { case "prod": macaron.Env = macaron.PROD + macaron.ColorLog = false setting.ProdMode = true case "test": macaron.Env = macaron.TEST @@ -67,10 +68,11 @@ func GlobalInit() { models.HasEngine = true cron.NewCronContext() + models.InitDeliverHooks() log.NewGitLogger(path.Join(setting.LogRootPath, "http.log")) } if models.EnableSQLite3 { - log.Info("SQLite3 Enabled") + log.Info("SQLite3 Supported") } checkRunMode() } @@ -90,11 +92,20 @@ func InstallInit(ctx *middleware.Context) { func Install(ctx *middleware.Context) { form := auth.InstallForm{} + // Database settings form.DbHost = models.DbCfg.Host form.DbUser = models.DbCfg.User form.DbName = models.DbCfg.Name form.DbPath = models.DbCfg.Path + if models.EnableSQLite3 { + ctx.Data["CurDbOption"] = "SQLite3" // Default when enabled. + } else { + ctx.Data["CurDbOption"] = "MySQL" + } + + // Application general settings + form.AppName = setting.AppName form.RepoRootPath = setting.RepoRootPath // Note(unknwon): it's hard for Windows users change a running user, @@ -112,11 +123,19 @@ func Install(ctx *middleware.Context) { form.HTTPPort = setting.HttpPort form.AppUrl = setting.AppUrl - curDbOp := "" - if models.EnableSQLite3 { - curDbOp = "SQLite3" // Default when enabled. + // E-mail service settings + if setting.MailService != nil { + form.SMTPHost = setting.MailService.Host + form.SMTPFrom = setting.MailService.From + form.SMTPEmail = setting.MailService.User } - ctx.Data["CurDbOption"] = curDbOp + form.RegisterConfirm = setting.Service.RegisterEmailConfirm + form.MailNotify = setting.Service.EnableNotifyMail + + // Server and other services settings + form.OfflineMode = setting.OfflineMode + form.DisableRegistration = setting.Service.DisableRegistration + form.RequireSignInView = setting.Service.RequireSignInView auth.AssignForm(form, ctx.Data) ctx.HTML(200, INSTALL) @@ -126,6 +145,15 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { ctx.Data["CurDbOption"] = form.DbType if ctx.HasError() { + if ctx.HasValue("Err_SMTPEmail") { + ctx.Data["Err_SMTP"] = true + } + if ctx.HasValue("Err_AdminName") || + ctx.HasValue("Err_AdminPasswd") || + ctx.HasValue("Err_AdminEmail") { + ctx.Data["Err_Admin"] = true + } + ctx.HTML(200, INSTALL) return } @@ -146,12 +174,20 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { models.DbCfg.SSLMode = form.SSLMode models.DbCfg.Path = form.DbPath + if models.DbCfg.Type == "sqlite3" && len(models.DbCfg.Path) == 0 { + ctx.Data["Err_DbPath"] = true + ctx.RenderWithErr(ctx.Tr("install.err_empty_sqlite_path"), INSTALL, &form) + return + } + // Set test engine. var x *xorm.Engine if err := models.NewTestEngine(x); err != nil { if strings.Contains(err.Error(), `Unknown database type: sqlite3`) { + ctx.Data["Err_DbType"] = true ctx.RenderWithErr(ctx.Tr("install.sqlite3_not_available", "http://gogs.io/docs/installation/install_from_binary.html"), INSTALL, &form) } else { + ctx.Data["Err_DbSetting"] = true ctx.RenderWithErr(ctx.Tr("install.invalid_db_setting", err), INSTALL, &form) } return @@ -177,6 +213,7 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { // Check admin password. if form.AdminPasswd != form.AdminConfirmPasswd { + ctx.Data["Err_Admin"] = true ctx.Data["Err_AdminPasswd"] = true ctx.RenderWithErr(ctx.Tr("form.password_not_match"), INSTALL, form) return @@ -202,6 +239,7 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { cfg.Section("database").Key("SSL_MODE").SetValue(models.DbCfg.SSLMode) cfg.Section("database").Key("PATH").SetValue(models.DbCfg.Path) + cfg.Section("").Key("APP_NAME").SetValue(form.AppName) cfg.Section("repository").Key("ROOT").SetValue(form.RepoRootPath) cfg.Section("").Key("RUN_USER").SetValue(form.RunUser) cfg.Section("server").Key("DOMAIN").SetValue(form.Domain) @@ -211,12 +249,18 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { if len(strings.TrimSpace(form.SMTPHost)) > 0 { cfg.Section("mailer").Key("ENABLED").SetValue("true") cfg.Section("mailer").Key("HOST").SetValue(form.SMTPHost) + cfg.Section("mailer").Key("FROM").SetValue(form.SMTPFrom) cfg.Section("mailer").Key("USER").SetValue(form.SMTPEmail) cfg.Section("mailer").Key("PASSWD").SetValue(form.SMTPPasswd) - - cfg.Section("service").Key("REGISTER_EMAIL_CONFIRM").SetValue(com.ToStr(form.RegisterConfirm == "on")) - cfg.Section("service").Key("ENABLE_NOTIFY_MAIL").SetValue(com.ToStr(form.MailNotify == "on")) + } else { + cfg.Section("mailer").Key("ENABLED").SetValue("false") } + cfg.Section("service").Key("REGISTER_EMAIL_CONFIRM").SetValue(com.ToStr(form.RegisterConfirm)) + cfg.Section("service").Key("ENABLE_NOTIFY_MAIL").SetValue(com.ToStr(form.MailNotify)) + + cfg.Section("server").Key("OFFLINE_MODE").SetValue(com.ToStr(form.OfflineMode)) + cfg.Section("service").Key("DISABLE_REGISTRATION").SetValue(com.ToStr(form.DisableRegistration)) + cfg.Section("service").Key("REQUIRE_SIGNIN_VIEW").SetValue(com.ToStr(form.RequireSignInView)) cfg.Section("").Key("RUN_MODE").SetValue("prod") @@ -237,16 +281,23 @@ func InstallPost(ctx *middleware.Context, form auth.InstallForm) { GlobalInit() // Create admin account. - if err := models.CreateUser(&models.User{Name: form.AdminName, Email: form.AdminEmail, Passwd: form.AdminPasswd, - IsAdmin: true, IsActive: true}); err != nil { - if err != models.ErrUserAlreadyExist { - setting.InstallLock = false - ctx.Data["Err_AdminName"] = true - ctx.Data["Err_AdminEmail"] = true - ctx.RenderWithErr(ctx.Tr("install.invalid_admin_setting", err), INSTALL, &form) - return + if len(form.AdminName) > 0 { + if err := models.CreateUser(&models.User{ + Name: form.AdminName, + Email: form.AdminEmail, + Passwd: form.AdminPasswd, + IsAdmin: true, + IsActive: true, + }); err != nil { + if !models.IsErrUserAlreadyExist(err) { + setting.InstallLock = false + ctx.Data["Err_AdminName"] = true + ctx.Data["Err_AdminEmail"] = true + ctx.RenderWithErr(ctx.Tr("install.invalid_admin_setting", err), INSTALL, &form) + return + } + log.Info("Admin account already exist") } - log.Info("Admin account already exist") } log.Info("First-time run install finished!") |