docxTemplater/dal/mongos/amo.go

194 lines
4.2 KiB
Go
Raw Normal View History

2022-07-28 15:00:43 +00:00
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) {
2022-08-10 13:53:34 +00:00
filter := bson.M{"user_id": userID, "is_deleted": false}
2022-07-28 15:00:43 +00:00
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) {
2022-08-10 13:53:34 +00:00
filter := bson.M{"account_id": accId, "is_deleted": false}
2022-07-28 15:00:43 +00:00
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
}
2022-08-10 13:53:34 +00:00
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}
2022-07-28 15:00:43 +00:00
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
}
2022-08-10 13:53:34 +00:00
_, err = d.coll.UpdateOne(ctx, filter, bson.D{{"$set", update}})
2022-07-28 15:00:43 +00:00
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
}