feat:完善入驻信息管理
This commit is contained in:
@ -4,23 +4,31 @@ import (
|
||||
"SciencesServer/app/api/enterprise/model"
|
||||
"SciencesServer/app/basic/config"
|
||||
model2 "SciencesServer/app/common/model"
|
||||
"SciencesServer/app/session"
|
||||
"errors"
|
||||
"gorm.io/gorm"
|
||||
"time"
|
||||
)
|
||||
|
||||
// TODO:入驻流程
|
||||
// 2021-12-02
|
||||
// 一:
|
||||
|
||||
// BasicParams 基本信息
|
||||
type BasicParams struct {
|
||||
ID uint64
|
||||
Name, Image, Code, Introduce string
|
||||
config.Area
|
||||
Industrys, Keywords []string
|
||||
}
|
||||
|
||||
// filter 筛选信息
|
||||
func (c *BasicParams) filter(identity int, where ...*model2.ModelWhere) (bool, error) {
|
||||
func (c *BasicParams) filter(identity int, where ...*model2.ModelWhere) error {
|
||||
mSysIdentity := model.NewSysIdentity()
|
||||
_, err := model2.FirstField(mSysIdentity.SysIdentity, []string{"id", "register_count", "is_examine"}, model2.NewWhere("identity", identity))
|
||||
_, err := model2.FirstField(mSysIdentity.SysIdentity, []string{"id", "register_count"}, model2.NewWhere("identity", identity))
|
||||
|
||||
if err != nil {
|
||||
return true, err
|
||||
return err
|
||||
}
|
||||
var iModel model2.IModel
|
||||
|
||||
@ -40,10 +48,34 @@ func (c *BasicParams) filter(identity int, where ...*model2.ModelWhere) (bool, e
|
||||
where = append(where, model2.NewWhere("status", model2.InvalidStatusForNot))
|
||||
|
||||
if err = model2.Count(iModel, &count, where...); err != nil {
|
||||
return true, err
|
||||
return err
|
||||
}
|
||||
if count >= int64(mSysIdentity.RegisterCount) {
|
||||
return true, errors.New("操作错误,已超过当前身份最大入驻人数")
|
||||
return errors.New("操作错误,已超过当前身份最大入驻人数")
|
||||
}
|
||||
return mSysIdentity.IsExamine == model2.SysIdentityExamineForYes, nil
|
||||
return nil
|
||||
}
|
||||
|
||||
// fillIdentity 填充身份信息
|
||||
func (c *BasicParams) fillIdentity(tx *gorm.DB, session *session.Enterprise, identity int) error {
|
||||
if session.SelectIdentity <= 0 {
|
||||
session.SelectIdentity = identity
|
||||
}
|
||||
session.Identity = session.Identity | identity
|
||||
|
||||
mUserInstance := model.NewUserInstance()
|
||||
|
||||
err := model2.UpdatesWhere(mUserInstance.UserInstance, map[string]interface{}{
|
||||
"identity": session.Identity, "updated_at": time.Now(),
|
||||
}, []*model2.ModelWhere{model2.NewWhere("uuid", session.UID)}, tx)
|
||||
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
mUserIdentity := model.NewUserIdentity()
|
||||
mUserIdentity.UID = session.UID
|
||||
mUserIdentity.Name = session.Name
|
||||
mUserIdentity.Identity = identity
|
||||
|
||||
return model2.Create(mUserIdentity.UserIdentity)
|
||||
}
|
||||
|
Reference in New Issue
Block a user