From fedcae5c0447b0b8187994ffd3a4b77bbc792db3 Mon Sep 17 00:00:00 2001 From: wucongxing8150 <815046773@qq.com> Date: Mon, 13 Jan 2025 16:27:55 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E6=94=B9=E4=BA=86=E7=99=BD=E5=90=8D?= =?UTF-8?q?=E5=8D=95=E9=AA=8C=E8=AF=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- api/controller/Res.go | 9 ++++++++- api/service/ProjectPlatformWhite.go | 20 +++++++++++++++----- 2 files changed, 23 insertions(+), 6 deletions(-) diff --git a/api/controller/Res.go b/api/controller/Res.go index 391392f..941a14f 100644 --- a/api/controller/Res.go +++ b/api/controller/Res.go @@ -11,6 +11,7 @@ import ( "fmt" "github.com/gin-gonic/gin" "math" + "strconv" "time" ) @@ -138,6 +139,12 @@ func (b *Res) GetResCaseRecordList(c *gin.Context) { return } + projectId, err := strconv.ParseInt(req.ProjectId, 10, 64) + if err != nil { + responses.Fail(c) + return + } + req.PlatformId = platformId if req.StartTime != "" { @@ -287,7 +294,7 @@ func (b *Res) GetResCaseRecordList(c *gin.Context) { user, _ := userDao.GetUserById(v.UserId) if user != nil { // 检测用户是否白名单 - isWhite, _ := projectPlatformWhiteService.CheckProjectPlatformWhiteByUser(user, v.PlatformId) + isWhite, _ := projectPlatformWhiteService.CheckProjectPlatformWhiteByUser(user, projectId, v.PlatformId) if isWhite { response.IsVip = 1 } diff --git a/api/service/ProjectPlatformWhite.go b/api/service/ProjectPlatformWhite.go index b2e5882..3ccc678 100644 --- a/api/service/ProjectPlatformWhite.go +++ b/api/service/ProjectPlatformWhite.go @@ -11,11 +11,21 @@ type ProjectPlatformWhiteService struct { } // CheckProjectPlatformWhiteByUser 检测用户是否属于白名单 -func (r *ProjectPlatformWhiteService) CheckProjectPlatformWhiteByUser(user *model.User, platformId int64) (b bool, err error) { +func (r *ProjectPlatformWhiteService) CheckProjectPlatformWhiteByUser(user *model.User, projectId, platformId int64) (b bool, err error) { + // 获取项目关联平台数据 + projectPlatformDao := dao.ProjectPlatformDao{} + maps := make(map[string]interface{}) + maps["project_id"] = projectId + maps["platform_id"] = platformId + projectPlatform, err := projectPlatformDao.GetProjectPlatform(maps) + if err != nil { + return false, err + } + // 白名单-医生 projectPlatformDoctorDao := dao.ProjectPlatformDoctorDao{} - maps := make(map[string]interface{}) - maps["platform_id"] = platformId + maps = make(map[string]interface{}) + maps["project_platform_id"] = projectPlatform.ProjectPlatformId maps["user_id"] = user.UserId projectPlatformDoctor, _ := projectPlatformDoctorDao.GetProjectPlatformDoctor(maps) if projectPlatformDoctor != nil { @@ -34,7 +44,7 @@ func (r *ProjectPlatformWhiteService) CheckProjectPlatformWhiteByUser(user *mode // 白名单-医院 projectPlatformHospitalDao := dao.ProjectPlatformHospitalDao{} maps = make(map[string]interface{}) - maps["platform_id"] = platformId + maps["project_platform_id"] = projectPlatform.ProjectPlatformId maps["hospital_id"] = user.HospitalId projectPlatformHospital, _ := projectPlatformHospitalDao.GetProjectPlatformHospital(maps) if projectPlatformHospital != nil { @@ -46,7 +56,7 @@ func (r *ProjectPlatformWhiteService) CheckProjectPlatformWhiteByUser(user *mode // 白名单-动态 projectPlatformDynamicDao := dao.ProjectPlatformDynamicDao{} maps = make(map[string]interface{}) - maps["platform_id"] = platformId + maps["project_platform_id"] = projectPlatform.ProjectPlatformId projectPlatformDynamics, _ := projectPlatformDynamicDao.GetProjectPlatformDynamicPreloadList(maps) if len(projectPlatformDynamics) > 0 { area := true