You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
188 lines
5.0 KiB
Go
188 lines
5.0 KiB
Go
![]()
3 weeks ago
|
package price
|
||
|
|
||
|
import (
|
||
|
article2 "cls-server/internal/application/article"
|
||
|
"cls-server/internal/domain/article"
|
||
|
"cls-server/internal/domain/price"
|
||
|
"cls-server/pkg/logger"
|
||
|
"cls-server/pkg/util/page"
|
||
|
"errors"
|
||
|
"xorm.io/builder"
|
||
|
)
|
||
|
|
||
|
var (
|
||
|
ErrInvalidAmount = errors.New("价格不能小于0")
|
||
|
ErrInvalidType = errors.New("无效的价格类型")
|
||
|
ErrInvalidDuration = errors.New("无效的订阅时长")
|
||
|
)
|
||
|
|
||
|
// PriceService 价格管理服务
|
||
|
type PriceService struct {
|
||
|
repo price.PriceRepository
|
||
|
articleRepo article.ArticleRepository
|
||
|
log logger.Logger
|
||
|
}
|
||
|
|
||
|
// NewService 创建价格管理服务
|
||
|
func NewPriceService(repo price.PriceRepository, articleRepo article.ArticleRepository, log logger.New) *PriceService {
|
||
|
return &PriceService{
|
||
|
repo: repo,
|
||
|
articleRepo: articleRepo,
|
||
|
log: log("cls:service:price"),
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// SetPrice 设置价格
|
||
|
func (s *PriceService) SetPrice(dto *PriceDto) error {
|
||
|
if dto.Amount < 0 {
|
||
|
return ErrInvalidAmount
|
||
|
}
|
||
|
|
||
|
// 检查是否已存在价格记录
|
||
|
existingPrice, err := s.repo.FindByTargetID(dto.TargetID, dto.Type)
|
||
|
if err != nil {
|
||
|
// 如果记录不存在,创建新记录
|
||
|
newPrice := dto.ToPrice()
|
||
|
return s.repo.Save(newPrice)
|
||
|
}
|
||
|
|
||
|
// 如果记录存在,更新价格
|
||
|
existingPrice.Amount = dto.Amount
|
||
|
existingPrice.OneMonthPrice = dto.OneMonthPrice
|
||
|
existingPrice.ThreeMonthsPrice = dto.ThreeMonthsPrice
|
||
|
existingPrice.SixMonthsPrice = dto.SixMonthsPrice
|
||
|
existingPrice.OneYearPrice = dto.OneYearPrice
|
||
|
existingPrice.AdminID = dto.AdminID
|
||
|
return s.repo.Update(existingPrice)
|
||
|
}
|
||
|
|
||
|
// GetPrice 获取价格(如果不存在则使用默认价格)
|
||
|
func (s *PriceService) GetPrice(dto *PriceDto) (*PriceDto, error) {
|
||
|
// 检查是否已存在价格记录
|
||
|
existingPrice, err := s.repo.FindByTargetID(dto.TargetID, dto.Type)
|
||
|
if err != nil {
|
||
|
// 如果记录不存在,使用默认价格
|
||
|
var defaultAmount int64
|
||
|
switch dto.Type {
|
||
|
case price.TypeArticle:
|
||
|
defaultAmount = price.DefaultArticlePrice
|
||
|
case price.TypeColumn:
|
||
|
defaultAmount = price.DefaultColumnPrice
|
||
|
default:
|
||
|
return nil, ErrInvalidType
|
||
|
}
|
||
|
// 创建默认价格记录
|
||
|
newPrice := price.NewPrice(dto.TargetID, dto.Type, defaultAmount, 0)
|
||
|
if err := s.repo.Save(newPrice); err != nil {
|
||
|
return nil, err
|
||
|
}
|
||
|
if dto.Type == price.TypeArticle {
|
||
|
return &PriceDto{
|
||
|
Amount: newPrice.Amount,
|
||
|
Discount: newPrice.Discount,
|
||
|
}, nil
|
||
|
}
|
||
|
return &PriceDto{
|
||
|
OneMonthPrice: newPrice.OneMonthPrice,
|
||
|
ThreeMonthsPrice: newPrice.ThreeMonthsPrice,
|
||
|
SixMonthsPrice: newPrice.SixMonthsPrice,
|
||
|
OneYearPrice: newPrice.OneYearPrice,
|
||
|
Discount: 0.3,
|
||
|
}, nil
|
||
|
}
|
||
|
priceDto := &PriceDto{
|
||
|
Discount: existingPrice.Discount,
|
||
|
}
|
||
|
if dto.Type == price.TypeArticle {
|
||
|
priceDto.Amount = existingPrice.Amount
|
||
|
} else {
|
||
|
priceDto.OneMonthPrice = existingPrice.OneMonthPrice
|
||
|
priceDto.ThreeMonthsPrice = existingPrice.ThreeMonthsPrice
|
||
|
priceDto.SixMonthsPrice = existingPrice.SixMonthsPrice
|
||
|
priceDto.OneYearPrice = existingPrice.OneYearPrice
|
||
|
}
|
||
|
|
||
|
return priceDto, nil
|
||
|
}
|
||
|
|
||
|
func (s *PriceService) GetArticlePricePage(p *page.Page) error {
|
||
|
conds := make([]builder.Cond, 0)
|
||
|
conds = append(conds, builder.Eq{"type": price.TypeArticle})
|
||
|
data := make([]*price.Price, 0)
|
||
|
p.Content = &data
|
||
|
err := s.repo.FindAll(p, conds)
|
||
|
if err != nil {
|
||
|
s.log.Error(err)
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
ids := make([]uint64, 0, len(data))
|
||
|
for _, v := range data {
|
||
|
ids = append(ids, v.TargetID)
|
||
|
}
|
||
|
as, err := s.articleRepo.GetArticlesByIds(ids)
|
||
|
if err != nil {
|
||
|
s.log.Error(err)
|
||
|
return err
|
||
|
}
|
||
|
asMap := make(map[uint64]*article2.ArticleDto, 0)
|
||
|
for _, v := range *as {
|
||
|
asMap[v.Id] = &article2.ArticleDto{
|
||
|
EventId: v.Id,
|
||
|
Title: v.Title,
|
||
|
Class: article2.GetClassNameById(v.Type),
|
||
|
Stocks: v.Stocks,
|
||
|
Brief: v.Brief,
|
||
|
}
|
||
|
}
|
||
|
ids = nil
|
||
|
dtoData := make([]*ArticlePriceDto, 0, len(data))
|
||
|
for _, v := range data {
|
||
|
dtoData = append(dtoData, &ArticlePriceDto{
|
||
|
Article: asMap[v.TargetID],
|
||
|
Price: &PriceDto{
|
||
|
ID: v.ID,
|
||
|
TargetID: v.TargetID,
|
||
|
Amount: v.Amount,
|
||
|
Discount: v.Discount,
|
||
|
},
|
||
|
})
|
||
|
}
|
||
|
p.Content = &dtoData
|
||
|
return nil
|
||
|
}
|
||
|
|
||
|
func (s *PriceService) GetColumnPricePage(p *page.Page) error {
|
||
|
conds := make([]builder.Cond, 0)
|
||
|
conds = append(conds, builder.Eq{"p.type": price.TypeColumn})
|
||
|
data := make([]*ColumnPriceDto, 0)
|
||
|
p.Content = &data
|
||
|
err := s.repo.FindColumnAll(p, conds)
|
||
|
if err != nil {
|
||
|
s.log.Error(err.Error())
|
||
|
}
|
||
|
return err
|
||
|
}
|
||
|
|
||
|
// DeletePrice 删除价格记录
|
||
|
func (s *PriceService) DeletePrice(id uint64) error {
|
||
|
return s.repo.Delete(id)
|
||
|
}
|
||
|
|
||
|
func (s *PriceService) UpdatePrice(dto *PriceDto) error {
|
||
|
if err := dto.Validate(); err != nil {
|
||
|
return err
|
||
|
}
|
||
|
existingPrice, err := s.repo.FindByTargetID(dto.TargetID, dto.Type)
|
||
|
if err != nil {
|
||
|
return err
|
||
|
}
|
||
|
existingPrice.Amount = dto.Amount
|
||
|
existingPrice.OneMonthPrice = dto.OneMonthPrice
|
||
|
existingPrice.ThreeMonthsPrice = dto.ThreeMonthsPrice
|
||
|
existingPrice.SixMonthsPrice = dto.SixMonthsPrice
|
||
|
existingPrice.OneYearPrice = dto.OneYearPrice
|
||
|
existingPrice.AdminID = dto.AdminID
|
||
|
return s.repo.Update(existingPrice)
|
||
|
}
|