aboutsummaryrefslogtreecommitdiff
path: root/routers/install.go
diff options
context:
space:
mode:
Diffstat (limited to 'routers/install.go')
-rw-r--r--routers/install.go117
1 files changed, 59 insertions, 58 deletions
diff --git a/routers/install.go b/routers/install.go
index ccc87b3d..3b48d8d3 100644
--- a/routers/install.go
+++ b/routers/install.go
@@ -5,7 +5,6 @@
package routers
import (
- "errors"
"net/mail"
"os"
"os/exec"
@@ -92,23 +91,23 @@ func GlobalInit() {
}
}
-func InstallInit(ctx *context.Context) {
+func InstallInit(c *context.Context) {
if setting.InstallLock {
- ctx.Handle(404, "Install", errors.New("Installation is prohibited"))
+ c.NotFound()
return
}
- ctx.Data["Title"] = ctx.Tr("install.install")
- ctx.Data["PageIsInstall"] = true
+ c.Title("install.install")
+ c.PageIs("Install")
dbOpts := []string{"MySQL", "PostgreSQL", "MSSQL"}
if models.EnableSQLite3 {
dbOpts = append(dbOpts, "SQLite3")
}
- ctx.Data["DbOptions"] = dbOpts
+ c.Data["DbOptions"] = dbOpts
}
-func Install(ctx *context.Context) {
+func Install(c *context.Context) {
f := form.Install{}
// Database settings
@@ -117,15 +116,15 @@ func Install(ctx *context.Context) {
f.DbName = models.DbCfg.Name
f.DbPath = models.DbCfg.Path
- ctx.Data["CurDbOption"] = "MySQL"
+ c.Data["CurDbOption"] = "MySQL"
switch models.DbCfg.Type {
case "postgres":
- ctx.Data["CurDbOption"] = "PostgreSQL"
+ c.Data["CurDbOption"] = "PostgreSQL"
case "mssql":
- ctx.Data["CurDbOption"] = "MSSQL"
+ c.Data["CurDbOption"] = "MSSQL"
case "sqlite3":
if models.EnableSQLite3 {
- ctx.Data["CurDbOption"] = "SQLite3"
+ c.Data["CurDbOption"] = "SQLite3"
}
}
@@ -165,29 +164,29 @@ func Install(ctx *context.Context) {
f.EnableCaptcha = setting.Service.EnableCaptcha
f.RequireSignInView = setting.Service.RequireSignInView
- form.Assign(f, ctx.Data)
- ctx.HTML(200, INSTALL)
+ form.Assign(f, c.Data)
+ c.Success(INSTALL)
}
-func InstallPost(ctx *context.Context, f form.Install) {
- ctx.Data["CurDbOption"] = f.DbType
+func InstallPost(c *context.Context, f form.Install) {
+ c.Data["CurDbOption"] = f.DbType
- if ctx.HasError() {
- if ctx.HasValue("Err_SMTPEmail") {
- ctx.Data["Err_SMTP"] = true
+ if c.HasError() {
+ if c.HasValue("Err_SMTPEmail") {
+ c.FormErr("SMTP")
}
- if ctx.HasValue("Err_AdminName") ||
- ctx.HasValue("Err_AdminPasswd") ||
- ctx.HasValue("Err_AdminEmail") {
- ctx.Data["Err_Admin"] = true
+ if c.HasValue("Err_AdminName") ||
+ c.HasValue("Err_AdminPasswd") ||
+ c.HasValue("Err_AdminEmail") {
+ c.FormErr("Admin")
}
- ctx.HTML(200, INSTALL)
+ c.Success(INSTALL)
return
}
if _, err := exec.LookPath("git"); err != nil {
- ctx.RenderWithErr(ctx.Tr("install.test_git_failed", err), INSTALL, &f)
+ c.RenderWithErr(c.Tr("install.test_git_failed", err), INSTALL, &f)
return
}
@@ -203,8 +202,8 @@ func InstallPost(ctx *context.Context, f form.Install) {
models.DbCfg.Path = f.DbPath
if models.DbCfg.Type == "sqlite3" && len(models.DbCfg.Path) == 0 {
- ctx.Data["Err_DbPath"] = true
- ctx.RenderWithErr(ctx.Tr("install.err_empty_db_path"), INSTALL, &f)
+ c.FormErr("DbPath")
+ c.RenderWithErr(c.Tr("install.err_empty_db_path"), INSTALL, &f)
return
}
@@ -212,11 +211,11 @@ func InstallPost(ctx *context.Context, f form.Install) {
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", "https://gogs.io/docs/installation/install_from_binary.html"), INSTALL, &f)
+ c.FormErr("DbType")
+ c.RenderWithErr(c.Tr("install.sqlite3_not_available", "https://gogs.io/docs/installation/install_from_binary.html"), INSTALL, &f)
} else {
- ctx.Data["Err_DbSetting"] = true
- ctx.RenderWithErr(ctx.Tr("install.invalid_db_setting", err), INSTALL, &f)
+ c.FormErr("DbSetting")
+ c.RenderWithErr(c.Tr("install.invalid_db_setting", err), INSTALL, &f)
}
return
}
@@ -224,23 +223,30 @@ func InstallPost(ctx *context.Context, f form.Install) {
// Test repository root path.
f.RepoRootPath = strings.Replace(f.RepoRootPath, "\\", "/", -1)
if err := os.MkdirAll(f.RepoRootPath, os.ModePerm); err != nil {
- ctx.Data["Err_RepoRootPath"] = true
- ctx.RenderWithErr(ctx.Tr("install.invalid_repo_path", err), INSTALL, &f)
+ c.FormErr("RepoRootPath")
+ c.RenderWithErr(c.Tr("install.invalid_repo_path", err), INSTALL, &f)
return
}
// Test log root path.
f.LogRootPath = strings.Replace(f.LogRootPath, "\\", "/", -1)
if err := os.MkdirAll(f.LogRootPath, os.ModePerm); err != nil {
- ctx.Data["Err_LogRootPath"] = true
- ctx.RenderWithErr(ctx.Tr("install.invalid_log_root_path", err), INSTALL, &f)
+ c.FormErr("LogRootPath")
+ c.RenderWithErr(c.Tr("install.invalid_log_root_path", err), INSTALL, &f)
return
}
currentUser, match := setting.IsRunUserMatchCurrentUser(f.RunUser)
if !match {
- ctx.Data["Err_RunUser"] = true
- ctx.RenderWithErr(ctx.Tr("install.run_user_not_match", f.RunUser, currentUser), INSTALL, &f)
+ c.FormErr("RunUser")
+ c.RenderWithErr(c.Tr("install.run_user_not_match", f.RunUser, currentUser), INSTALL, &f)
+ return
+ }
+
+ // Check host address and port
+ if len(f.SMTPHost) > 0 && !strings.Contains(f.SMTPHost, ":") {
+ c.FormErr("SMTP", "SMTPHost")
+ c.RenderWithErr(c.Tr("install.smtp_host_missing_port"), INSTALL, &f)
return
}
@@ -248,32 +254,28 @@ func InstallPost(ctx *context.Context, f form.Install) {
if len(f.SMTPFrom) > 0 {
_, err := mail.ParseAddress(f.SMTPFrom)
if err != nil {
- ctx.Data["Err_SMTP"] = true
- ctx.Data["Err_SMTPFrom"] = true
- ctx.RenderWithErr(ctx.Tr("install.invalid_smtp_from", err), INSTALL, &f)
+ c.FormErr("SMTP", "SMTPFrom")
+ c.RenderWithErr(c.Tr("install.invalid_smtp_from", err), INSTALL, &f)
return
}
}
// Check logic loophole between disable self-registration and no admin account.
if f.DisableRegistration && len(f.AdminName) == 0 {
- ctx.Data["Err_Services"] = true
- ctx.Data["Err_Admin"] = true
- ctx.RenderWithErr(ctx.Tr("install.no_admin_and_disable_registration"), INSTALL, f)
+ c.FormErr("Services", "Admin")
+ c.RenderWithErr(c.Tr("install.no_admin_and_disable_registration"), INSTALL, f)
return
}
// Check admin password.
if len(f.AdminName) > 0 && len(f.AdminPasswd) == 0 {
- ctx.Data["Err_Admin"] = true
- ctx.Data["Err_AdminPasswd"] = true
- ctx.RenderWithErr(ctx.Tr("install.err_empty_admin_password"), INSTALL, f)
+ c.FormErr("Admin", "AdminPasswd")
+ c.RenderWithErr(c.Tr("install.err_empty_admin_password"), INSTALL, f)
return
}
if f.AdminPasswd != f.AdminConfirmPasswd {
- ctx.Data["Err_Admin"] = true
- ctx.Data["Err_AdminPasswd"] = true
- ctx.RenderWithErr(ctx.Tr("form.password_not_match"), INSTALL, f)
+ c.FormErr("Admin", "AdminPasswd")
+ c.RenderWithErr(c.Tr("form.password_not_match"), INSTALL, f)
return
}
@@ -286,7 +288,7 @@ func InstallPost(ctx *context.Context, f form.Install) {
if com.IsFile(setting.CustomConf) {
// Keeps custom settings if there is already something.
if err := cfg.Append(setting.CustomConf); err != nil {
- log.Error(4, "Fail to load custom conf '%s': %v", setting.CustomConf, err)
+ log.Error(2, "Fail to load custom conf '%s': %v", setting.CustomConf, err)
}
}
cfg.Section("database").Key("DB_TYPE").SetValue(models.DbCfg.Type)
@@ -346,14 +348,14 @@ func InstallPost(ctx *context.Context, f form.Install) {
cfg.Section("security").Key("INSTALL_LOCK").SetValue("true")
secretKey, err := tool.RandomString(15)
if err != nil {
- ctx.RenderWithErr(ctx.Tr("install.secret_key_failed", err), INSTALL, &f)
+ c.RenderWithErr(c.Tr("install.secret_key_failed", err), INSTALL, &f)
return
}
cfg.Section("security").Key("SECRET_KEY").SetValue(secretKey)
os.MkdirAll(filepath.Dir(setting.CustomConf), os.ModePerm)
if err := cfg.SaveTo(setting.CustomConf); err != nil {
- ctx.RenderWithErr(ctx.Tr("install.save_config_failed", err), INSTALL, &f)
+ c.RenderWithErr(c.Tr("install.save_config_failed", err), INSTALL, &f)
return
}
@@ -371,9 +373,8 @@ func InstallPost(ctx *context.Context, f form.Install) {
if err := models.CreateUser(u); 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, &f)
+ c.FormErr("AdminName", "AdminEmail")
+ c.RenderWithErr(c.Tr("install.invalid_admin_setting", err), INSTALL, &f)
return
}
log.Info("Admin account already exist")
@@ -381,11 +382,11 @@ func InstallPost(ctx *context.Context, f form.Install) {
}
// Auto-login for admin
- ctx.Session.Set("uid", u.ID)
- ctx.Session.Set("uname", u.Name)
+ c.Session.Set("uid", u.ID)
+ c.Session.Set("uname", u.Name)
}
log.Info("First-time run install finished!")
- ctx.Flash.Success(ctx.Tr("install.install_success"))
- ctx.Redirect(f.AppUrl + "user/login")
+ c.Flash.Success(c.Tr("install.install_success"))
+ c.Redirect(f.AppUrl + "user/login")
}