2024-05-18 17:59:54 +07:00
|
|
|
package server
|
2024-05-04 00:11:56 +07:00
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2024-05-13 18:40:01 +07:00
|
|
|
"log/slog"
|
2024-05-04 00:11:56 +07:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
"syscall"
|
2024-05-23 02:58:58 +07:00
|
|
|
"time"
|
2024-07-07 01:28:44 +07:00
|
|
|
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/config"
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/cron"
|
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/database"
|
2024-07-07 01:42:29 +07:00
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/handler"
|
2024-10-29 20:41:22 +07:00
|
|
|
"github.com/ditatompel/xmr-remote-nodes/internal/handler/views"
|
2024-05-04 00:11:56 +07:00
|
|
|
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"github.com/gofiber/fiber/v2/middleware/cors"
|
|
|
|
"github.com/gofiber/fiber/v2/middleware/logger"
|
|
|
|
"github.com/gofiber/fiber/v2/middleware/recover"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
)
|
|
|
|
|
2024-05-18 18:42:32 +07:00
|
|
|
var serveCmd = &cobra.Command{
|
2024-05-04 00:11:56 +07:00
|
|
|
Use: "serve",
|
2024-05-23 02:58:58 +07:00
|
|
|
Short: "Serve the WebUI and APIs",
|
2024-05-04 00:11:56 +07:00
|
|
|
Long: `This command will run HTTP server for APIs and WebUI.`,
|
|
|
|
Run: func(_ *cobra.Command, _ []string) {
|
|
|
|
serve()
|
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
func serve() {
|
|
|
|
appCfg := config.AppCfg()
|
|
|
|
if err := database.ConnectDB(); err != nil {
|
2024-05-23 02:58:58 +07:00
|
|
|
slog.Error(fmt.Sprintf("[DB] %s", err.Error()))
|
|
|
|
os.Exit(1)
|
2024-05-04 00:11:56 +07:00
|
|
|
}
|
|
|
|
|
2024-05-23 02:58:58 +07:00
|
|
|
// signal channel to capture system calls
|
|
|
|
sigCh := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(sigCh, syscall.SIGTERM, syscall.SIGINT, syscall.SIGQUIT)
|
|
|
|
|
|
|
|
stopCron := make(chan struct{})
|
|
|
|
if !fiber.IsChild() {
|
|
|
|
// run db migrations
|
|
|
|
if err := database.MigrateDb(database.GetDB()); err != nil {
|
|
|
|
slog.Error(fmt.Sprintf("[DB] %s", err.Error()))
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
|
|
|
|
// run cron process
|
|
|
|
cronRepo := cron.New()
|
|
|
|
go cronRepo.RunCronProcess(stopCron)
|
2024-05-12 04:19:40 +07:00
|
|
|
}
|
|
|
|
|
2024-05-04 00:11:56 +07:00
|
|
|
// Define Fiber config & app.
|
2024-10-29 21:30:04 +07:00
|
|
|
app := handler.NewServer()
|
2024-05-04 00:11:56 +07:00
|
|
|
|
|
|
|
// recover
|
2024-05-13 18:40:01 +07:00
|
|
|
app.Use(recover.New(recover.Config{EnableStackTrace: true}))
|
2024-05-04 00:11:56 +07:00
|
|
|
|
|
|
|
// logger middleware
|
2024-05-13 18:40:01 +07:00
|
|
|
if appCfg.LogLevel == "DEBUG" {
|
2024-05-04 00:11:56 +07:00
|
|
|
app.Use(logger.New(logger.Config{
|
2024-05-13 18:40:01 +07:00
|
|
|
Format: "${time} DEBUG [HTTP] ${status} - ${latency} ${method} ${path} ${queryParams} ${ip} ${ua}\n",
|
|
|
|
TimeFormat: "2006/01/02 15:04:05",
|
2024-05-04 00:11:56 +07:00
|
|
|
}))
|
|
|
|
}
|
|
|
|
|
|
|
|
app.Use(cors.New(cors.Config{
|
|
|
|
AllowOrigins: appCfg.AllowOrigin,
|
|
|
|
AllowHeaders: "Origin, Content-Type, Accept",
|
|
|
|
AllowCredentials: true,
|
|
|
|
}))
|
|
|
|
|
2024-10-29 20:41:22 +07:00
|
|
|
app.Use("/assets", views.EmbedAssets())
|
2024-10-29 21:30:04 +07:00
|
|
|
app.Routes()
|
2024-05-04 00:11:56 +07:00
|
|
|
|
2024-05-23 02:58:58 +07:00
|
|
|
// go routine to capture system calls
|
2024-05-04 00:11:56 +07:00
|
|
|
go func() {
|
|
|
|
<-sigCh
|
2024-05-23 02:58:58 +07:00
|
|
|
close(stopCron) // stop cron goroutine
|
2024-05-13 18:40:01 +07:00
|
|
|
slog.Info("Shutting down HTTP server...")
|
2024-05-04 00:11:56 +07:00
|
|
|
_ = app.Shutdown()
|
2024-05-23 02:58:58 +07:00
|
|
|
|
|
|
|
// give time for graceful shutdown
|
|
|
|
time.Sleep(1 * time.Second)
|
2024-05-04 00:11:56 +07:00
|
|
|
}()
|
|
|
|
|
|
|
|
// start http server
|
|
|
|
serverAddr := fmt.Sprintf("%s:%d", appCfg.Host, appCfg.Port)
|
|
|
|
if err := app.Listen(serverAddr); err != nil {
|
2024-05-23 02:58:58 +07:00
|
|
|
slog.Error(fmt.Sprintf("[HTTP] Server is not running! error: %v", err))
|
2024-05-04 00:11:56 +07:00
|
|
|
}
|
|
|
|
}
|