1 Star 0 Fork 0

Wshile / keyauth

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
dao.go 2.18 KB
一键复制 编辑 原始数据 按行查看 历史
wangshile 提交于 2023-05-16 10:50 . 添加角色校验
package impl
import (
"context"
"gitee.com/wshile/keyauth/apps/role"
"github.com/infraboard/mcube/exception"
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo/options"
)
// Save Object
func (s *service) save(ctx context.Context, ins *role.Role) error {
// s.col.InsertMany()
if _, err := s.col.InsertOne(ctx, ins); err != nil {
return exception.NewInternalServerError("inserted role(%s) document error, %s",
ins.Spec.Name, err)
}
return nil
}
func newQueryRequest(r *role.QueryRoleRequest) *queryRequest {
return &queryRequest{
r,
}
}
// 把QueryReq --> MongoDB Options
type queryRequest struct {
*role.QueryRoleRequest
}
// Find参数
func (r *queryRequest) FindOptions() *options.FindOptions {
pageSize := int64(r.Page.PageSize)
skip := int64(r.Page.PageSize) * int64(r.Page.PageNumber-1)
opt := &options.FindOptions{
// 排序: Order By create_at Desc
Sort: bson.D{
{Key: "create_at", Value: -1},
},
// 分页: limit 0,10 skip:0, limit:10
Limit: &pageSize,
Skip: &skip,
}
return opt
}
// 过滤条件
// 由于Mongodb支持嵌套, JSON, 如何过滤嵌套里面的条件, 使用.访问嵌套对象属性
func (r *queryRequest) FindFilter() bson.M {
filter := bson.M{}
if len(r.RoleNames) > 0 {
// IN ()
filter["spec.name"] = bson.M{"$in": r.RoleNames}
}
return filter
}
// LIST, Query, 会很多条件(分页, 关键字, 条件过滤, 排序)
// 需要单独为其 做过滤参数构建
func (s *service) query(ctx context.Context, req *queryRequest) (*role.RoleSet, error) {
// SQL Where
// FindFilter
resp, err := s.col.Find(ctx, req.FindFilter(), req.FindOptions())
if err != nil {
return nil, exception.NewInternalServerError("find policy error, error is %s", err)
}
set := role.NewRoleSet()
// 循环
for resp.Next(ctx) {
ins := role.NewDefaultRole()
if err := resp.Decode(ins); err != nil {
return nil, exception.NewInternalServerError("decode policy error, error is %s", err)
}
set.Add(ins)
}
// count
count, err := s.col.CountDocuments(ctx, req.FindFilter())
if err != nil {
return nil, exception.NewInternalServerError("get policy count error, error is %s", err)
}
set.Total = count
return set, nil
}
Go
1
https://gitee.com/wshile/keyauth.git
git@gitee.com:wshile/keyauth.git
wshile
keyauth
keyauth
v0.0.7

搜索帮助