All checks were successful
continuous-integration/drone/push Build is passing
This way the config module can already use the log module with the same result (default logging to StdOut with Level INFO, same output as before) but ENV variables can already change the logging of config file related log output). It is now possible to dump as a cronjob without having to filter the default log about the used config file. Also: - all logging modules are now configurable when initializing which makes testing easier - viper dependency removed from logging - log correct settings when configured error level is invalid - deprecation of value "false" for log.standard and log.events (already not mentioned in https://vikunja.io/docs/config-options/) Co-authored-by: Berengar W. Lehr <Berengar.Lehr@uni-jena.de> Reviewed-on: vikunja/api#1606 Reviewed-by: konrad <k@knt.li> Co-authored-by: Peter H0ffmann <hoffmannp@noreply.kolaente.de> Co-committed-by: Peter H0ffmann <hoffmannp@noreply.kolaente.de>
116 lines
2.8 KiB
Go
116 lines
2.8 KiB
Go
// Vikunja is a to-do list application to facilitate your life.
|
|
// Copyright 2018-present Vikunja and contributors. All rights reserved.
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU Affero General Public Licensee as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU Affero General Public Licensee for more details.
|
|
//
|
|
// You should have received a copy of the GNU Affero General Public Licensee
|
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
package initialize
|
|
|
|
import (
|
|
"time"
|
|
|
|
"code.vikunja.io/api/pkg/config"
|
|
"code.vikunja.io/api/pkg/cron"
|
|
"code.vikunja.io/api/pkg/events"
|
|
"code.vikunja.io/api/pkg/files"
|
|
"code.vikunja.io/api/pkg/log"
|
|
"code.vikunja.io/api/pkg/mail"
|
|
"code.vikunja.io/api/pkg/migration"
|
|
"code.vikunja.io/api/pkg/models"
|
|
"code.vikunja.io/api/pkg/modules/auth/openid"
|
|
"code.vikunja.io/api/pkg/modules/keyvalue"
|
|
"code.vikunja.io/api/pkg/red"
|
|
"code.vikunja.io/api/pkg/user"
|
|
)
|
|
|
|
// LightInit will only fullInit config, redis, logger but no db connection.
|
|
func LightInit() {
|
|
// Set logger
|
|
log.InitLogger()
|
|
|
|
// Init the config
|
|
config.InitConfig()
|
|
|
|
// Init redis
|
|
red.InitRedis()
|
|
|
|
// Init keyvalue store
|
|
keyvalue.InitStorage()
|
|
}
|
|
|
|
// InitEngines intializes all db connections
|
|
func InitEngines() {
|
|
err := models.SetEngine()
|
|
if err != nil {
|
|
log.Fatal(err.Error())
|
|
}
|
|
err = files.SetEngine()
|
|
if err != nil {
|
|
log.Fatal(err.Error())
|
|
}
|
|
}
|
|
|
|
// FullInitWithoutAsync does a full init without any async handlers (cron or events)
|
|
func FullInitWithoutAsync() {
|
|
LightInit()
|
|
|
|
// Initialize the files handler
|
|
files.InitFileHandler()
|
|
|
|
// Run the migrations
|
|
migration.Migrate(nil)
|
|
|
|
// Set Engine
|
|
InitEngines()
|
|
|
|
// Init Typesense
|
|
models.InitTypesense()
|
|
|
|
// Start the mail daemon
|
|
mail.StartMailDaemon()
|
|
}
|
|
|
|
// FullInit initializes all kinds of things in the right order
|
|
func FullInit() {
|
|
|
|
FullInitWithoutAsync()
|
|
|
|
// Start the cron
|
|
cron.Init()
|
|
models.RegisterReminderCron()
|
|
models.RegisterOverdueReminderCron()
|
|
user.RegisterTokenCleanupCron()
|
|
user.RegisterDeletionNotificationCron()
|
|
models.RegisterUserDeletionCron()
|
|
models.RegisterOldExportCleanupCron()
|
|
openid.CleanupSavedOpenIDProviders()
|
|
models.RegisterPeriodicTypesenseResyncCron()
|
|
|
|
// Start processing events
|
|
go func() {
|
|
models.RegisterListeners()
|
|
user.RegisterListeners()
|
|
err := events.InitEvents()
|
|
if err != nil {
|
|
log.Fatal(err.Error())
|
|
}
|
|
|
|
err = events.Dispatch(&BootedEvent{
|
|
BootedAt: time.Now(),
|
|
})
|
|
if err != nil {
|
|
log.Fatal(err)
|
|
}
|
|
}()
|
|
}
|