package logic import ( "app.yhyue.com/moapp/jybase/common" "context" IC "jyBXCore/rpc/init" "jyBXCore/rpc/model/es" "jyBXCore/rpc/service" "jyBXCore/rpc/util" "time" "jyBXCore/rpc/internal/svc" "jyBXCore/rpc/type/bxcore" "github.com/zeromicro/go-zero/core/logx" ) type ParticipateInfoLogic struct { ctx context.Context svcCtx *svc.ServiceContext logx.Logger } func NewParticipateInfoLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ParticipateInfoLogic { return &ParticipateInfoLogic{ ctx: ctx, svcCtx: svcCtx, Logger: logx.WithContext(ctx), } } // 详情页参标信息接口 func (l *ParticipateInfoLogic) ParticipateInfo(in *bxcore.ParticipateInfoReq) (*bxcore.ParticipateInfoRes, error) { format := &bxcore.ParticipateDetailInfo{} result := bxcore.ParticipateInfoRes{ ErrMsg: "", ErrCode: -1, Data: format, } // 1. 判断身份是否有权限 不是超级订阅也不是大会员 则直接返回不展示 userInfo := IC.Middleground.PowerCheckCenter.Check(in.AppId, in.UserId, in.NewUserId, in.AccountId, in.EntId, in.PositionType, in.PositionId) //不是超级订阅 也不是大会员 if userInfo.Vip.Status <= 0 && userInfo.Member.Status <= 0 { result.ErrMsg = "没有权限" return &result, nil } participateService := service.NewParticipateBid(in.EntId, in.EntUserId, in.PositionType, in.PositionId) participateService.EntRoleId = userInfo.Ent.EntRoleId // 信息id解密 infoList, infoSet := service.DecodeId(in.Sid) if len(infoList) == 0 { result.ErrMsg = "信息id无效" return &result, nil } // 2. 根据标讯id 查询项目信息 projectInfos := es.GetProjectByInfoId(infoList) if projectInfos == nil || len(*projectInfos) == 0 { result.ErrMsg = "未查询到项目信息" return &result, nil } // 判断是否已经过了开标时间 var isValid bool bidopentime := common.Int64All((*projectInfos)[0]["bidopentime"]) bidendtime := common.Int64All((*projectInfos)[0]["bidendtime"]) if time.Now().Unix() >= bidopentime || bidopentime == 0 { isValid = true } // 获取项目id _, projectIds := service.HandlerProjectId(*projectInfos, infoSet) //区分个人和企业 var formatData *bxcore.ParticipateDetailInfo switch int(in.PositionType) { case service.PositionTypePersonal: existList := participateService.PersonalExistProject(projectIds) formatData = participateService.DetailPersonalFormat(existList, isValid, bidendtime) case service.PositionTypeEnt: isAllow := util.IsALLow(in.EntId) existList := participateService.EntExistProject(projectIds) // 查询出已经存在的 formatData = participateService.DetailEntFormat(existList, isValid, isAllow, bidendtime) // 格式化数据 } result.ErrCode = 0 result.Data = formatData return &result, nil }