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: 添加道具卡测试脚本
46 lines
948 B
Go
46 lines
948 B
Go
package admin
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"bindbox-game/internal/repository/mysql/model"
|
|
|
|
"gorm.io/gorm"
|
|
)
|
|
|
|
type ListInput struct {
|
|
Username string
|
|
Nickname string
|
|
Page int
|
|
PageSize int
|
|
}
|
|
|
|
func (s *service) List(ctx context.Context, in ListInput) ([]*model.Admin, int64, error) {
|
|
query := s.readDB.Admin.WithContext(ctx)
|
|
if in.Username != "" {
|
|
query = query.Where(s.readDB.Admin.Username.Like(fmt.Sprintf("%%%s%%", in.Username)))
|
|
}
|
|
if in.Nickname != "" {
|
|
query = query.Where(s.readDB.Admin.Nickname.Like(fmt.Sprintf("%%%s%%", in.Nickname)))
|
|
}
|
|
|
|
listQueryDB := query.Session(&gorm.Session{})
|
|
countQueryDB := query.Session(&gorm.Session{})
|
|
|
|
resultData, err := listQueryDB.
|
|
Order(s.readDB.Admin.ID.Desc()).
|
|
Limit(in.PageSize).
|
|
Offset((in.Page - 1) * in.PageSize).Find()
|
|
if err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
count, err := countQueryDB.Count()
|
|
if err != nil {
|
|
return nil, 0, err
|
|
}
|
|
|
|
return resultData, count, nil
|
|
}
|