summaryrefslogtreecommitdiffstats
path: root/routers/install.go
diff options
context:
space:
mode:
authorcrohr <cyril.rohr@gmail.com>2015-07-14 15:09:08 +0000
committercrohr <cyril.rohr@gmail.com>2015-07-14 15:09:08 +0000
commitcbce2ec9cf74a96b15bbd1a5463957921465a980 (patch)
tree48f08facd06aa9910c98cdcada1a73d8d308775c /routers/install.go
parentb8e9c600409683b0f5eb10b637de003ce23b7796 (diff)
parentec774d48c58f83b599ac210d6def718187806ecd (diff)
downloadgitea-cbce2ec9cf74a96b15bbd1a5463957921465a980.tar.gz
gitea-cbce2ec9cf74a96b15bbd1a5463957921465a980.zip
Merge remote-tracking branch 'origin/master' into pkgr
Diffstat (limited to 'routers/install.go')
-rw-r--r--routers/install.go80
1 files changed, 64 insertions, 16 deletions
diff --git a/routers/install.go b/routers/install.go
index 6da611286f..7a951ad27a 100644
--- a/routers/install.go
+++ b/routers/install.go
@@ -90,11 +90,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
+ curDbOp := ""
+ if models.EnableSQLite3 {
+ curDbOp = "SQLite3" // Default when enabled.
+ }
+ ctx.Data["CurDbOption"] = curDbOp
+
+ // 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 +121,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 +143,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 +172,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
@@ -202,6 +236,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 +246,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 +278,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 !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
+ 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!")