micrach/main.go

87 lines
1.9 KiB
Go
Raw Normal View History

2021-08-26 16:16:50 +03:00
package main
import (
"log"
"strconv"
2022-04-11 09:31:17 +03:00
"strings"
2021-08-26 16:16:50 +03:00
2021-08-26 17:32:19 +03:00
_ "github.com/joho/godotenv/autoload"
2021-08-26 16:16:50 +03:00
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/compress"
2022-04-11 09:31:17 +03:00
"github.com/gofiber/fiber/v2/middleware/limiter"
"github.com/gofiber/fiber/v2/middleware/recover"
"github.com/gofiber/template/html"
"micrach/build"
"micrach/config"
"micrach/controllers"
"micrach/db"
"micrach/gateway"
"micrach/repositories"
"micrach/templates"
"micrach/utils"
2021-08-26 16:16:50 +03:00
)
func main() {
config.Init()
db.Init()
db.Migrate()
defer db.Pool.Close()
if config.App.IsDbSeeded {
repositories.Seed()
2021-09-08 15:36:13 +03:00
}
2021-08-26 16:16:50 +03:00
if config.App.Env == "production" {
build.RenameCss()
}
err := utils.CreateUploadsFolder()
2021-09-04 21:53:48 +03:00
if err != nil {
log.Panicln(err)
}
engine := html.New("./templates", ".html")
engine.AddFunc("Iterate", templates.Iterate)
engine.AddFunc("NotNil", templates.NotNil)
2021-09-08 16:56:03 +03:00
app := fiber.New(fiber.Config{Views: engine})
app.Use(recover.New())
2022-05-18 10:45:53 +03:00
if config.App.IsRateLimiterEnabled {
app.Use(limiter.New(limiter.Config{
Next: func(c *fiber.Ctx) bool {
isDev := c.IsFromLocal()
path := c.Path()
isRequestForStatic := strings.Contains(path, "/static") || strings.Contains(path, "/uploads") || strings.Contains(path, "/captcha")
return isRequestForStatic || isDev
},
Max: 50,
}))
}
app.Use(compress.New())
app.Static("/uploads", "./uploads")
app.Static("/static", "./static")
app.Get("/", controllers.GetThreads)
app.Post("/", controllers.CreateThread)
app.Get("/:threadID", controllers.GetThread)
app.Post("/:threadID", controllers.UpdateThread)
app.Get("/captcha/:captchaID", controllers.GetCaptcha)
if config.App.Gateway.Url != "" {
app.Get("/api/ping", gateway.Ping)
gateway.Connect()
}
2021-08-26 16:16:50 +03:00
log.Println("app - online, port -", strconv.Itoa(config.App.Port))
2021-08-26 16:16:50 +03:00
log.Println("all systems nominal")
err = app.Listen(":" + strconv.Itoa(config.App.Port))
if err != nil {
log.Println("app - ofline")
log.Panicln(err)
}
2021-08-26 16:16:50 +03:00
}