feat: 迁移plant
This commit is contained in:
@@ -8,6 +8,7 @@ import (
|
||||
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
"sundynix-micro-go/app/plant/rpc/plant"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
@@ -28,7 +29,9 @@ func NewCreateWikiClassLogic(ctx context.Context, svcCtx *svc.ServiceContext) *C
|
||||
}
|
||||
|
||||
func (l *CreateWikiClassLogic) CreateWikiClass(req *types.WikiClassReq) error {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
return nil
|
||||
_, err := l.svcCtx.PlantRpc.CreateWikiClass(l.ctx, &plant.CreateWikiClassReq{
|
||||
Name: req.Name,
|
||||
Icon: req.Icon,
|
||||
})
|
||||
return err
|
||||
}
|
||||
|
||||
@@ -0,0 +1,67 @@
|
||||
// Code scaffolded by goctl. Safe to edit.
|
||||
// goctl 1.10.1
|
||||
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
|
||||
type CreateWikiLogic struct {
|
||||
logx.Logger
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
// 创建百科
|
||||
func NewCreateWikiLogic(ctx context.Context, svcCtx *svc.ServiceContext) *CreateWikiLogic {
|
||||
return &CreateWikiLogic{
|
||||
Logger: logx.WithContext(ctx),
|
||||
ctx: ctx,
|
||||
svcCtx: svcCtx,
|
||||
}
|
||||
}
|
||||
|
||||
func (l *CreateWikiLogic) CreateWiki(req *types.CreateWikiReq) error {
|
||||
classID := req.ClassId
|
||||
if classID == "" && len(req.ClassIds) > 0 {
|
||||
classID = req.ClassIds[0]
|
||||
}
|
||||
_, err := l.svcCtx.PlantRpc.CreateWiki(l.ctx, &plantPb.CreateWikiReq{
|
||||
Name: req.Name,
|
||||
LatinName: req.LatinName,
|
||||
Aliases: req.Aliases,
|
||||
Genus: req.Genus,
|
||||
Difficulty: int32(req.Difficulty),
|
||||
IsHot: int32(req.IsHot),
|
||||
GrowthHabit: req.GrowthHabit,
|
||||
LightIntensity: req.LightIntensity,
|
||||
OptimalTempPeriod: req.OptimalTempPeriod,
|
||||
ClassId: classID,
|
||||
DistributionArea: req.DistributionArea,
|
||||
LifeCycle: req.LifeCycle,
|
||||
ClassIds: req.ClassIds,
|
||||
OssIds: req.OssIds,
|
||||
RelatedWikiIds: req.RelatedWikiIds,
|
||||
ReproductionMethod: req.ReproductionMethod,
|
||||
PestsDiseases: req.PestsDiseases,
|
||||
LightType: req.LightType,
|
||||
Stem: req.Stem,
|
||||
Fruit: req.Fruit,
|
||||
FoliageType: req.FoliageType,
|
||||
FoliageColor: req.FoliageColor,
|
||||
FoliageShape: req.FoliageShape,
|
||||
Height: int32(req.Height),
|
||||
FloweringPeriod: req.FloweringPeriod,
|
||||
FloweringColor: req.FloweringColor,
|
||||
FloweringShape: req.FloweringShape,
|
||||
FloweringDiameter: int32(req.FlowerDiameter),
|
||||
})
|
||||
return err
|
||||
}
|
||||
@@ -0,0 +1,24 @@
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
)
|
||||
|
||||
type DeleteWikiClassLogic struct {
|
||||
logx.Logger
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
func NewDeleteWikiClassLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DeleteWikiClassLogic {
|
||||
return &DeleteWikiClassLogic{Logger: logx.WithContext(ctx), ctx: ctx, svcCtx: svcCtx}
|
||||
}
|
||||
|
||||
func (l *DeleteWikiClassLogic) DeleteWikiClass(req *types.IdsReq) error {
|
||||
_, err := l.svcCtx.PlantRpc.DeleteWikiClass(l.ctx, &plantPb.IdsReq{Ids: req.Ids})
|
||||
return err
|
||||
}
|
||||
@@ -0,0 +1,24 @@
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
)
|
||||
|
||||
type DeleteWikiLogic struct {
|
||||
logx.Logger
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
func NewDeleteWikiLogic(ctx context.Context, svcCtx *svc.ServiceContext) *DeleteWikiLogic {
|
||||
return &DeleteWikiLogic{Logger: logx.WithContext(ctx), ctx: ctx, svcCtx: svcCtx}
|
||||
}
|
||||
|
||||
func (l *DeleteWikiLogic) DeleteWiki(req *types.IdsReq) error {
|
||||
_, err := l.svcCtx.PlantRpc.DeleteWiki(l.ctx, &plantPb.IdsReq{Ids: req.Ids})
|
||||
return err
|
||||
}
|
||||
@@ -8,6 +8,7 @@ import (
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/rpc/plant"
|
||||
)
|
||||
|
||||
type GetWikiClassListLogic struct {
|
||||
@@ -25,8 +26,10 @@ func NewGetWikiClassListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *
|
||||
}
|
||||
}
|
||||
|
||||
func (l *GetWikiClassListLogic) GetWikiClassList() error {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
return nil
|
||||
func (l *GetWikiClassListLogic) GetWikiClassList() (interface{}, error) {
|
||||
result, err := l.svcCtx.PlantRpc.GetWikiClassList(l.ctx, &plant.IdReq{})
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return map[string]interface{}{"list": result.List}, nil
|
||||
}
|
||||
|
||||
@@ -1,13 +1,14 @@
|
||||
// Code scaffolded by goctl. Safe to edit.
|
||||
// goctl 1.10.1
|
||||
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
"time"
|
||||
|
||||
filePb "sundynix-micro-go/app/file/rpc/file"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
@@ -27,8 +28,66 @@ func NewGetWikiDetailLogic(ctx context.Context, svcCtx *svc.ServiceContext) *Get
|
||||
}
|
||||
}
|
||||
|
||||
func (l *GetWikiDetailLogic) GetWikiDetail(req *types.IdPathReq) error {
|
||||
// todo: add your logic here and delete this line
|
||||
func (l *GetWikiDetailLogic) GetWikiDetail(req *types.IdPathReq) (interface{}, error) {
|
||||
userId := fmt.Sprintf("%v", l.ctx.Value("userId"))
|
||||
result, err := l.svcCtx.PlantRpc.GetWikiDetail(l.ctx, &plantPb.IdReq{Id: req.Id})
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if result == nil || result.Wiki == nil {
|
||||
return nil, nil
|
||||
}
|
||||
|
||||
return nil
|
||||
// 通过 FileRpc 获取图片
|
||||
imgList := fetchWikiImages(l.ctx, l.svcCtx, result.Wiki.OssIds)
|
||||
|
||||
_ = userId
|
||||
return map[string]interface{}{
|
||||
"wiki": result.Wiki,
|
||||
"imgList": imgList,
|
||||
"classIds": result.Wiki.ClassIds,
|
||||
"relatedWikiIds": result.Wiki.RelatedWikiIds,
|
||||
}, nil
|
||||
}
|
||||
|
||||
func fetchWikiImages(ctx context.Context, svcCtx *svc.ServiceContext, ossIds []string) []map[string]interface{} {
|
||||
if len(ossIds) == 0 {
|
||||
return []map[string]interface{}{}
|
||||
}
|
||||
resp, err := svcCtx.FileRpc.GetFilesByIds(ctx, &filePb.GetFilesByIdsReq{Ids: ossIds})
|
||||
if err != nil || resp == nil {
|
||||
return []map[string]interface{}{}
|
||||
}
|
||||
// 按 ossIds 顺序排列
|
||||
fileMap := make(map[string]*filePb.FileInfo)
|
||||
for _, f := range resp.Files {
|
||||
fileMap[f.Id] = f
|
||||
}
|
||||
var list []map[string]interface{}
|
||||
for _, id := range ossIds {
|
||||
if f, ok := fileMap[id]; ok {
|
||||
list = append(list, map[string]interface{}{
|
||||
"id": f.Id, "name": f.Name, "url": f.Url, "tag": f.Tag,
|
||||
"key": f.Key, "suffix": f.Suffix, "md5": f.Md5,
|
||||
"createdAt": unixToRFC3339(f.CreatedAt),
|
||||
"updatedAt": unixToRFC3339(f.CreatedAt),
|
||||
"createdAtStr": unixToShort(f.CreatedAt),
|
||||
})
|
||||
}
|
||||
}
|
||||
return list
|
||||
}
|
||||
|
||||
func unixToRFC3339(ts int64) string {
|
||||
if ts == 0 {
|
||||
return ""
|
||||
}
|
||||
return time.Unix(ts, 0).Format(time.RFC3339)
|
||||
}
|
||||
|
||||
func unixToShort(ts int64) string {
|
||||
if ts == 0 {
|
||||
return ""
|
||||
}
|
||||
return time.Unix(ts, 0).Format("2006-01-02 15:04:05")
|
||||
}
|
||||
|
||||
@@ -8,6 +8,7 @@ import (
|
||||
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
"sundynix-micro-go/app/plant/rpc/plant"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
@@ -27,8 +28,16 @@ func NewGetWikiListLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetWi
|
||||
}
|
||||
}
|
||||
|
||||
func (l *GetWikiListLogic) GetWikiList(req *types.WikiListReq) error {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
return nil
|
||||
func (l *GetWikiListLogic) GetWikiList(req *types.WikiListReq) (interface{}, error) {
|
||||
result, err := l.svcCtx.PlantRpc.GetWikiList(l.ctx, &plant.WikiListReq{
|
||||
Current: int32(req.Current),
|
||||
PageSize: int32(req.PageSize),
|
||||
Name: req.Name,
|
||||
ClassId: req.ClassId,
|
||||
IsHot: int32(req.IsHot),
|
||||
})
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return map[string]interface{}{"list": result.List, "total": result.Total}, nil
|
||||
}
|
||||
|
||||
@@ -5,9 +5,11 @@ package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"fmt"
|
||||
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
"sundynix-micro-go/app/plant/rpc/plant"
|
||||
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
)
|
||||
@@ -28,7 +30,11 @@ func NewToggleWikiStarLogic(ctx context.Context, svcCtx *svc.ServiceContext) *To
|
||||
}
|
||||
|
||||
func (l *ToggleWikiStarLogic) ToggleWikiStar(req *types.IdReq) error {
|
||||
// todo: add your logic here and delete this line
|
||||
|
||||
return nil
|
||||
userId := fmt.Sprintf("%v", l.ctx.Value("userId"))
|
||||
_, err := l.svcCtx.PlantRpc.ToggleWikiStar(l.ctx, &plant.ToggleStarReq{
|
||||
UserId: userId,
|
||||
TargetId: req.Id,
|
||||
Type: "wiki",
|
||||
})
|
||||
return err
|
||||
}
|
||||
|
||||
@@ -0,0 +1,26 @@
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
)
|
||||
|
||||
type UpdateWikiClassLogic struct {
|
||||
logx.Logger
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
func NewUpdateWikiClassLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateWikiClassLogic {
|
||||
return &UpdateWikiClassLogic{Logger: logx.WithContext(ctx), ctx: ctx, svcCtx: svcCtx}
|
||||
}
|
||||
|
||||
func (l *UpdateWikiClassLogic) UpdateWikiClass(req *types.UpdateWikiClassReq) error {
|
||||
_, err := l.svcCtx.PlantRpc.UpdateWikiClass(l.ctx, &plantPb.UpdateWikiClassReq{
|
||||
Id: req.Id, Name: req.Name, Icon: req.Icon,
|
||||
})
|
||||
return err
|
||||
}
|
||||
@@ -0,0 +1,37 @@
|
||||
package wiki
|
||||
|
||||
import (
|
||||
"context"
|
||||
"github.com/zeromicro/go-zero/core/logx"
|
||||
"sundynix-micro-go/app/plant/api/internal/svc"
|
||||
"sundynix-micro-go/app/plant/api/internal/types"
|
||||
plantPb "sundynix-micro-go/app/plant/rpc/plant"
|
||||
)
|
||||
|
||||
type UpdateWikiLogic struct {
|
||||
logx.Logger
|
||||
ctx context.Context
|
||||
svcCtx *svc.ServiceContext
|
||||
}
|
||||
|
||||
func NewUpdateWikiLogic(ctx context.Context, svcCtx *svc.ServiceContext) *UpdateWikiLogic {
|
||||
return &UpdateWikiLogic{Logger: logx.WithContext(ctx), ctx: ctx, svcCtx: svcCtx}
|
||||
}
|
||||
|
||||
func (l *UpdateWikiLogic) UpdateWiki(req *types.UpdateWikiReq) error {
|
||||
_, err := l.svcCtx.PlantRpc.UpdateWiki(l.ctx, &plantPb.UpdateWikiReq{
|
||||
Id: req.Id, Name: req.Name, LatinName: req.LatinName, Aliases: req.Aliases,
|
||||
Genus: req.Genus, Difficulty: int32(req.Difficulty), IsHot: int32(req.IsHot),
|
||||
GrowthHabit: req.GrowthHabit, LightIntensity: req.LightIntensity,
|
||||
OptimalTempPeriod: req.OptimalTempPeriod, ClassId: req.ClassId,
|
||||
DistributionArea: req.DistributionArea, LifeCycle: req.LifeCycle,
|
||||
ClassIds: req.ClassIds, OssIds: req.OssIds, RelatedWikiIds: req.RelatedWikiIds,
|
||||
ReproductionMethod: req.ReproductionMethod, PestsDiseases: req.PestsDiseases,
|
||||
LightType: req.LightType, Stem: req.Stem, Fruit: req.Fruit,
|
||||
FoliageType: req.FoliageType, FoliageColor: req.FoliageColor,
|
||||
FoliageShape: req.FoliageShape, Height: int32(req.Height),
|
||||
FloweringPeriod: req.FloweringPeriod, FloweringColor: req.FloweringColor,
|
||||
FloweringShape: req.FloweringShape, FloweringDiameter: int32(req.FlowerDiameter),
|
||||
})
|
||||
return err
|
||||
}
|
||||
Reference in New Issue
Block a user