|
|
package repository
|
|
|
|
|
|
import (
|
|
|
"context"
|
|
|
|
|
|
"github.com/jinzhu/copier"
|
|
|
"github.com/pkg/errors"
|
|
|
"github.com/tiptok/gocomm/pkg/cache"
|
|
|
"gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/models"
|
|
|
"gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/db/transaction"
|
|
|
"gitlab.fjmaimaimai.com/allied-creation/sumifcc-discuss/cmd/discuss/interanl/pkg/domain"
|
|
|
"gorm.io/gorm"
|
|
|
)
|
|
|
|
|
|
type ArticleTagRepository struct {
|
|
|
*cache.CachedRepository
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) Insert(ctx context.Context, conn transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
err error
|
|
|
m = &models.ArticleTag{}
|
|
|
tx = conn.DB()
|
|
|
)
|
|
|
if m, err = repository.DomainModelToModel(dm); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
if tx = tx.Model(m).Save(m); tx.Error != nil {
|
|
|
return nil, tx.Error
|
|
|
}
|
|
|
dm.Id = m.Id
|
|
|
return repository.ModelToDomainModel(m)
|
|
|
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) Update(ctx context.Context, conn transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
err error
|
|
|
m *models.ArticleTag
|
|
|
tx = conn.DB()
|
|
|
)
|
|
|
if m, err = repository.DomainModelToModel(dm); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
queryFunc := func() (interface{}, error) {
|
|
|
tx = tx.Model(m).Updates(m)
|
|
|
return nil, tx.Error
|
|
|
}
|
|
|
if _, err = repository.Query(queryFunc, m.CacheKeyFunc()); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
return repository.ModelToDomainModel(m)
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) UpdateWithVersion(ctx context.Context, transaction transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
err error
|
|
|
m *models.ArticleTag
|
|
|
tx = transaction.DB()
|
|
|
)
|
|
|
if m, err = repository.DomainModelToModel(dm); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
oldVersion := dm.Version
|
|
|
m.Version += 1
|
|
|
queryFunc := func() (interface{}, error) {
|
|
|
tx = tx.Model(m).Select("*").Where("id = ?", m.Id).Where("version = ?", oldVersion).Updates(m)
|
|
|
if tx.RowsAffected == 0 {
|
|
|
return nil, domain.ErrUpdateFail
|
|
|
}
|
|
|
return nil, tx.Error
|
|
|
}
|
|
|
if _, err = repository.Query(queryFunc, m.CacheKeyFunc()); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
return repository.ModelToDomainModel(m)
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) Delete(ctx context.Context, conn transaction.Conn, dm *domain.ArticleTag) (*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
tx = conn.DB()
|
|
|
m = &models.ArticleTag{Id: dm.Id}
|
|
|
)
|
|
|
queryFunc := func() (interface{}, error) {
|
|
|
tx = tx.Where("id = ?", m.Id).Delete(m)
|
|
|
return m, tx.Error
|
|
|
}
|
|
|
if _, err := repository.Query(queryFunc, m.CacheKeyFunc()); err != nil {
|
|
|
return dm, err
|
|
|
}
|
|
|
return repository.ModelToDomainModel(m)
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) FindOne(ctx context.Context, conn transaction.Conn, id int64) (*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
err error
|
|
|
tx = conn.DB()
|
|
|
m = new(models.ArticleTag)
|
|
|
)
|
|
|
queryFunc := func() (interface{}, error) {
|
|
|
tx = tx.Model(m).Where("id = ?", id).First(m)
|
|
|
if errors.Is(tx.Error, gorm.ErrRecordNotFound) {
|
|
|
return nil, domain.ErrNotFound
|
|
|
}
|
|
|
return m, tx.Error
|
|
|
}
|
|
|
cacheModel := new(models.ArticleTag)
|
|
|
cacheModel.Id = id
|
|
|
if err = repository.QueryCache(cacheModel.CacheKeyFunc, m, queryFunc); err != nil {
|
|
|
return nil, err
|
|
|
}
|
|
|
return repository.ModelToDomainModel(m)
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) Find(ctx context.Context, conn transaction.Conn, companyId int64, queryOptions map[string]interface{}) (int64, []*domain.ArticleTag, error) {
|
|
|
var (
|
|
|
tx = conn.DB()
|
|
|
ms []*models.ArticleTag
|
|
|
dms = make([]*domain.ArticleTag, 0)
|
|
|
total int64
|
|
|
)
|
|
|
queryFunc := func() (interface{}, error) {
|
|
|
tx = tx.Model(&ms).
|
|
|
Where("company_id=?", companyId).
|
|
|
Order("id desc")
|
|
|
|
|
|
if v, ok := queryOptions["name"]; ok {
|
|
|
tx.Where("id like ?", v)
|
|
|
}
|
|
|
if v, ok := queryOptions["group"]; ok {
|
|
|
tx.Where("group like ?", v)
|
|
|
}
|
|
|
|
|
|
if total, tx = transaction.PaginationAndCount(ctx, tx, queryOptions, &ms); tx.Error != nil {
|
|
|
return dms, tx.Error
|
|
|
}
|
|
|
return dms, nil
|
|
|
}
|
|
|
|
|
|
if _, err := repository.Query(queryFunc); err != nil {
|
|
|
return 0, nil, err
|
|
|
}
|
|
|
|
|
|
for _, item := range ms {
|
|
|
if dm, err := repository.ModelToDomainModel(item); err != nil {
|
|
|
return 0, dms, err
|
|
|
} else {
|
|
|
dms = append(dms, dm)
|
|
|
}
|
|
|
}
|
|
|
return total, dms, nil
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) ModelToDomainModel(from *models.ArticleTag) (*domain.ArticleTag, error) {
|
|
|
to := &domain.ArticleTag{}
|
|
|
err := copier.Copy(to, from)
|
|
|
return to, err
|
|
|
}
|
|
|
|
|
|
func (repository *ArticleTagRepository) DomainModelToModel(from *domain.ArticleTag) (*models.ArticleTag, error) {
|
|
|
to := &models.ArticleTag{}
|
|
|
err := copier.Copy(to, from)
|
|
|
return to, err
|
|
|
}
|
|
|
|
|
|
func NewArticleTagRepository(cache *cache.CachedRepository) domain.ArticleTagRepository {
|
|
|
return &ArticleTagRepository{CachedRepository: cache}
|
|
|
} |
...
|
...
|
|