package services import ( "errors" "hongze/hongze_clpt/models" "hongze/hongze_clpt/utils" "strings" ) var ( UserPermissionOperationModeApply = "Apply" UserPermissionOperationModeCall = "Call" UserPermissionPopupMsgApplyActivity = "您暂无权限参加此活动,若想参加可以申请开通对应的试用权限" UserPermissionPopupMsgCallActivity = "您暂无权限参加此活动,若想参加可以联系对口销售" UserPermissionPopupMsgApplyMicroVideo = "您暂无权限查看此视频,若想查看可以申请开通对应的试用权限" UserPermissionPopupMsgApplyMicroVoice = "您暂无权限查看此音频,若想查看可以申请开通对应的试用权限" UserPermissionPopupMsgCallMicroVoice = "您暂无权限查看此音频,若想参加可以联系对口销售" UserPermissionPopupMsgCallMicroVideo = "您暂无权限查看此视频,若想查看可以联系对口销售" ) // GetUserRaiPermissionInfo 获取权限类型及信息 // HasPermission int `description:"1:有该行业权限,正常展示,2:无该行业权限,不存在权益客户下(ficc),3:无该品类权限,已提交过申请,4:无该品类权限,未提交过申请,5:潜在客户,未提交过申请,6:潜在客户,已提交过申请"` func GetUserRaiPermissionInfo1(userId, companyId int) (authInfo models.UserPermissionAuthInfo, permissionArr []string, err error) { // 用户申请记录 applyCount, e := models.GetApplyRecordCount(userId) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取用户申请信息失败, Err: " + e.Error()) return } // 潜在用户 if companyId <= 1 { authInfo.HasPermission = 5 if applyCount > 0 { authInfo.HasPermission = 6 } authInfo.OperationMode = UserPermissionOperationModeApply authInfo.PopupMsg = UserPermissionPopupMsgApplyActivity return } // 销售信息 ficcSeller, e := models.GetSellerByCompanyIdCheckFicc(companyId, utils.COMPANY_PRODUCT_FICC_ID) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取FICC销售信息失败, Err: " + e.Error()) return } raiSeller, e := models.GetSellerByCompanyIdCheckFicc(companyId, utils.COMPANY_PRODUCT_RAI_ID) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取权益销售信息失败, Err: " + e.Error()) return } if raiSeller != nil { authInfo.SellerMobile = raiSeller.Mobile authInfo.SellerName = raiSeller.RealName authInfo.HasPermission = 4 if applyCount > 0 { authInfo.HasPermission = 3 } authInfo.OperationMode = UserPermissionOperationModeApply authInfo.PopupMsg = UserPermissionPopupMsgApplyActivity return } // 仅有FICC权限 if ficcSeller != nil { authInfo.HasPermission = 2 authInfo.OperationMode = UserPermissionOperationModeApply authInfo.PopupMsg = UserPermissionPopupMsgApplyActivity return } // permissions示例: 医药,消费,科技,智造,策略,专家,买方研选 permissions, e := models.GetCompanyPermissionName(companyId) if e != nil { err = errors.New("获取客户权限失败, Err: " + e.Error()) return } if permissions == "" { // 无权益权限 // 有销售信息 authInfo.HasPermission = 2 authInfo.OperationMode = UserPermissionOperationModeCall authInfo.PopupMsg = UserPermissionPopupMsgCallActivity return // 无销售信息, 无申请, 视作潜在用户 //authInfo.HasPermission = 3 //authInfo.OperationMode = UserPermissionOperationModeApply //return } // 有基本的权益权限 authInfo.HasPermission = 1 permissionArr = strings.Split(permissions, ",") return } func GetUserRaiPermissionInfo(userId, companyId int) (authInfo models.UserPermissionAuthInfo, permissionArr []string, err error) { // 用户申请记录 applyCount, e := models.GetApplyRecordCount(userId) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取用户申请信息失败, Err: " + e.Error()) return } // 潜在用户 if companyId <= 1 { authInfo.HasPermission = 5 if applyCount > 0 { authInfo.HasPermission = 6 } authInfo.OperationMode = UserPermissionOperationModeApply authInfo.PopupMsg = UserPermissionPopupMsgApplyActivity return } // 销售信息 ficcSeller, e := models.GetSellerByCompanyIdCheckFicc(companyId, utils.COMPANY_PRODUCT_FICC_ID) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取FICC销售信息失败, Err: " + e.Error()) return } raiSeller, e := models.GetSellerByCompanyIdCheckFicc(companyId, utils.COMPANY_PRODUCT_RAI_ID) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("获取权益销售信息失败, Err: " + e.Error()) return } if raiSeller != nil { authInfo.SellerMobile = raiSeller.Mobile authInfo.SellerName = raiSeller.RealName } // 仅有FICC权限 if ficcSeller != nil && raiSeller == nil { authInfo.HasPermission = 2 authInfo.OperationMode = UserPermissionOperationModeApply authInfo.PopupMsg = UserPermissionPopupMsgApplyActivity return } // permissions示例: 医药,消费,科技,智造,策略,专家,买方研选 permissions, e := models.GetCompanyPermissionName(companyId) if e != nil { err = errors.New("获取客户权限失败, Err: " + e.Error()) return } if permissions == "" { // 无权益权限 if raiSeller != nil { // 有销售信息 authInfo.HasPermission = 2 authInfo.OperationMode = UserPermissionOperationModeCall authInfo.PopupMsg = UserPermissionPopupMsgCallActivity return } // 无销售信息, 无申请, 视作潜在用户 authInfo.HasPermission = 3 authInfo.OperationMode = UserPermissionOperationModeApply return } // 有基本的权益权限 authInfo.HasPermission = 1 permissionArr = strings.Split(permissions, ",") //判断用户是否开通了个人研选权限,如果有权限后缀拼接权限名称 mfyxUserPermissionTotal := GetMfyxUserPermissionTotal(userId) if mfyxUserPermissionTotal == 1 { permissionArr = append(permissionArr, utils.CHART_PERMISSION_NAME_MF_YANXUAN) } return } // 查询研选的权限状态 func GetUserRaiPermissionYanXuanInfo(user *models.WxUserItem) (hasPermission int, err error) { //判断用户是否开通了个人研选权限 mfyxUserPermissionTotal := GetMfyxUserPermissionTotal(user.UserId) if mfyxUserPermissionTotal == 1 { hasPermission = 1 return } var condition string var pars []interface{} condition = " AND company_id = ? AND status IN ('正式','试用') AND chart_permission_id = ? ORDER BY company_report_permission_id DESC LIMIT 1 " pars = append(pars, user.CompanyId, utils.CHART_PERMISSION_ID_YANXUAN) companyReportPermissionDetail, e := models.GetCompanyReportPermissionDetailByCondition(condition, pars) if e != nil && e.Error() != utils.ErrNoRow() { err = errors.New("GetCompanyReportPermissionDetailByCondition, Err: " + e.Error()) return } //如果用户没有研选权限,那么就获取他对应的状态码 if companyReportPermissionDetail == nil { hasPermission, _, _, _, e = GetUserHasPermissionArticle(user) if e != nil { err = errors.New("GetUserHasPermissionArticle, Err: " + e.Error()) return } } else { hasPermission = 1 } return }