go-urlsh/internal/api/links.go

157 lines
4.3 KiB
Go

package api
import (
"context"
"database/sql"
"encoding/json"
"fmt"
"log"
"time"
"code.lila.network/adoralaura/go-urlsh/internal/constants"
"code.lila.network/adoralaura/go-urlsh/internal/db"
"code.lila.network/adoralaura/go-urlsh/internal/misc"
"code.lila.network/adoralaura/go-urlsh/models"
"github.com/gofiber/fiber/v2"
)
func (am APIRouteManager) HandleLinkGetAll(c *fiber.Ctx) error {
if !db.IsCookieValid(c.Cookies(constants.LoginCookieName, "")) && !db.IsApiKeyValid(c.GetRespHeader("x-api-key", "")) {
return fiber.NewError(fiber.StatusUnauthorized, "401 Unauthorized")
}
var links []models.Link
err := am.db.NewSelect().Model(&links).Scan(context.Background())
if err != nil {
return fmt.Errorf("error querying links: %v", err.Error())
}
for _, link := range links {
log.Printf("id: %v, url: %v", link.ID, link.URL)
}
err = c.JSON(links)
if err != nil {
log.Println(err)
}
return nil
}
func (am APIRouteManager) HandleLinkGet(c *fiber.Ctx) error {
return fiber.NewError(fiber.StatusNotImplemented, "501 Not Implemented")
}
func (am APIRouteManager) HandleLinkPost(c *fiber.Ctx) error {
if !db.IsCookieValid(c.Cookies(constants.LoginCookieName, "")) && !db.IsApiKeyValid(c.GetRespHeader("x-api-key", "")) {
return fiber.NewError(fiber.StatusUnauthorized, "401 Unauthorized")
}
var newlink models.Link
err := json.Unmarshal(c.Body(), &newlink)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, "400 Bad Request: "+err.Error())
}
// TODO: check if ID is already taken when ID is given
if newlink.ID == "" {
newlink.ID = misc.RandomString(6)
}
now := time.Now()
newlink.Created = now
newlink.Modified = now
_, err = am.db.NewInsert().Model(&newlink).Exec(context.Background())
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, "500 Internal Server Error: "+err.Error())
}
c.Append("Location", c.BaseURL()+"/api/v1/links/"+newlink.ID)
c.Status(fiber.StatusCreated)
err = c.JSON(newlink)
if err != nil {
log.Println(err)
}
return nil
}
func (am APIRouteManager) HandleLinkPut(c *fiber.Ctx) error {
if !db.IsCookieValid(c.Cookies(constants.LoginCookieName, "")) && !db.IsApiKeyValid(c.GetRespHeader("x-api-key", "")) {
return fiber.NewError(fiber.StatusUnauthorized, "401 Unauthorized")
}
var dblink models.Link
var editlink models.Link
id := c.Params("id")
if id == "" {
return fiber.NewError(fiber.StatusBadRequest, "400 Bad Request")
}
err := am.db.NewSelect().Model(&dblink).Where("id = ?", id).Scan(context.Background())
if err != nil {
if err == sql.ErrNoRows {
log.Printf("[HandleAdminLinkEditGet] Shortlink %v not found\n", id)
return fiber.NewError(fiber.StatusNotFound, "404 Not Found")
} else {
log.Printf("[HandleAdminLinkEditGet] Error querying Shortlink %v from database: %v\n", id, err)
return fiber.NewError(fiber.StatusInternalServerError, "500 Internal Server Error")
}
}
err = json.Unmarshal(c.Body(), &editlink)
if err != nil {
return fiber.NewError(fiber.StatusBadRequest, "400 Bad Request: "+err.Error())
}
dblink.Description = editlink.Description
dblink.URL = editlink.URL
dblink.Modified = time.Now()
_, err = am.db.NewUpdate().Model(&dblink).WherePK().Exec(context.Background())
if err != nil {
return fiber.NewError(fiber.StatusInternalServerError, "500 Internal Server Error: "+err.Error())
}
c.Append("Location", c.BaseURL()+"/api/v1/links/"+editlink.ID)
c.Status(fiber.StatusNoContent)
return nil
}
func (am APIRouteManager) HandleLinkDelete(c *fiber.Ctx) error {
id := c.Params("id")
if id == "" {
return fiber.NewError(fiber.StatusBadRequest, "400 Bad Request")
}
numrows, err := am.db.NewSelect().Model((*models.Link)(nil)).Where("id = ?", id).Count(context.Background())
if err != nil {
log.Println(err.Error())
return fiber.NewError(fiber.StatusInternalServerError, "500 Internal Server Error")
}
if numrows < 1 {
return fiber.NewError(fiber.StatusNotFound, "404 Not Found")
}
_, err = am.db.NewDelete().Model((*models.Link)(nil)).Where("id = ?", id).Exec(context.Background())
if err != nil {
log.Println(err.Error())
return fiber.NewError(fiber.StatusInternalServerError, "500 Internal Server Error")
}
c.Status(fiber.StatusNoContent)
err = c.SendString("204 No Content")
if err != nil {
log.Println(err)
}
return nil
}