feat:完善信息,优化入驻接口
This commit is contained in:
@ -8,7 +8,6 @@ import (
|
||||
"SciencesServer/serve/orm"
|
||||
"errors"
|
||||
"gorm.io/gorm"
|
||||
"time"
|
||||
)
|
||||
|
||||
// Research 研究机构入驻信息
|
||||
@ -27,24 +26,44 @@ func (c *Research) Launch(params *BasicParams, other *config.IdentityForResearch
|
||||
mManageResearch := model.NewManageResearch()
|
||||
// 查询相应专家入驻信息
|
||||
isExist, err := model2.FirstField(mManageResearch.ManageResearch, []string{"id", "examine_status"},
|
||||
model2.NewWhere("code", params.Code), model2.NewWhere("tenant_id", c.tenantID))
|
||||
model2.NewWhere("code", params.Code))
|
||||
|
||||
mUserResearch := model.NewUserResearch()
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
} else if isExist {
|
||||
// 审核中
|
||||
if mManageResearch.Examine.ExamineStatus == model2.ExamineStatusForOngoing {
|
||||
return errors.New("操作错误,当前该研究机构信息审核中,不可入驻")
|
||||
}
|
||||
// 审核通过
|
||||
if mManageResearch.Examine.ExamineStatus == model2.ExamineStatusForAgree {
|
||||
// 筛选企业条件
|
||||
if err = params.filter(config.TenantUserIdentityForResearch,
|
||||
model2.NewWhere("research_id", mManageResearch.ID)); err != nil {
|
||||
if mManageResearch.Examine.ExamineStatus == model2.ExamineStatusForOngoing ||
|
||||
mManageResearch.Examine.ExamineStatus == model2.ExamineStatusForAgree {
|
||||
// 筛选判断是否满足入驻条件
|
||||
if err = params.filter(config.TenantUserIdentityForResearch, model2.NewWhere("research_id", mManageResearch.ID)); err != nil {
|
||||
return err
|
||||
}
|
||||
// 判断当前用户是否入驻
|
||||
var count int64
|
||||
|
||||
if err = model2.Count(mUserResearch.UserResearch, &count, model2.NewWhere("research_id", mManageResearch.ID),
|
||||
model2.NewWhere("uid", c.UID), model2.NewWhere("invalid_status", model2.InvalidStatusForNot)); err != nil {
|
||||
return err
|
||||
}
|
||||
if count > 0 {
|
||||
return errors.New("操作错误,已申请入驻,不可重复申请")
|
||||
}
|
||||
return orm.GetDB().Transaction(func(tx *gorm.DB) error {
|
||||
mUserResearch.UID = c.UID
|
||||
mUserResearch.ResearchID = mManageResearch.ID
|
||||
|
||||
if err = model2.Create(mUserResearch.UserResearch, tx); err != nil {
|
||||
return err
|
||||
}
|
||||
// 直接同步身份信息
|
||||
if mManageResearch.Examine.ExamineStatus == model2.ExamineStatusForAgree {
|
||||
if err = params.fillIdentity(tx, c.Enterprise, config.TenantUserIdentityForResearch); err != nil {
|
||||
return err
|
||||
}
|
||||
}
|
||||
return nil
|
||||
})
|
||||
}
|
||||
mManageResearch.ID = 0
|
||||
}
|
||||
@ -61,21 +80,13 @@ func (c *Research) Launch(params *BasicParams, other *config.IdentityForResearch
|
||||
mManageResearch.SetResearchAttribute(other.Researchs)
|
||||
mManageResearch.License = other.FilterLicense()
|
||||
mManageResearch.Introduce = params.Introduce
|
||||
mManageResearch.ExamineStatus = model2.ExamineStatusForOngoing
|
||||
|
||||
return orm.GetDB().Transaction(func(tx *gorm.DB) error {
|
||||
// 删除区域相同编码公司信息
|
||||
if err = model2.DeleteWhere(mManageResearch.ManageResearch, []*model2.ModelWhere{
|
||||
model2.NewWhere("code", params.Code), model2.NewWhere("tenant_id", c.tenantID)}, tx); err != nil {
|
||||
return err
|
||||
}
|
||||
if err = model2.Create(mManageResearch.ManageResearch, tx); err != nil {
|
||||
return err
|
||||
}
|
||||
if err := model2.UpdatesWhere(mUserResearch.UserResearch, map[string]interface{}{
|
||||
"invalid_status": model2.InvalidStatusForYes, "updated_at": time.Now(),
|
||||
}, []*model2.ModelWhere{model2.NewWhere("uid", c.UID)}, tx); err != nil {
|
||||
return err
|
||||
}
|
||||
mUserResearch.UID = c.UID
|
||||
mUserResearch.ResearchID = mManageResearch.ID
|
||||
return model2.Create(mUserResearch.UserResearch, tx)
|
||||
|
Reference in New Issue
Block a user