✨ List attachments now return with userinfo
This commit is contained in:
parent
370ee84b34
commit
11d54c7c78
@ -5,6 +5,7 @@ import (
|
|||||||
|
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/cachekit"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/cachekit"
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/cruda"
|
||||||
|
"git.solsynth.dev/hypernet/passport/pkg/authkit/models"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/gap"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/gap"
|
||||||
|
|
||||||
@ -68,7 +69,8 @@ type Attachment struct {
|
|||||||
|
|
||||||
Boosts []AttachmentBoost `json:"boosts"`
|
Boosts []AttachmentBoost `json:"boosts"`
|
||||||
|
|
||||||
AccountID uint `json:"account_id"`
|
AccountID uint `json:"account_id"`
|
||||||
|
Account models.Account `gorm:"-" json:"account"`
|
||||||
|
|
||||||
// Outdated fields, just for backward compatibility
|
// Outdated fields, just for backward compatibility
|
||||||
FileChunks datatypes.JSONMap `json:"file_chunks" gorm:"-"`
|
FileChunks datatypes.JSONMap `json:"file_chunks" gorm:"-"`
|
||||||
|
@ -4,8 +4,8 @@ import (
|
|||||||
"context"
|
"context"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
||||||
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/proto"
|
"git.solsynth.dev/hypernet/paperclip/pkg/proto"
|
||||||
"github.com/rs/zerolog/log"
|
"github.com/rs/zerolog/log"
|
||||||
@ -33,8 +33,13 @@ func (v *Server) GetAttachment(ctx context.Context, request *proto.GetAttachment
|
|||||||
return nil, status.Error(codes.NotFound, "attachment not found")
|
return nil, status.Error(codes.NotFound, "attachment not found")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out, err := services.CompleteAttachmentMeta(attachment)
|
||||||
|
if err != nil {
|
||||||
|
return nil, status.Error(codes.Internal, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
return &proto.GetAttachmentResponse{
|
return &proto.GetAttachmentResponse{
|
||||||
Attachment: nex.EncodeMap(attachment),
|
Attachment: nex.EncodeMap(out[0]),
|
||||||
}, nil
|
}, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -56,8 +61,13 @@ func (v *Server) ListAttachment(ctx context.Context, request *proto.ListAttachme
|
|||||||
return nil, status.Error(codes.Internal, err.Error())
|
return nil, status.Error(codes.Internal, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out, err := services.CompleteAttachmentMeta(attachments...)
|
||||||
|
if err != nil {
|
||||||
|
return nil, status.Error(codes.Internal, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
return &proto.ListAttachmentResponse{
|
return &proto.ListAttachmentResponse{
|
||||||
Attachments: lo.Map(attachments, func(v models.Attachment, _ int) []byte {
|
Attachments: lo.Map(out, func(v models.Attachment, _ int) []byte {
|
||||||
return nex.EncodeMap(v)
|
return nex.EncodeMap(v)
|
||||||
}),
|
}),
|
||||||
}, nil
|
}, nil
|
||||||
|
@ -9,8 +9,8 @@ import (
|
|||||||
"github.com/spf13/viper"
|
"github.com/spf13/viper"
|
||||||
"gorm.io/datatypes"
|
"gorm.io/datatypes"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
||||||
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/database"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/services"
|
||||||
"github.com/gofiber/fiber/v2"
|
"github.com/gofiber/fiber/v2"
|
||||||
)
|
)
|
||||||
@ -111,8 +111,13 @@ func listAttachment(c *fiber.Ctx) error {
|
|||||||
services.CacheAttachment(item)
|
services.CacheAttachment(item)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
out, err := services.CompleteAttachmentMeta(result...)
|
||||||
|
if err != nil {
|
||||||
|
return fiber.NewError(fiber.StatusInternalServerError, err.Error())
|
||||||
|
}
|
||||||
|
|
||||||
return c.JSON(fiber.Map{
|
return c.JSON(fiber.Map{
|
||||||
"count": count,
|
"count": count,
|
||||||
"data": result,
|
"data": out,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
@ -10,13 +10,16 @@ import (
|
|||||||
|
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/cachekit"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/cachekit"
|
||||||
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
|
"git.solsynth.dev/hypernet/nexus/pkg/nex/sec"
|
||||||
|
"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/fs"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/fs"
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/internal/gap"
|
"git.solsynth.dev/hypernet/paperclip/pkg/internal/gap"
|
||||||
|
|
||||||
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
"git.solsynth.dev/hypernet/paperclip/pkg/filekit/models"
|
||||||
|
amodels "git.solsynth.dev/hypernet/passport/pkg/authkit/models"
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
|
"github.com/samber/lo"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -24,6 +27,27 @@ func KgAttachmentCache(rid string) string {
|
|||||||
return cachekit.FKey(cachekit.DAAttachment, rid)
|
return cachekit.FKey(cachekit.DAAttachment, rid)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func CompleteAttachmentMeta(in ...models.Attachment) ([]models.Attachment, error) {
|
||||||
|
var usersId []uint
|
||||||
|
for _, item := range in {
|
||||||
|
usersId = append(usersId, item.AccountID)
|
||||||
|
}
|
||||||
|
usersId = lo.Uniq(usersId)
|
||||||
|
users, err := authkit.ListUser(gap.Nx, usersId)
|
||||||
|
if err != nil {
|
||||||
|
return in, fmt.Errorf("failed to list users: %v", err)
|
||||||
|
}
|
||||||
|
|
||||||
|
for idx, item := range in {
|
||||||
|
item.Account = lo.FindOrElse(users, amodels.Account{}, func(idx amodels.Account) bool {
|
||||||
|
return item.AccountID == idx.ID
|
||||||
|
})
|
||||||
|
in[idx] = item
|
||||||
|
}
|
||||||
|
|
||||||
|
return in, nil
|
||||||
|
}
|
||||||
|
|
||||||
func GetAttachmentByID(id uint) (models.Attachment, error) {
|
func GetAttachmentByID(id uint) (models.Attachment, error) {
|
||||||
var attachment models.Attachment
|
var attachment models.Attachment
|
||||||
if err := database.C.
|
if err := database.C.
|
||||||
@ -38,7 +62,8 @@ func GetAttachmentByID(id uint) (models.Attachment, error) {
|
|||||||
CacheAttachment(attachment)
|
CacheAttachment(attachment)
|
||||||
}
|
}
|
||||||
|
|
||||||
return attachment, nil
|
out, err := CompleteAttachmentMeta(attachment)
|
||||||
|
return out[0], err
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetAttachmentByRID(rid string) (models.Attachment, error) {
|
func GetAttachmentByRID(rid string) (models.Attachment, error) {
|
||||||
@ -63,7 +88,8 @@ func GetAttachmentByRID(rid string) (models.Attachment, error) {
|
|||||||
CacheAttachment(attachment)
|
CacheAttachment(attachment)
|
||||||
}
|
}
|
||||||
|
|
||||||
return attachment, nil
|
out, err := CompleteAttachmentMeta(attachment)
|
||||||
|
return out[0], err
|
||||||
}
|
}
|
||||||
|
|
||||||
func GetAttachmentByHash(hash string) (models.Attachment, error) {
|
func GetAttachmentByHash(hash string) (models.Attachment, error) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user