swirl/dao/mongo/user.go

134 lines
3.3 KiB
Go
Raw Normal View History

2017-09-26 12:50:09 +00:00
package mongo
import (
2021-12-06 12:24:22 +00:00
"context"
2017-09-26 12:50:09 +00:00
"time"
"github.com/cuigh/swirl/model"
2021-12-06 12:24:22 +00:00
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo"
"go.mongodb.org/mongo-driver/mongo/options"
2017-09-26 12:50:09 +00:00
)
2021-12-06 12:24:22 +00:00
const (
User = "user"
Session = "session"
)
2017-09-26 12:50:09 +00:00
2021-12-06 12:24:22 +00:00
func (d *Dao) UserCount(ctx context.Context) (int, error) {
count, err := d.db.Collection(User).CountDocuments(ctx, bson.M{})
return int(count), err
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserCreate(ctx context.Context, user *model.User) (err error) {
return d.create(ctx, User, user)
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserUpdate(ctx context.Context, user *model.User) (err error) {
update := bson.M{
"$set": bson.M{
"name": user.Name,
"login_name": user.LoginName,
"email": user.Email,
"admin": user.Admin,
"type": user.Type,
"roles": user.Roles,
"updated_at": user.UpdatedAt,
},
}
return d.update(ctx, User, user.ID, update)
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserSetStatus(ctx context.Context, id string, status int32) (err error) {
update := bson.M{
"$set": bson.M{
"status": status,
"updated_at": time.Now(),
},
}
return d.update(ctx, User, id, update)
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserDelete(ctx context.Context, id string) (err error) {
return d.delete(ctx, User, id)
}
2017-09-26 12:50:09 +00:00
2021-12-06 12:24:22 +00:00
func (d *Dao) UserList(ctx context.Context, args *model.UserSearchArgs) (users []*model.User, count int, err error) {
filter := bson.M{}
if args.Name != "" {
filter["name"] = args.Name
}
if args.LoginName != "" {
filter["login_name"] = args.LoginName
}
if args.Admin {
filter["admin"] = true
}
if args.Status >= 0 {
filter["status"] = args.Status
}
opts := searchOptions{filter: filter, pageIndex: args.PageIndex, pageSize: args.PageSize}
users = []*model.User{}
count, err = d.search(ctx, User, opts, &users)
2017-09-26 12:50:09 +00:00
return
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserGetByID(ctx context.Context, id string) (user *model.User, err error) {
user = &model.User{}
found, err := d.find(ctx, User, id, user)
if !found {
return nil, err
}
2017-09-26 12:50:09 +00:00
return
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserGetByName(ctx context.Context, loginName string) (user *model.User, err error) {
user = &model.User{}
err = d.db.Collection(User).FindOne(ctx, bson.M{"login_name": loginName}).Decode(user)
if err == mongo.ErrNoDocuments {
return nil, nil
} else if err != nil {
return nil, err
}
2017-09-26 12:50:09 +00:00
return
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserModifyProfile(ctx context.Context, user *model.User) (err error) {
update := bson.M{
"$set": bson.M{
"name": user.Name,
"login_name": user.LoginName,
"email": user.Email,
"updated_at": time.Now(),
},
}
return d.update(ctx, User, user.ID, update)
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) UserModifyPassword(ctx context.Context, id, pwd, salt string) (err error) {
update := bson.M{
"$set": bson.M{
"password": pwd,
"salt": salt,
"updated_at": time.Now(),
},
}
return d.update(ctx, User, id, update)
2017-09-26 12:50:09 +00:00
}
2021-12-06 12:24:22 +00:00
func (d *Dao) SessionGet(ctx context.Context, token string) (session *model.Session, err error) {
session = &model.Session{}
err = d.db.Collection(Session).FindOne(ctx, bson.M{"token": token}).Decode(session)
if err == mongo.ErrNoDocuments {
return nil, nil
} else if err != nil {
return nil, err
}
2017-09-26 12:50:09 +00:00
return
}
2021-12-06 12:24:22 +00:00
func (d *Dao) SessionUpdate(ctx context.Context, session *model.Session) (err error) {
_, err = d.db.Collection(Session).UpdateByID(ctx, session.UserID, session, options.Update().SetUpsert(true))
2017-09-26 12:50:09 +00:00
return
}