WIP: Refractor code / remove html engine / new restapi #21

Draft
Phil wants to merge 2 commits from backend/rework-restapi into main
8 changed files with 58 additions and 91 deletions
Showing only changes of commit fce20e7c61 - Show all commits

4
go.mod
View file

@ -7,7 +7,6 @@ toolchain go1.24.2
require (
github.com/go-redis/redis/v8 v8.11.5
github.com/gofiber/fiber/v2 v2.52.6
github.com/gofiber/template/html/v2 v2.1.3
github.com/joho/godotenv v1.5.1
github.com/matoous/go-nanoid/v2 v2.1.0
)
@ -16,8 +15,6 @@ require (
github.com/andybalholm/brotli v1.1.1 // indirect
github.com/cespare/xxhash/v2 v2.3.0 // indirect
github.com/dgryski/go-rendezvous v0.0.0-20200823014737-9f7001d12a5f // indirect
github.com/gofiber/template v1.8.3 // indirect
github.com/gofiber/utils v1.1.0 // indirect
github.com/google/uuid v1.6.0 // indirect
github.com/klauspost/compress v1.18.0 // indirect
github.com/mattn/go-colorable v0.1.14 // indirect
@ -25,6 +22,7 @@ require (
github.com/mattn/go-runewidth v0.0.16 // indirect
github.com/philhofer/fwd v1.1.3-0.20240916144458-20a13a1f6b7c // indirect
github.com/rivo/uniseg v0.4.7 // indirect
github.com/stretchr/testify v1.10.0 // indirect
github.com/tinylib/msgp v1.2.5 // indirect
github.com/valyala/bytebufferpool v1.0.0 // indirect
github.com/valyala/fasthttp v1.60.0 // indirect

6
go.sum
View file

@ -12,12 +12,6 @@ github.com/go-redis/redis/v8 v8.11.5 h1:AcZZR7igkdvfVmQTPnu9WE37LRrO/YrBH5zWyjDC
github.com/go-redis/redis/v8 v8.11.5/go.mod h1:gREzHqY1hg6oD9ngVRbLStwAWKhA0FEgq8Jd4h5lpwo=
github.com/gofiber/fiber/v2 v2.52.6 h1:Rfp+ILPiYSvvVuIPvxrBns+HJp8qGLDnLJawAu27XVI=
github.com/gofiber/fiber/v2 v2.52.6/go.mod h1:YEcBbO/FB+5M1IZNBP9FO3J9281zgPAreiI1oqg8nDw=
github.com/gofiber/template v1.8.3 h1:hzHdvMwMo/T2kouz2pPCA0zGiLCeMnoGsQZBTSYgZxc=
github.com/gofiber/template v1.8.3/go.mod h1:bs/2n0pSNPOkRa5VJ8zTIvedcI/lEYxzV3+YPXdBvq8=
github.com/gofiber/template/html/v2 v2.1.3 h1:n1LYBtmr9C0V/k/3qBblXyMxV5B0o/gpb6dFLp8ea+o=
github.com/gofiber/template/html/v2 v2.1.3/go.mod h1:U5Fxgc5KpyujU9OqKzy6Kn6Qup6Tm7zdsISR+VpnHRE=
github.com/gofiber/utils v1.1.0 h1:vdEBpn7AzIUJRhe+CiTOJdUcTg4Q9RK+pEa0KPbLdrM=
github.com/gofiber/utils v1.1.0/go.mod h1:poZpsnhBykfnY1Mc0KeEa6mSHrS3dV0+oBWyeQmb2e0=
github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0=
github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo=
github.com/joho/godotenv v1.5.1 h1:7eLL/+HRGLY0ldzfGMeQkb7vMd0as4CfYvUVzLqw0N0=

View file

@ -1,21 +1,15 @@
package main
import (
"embed"
"log"
"net/http"
"git.hackmi.ch/Phil/goshorly/db"
"git.hackmi.ch/Phil/goshorly/routes"
"git.hackmi.ch/Phil/goshorly/utils"
"github.com/gofiber/fiber/v2"
"github.com/gofiber/fiber/v2/middleware/limiter"
"github.com/gofiber/template/html/v2"
)
//go:embed views/*
var viewsfs embed.FS
func main() {
utils.Print_Starting_Screen()
utils.Init_env_file()
@ -24,11 +18,8 @@ func main() {
db.Init_redis()
engine := html.NewFileSystem(http.FS(viewsfs), ".html")
app := fiber.New(fiber.Config{
CaseSensitive: true,
Views: engine,
})
app.Get("/", routes.Gethome)

View file

@ -1,19 +1,9 @@
package routes
import (
"git.hackmi.ch/Phil/goshorly/db"
"git.hackmi.ch/Phil/goshorly/utils"
"github.com/gofiber/fiber/v2"
)
func Gethome(c *fiber.Ctx) error {
return c.Render("views/home", fiber.Map{
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
return c.SendString("Homepage")
}

View file

@ -4,7 +4,6 @@ import (
"log"
"git.hackmi.ch/Phil/goshorly/db"
"git.hackmi.ch/Phil/goshorly/utils"
"github.com/gofiber/fiber/v2"
)
@ -18,9 +17,7 @@ func ID(c *fiber.Ctx) error {
"url": "URL not found",
})
} else {
return c.Render("views/404", fiber.Map{
"BASEURL": utils.URL,
})
return c.SendStatus(404)
}
}

View file

@ -27,16 +27,16 @@ func Posthome(c *fiber.Ctx) error {
})
}
return c.Status(500).Render("views/home", fiber.Map{
"ERR": "Parsing Error",
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
// return c.Status(500).Render("views/home", fiber.Map{
// "ERR": "Parsing Error",
// "CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
// "CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
// "CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
// "CI_TAGGED": utils.CI_TAGGED,
// "CI_BUILD": utils.CI_BUILD,
// "TotalLinks": db.GetTotalLinks(),
// "TotalViews": db.GetTotalViews(),
// })
}
if !regexp.MustCompile(`^(http|https|mailto|ts3server)://`).MatchString(u.URL) {
@ -48,16 +48,16 @@ func Posthome(c *fiber.Ctx) error {
})
}
return c.Status(424).Render("views/home", fiber.Map{
"ERR": "Invalid URL, please check and try again.",
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
// return c.Status(424).Render("views/home", fiber.Map{
// "ERR": "Invalid URL, please check and try again.",
// "CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
// "CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
// "CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
// "CI_TAGGED": utils.CI_TAGGED,
// "CI_BUILD": utils.CI_BUILD,
// "TotalLinks": db.GetTotalLinks(),
// "TotalViews": db.GetTotalViews(),
// })
}
id, err := gonanoid.New(8)
@ -71,16 +71,16 @@ func Posthome(c *fiber.Ctx) error {
})
}
return c.Status(500).Render("views/home", fiber.Map{
"ERR": err.Error(),
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
// return c.Status(500).Render("views/home", fiber.Map{
// "ERR": err.Error(),
// "CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
// "CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
// "CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
// "CI_TAGGED": utils.CI_TAGGED,
// "CI_BUILD": utils.CI_BUILD,
// "TotalLinks": db.GetTotalLinks(),
// "TotalViews": db.GetTotalViews(),
// })
}
err = db.Set(id, u.URL, 1296000*time.Second)
@ -93,16 +93,16 @@ func Posthome(c *fiber.Ctx) error {
})
}
return c.Status(500).Render("views/home", fiber.Map{
"ERR": err.Error(),
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
// return c.Status(500).Render("views/home", fiber.Map{
// "ERR": err.Error(),
// "CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
// "CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
// "CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
// "CI_TAGGED": utils.CI_TAGGED,
// "CI_BUILD": utils.CI_BUILD,
// "TotalLinks": db.GetTotalLinks(),
// "TotalViews": db.GetTotalViews(),
// })
}
fURL := utils.URL + id
@ -121,14 +121,16 @@ func Posthome(c *fiber.Ctx) error {
})
}
return c.Status(201).Render("views/home", fiber.Map{
"URL": fURL,
"CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
"CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
"CI_TAGGED": utils.CI_TAGGED,
"CI_BUILD": utils.CI_BUILD,
"TotalLinks": db.GetTotalLinks(),
"TotalViews": db.GetTotalViews(),
})
// return c.Status(201).Render("views/home", fiber.Map{
// "URL": fURL,
// "CI_COMMIT_SHA": utils.CI_COMMIT_SHA,
// "CI_COMMIT_BRANCH": utils.CI_COMMIT_BRANCH,
// "CI_COMMIT_TAG": utils.CI_COMMIT_TAG,
// "CI_TAGGED": utils.CI_TAGGED,
// "CI_BUILD": utils.CI_BUILD,
// "TotalLinks": db.GetTotalLinks(),
// "TotalViews": db.GetTotalViews(),
// })
return c.SendStatus(200)
}

View file

@ -12,16 +12,11 @@ var ConfigLimiter limiter.Config = limiter.Config{
Expiration: 60 * time.Second,
LimitReached: func(c *fiber.Ctx) error {
if c.Get("content-type") == "application/json" {
return c.Status(418).JSON(fiber.Map{
return c.Status(429).JSON(fiber.Map{
"msg": "Too many requests, slow down I'm a teapot (10 requests per minute)",
"success": false,
})
}
return c.Render("views/home", fiber.Map{
"ERR": "You have reached the limit of requests! Please check back later. (1 minute)",
"CI_COMMIT_SHA": CI_COMMIT_SHA,
"CI_COMMIT_BRANCH": CI_COMMIT_BRANCH,
"CI_BUILD": CI_BUILD,
})
return c.SendStatus(429)
},
}