bindbox-game/internal/service/activity/activities_list.go
邹方成 1ab39d2f5a
Some checks failed
Build docker and publish / linux (1.24.5) (push) Failing after 25s
refactor: 重构项目结构并重命名模块
feat(admin): 新增工会管理功能
feat(activity): 添加活动管理相关服务
feat(user): 实现用户道具卡和积分管理
feat(guild): 新增工会成员管理功能

fix: 修复数据库连接配置
fix: 修正jwtoken导入路径
fix: 解决端口冲突问题

style: 统一代码格式和注释风格
style: 更新项目常量命名

docs: 添加项目框架和开发规范文档
docs: 更新接口文档注释

chore: 移除无用代码和文件
chore: 更新Makefile和配置文件
chore: 清理日志文件

test: 添加道具卡测试脚本
2025-11-14 21:10:00 +08:00

46 lines
1010 B
Go

package activity
import (
"context"
"bindbox-game/internal/repository/mysql/model"
)
func (s *service) ListActivities(ctx context.Context, in ListActivitiesInput) (items []*model.Activities, total int64, err error) {
q := s.readDB.Activities.WithContext(ctx).ReadDB()
if in.Name != "" {
q = q.Where(s.readDB.Activities.Name.Like("%" + in.Name + "%"))
}
if in.CategoryID != 0 {
q = q.Where(s.readDB.Activities.ActivityCategoryID.Eq(in.CategoryID))
}
if in.IsBoss != nil {
q = q.Where(s.readDB.Activities.IsBoss.Eq(*in.IsBoss))
}
if in.Status != nil {
q = q.Where(s.readDB.Activities.Status.Eq(*in.Status))
}
total, err = q.Count()
if err != nil {
return nil, 0, err
}
if in.Page <= 0 {
in.Page = 1
}
if in.PageSize <= 0 {
in.PageSize = 20
}
if in.PageSize > 100 {
in.PageSize = 100
}
items, err = q.Order(s.readDB.Activities.ID.Desc()).Offset((in.Page - 1) * in.PageSize).Limit(in.PageSize).Find()
if err != nil {
return nil, 0, err
}
return items, total, nil
}