2023-04-25 18:43:01 +02:00
|
|
|
package api
|
|
|
|
|
|
|
|
import (
|
2023-04-27 19:03:28 +02:00
|
|
|
"codeberg.org/lauralani/go-urlsh/internal/db"
|
2023-04-25 18:43:01 +02:00
|
|
|
"codeberg.org/lauralani/go-urlsh/internal/misc"
|
|
|
|
"codeberg.org/lauralani/go-urlsh/models"
|
|
|
|
"context"
|
2023-06-16 12:46:08 +02:00
|
|
|
"database/sql"
|
2023-04-25 18:43:01 +02:00
|
|
|
"encoding/json"
|
|
|
|
"fmt"
|
|
|
|
"github.com/gofiber/fiber/v2"
|
|
|
|
"log"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
func HandleLinkGetAll(c *fiber.Ctx) error {
|
2023-05-05 15:16:54 +02:00
|
|
|
if !db.IsCookieValid(c.Cookies(misc.CookieName, "")) && !db.IsApiKeyValid(c.GetRespHeader("x-api-key", "")) {
|
|
|
|
return fiber.NewError(fiber.StatusUnauthorized, "401 Unauthorized")
|
|
|
|
}
|
|
|
|
|
2023-04-25 18:43:01 +02:00
|
|
|
var links []models.Link
|
|
|
|
|
|
|
|
err := models.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)
|
|
|
|
}
|
2023-05-05 15:16:54 +02:00
|
|
|
err = c.JSON(links)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2023-04-25 18:43:01 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func HandleLinkGet(c *fiber.Ctx) error {
|
2023-06-16 12:46:08 +02:00
|
|
|
return fiber.NewError(fiber.StatusNotImplemented, "501 Not Implemented")
|
2023-04-25 18:43:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
func HandleLinkPost(c *fiber.Ctx) error {
|
2023-05-05 15:16:54 +02:00
|
|
|
if !db.IsCookieValid(c.Cookies(misc.CookieName, "")) && !db.IsApiKeyValid(c.GetRespHeader("x-api-key", "")) {
|
2023-04-27 19:03:28 +02:00
|
|
|
return fiber.NewError(fiber.StatusUnauthorized, "401 Unauthorized")
|
|
|
|
}
|
|
|
|
|
2023-04-25 18:43:01 +02:00
|
|
|
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 = models.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)
|
2023-04-27 19:03:28 +02:00
|
|
|
c.Status(fiber.StatusCreated)
|
2023-05-05 15:16:54 +02:00
|
|
|
|
|
|
|
err = c.JSON(newlink)
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
2023-04-25 18:43:01 +02:00
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func HandleLinkPut(c *fiber.Ctx) error {
|
2023-06-16 12:46:08 +02:00
|
|
|
if !db.IsCookieValid(c.Cookies(misc.CookieName, "")) && !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 := models.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 = models.DB.NewUpdate().Model(&dblink).Where("id = ?", id).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)
|
|
|
|
|
2023-04-25 18:43:01 +02:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func HandleLinkDelete(c *fiber.Ctx) error {
|
|
|
|
id := c.Params("id")
|
|
|
|
|
|
|
|
if id == "" {
|
|
|
|
return fiber.NewError(fiber.StatusBadRequest, "400 Bad Request")
|
|
|
|
}
|
|
|
|
|
|
|
|
numrows, err := models.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 = models.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")
|
|
|
|
}
|
2023-05-05 15:16:54 +02:00
|
|
|
|
|
|
|
c.Status(fiber.StatusNoContent)
|
|
|
|
err = c.SendString("204 No Content")
|
|
|
|
if err != nil {
|
|
|
|
log.Println(err)
|
|
|
|
}
|
|
|
|
|
2023-04-25 18:43:01 +02:00
|
|
|
return nil
|
|
|
|
}
|