// 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 }