Feat: finish putImageAliases

This commit is contained in:
2025-12-07 20:34:53 +08:00
parent cada4d25fa
commit b609421a6e
15 changed files with 242 additions and 42 deletions

View File

@@ -19,5 +19,6 @@ import (
func (self *Handlers) DeleteAlias(
w http.ResponseWriter, req bunrouter.Request,
) error {
// TODO
return utils.Success(w)
}

View File

@@ -19,5 +19,6 @@ import (
func (self *Handlers) DeleteImage(
w http.ResponseWriter, req bunrouter.Request,
) error {
// TODO
return utils.Success(w)
}

View File

@@ -15,5 +15,6 @@ import (
func (self *Handlers) GetAliasUpdate(
w http.ResponseWriter, req bunrouter.Request,
) error {
// TODO
return utils.Success(w)
}

View File

@@ -23,7 +23,6 @@ type getAliasesOutputAlias struct {
func (self *Handlers) GetAliases(
w http.ResponseWriter, req bunrouter.Request,
) error {
// mock output
ctx := req.Context()
aliases, err := self.db.GetAliases(ctx)

View File

@@ -2,18 +2,18 @@ package api
import (
"net/http"
"strconv"
"strings"
"gitea.konchin.com/go2025/backend/middlewares"
"gitea.konchin.com/go2025/backend/utils"
"github.com/uptrace/bunrouter"
)
type getImagesOutputImage struct {
Id int64 `json:"id"`
Uploader string `json:"uploadedUserId"`
UploadTS int64 `json:"uploadedAt"`
Aliases []string `json:"aliases"`
Id int64 `json:"id"`
Uploader string `json:"uploadedUserId"`
UploadTS int64 `json:"uploadedAt"`
AliasesIds []int64 `json:"aliasesIds"`
}
// GetImages
@@ -27,18 +27,63 @@ type getImagesOutputImage struct {
func (self *Handlers) GetImages(
w http.ResponseWriter, req bunrouter.Request,
) error {
// ctx := req.Context()
ctx := req.Context()
images := strings.Split(req.Param("images"), ",")
aliases := strings.Split(req.Param("aliases"), ",")
rawReqImages := strings.Split(req.Param("images"), ",")
rawReqAliases := strings.Split(req.Param("aliases"), ",")
if (len(images) == 0 && len(aliases) == 0) ||
(len(images) > 0 && len(aliases) > 0) {
if (len(rawReqImages) == 0 && len(rawReqAliases) == 0) ||
(len(rawReqImages) > 0 && len(rawReqAliases) > 0) {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "images and aliases should exist exactly one",
}
}
return utils.Success(w)
var reqImages, reqAliases []int64
for _, img := range rawReqImages {
imgId, err := strconv.ParseInt(img, 10, 64)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to parse image ids",
}
}
reqImages = append(reqImages, imgId)
}
for _, ali := range rawReqAliases {
aliId, err := strconv.ParseInt(ali, 10, 64)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to parse alias ids",
}
}
reqAliases = append(reqAliases, aliId)
}
images, err := self.db.GetImages(ctx, reqImages, reqAliases)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to get images",
OriginError: err,
}
}
var output []getImagesOutputImage
for _, img := range images {
var aliases []int64
for _, alias := range img.Aliases {
aliases = append(aliases, alias.Id)
}
output = append(output, getImagesOutputImage{
Id: img.Id,
Uploader: img.Uploader,
UploadTS: img.UploadTS.Unix(),
AliasesIds: aliases,
})
}
return bunrouter.JSON(w, output)
}

View File

@@ -2,7 +2,9 @@ package api
import (
"net/http"
"strings"
"gitea.konchin.com/go2025/backend/middlewares"
"gitea.konchin.com/go2025/backend/utils"
"github.com/uptrace/bunrouter"
)
@@ -19,5 +21,14 @@ import (
func (self *Handlers) PostImage(
w http.ResponseWriter, req bunrouter.Request,
) error {
typeHeader := strings.Split(req.Header.Get("Content-Type"), "/")
if len(typeHeader) != 2 || typeHeader[0] != "image" {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "incorrect 'Content-Type' header",
}
}
// TODO
return utils.Success(w)
}

View File

@@ -1,18 +1,23 @@
package api
import (
"encoding/json"
"io"
"net/http"
"gitea.konchin.com/go2025/backend/middlewares"
"gitea.konchin.com/go2025/backend/utils"
"github.com/uptrace/bunrouter"
)
type putImageAliasesInputAlias = string
type putImageAliasesInput struct {
Aliases []string `json:"aliases"`
}
// PutImageAliases
//
// @param id path int64 true "Image Id"
// @param payload body []putImageAliasesInputAlias true "Payload"
// @param id path int64 true "Image Id"
// @param payload body putImageAliasesInput true "Payload"
// @success 200
// @failure 401
// @failure 404
@@ -20,5 +25,43 @@ type putImageAliasesInputAlias = string
func (self *Handlers) PutImageAliases(
w http.ResponseWriter, req bunrouter.Request,
) error {
ctx := req.Context()
imgId, err := req.Params().Int64("id")
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "falied to parse image id in path",
OriginError: err,
}
}
b, err := io.ReadAll(req.Body)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to read payload",
OriginError: err,
}
}
var input putImageAliasesInput
if err := json.Unmarshal(b, &input); err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusBadRequest,
Message: "failed to unmarshal json",
OriginError: err,
}
}
err = self.db.UpdateAliases(ctx, imgId, input.Aliases)
if err != nil {
return middlewares.HTTPError{
StatusCode: http.StatusInternalServerError,
Message: "failed to update aliases",
OriginError: err,
}
}
return utils.Success(w)
}