phoenix/main.go

60 lines
1.1 KiB
Go
Raw Normal View History

2023-04-06 10:36:11 +05:00
package main
import (
2023-07-22 11:33:14 +05:00
"github.com/ordinary-dev/phoenix/config"
2023-07-22 15:24:01 +05:00
"github.com/ordinary-dev/phoenix/database"
2023-04-06 10:36:11 +05:00
"github.com/ordinary-dev/phoenix/views"
log "github.com/sirupsen/logrus"
2023-04-06 10:36:11 +05:00
)
func main() {
2023-07-22 11:33:14 +05:00
// Configure logger
log.SetFormatter(&log.TextFormatter{
2023-07-22 11:33:14 +05:00
FullTimestamp: true,
})
// Read config
cfg, err := config.GetConfig()
if err != nil {
log.Fatal(err)
2023-07-22 11:33:14 +05:00
}
// Set log level
logLevel := cfg.GetLogLevel()
log.SetLevel(logLevel)
log.Infof("Setting log level to %v", logLevel)
2023-07-22 11:33:14 +05:00
// Connect to the database
err = database.EstablishDatabaseConnection(cfg)
2023-04-06 10:36:11 +05:00
if err != nil {
log.Fatal(err)
}
// Apply migrations.
if err := database.ApplyMigrations(); err != nil {
log.Fatal(err)
2023-04-06 10:36:11 +05:00
}
// Create the first user
if cfg.DefaultUsername != "" && cfg.DefaultPassword != "" {
adminCount, err := database.CountAdmins()
if err != nil {
log.Fatal(err)
}
if adminCount < 1 {
_, err := database.CreateAdmin(cfg.DefaultUsername, cfg.DefaultPassword)
if err != nil {
log.Fatal(err)
}
}
}
server, err := views.GetHttpServer()
if err != nil {
log.Fatal(err)
}
server.ListenAndServe()
2023-04-06 10:36:11 +05:00
}