Some checks failed
Build docker and publish / linux (1.24.5) (push) Failing after 25s
feat(admin): 新增工会管理功能 feat(activity): 添加活动管理相关服务 feat(user): 实现用户道具卡和积分管理 feat(guild): 新增工会成员管理功能 fix: 修复数据库连接配置 fix: 修正jwtoken导入路径 fix: 解决端口冲突问题 style: 统一代码格式和注释风格 style: 更新项目常量命名 docs: 添加项目框架和开发规范文档 docs: 更新接口文档注释 chore: 移除无用代码和文件 chore: 更新Makefile和配置文件 chore: 清理日志文件 test: 添加道具卡测试脚本
42 lines
949 B
Go
42 lines
949 B
Go
package guild
|
|
|
|
import (
|
|
"context"
|
|
|
|
"bindbox-game/internal/repository/mysql/model"
|
|
)
|
|
|
|
func (s *service) ListGuilds(ctx context.Context, in ListGuildsInput) (items []*model.Guild, total int64, err error) {
|
|
q := s.readDB.Guild.WithContext(ctx).ReadDB()
|
|
if in.Name != "" {
|
|
q = q.Where(s.readDB.Guild.Name.Like("%" + in.Name + "%"))
|
|
}
|
|
if in.IsOpen != nil {
|
|
q = q.Where(s.readDB.Guild.IsOpen.Eq(*in.IsOpen))
|
|
}
|
|
if in.Status != nil {
|
|
q = q.Where(s.readDB.Guild.Status.Eq(*in.Status))
|
|
}
|
|
if in.JoinMode != nil {
|
|
q = q.Where(s.readDB.Guild.JoinMode.Eq(*in.JoinMode))
|
|
}
|
|
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.Guild.ID.Desc()).Offset((in.Page - 1) * in.PageSize).Limit(in.PageSize).Find()
|
|
if err != nil {
|
|
return nil, 0, err
|
|
}
|
|
return items, total, nil
|
|
}
|