mirror of
https://codeberg.org/forgejo/forgejo.git
synced 2025-01-01 08:33:52 +03:00
35f37a3625
One of the repeatedly reported issues has been that gitea produces too much console logging during set up even if the console logger is turned off. Fundamentally this is due to some otherwise very helpful logging that has to occur before logging is set up. This has come to a head with the merging of #16243 where otherwise potentially helpful Trace logging in the git module now appears on the console. This PR proposes three things: 1. Change the initial default logger to Info not Trace. 2. Change the logging for the AppPath things to Info in recompense. 3. Add two new command line options to gitea web: --quiet and --verbose `gitea web -q` or `gitea web --quiet` will only log Fatal level initially. `gitea web -verbose` will log at Trace. Signed-off-by: Andrew Thornton <art27@cantab.net> Co-authored-by: techknowlogick <techknowlogick@gitea.io>
149 lines
4.5 KiB
Go
149 lines
4.5 KiB
Go
// 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 (
|
|
"context"
|
|
"strings"
|
|
|
|
"code.gitea.io/gitea/models"
|
|
"code.gitea.io/gitea/modules/cache"
|
|
"code.gitea.io/gitea/modules/cron"
|
|
"code.gitea.io/gitea/modules/eventsource"
|
|
"code.gitea.io/gitea/modules/git"
|
|
"code.gitea.io/gitea/modules/highlight"
|
|
code_indexer "code.gitea.io/gitea/modules/indexer/code"
|
|
issue_indexer "code.gitea.io/gitea/modules/indexer/issues"
|
|
stats_indexer "code.gitea.io/gitea/modules/indexer/stats"
|
|
"code.gitea.io/gitea/modules/log"
|
|
"code.gitea.io/gitea/modules/markup"
|
|
"code.gitea.io/gitea/modules/markup/external"
|
|
repo_migrations "code.gitea.io/gitea/modules/migrations"
|
|
"code.gitea.io/gitea/modules/notification"
|
|
"code.gitea.io/gitea/modules/setting"
|
|
"code.gitea.io/gitea/modules/ssh"
|
|
"code.gitea.io/gitea/modules/storage"
|
|
"code.gitea.io/gitea/modules/svg"
|
|
"code.gitea.io/gitea/modules/task"
|
|
"code.gitea.io/gitea/modules/translation"
|
|
"code.gitea.io/gitea/modules/web"
|
|
apiv1 "code.gitea.io/gitea/routers/api/v1"
|
|
"code.gitea.io/gitea/routers/common"
|
|
"code.gitea.io/gitea/routers/private"
|
|
web_routers "code.gitea.io/gitea/routers/web"
|
|
"code.gitea.io/gitea/services/archiver"
|
|
"code.gitea.io/gitea/services/auth"
|
|
"code.gitea.io/gitea/services/mailer"
|
|
mirror_service "code.gitea.io/gitea/services/mirror"
|
|
pull_service "code.gitea.io/gitea/services/pull"
|
|
"code.gitea.io/gitea/services/repository"
|
|
"code.gitea.io/gitea/services/webhook"
|
|
)
|
|
|
|
// NewServices init new services
|
|
func NewServices() {
|
|
setting.NewServices()
|
|
if err := storage.Init(); err != nil {
|
|
log.Fatal("storage init failed: %v", err)
|
|
}
|
|
if err := repository.NewContext(); err != nil {
|
|
log.Fatal("repository init failed: %v", err)
|
|
}
|
|
mailer.NewContext()
|
|
_ = cache.NewContext()
|
|
notification.NewContext()
|
|
if err := archiver.Init(); err != nil {
|
|
log.Fatal("archiver init failed: %v", err)
|
|
}
|
|
}
|
|
|
|
// GlobalInit is for global configuration reload-able.
|
|
func GlobalInit(ctx context.Context) {
|
|
setting.NewContext()
|
|
if !setting.InstallLock {
|
|
log.Fatal("Gitea is not installed")
|
|
}
|
|
|
|
if err := git.Init(ctx); err != nil {
|
|
log.Fatal("Git module init failed: %v", err)
|
|
}
|
|
log.Info(git.VersionInfo())
|
|
|
|
git.CheckLFSVersion()
|
|
log.Info("AppPath: %s", setting.AppPath)
|
|
log.Info("AppWorkPath: %s", setting.AppWorkPath)
|
|
log.Info("Custom path: %s", setting.CustomPath)
|
|
log.Info("Log path: %s", setting.LogRootPath)
|
|
log.Info("Run Mode: %s", strings.Title(setting.RunMode))
|
|
|
|
// Setup i18n
|
|
translation.InitLocales()
|
|
|
|
NewServices()
|
|
|
|
highlight.NewContext()
|
|
external.RegisterRenderers()
|
|
markup.Init()
|
|
|
|
if setting.EnableSQLite3 {
|
|
log.Info("SQLite3 Supported")
|
|
} else if setting.Database.UseSQLite3 {
|
|
log.Fatal("SQLite3 is set in settings but NOT Supported")
|
|
}
|
|
if err := common.InitDBEngine(ctx); err == nil {
|
|
log.Info("ORM engine initialization successful!")
|
|
} else {
|
|
log.Fatal("ORM engine initialization failed: %v", err)
|
|
}
|
|
|
|
if err := models.InitOAuth2(); err != nil {
|
|
log.Fatal("Failed to initialize OAuth2 support: %v", err)
|
|
}
|
|
|
|
models.NewRepoContext()
|
|
|
|
// Booting long running goroutines.
|
|
cron.NewContext()
|
|
issue_indexer.InitIssueIndexer(false)
|
|
code_indexer.Init()
|
|
if err := stats_indexer.Init(); err != nil {
|
|
log.Fatal("Failed to initialize repository stats indexer queue: %v", err)
|
|
}
|
|
mirror_service.InitSyncMirrors()
|
|
webhook.InitDeliverHooks()
|
|
if err := pull_service.Init(); err != nil {
|
|
log.Fatal("Failed to initialize test pull requests queue: %v", err)
|
|
}
|
|
if err := task.Init(); err != nil {
|
|
log.Fatal("Failed to initialize task scheduler: %v", err)
|
|
}
|
|
if err := repo_migrations.Init(); err != nil {
|
|
log.Fatal("Failed to initialize repository migrations: %v", err)
|
|
}
|
|
eventsource.GetManager().Init()
|
|
|
|
if setting.SSH.StartBuiltinServer {
|
|
ssh.Listen(setting.SSH.ListenHost, setting.SSH.ListenPort, setting.SSH.ServerCiphers, setting.SSH.ServerKeyExchanges, setting.SSH.ServerMACs)
|
|
log.Info("SSH server started on %s:%d. Cipher list (%v), key exchange algorithms (%v), MACs (%v)", setting.SSH.ListenHost, setting.SSH.ListenPort, setting.SSH.ServerCiphers, setting.SSH.ServerKeyExchanges, setting.SSH.ServerMACs)
|
|
} else {
|
|
ssh.Unused()
|
|
}
|
|
auth.Init()
|
|
|
|
svg.Init()
|
|
}
|
|
|
|
// NormalRoutes represents non install routes
|
|
func NormalRoutes() *web.Route {
|
|
r := web.NewRoute()
|
|
for _, middle := range common.Middlewares() {
|
|
r.Use(middle)
|
|
}
|
|
|
|
r.Mount("/", web_routers.Routes())
|
|
r.Mount("/api/v1", apiv1.Routes())
|
|
r.Mount("/api/internal", private.Routes())
|
|
return r
|
|
}
|