✨ Sticker pack ownership
This commit is contained in:
parent
cfd1735aee
commit
1dae405232
@ -12,6 +12,7 @@ var AutoMaintainRange = []any{
|
|||||||
&models.AttachmentBoost{},
|
&models.AttachmentBoost{},
|
||||||
&models.StickerPack{},
|
&models.StickerPack{},
|
||||||
&models.Sticker{},
|
&models.Sticker{},
|
||||||
|
&models.StickerPackOwnership{},
|
||||||
}
|
}
|
||||||
|
|
||||||
func RunMigration(source *gorm.DB) error {
|
func RunMigration(source *gorm.DB) error {
|
||||||
|
@ -25,3 +25,8 @@ type StickerPack struct {
|
|||||||
Stickers []Sticker `json:"stickers" gorm:"foreignKey:PackID;constraint:OnDelete:CASCADE"`
|
Stickers []Sticker `json:"stickers" gorm:"foreignKey:PackID;constraint:OnDelete:CASCADE"`
|
||||||
AccountID uint `json:"account_id"`
|
AccountID uint `json:"account_id"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type StickerPackOwnership struct {
|
||||||
|
PackID uint `json:"pack_id" gorm:"primaryKey"`
|
||||||
|
AccountID uint `json:"account_id" gorm:"primaryKey"`
|
||||||
|
}
|
||||||
|
@ -62,10 +62,13 @@ func MapAPIs(app *fiber.App, baseURL string) {
|
|||||||
packs := stickers.Group("/packs").Name("Sticker Packs API")
|
packs := stickers.Group("/packs").Name("Sticker Packs API")
|
||||||
{
|
{
|
||||||
packs.Get("/", listStickerPacks)
|
packs.Get("/", listStickerPacks)
|
||||||
|
packs.Get("/own", listOwnedStickerPacks)
|
||||||
packs.Get("/:packId", getStickerPack)
|
packs.Get("/:packId", getStickerPack)
|
||||||
packs.Post("/", sec.ValidatorMiddleware, createStickerPack)
|
packs.Post("/", sec.ValidatorMiddleware, createStickerPack)
|
||||||
packs.Put("/:packId", sec.ValidatorMiddleware, updateStickerPack)
|
packs.Put("/:packId", sec.ValidatorMiddleware, updateStickerPack)
|
||||||
packs.Delete("/:packId", sec.ValidatorMiddleware, deleteStickerPack)
|
packs.Delete("/:packId", sec.ValidatorMiddleware, deleteStickerPack)
|
||||||
|
packs.Post("/:packId/own", addStickerPack)
|
||||||
|
packs.Delete("/:packId/own", removeStickerPack)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,7 @@ import (
|
|||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
||||||
"git.solsynth.dev/hypernet/passport/pkg/authkit"
|
"git.solsynth.dev/hypernet/passport/pkg/authkit"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
|
"github.com/samber/lo"
|
||||||
)
|
)
|
||||||
|
|
||||||
func listStickerPacks(c *fiber.Ctx) error {
|
func listStickerPacks(c *fiber.Ctx) error {
|
||||||
@ -44,6 +45,29 @@ func listStickerPacks(c *fiber.Ctx) error {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func listOwnedStickerPacks(c *fiber.Ctx) error {
|
||||||
|
if err := sec.EnsureAuthenticated(c); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
user := c.Locals("nex_user").(*sec.UserInfo)
|
||||||
|
|
||||||
|
var ownerships []models.StickerPackOwnership
|
||||||
|
if err := database.C.Where("account_id = ?", user.ID).Find(&ownerships).Error; err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
idSet := lo.Map(ownerships, func(o models.StickerPackOwnership, _ int) uint {
|
||||||
|
return o.PackID
|
||||||
|
})
|
||||||
|
|
||||||
|
var packs []models.StickerPack
|
||||||
|
if err := database.C.Where("id IN ?", idSet).Find(&packs).Error; err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.JSON(packs)
|
||||||
|
}
|
||||||
|
|
||||||
func getStickerPack(c *fiber.Ctx) error {
|
func getStickerPack(c *fiber.Ctx) error {
|
||||||
id, _ := c.ParamsInt("packId", 0)
|
id, _ := c.ParamsInt("packId", 0)
|
||||||
pack, err := services.GetStickerPack(uint(id))
|
pack, err := services.GetStickerPack(uint(id))
|
||||||
@ -120,3 +144,43 @@ func deleteStickerPack(c *fiber.Ctx) error {
|
|||||||
|
|
||||||
return c.JSON(pack)
|
return c.JSON(pack)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func addStickerPack(c *fiber.Ctx) error {
|
||||||
|
if err := sec.EnsureAuthenticated(c); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
user := c.Locals("nex_user").(*sec.UserInfo)
|
||||||
|
|
||||||
|
packId, _ := c.ParamsInt("packId", 0)
|
||||||
|
var pack models.StickerPack
|
||||||
|
if err := database.C.Where("id = ?", packId).First(&pack).Error; err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusNotFound, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
ownership, err := services.AddStickerPack(user.ID, pack)
|
||||||
|
if err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusBadRequest, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.JSON(ownership)
|
||||||
|
}
|
||||||
|
|
||||||
|
func removeStickerPack(c *fiber.Ctx) error {
|
||||||
|
if err := sec.EnsureAuthenticated(c); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
user := c.Locals("nex_user").(*sec.UserInfo)
|
||||||
|
|
||||||
|
packId, _ := c.ParamsInt("packId", 0)
|
||||||
|
var pack models.StickerPack
|
||||||
|
if err := database.C.Where("id = ?", packId).First(&pack).Error; err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusNotFound, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
ownership, err := services.RemoveStickerPack(user.ID, pack)
|
||||||
|
if err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusBadRequest, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
|
return c.JSON(ownership)
|
||||||
|
}
|
||||||
|
@ -2,12 +2,10 @@ package api
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"github.com/samber/lo"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/gap"
|
|
||||||
"git.solsynth.dev/hypernet/passport/pkg/authkit"
|
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/server/exts"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/server/exts"
|
||||||
@ -64,43 +62,28 @@ func openStickerByAlias(c *fiber.Ctx) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func listStickers(c *fiber.Ctx) error {
|
func listStickers(c *fiber.Ctx) error {
|
||||||
take := c.QueryInt("take", 0)
|
if err := sec.EnsureAuthenticated(c); err != nil {
|
||||||
offset := c.QueryInt("offset", 0)
|
return err
|
||||||
|
|
||||||
if take > 100 {
|
|
||||||
take = 100
|
|
||||||
}
|
}
|
||||||
|
user := c.Locals("nex_user").(*sec.UserInfo)
|
||||||
|
|
||||||
tx := database.C
|
var ownerships []models.StickerPackOwnership
|
||||||
|
if err := database.C.Where("account_id = ?", user.ID).Find(&ownerships).Error; err != nil {
|
||||||
if len(c.Query("author")) > 0 {
|
|
||||||
author, err := authkit.GetUserByName(gap.Nx, c.Query("author"))
|
|
||||||
if err == nil {
|
|
||||||
tx = tx.Where("account_id = ?", author.ID)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if val := c.QueryInt("pack", 0); val > 0 {
|
|
||||||
tx = tx.Where("pack_id = ?", val)
|
|
||||||
}
|
|
||||||
|
|
||||||
var count int64
|
|
||||||
countTx := tx
|
|
||||||
if err := countTx.Model(&models.Sticker{}).Count(&count).Error; err != nil {
|
|
||||||
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tx := database.C.Where("pack_id IN ?", lo.Map(ownerships, func(o models.StickerPackOwnership, _ int) uint {
|
||||||
|
return o.PackID
|
||||||
|
}))
|
||||||
|
|
||||||
var stickers []models.Sticker
|
var stickers []models.Sticker
|
||||||
if err := tx.Limit(take).Offset(offset).
|
if err := tx.
|
||||||
Preload("Attachment").Preload("Pack").
|
Preload("Attachment").Preload("Pack").
|
||||||
Find(&stickers).Error; err != nil {
|
Find(&stickers).Error; err != nil {
|
||||||
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
return c.JSON(fiber.Map{
|
return c.JSON(stickers)
|
||||||
"count": count,
|
|
||||||
"data": stickers,
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func getSticker(c *fiber.Ctx) error {
|
func getSticker(c *fiber.Ctx) error {
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
package services
|
package services
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"gorm.io/gorm"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/models"
|
||||||
@ -71,3 +73,36 @@ func DeleteSticker(sticker models.Sticker) (models.Sticker, error) {
|
|||||||
}
|
}
|
||||||
return sticker, nil
|
return sticker, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func AddStickerPack(user uint, pack models.StickerPack) (models.StickerPackOwnership, error) {
|
||||||
|
var ownership models.StickerPackOwnership
|
||||||
|
if err := database.C.
|
||||||
|
Where("account_id = ?", user).
|
||||||
|
First(&ownership).Error; err != nil && !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||||
|
return ownership, fmt.Errorf("unable to get current ownership: %v", err)
|
||||||
|
} else if err == nil {
|
||||||
|
return ownership, fmt.Errorf("you already own this pack")
|
||||||
|
}
|
||||||
|
|
||||||
|
ownership = models.StickerPackOwnership{
|
||||||
|
AccountID: user,
|
||||||
|
PackID: pack.ID,
|
||||||
|
}
|
||||||
|
|
||||||
|
err := database.C.Save(&ownership).Error
|
||||||
|
|
||||||
|
return ownership, err
|
||||||
|
}
|
||||||
|
|
||||||
|
func RemoveStickerPack(user uint, pack models.StickerPack) (models.StickerPackOwnership, error) {
|
||||||
|
var ownership models.StickerPackOwnership
|
||||||
|
if err := database.C.
|
||||||
|
Where("account_id = ? AND pack_id = ?", user, pack.ID).
|
||||||
|
First(&ownership).Error; err != nil {
|
||||||
|
return ownership, fmt.Errorf("unable to get current ownership: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
err := database.C.Delete(&ownership).Error
|
||||||
|
|
||||||
|
return ownership, err
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user