2022-05-11 18:47:31 -04:00
|
|
|
package main
|
|
|
|
|
|
|
|
import (
|
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
|
|
|
|
|
|
|
"npm/internal/api"
|
|
|
|
"npm/internal/config"
|
|
|
|
"npm/internal/database"
|
2022-07-14 18:52:38 -04:00
|
|
|
"npm/internal/entity/certificate"
|
|
|
|
"npm/internal/entity/host"
|
2022-05-11 18:47:31 -04:00
|
|
|
"npm/internal/entity/setting"
|
2023-05-25 21:04:43 -04:00
|
|
|
"npm/internal/entity/user"
|
|
|
|
"npm/internal/errors"
|
2022-07-14 18:52:38 -04:00
|
|
|
"npm/internal/jobqueue"
|
2023-05-26 00:50:41 -04:00
|
|
|
"npm/internal/jwt"
|
2022-05-11 18:47:31 -04:00
|
|
|
"npm/internal/logger"
|
|
|
|
)
|
|
|
|
|
|
|
|
var commit string
|
|
|
|
var version string
|
|
|
|
var sentryDSN string
|
|
|
|
|
|
|
|
func main() {
|
|
|
|
config.InitArgs(&version, &commit)
|
|
|
|
config.Init(&version, &commit, &sentryDSN)
|
|
|
|
|
|
|
|
database.Migrate(func() {
|
2023-05-26 00:50:41 -04:00
|
|
|
if err := jwt.LoadKeys(); err != nil {
|
|
|
|
logger.Error("KeysError", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
2022-05-11 18:47:31 -04:00
|
|
|
setting.ApplySettings()
|
2023-05-25 21:04:43 -04:00
|
|
|
checkSetup()
|
2022-05-11 18:47:31 -04:00
|
|
|
|
2022-07-14 18:52:38 -04:00
|
|
|
// Internal Job Queue
|
|
|
|
jobqueue.Start()
|
|
|
|
certificate.AddPendingJobs()
|
|
|
|
host.AddPendingJobs()
|
|
|
|
|
|
|
|
// Http server
|
2022-05-11 18:47:31 -04:00
|
|
|
api.StartServer()
|
|
|
|
irqchan := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(irqchan, syscall.SIGINT, syscall.SIGTERM)
|
|
|
|
|
|
|
|
for irq := range irqchan {
|
|
|
|
if irq == syscall.SIGINT || irq == syscall.SIGTERM {
|
|
|
|
logger.Info("Got ", irq, " shutting server down ...")
|
|
|
|
// Close db
|
2023-05-25 21:04:43 -04:00
|
|
|
sqlDB, _ := database.GetDB().DB()
|
|
|
|
err := sqlDB.Close()
|
2022-05-11 18:47:31 -04:00
|
|
|
if err != nil {
|
|
|
|
logger.Error("DatabaseCloseError", err)
|
|
|
|
}
|
2022-07-14 18:52:38 -04:00
|
|
|
// nolint
|
|
|
|
jobqueue.Shutdown()
|
2022-05-11 18:47:31 -04:00
|
|
|
break
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
2023-05-25 21:04:43 -04:00
|
|
|
|
|
|
|
// checkSetup Quick check by counting the number of users in the database
|
|
|
|
func checkSetup() {
|
|
|
|
db := database.GetDB()
|
|
|
|
var count int64
|
|
|
|
|
|
|
|
if db != nil {
|
|
|
|
db.Model(&user.Model{}).
|
2023-05-29 23:26:46 -04:00
|
|
|
Where("is_disabled = ?", 0).
|
|
|
|
Where("is_system = ?", 0).
|
2023-05-25 21:04:43 -04:00
|
|
|
Count(&count)
|
|
|
|
|
|
|
|
if count == 0 {
|
|
|
|
logger.Warn("No users found, starting in Setup Mode")
|
|
|
|
} else {
|
|
|
|
config.IsSetup = true
|
|
|
|
logger.Info("Application is setup")
|
|
|
|
}
|
|
|
|
if config.ErrorReporting {
|
|
|
|
logger.Warn("Error reporting is enabled - Application Errors WILL be sent to Sentry, you can disable this in the Settings interface")
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
logger.Error("DatabaseError", errors.ErrDatabaseUnavailable)
|
|
|
|
}
|
|
|
|
}
|