perf: caching certain routes
This commit is contained in:
parent
c0f817722d
commit
e3e178087c
|
@ -2,13 +2,15 @@ package routes
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"jokes-bapak2-api/app/v1/handler/health"
|
"jokes-bapak2-api/app/v1/handler/health"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
|
"github.com/gofiber/fiber/v2/middleware/cache"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Health(app *fiber.App) *fiber.App {
|
func Health(app *fiber.App) *fiber.App {
|
||||||
// Health check
|
// Health check
|
||||||
app.Get("/health", health.Health)
|
app.Get("/health", cache.New(cache.Config{Expiration: 30 * time.Minute}), health.Health)
|
||||||
|
|
||||||
return app
|
return app
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,8 +3,10 @@ package routes
|
||||||
import (
|
import (
|
||||||
"jokes-bapak2-api/app/v1/handler/joke"
|
"jokes-bapak2-api/app/v1/handler/joke"
|
||||||
"jokes-bapak2-api/app/v1/middleware"
|
"jokes-bapak2-api/app/v1/middleware"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
|
"github.com/gofiber/fiber/v2/middleware/cache"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Joke(app *fiber.App) *fiber.App {
|
func Joke(app *fiber.App) *fiber.App {
|
||||||
|
@ -12,13 +14,13 @@ func Joke(app *fiber.App) *fiber.App {
|
||||||
app.Get("/", joke.SingleJoke)
|
app.Get("/", joke.SingleJoke)
|
||||||
|
|
||||||
// Today's joke
|
// Today's joke
|
||||||
app.Get("/today", joke.TodayJoke)
|
app.Get("/today", cache.New(cache.Config{Expiration: 6 * time.Hour}), joke.TodayJoke)
|
||||||
|
|
||||||
// Joke by ID
|
// Joke by ID
|
||||||
app.Get("/id/:id", middleware.OnlyIntegerAsID(), joke.JokeByID)
|
app.Get("/id/:id", middleware.OnlyIntegerAsID(), joke.JokeByID)
|
||||||
|
|
||||||
// Count total jokes
|
// Count total jokes
|
||||||
app.Get("/total", joke.TotalJokes)
|
app.Get("/total", cache.New(cache.Config{Expiration: 15 * time.Minute}), joke.TotalJokes)
|
||||||
|
|
||||||
// Add new joke
|
// Add new joke
|
||||||
app.Put("/", middleware.RequireAuth(), joke.AddNewJoke)
|
app.Put("/", middleware.RequireAuth(), joke.AddNewJoke)
|
||||||
|
|
|
@ -2,13 +2,23 @@ package routes
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"jokes-bapak2-api/app/v1/handler/submit"
|
"jokes-bapak2-api/app/v1/handler/submit"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
|
"github.com/gofiber/fiber/v2/middleware/cache"
|
||||||
)
|
)
|
||||||
|
|
||||||
func Submit(app *fiber.App) *fiber.App {
|
func Submit(app *fiber.App) *fiber.App {
|
||||||
// Get pending submitted joke
|
// Get pending submitted joke
|
||||||
app.Get("/submit", submit.GetSubmission)
|
app.Get(
|
||||||
|
"/submit",
|
||||||
|
cache.New(cache.Config{
|
||||||
|
Expiration: 5 * time.Minute,
|
||||||
|
KeyGenerator: func(c *fiber.Ctx) string {
|
||||||
|
return c.OriginalURL()
|
||||||
|
},
|
||||||
|
}),
|
||||||
|
submit.GetSubmission)
|
||||||
|
|
||||||
// Add a joke
|
// Add a joke
|
||||||
app.Post("/submit", submit.SubmitJoke)
|
app.Post("/submit", submit.SubmitJoke)
|
||||||
|
|
Loading…
Reference in New Issue