package mongos import ( "amocrm_templategen_back/dal/model" "context" "errors" "go.mongodb.org/mongo-driver/bson" "go.mongodb.org/mongo-driver/bson/primitive" "go.mongodb.org/mongo-driver/mongo" "go.mongodb.org/mongo-driver/mongo/options" "go.uber.org/zap" "time" ) type Amo struct { coll *mongo.Collection logger *zap.Logger } func InitAmo(db *mongo.Database, logger *zap.Logger) *Amo { return &Amo{coll: db.Collection("amo"), logger: logger} } func (d *Amo) InsertOrUpdate(ctx context.Context, record *model.Amo) (string, error) { if record.UserID == "" { err := errors.New("got empty user id") d.logger.Error("ErrorDeleteAmo", zap.Error(err)) return "", err } found, err := d.GetByUserID(ctx, record.UserID) if err != nil { return "", err } if found == nil { result, err := d.coll.InsertOne(ctx, record) if err != nil { d.logger.Error("ErrorInsertOrUpdateAmo", zap.Error(err)) return "", err } return result.InsertedID.(primitive.ObjectID).Hex(), nil } record.CreatedAt = found.CreatedAt err = d.Update(ctx, record) if err != nil { d.logger.Error("ErrorInsertOrUpdateAmo", zap.Error(err)) return "", err } return found.ID, nil } func (d *Amo) InsertOrUpdateOLD(ctx context.Context, record *model.Amo) (string, error) { now := time.Now() record.UpdatedAt = now record.CreatedAt = now record.IsDeleted = false if record.UserID == "" { err := errors.New("got empty user id") d.logger.Error("ErrorDeleteAmo", zap.Error(err)) return "", err } filter := bson.M{"user_id": record.UserID, "is_deleted": false} opts := options.FindOneAndUpdate().SetUpsert(true) var result model.Amo err := d.coll.FindOneAndUpdate(ctx, filter, bson.D{{"$set", record}}, opts).Decode(&result) if err != nil { if err != mongo.ErrNoDocuments { d.logger.Error("ErrorInsertOrUpdateAmo", zap.Error(err)) return "", err } } return result.ID, nil } func (d *Amo) GetByUserID(ctx context.Context, userID string) (*model.Amo, error) { filter := bson.M{"user_id": userID, "is_deleted": false} var result model.Amo err := d.coll.FindOne(ctx, filter).Decode(&result) if err == mongo.ErrNoDocuments { return nil, nil } else { if err != nil { d.logger.Error("ErrorGetAmo", zap.Error(err)) return nil, err } } d.logger.Info("InfoGetAmo", zap.String("id", result.ID)) return &result, nil } func (d *Amo) GetByAccountID(ctx context.Context, accId string) (*model.Amo, error) { filter := bson.M{"account_id": accId, "is_deleted": false} var result model.Amo err := d.coll.FindOne(ctx, filter).Decode(&result) if err == mongo.ErrNoDocuments { return nil, nil } else { if err != nil { d.logger.Error("ErrorGetAmo", zap.Error(err)) return nil, err } } d.logger.Info("InfoGetAmo", zap.String("id", result.ID)) return &result, nil } func (d *Amo) Update(ctx context.Context, record *model.Amo) error { if record.UserID == "" && record.ID == "" { err := errors.New("got empty id and user id") d.logger.Error("ErrorUpdateAmo", zap.Error(err)) return err } objID, err := primitive.ObjectIDFromHex(record.ID) if err != nil { d.logger.Error("ErrorUpdateAmo", zap.Error(err)) return err } filter := bson.M{"_id": objID, "is_deleted": false} if record.ID != "" { filter["_id"] = record.ID } if record.UserID != "" { filter["user_id"] = record.UserID } update := bson.M{"updated_at": time.Now()} if record.AccessToken != "" { update["access_token"] = record.AccessToken } if !record.ExpiresIn.IsZero() { update["expires_in"] = record.ExpiresIn } if record.TokenType != "" { update["token_type"] = record.TokenType } _, err = d.coll.UpdateOne(ctx, filter, bson.D{{"$set", update}}) if err != nil { d.logger.Error("ErrorUpdateAmo", zap.Error(err)) return err } return nil } func (d *Amo) DeleteByUserID(ctx context.Context, userID string) error { if userID == "" { err := errors.New("got empty user id") d.logger.Error("ErrorDeleteAmo", zap.Error(err)) return err } filter := bson.M{"user_id": userID, "is_deleted": false} update := bson.M{"updated_at": time.Now(), "is_deleted": true} _, err := d.coll.UpdateOne(ctx, filter, bson.D{{"$set", update}}) if err != nil { d.logger.Error("ErrorDeleteAmo", zap.Error(err)) return err } return nil }