diff options
Diffstat (limited to 'routers/init.go')
-rw-r--r-- | routers/init.go | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/routers/init.go b/routers/init.go new file mode 100644 index 0000000000..07f84a25fb --- /dev/null +++ b/routers/init.go @@ -0,0 +1,82 @@ +// Copyright 2016 The Gitea Authors. All rights reserved. +// Use of this source code is governed by a MIT-style +// license that can be found in the LICENSE file. + +package routers + +import ( + "path" + "strings" + + "code.gitea.io/git" + "code.gitea.io/gitea/models" + "code.gitea.io/gitea/modules/cron" + "code.gitea.io/gitea/modules/log" + "code.gitea.io/gitea/modules/mailer" + "code.gitea.io/gitea/modules/markdown" + "code.gitea.io/gitea/modules/setting" + "code.gitea.io/gitea/modules/ssh" + "code.gitea.io/gitea/modules/template/highlight" + macaron "gopkg.in/macaron.v1" +) + +func checkRunMode() { + switch setting.Cfg.Section("").Key("RUN_MODE").String() { + case "prod": + macaron.Env = macaron.PROD + macaron.ColorLog = false + setting.ProdMode = true + default: + git.Debug = true + } + log.Info("Run Mode: %s", strings.Title(macaron.Env)) +} + +// NewServices init new services +func NewServices() { + setting.NewServices() + mailer.NewContext() +} + +// GlobalInit is for global configuration reload-able. +func GlobalInit() { + setting.NewContext() + log.Trace("Custom path: %s", setting.CustomPath) + log.Trace("Log path: %s", setting.LogRootPath) + models.LoadConfigs() + NewServices() + + if setting.InstallLock { + highlight.NewContext() + markdown.BuildSanitizer() + if err := models.NewEngine(); err != nil { + log.Fatal(4, "Fail to initialize ORM engine: %v", err) + } + models.HasEngine = true + + models.LoadRepoConfig() + models.NewRepoContext() + + // Booting long running goroutines. + cron.NewContext() + models.InitSyncMirrors() + models.InitDeliverHooks() + models.InitTestPullRequests() + log.NewGitLogger(path.Join(setting.LogRootPath, "http.log")) + } + if models.EnableSQLite3 { + log.Info("SQLite3 Supported") + } + if models.EnableTiDB { + log.Info("TiDB Supported") + } + if setting.SupportMiniWinService { + log.Info("Builtin Windows Service Supported") + } + checkRunMode() + + if setting.InstallLock && setting.SSH.StartBuiltinServer { + ssh.Listen(setting.SSH.ListenPort) + log.Info("SSH server started on :%v", setting.SSH.ListenPort) + } +} |