| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- // Code generated by goctl. DO NOT EDIT.
- package immodel
- import (
- "context"
- "time"
- "github.com/zeromicro/go-zero/core/stores/mon"
- "go.mongodb.org/mongo-driver/bson"
- "go.mongodb.org/mongo-driver/bson/primitive"
- "go.mongodb.org/mongo-driver/mongo"
- )
- type chatLogModel interface {
- Insert(ctx context.Context, data *ChatLog) error
- FindOne(ctx context.Context, id string) (*ChatLog, error)
- Update(ctx context.Context, data *ChatLog) (*mongo.UpdateResult, error)
- Delete(ctx context.Context, id string) (int64, error)
- ListByMsgIds(ctx context.Context, msgIds []string) ([]*ChatLog, error)
- UpdateMakeRead(ctx context.Context, id primitive.ObjectID, readRecords []byte) error
- }
- type defaultChatLogModel struct {
- conn *mon.Model
- }
- func newDefaultChatLogModel(conn *mon.Model) *defaultChatLogModel {
- return &defaultChatLogModel{conn: conn}
- }
- func (m *defaultChatLogModel) Insert(ctx context.Context, data *ChatLog) error {
- if data.ID.IsZero() {
- data.ID = primitive.NewObjectID()
- data.CreateAt = time.Now()
- data.UpdateAt = time.Now()
- }
- _, err := m.conn.InsertOne(ctx, data)
- return err
- }
- func (m *defaultChatLogModel) FindOne(ctx context.Context, id string) (*ChatLog, error) {
- oid, err := primitive.ObjectIDFromHex(id)
- if err != nil {
- return nil, ErrInvalidObjectId
- }
- var data ChatLog
- err = m.conn.FindOne(ctx, &data, bson.M{"_id": oid})
- switch err {
- case nil:
- return &data, nil
- case mon.ErrNotFound:
- return nil, ErrNotFound
- default:
- return nil, err
- }
- }
- func (m *defaultChatLogModel) Update(ctx context.Context, data *ChatLog) (*mongo.UpdateResult, error) {
- data.UpdateAt = time.Now()
- res, err := m.conn.UpdateOne(ctx, bson.M{"_id": data.ID}, bson.M{"$set": data})
- return res, err
- }
- func (m *defaultChatLogModel) Delete(ctx context.Context, id string) (int64, error) {
- oid, err := primitive.ObjectIDFromHex(id)
- if err != nil {
- return 0, ErrInvalidObjectId
- }
- res, err := m.conn.DeleteOne(ctx, bson.M{"_id": oid})
- return res, err
- }
- // 根据消息id区查询
- func (m *defaultChatLogModel) ListByMsgIds(ctx context.Context, msgIds []string) ([]*ChatLog, error) {
- var data []*ChatLog
- ids := make([]primitive.ObjectID, 0, len(msgIds))
- for _, id := range msgIds {
- oid, _ := primitive.ObjectIDFromHex(id)
- ids = append(ids, oid)
- }
- filter := bson.M{
- "_id": bson.M{
- "$in": ids,
- },
- }
- err := m.conn.Find(ctx, &data, filter)
- switch err {
- case nil:
- return data, nil
- case mon.ErrNotFound:
- return nil, ErrNotFound
- default:
- return nil, err
- }
- }
- // 修改已读记录
- func (m *defaultChatLogModel) UpdateMakeRead(ctx context.Context, id primitive.ObjectID, readRecords []byte) error {
- _, err := m.conn.UpdateOne(ctx, bson.M{"_id": id}, bson.M{"$set": bson.M{"readRecords": readRecords}})
- return err
- }
|