package pages import ( "strconv" "codeberg.org/rimgo/rimgo/utils" "github.com/gofiber/fiber/v2" ) func HandleUser(c *fiber.Ctx) error { utils.SetHeaders(c) c.Set("X-Frame-Options", "DENY") c.Set("Cache-Control", "public,max-age=604800") c.Set("Content-Security-Policy", "default-src 'none'; frame-ancestors 'none'; base-uri 'none'; form-action 'self'; media-src 'self' https://i.imgur.com https://i.stack.imgur.com; style-src 'unsafe-inline' 'self'; img-src 'self' https://i.imgur.com https://i.stack.imgur.com; manifest-src 'self'; block-all-mixed-content") page := "0" if c.Query("page") != "" { page = c.Query("page") } pageNumber, err := strconv.Atoi(c.Query("page")) if err != nil { pageNumber = 0 } user, err := ApiClient.FetchUser(c.Params("userID")) if err != nil && err.Error() == "ratelimited by imgur" { return utils.RenderError(c, 429) } if err != nil { return err } if user.Username == "" { return utils.RenderError(c, 404) } submissions, err := ApiClient.FetchSubmissions(c.Params("userID"), "newest", page) if err != nil && err.Error() == "ratelimited by imgur" { c.Status(429) return utils.RenderError(c, 429) } if err != nil { return err } return c.Render("user", fiber.Map{ "user": user, "submissions": submissions, "page": page, "nextPage": pageNumber + 1, "prevPage": pageNumber - 1, }) } func HandleUserComments(c *fiber.Ctx) error { utils.SetHeaders(c) c.Set("X-Frame-Options", "DENY") c.Set("Cache-Control", "public,max-age=604800") c.Set("Content-Security-Policy", "default-src 'none'; frame-ancestors 'none'; base-uri 'none'; form-action 'self'; media-src 'self'; style-src 'unsafe-inline' 'self'; img-src 'self'; manifest-src 'self'; block-all-mixed-content") user, err := ApiClient.FetchUser(c.Params("userID")) if err != nil && err.Error() == "ratelimited by imgur" { return utils.RenderError(c, 429) } if err != nil { return err } if user.Username == "" { return utils.RenderError(c, 404) } comments, err := ApiClient.FetchUserComments(c.Params("userID")) if err != nil && err.Error() == "ratelimited by imgur" { c.Status(429) return utils.RenderError(c, 429) } if err != nil { return err } return c.Render("userComments", fiber.Map{ "user": user, "comments": comments, }) } func HandleUserFavorites(c *fiber.Ctx) error { utils.SetHeaders(c) c.Set("X-Frame-Options", "DENY") c.Set("Cache-Control", "public,max-age=604800") c.Set("Content-Security-Policy", "default-src 'none'; frame-ancestors 'none'; base-uri 'none'; form-action 'self'; media-src 'self'; style-src 'unsafe-inline' 'self'; img-src 'self'; manifest-src 'self'; block-all-mixed-content") page := "0" if c.Query("page") != "" { page = c.Query("page") } pageNumber, err := strconv.Atoi(c.Query("page")) if err != nil { pageNumber = 0 } user, err := ApiClient.FetchUser(c.Params("userID")) if err != nil && err.Error() == "ratelimited by imgur" { return utils.RenderError(c, 429) } if err != nil { return err } if user.Username == "" { return utils.RenderError(c, 404) } favorites, err := ApiClient.FetchUserFavorites(c.Params("userID"), "newest", page) if err != nil && err.Error() == "ratelimited by imgur" { return utils.RenderError(c, 429) } if err != nil { return err } return c.Render("userFavorites", fiber.Map{ "user": user, "favorites": favorites, "page": page, "nextPage": pageNumber + 1, "prevPage": pageNumber - 1, }) }