pg_cooperation_mode_dao.go 4.3 KB
package dao

import (
	"fmt"
	"github.com/go-pg/pg/v10"
	pgTransaction "github.com/linmadan/egglib-go/transaction/pg"
	"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/domain"
	"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/infrastructure/pg/models"
	"gitlab.fjmaimaimai.com/allied-creation/allied-creation-cooperation/pkg/infrastructure/pg/transform"
)

type CooperationModeDao struct {
	transactionContext *pgTransaction.TransactionContext
}

// CheckModeNameAvailable 校验模式名称唯一性
func (dao *CooperationModeDao) CheckModeNameAvailable(queryOptions map[string]interface{}) (bool, error) {
	tx := dao.transactionContext.PgTx
	var cooperationModeModels []*models.CooperationMode
	query := tx.Model(&cooperationModeModels)
	if cooperationModeName, ok := queryOptions["cooperationModeName"]; ok && cooperationModeName != "" {
		query = query.Where("cooperation_mode_name = ?", cooperationModeName)
	}
	if companyId, ok := queryOptions["companyId"]; ok && companyId.(int64) != 0 {
		query = query.Where(`cooperation_mode.company @> '{"companyId":"?"}'`, companyId)
	}
	if orgId, ok := queryOptions["orgId"]; ok && orgId.(int64) != 0 {
		query = query.Where(`cooperation_mode.org @> '{"orgId":"?"}'`, orgId)
	}
	ok, err := query.Exists()
	return !ok, err
}

// CheckModeNumberAvailable 校验模式编码唯一性
func (dao *CooperationModeDao) CheckModeNumberAvailable(queryOptions map[string]interface{}) (bool, error) {
	tx := dao.transactionContext.PgTx
	var cooperationModeModels []*models.CooperationMode
	query := tx.Model(&cooperationModeModels)
	if cooperationModeNumber, ok := queryOptions["cooperationModeNumber"]; ok && cooperationModeNumber != "" {
		query = query.Where("cooperation_mode_number = ?", cooperationModeNumber)
	}
	if companyId, ok := queryOptions["companyId"]; ok && companyId.(int64) != 0 {
		query = query.Where(`cooperation_mode.company @> '{"companyId":"?"}'`, companyId)
	}
	if orgId, ok := queryOptions["orgId"]; ok && orgId.(int64) != 0 {
		query = query.Where(`cooperation_mode.org @> '{"orgId":"?"}'`, orgId)
	}
	ok, err := query.Exists()
	return !ok, err
}

// CheckModeIsDeleteAvailable 校验模式是否有项目数据关联
func (dao *CooperationModeDao) CheckModeIsDeleteAvailable(queryOptions map[string]interface{}) (bool, error) {
	tx := dao.transactionContext.PgTx
	var cooperationProjectModels []*models.CooperationProject
	query := tx.Model(&cooperationProjectModels)
	if cooperationModeNumber, ok := queryOptions["cooperationModeNumber"]; ok && cooperationModeNumber != "" {
		query = query.Where("cooperation_mode_number = ?", cooperationModeNumber)
	}
	if companyId, ok := queryOptions["companyId"]; ok && companyId.(int64) != 0 {
		query = query.Where(`cooperation_project.company @> '{"companyId":"?"}'`, companyId)
	}
	if orgId, ok := queryOptions["orgId"]; ok && orgId.(int64) != 0 {
		query = query.Where(`cooperation_project.org @> '{"orgId":"?"}'`, orgId)
	}
	ok, err := query.Exists()
	return !ok, err
}

// UpdateCooperationModeSlice 更新多个共创模式
func (dao *CooperationModeDao) UpdateCooperationModeSlice(modeIds []int64, status int32) ([]*domain.CooperationMode, error) {
	tx := dao.transactionContext.PgTx
	_, err := tx.QueryOne(
		pg.Scan(),
		"UPDATE cooperation_modes SET status=? WHERE cooperation_mode_id IN (?)",
		status, pg.In(modeIds))
	if err != nil {
		return nil, err
	} else {
		var cooperationModeModels []*models.CooperationMode
		cooperationModes := make([]*domain.CooperationMode, 0)
		query := tx.Model(&cooperationModeModels)
		query.Where("cooperation_mode_id IN (?)", pg.In(modeIds))
		query.Order("cooperation_mode_id DESC")
		if _, err := query.SelectAndCount(); err != nil {
			return cooperationModes, err
		} else {
			for _, cooperationModeModel := range cooperationModeModels {
				if cooperationMode, err := transform.TransformToCooperationModeDomainModelFromPgModels(cooperationModeModel); err != nil {
					return cooperationModes, err
				} else {
					cooperationModes = append(cooperationModes, cooperationMode)
				}
			}
			return cooperationModes, nil
		}
	}
}

func NewCooperationModeDao(transactionContext *pgTransaction.TransactionContext) (*CooperationModeDao, error) {
	if transactionContext == nil {
		return nil, fmt.Errorf("transactionContext参数不能为nil")
	} else {
		return &CooperationModeDao{
			transactionContext: transactionContext,
		}, nil
	}
}