123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600 |
- package cygx
- import (
- "errors"
- "fmt"
- "hongze/hz_crm_api/models"
- "hongze/hz_crm_api/models/company"
- "hongze/hz_crm_api/models/cygx"
- "hongze/hz_crm_api/models/system"
- "hongze/hz_crm_api/utils"
- "strconv"
- "strings"
- )
- func GetActivityDetailUserPowerold(user *models.WxUser, adminInfo *system.Admin, activityInfo *cygx.ActivityDetail) (havePower bool, err error) {
- var companyDetailStatus string
- var userTypeStr string
- if user.CompanyId == utils.HZ_COMPANY_ID {
- havePower = true
- return
- }
-
- if activityInfo.IsLimitPeople == 0 {
- havePower = true
- return
- }
-
-
-
-
-
-
- userType, permissionStr, permissionStrZhengShi, companyStatus, e := GetUserTypeZhengShi(user.CompanyId)
- if e != nil {
- err = errors.New("GetCompanyPermissionUpgrade, Err: " + e.Error())
- return
- }
-
-
-
-
-
-
- if (activityInfo.ActivityTypeId == 3 || activityInfo.ActivityTypeId == 5) && activityInfo.YidongActivityId == "" && strings.Contains(activityInfo.ChartPermissionName, utils.CHART_PERMISSION_NAME_YANXUAN) {
- if !strings.Contains(permissionStrZhengShi, activityInfo.ChartPermissionName) {
- havePower = false
- return
- }
- }
-
- if activityInfo.YidongActivityId != "" && permissionStr != "" && strings.Contains(activityInfo.ChartPermissionName, utils.CHART_PERMISSION_NAME_YANXUAN) {
- havePower = true
- return
- }
-
- if user.IsMaker == 0 && activityInfo.IsMakerShow == 1 {
- havePower = false
- return
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- if activityInfo.IsLimitPeople > 0 {
- mapUserType, e := GetActivityCcustomerTypeList()
- if e != nil {
- err = e
- return
- }
- userTypeStr = mapUserType[userType]
-
- if userTypeStr == "1" || userTypeStr == "2" || userTypeStr == "AA" {
- if strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) && strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
-
- }
- }
- } else {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- }
-
- companyProduct, e := company.GetCompanyProductDetail(user.CompanyId, 2)
- if e != nil {
- err = e
- return
- }
- if companyProduct != nil && activityInfo.Scale != "" {
- if strings.Contains(activityInfo.Scale, companyProduct.Scale) {
- havePower = true
- }
- }
- if user.CompanyId <= 1 {
- return
- } else {
- if permissionStr == "" {
- return
- } else {
-
-
-
-
-
-
-
-
-
- companyDetailStatus = companyStatus
- }
- }
- if activityInfo.ChartPermissionId == 1 {
- havePower = true
- return
- }
- if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3) && strings.Contains(permissionStr, "专家") && activityInfo.IsLimitPeople == 0 {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "正式" && strings.Contains(activityInfo.CustomerTypeIds, "4") {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "试用" && strings.Contains(activityInfo.CustomerTypeIds, "5") {
- havePower = true
- } else if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3 || activityInfo.ActivityTypeId == 4 || activityInfo.ActivityTypeId == 5) && strings.Contains(permissionStr, "专家") {
- havePower = true
- }
-
-
-
-
- fmt.Println(havePower)
- if strings.Contains(activityInfo.ChartPermissionName, "研选") || activityInfo.ChartPermissionName == "策略" {
- if strings.Contains(activityInfo.CustomerTypeIds, "5") {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- } else {
- if strings.Contains(permissionStrZhengShi, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- }
- }
- permissionShengji, errs := cygx.GetCompanyPermissionByUserZhengShiTrip(user.CompanyId)
- if errs != nil {
- err = errs
- return
- }
-
-
-
-
- if activityInfo.CustomerTypeIds != "" {
- if !strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) && userTypeStr != "8" {
- havePower = false
- if strings.Contains(permissionShengji, activityInfo.ChartPermissionName) && strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
- }
- }
- }
-
-
-
-
- if havePower && activityInfo.IsLimitPeople > 0 {
-
- noPower, e := GetShareNoPoweNew(activityInfo, permissionStr, userType, user)
- if e != nil {
- err = errors.New("GetShareNoPowe, Err: " + e.Error())
- return
- }
- if noPower {
- havePower = false
- }
- }
- return
- }
- func GetActivityDetailUserPower(user *models.WxUser, adminInfo *system.Admin, activityInfo *cygx.ActivityDetail) (havePower bool, err error) {
- var companyDetailStatus string
- var userTypeStr string
- userId := int(user.UserId)
-
-
- if user.CompanyId == utils.HZ_COMPANY_ID {
- havePower = true
- return
- }
-
- if activityInfo.IsLimitPeople == 0 {
- havePower = true
- return
- }
- userType, permissionStr, permissionStrZhengShi, _, e := GetUserTypeZhengShi(user.CompanyId)
- if e != nil {
- err = errors.New("GetUserTypeZhengShi, Err: " + e.Error())
- return
- }
-
-
- mfyxUserPermissionTotal, e := cygx.GetCygxUserYanxuanPermissionCountByUserId(userId)
- if e != nil {
- err = errors.New("GetCygxUserYanxuanPermissionCountByUserId, Err: " + e.Error())
- return
- }
- if mfyxUserPermissionTotal == 1 {
- permissionStr += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN
- }
-
- if strings.Contains(permissionStrZhengShi, utils.YAN_XUAN_KOU_DIAN_BAO_NAME) {
- permissionStr += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN
- permissionStrZhengShi += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN
- }
-
- if strings.Contains(permissionStr, utils.YAN_XUAN_KOU_DIAN_BAO_NAME) {
- permissionStr += "," + utils.CHART_PERMISSION_NAME_MF_YANXUAN
- }
-
- if permissionStr == "" {
- return
- }
- permissionStr += "," + utils.HONG_GUAN_NAME
- if permissionStrZhengShi == "" {
- permissionStrZhengShi = utils.HONG_GUAN_NAME
- } else {
- permissionStrZhengShi += "," + utils.HONG_GUAN_NAME
- }
-
- if activityInfo.YidongActivityId != "" {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName) || strings.Contains(permissionStr, activityInfo.ChartPermissionNameDeputy) {
- havePower = true
- return
- }
- }
-
- if !strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- return
- } else {
- havePower = true
- }
-
- if user.IsMaker == 0 && activityInfo.IsMakerShow == 1 {
- havePower = false
- return
- }
-
- if activityInfo.VisibleRange == 1 {
- adminIds, e := cygx.GetSelleridWhichGroup(user.CompanyId, 2)
- if e != nil {
- err = errors.New("GetSelleridWhichGroup, Err: " + e.Error())
- return
- }
- haveVisibleRange := false
- adminIdSlice := strings.Split(adminIds, ",")
- for _, v := range adminIdSlice {
- if v == strconv.Itoa(activityInfo.AdminId) {
- haveVisibleRange = true
- }
- }
- if !haveVisibleRange {
- havePower = false
- return
- }
- }
- if permissionStr == "" {
- return
- }
-
- if activityInfo.YidongActivityId != "" && permissionStr != "" && strings.Contains(activityInfo.ChartPermissionName, utils.CHART_PERMISSION_NAME_YANXUAN) {
- havePower = true
- return
- }
-
- if strings.Contains(utils.YI_YAO_NAME+utils.XIAO_FEI_NAME+utils.KE_JI_NAME+utils.ZHI_ZAO_NAME, activityInfo.ChartPermissionName) {
- if activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 6 || activityInfo.ActivityTypeId == 7 {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(主观)") {
- havePower = true
- } else {
- havePower = false
- }
- } else {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(客观)") {
- havePower = true
- } else {
- havePower = false
- }
- }
- if !havePower {
- return
- }
- }
- if activityInfo.IsLimitPeople > 0 {
- mapUserType, e := GetActivityCcustomerTypeList()
- if e != nil {
- err = errors.New("GetActivityCcustomerTypeList, Err: " + e.Error())
- return
- }
- userTypeStr = mapUserType[userType]
-
- if userTypeStr == "1" || userTypeStr == "2" || userTypeStr == "AA" {
- if strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) && strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
-
- }
- }
- } else {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- }
-
- companyProduct, e := cygx.GetCompanyProductDetail(user.CompanyId, 2)
- if e != nil {
- err = e
- return
- }
- if companyProduct != nil && activityInfo.Scale != "" {
- if strings.Contains(activityInfo.Scale, companyProduct.Scale) {
- havePower = true
- }
- }
- if user.CompanyId <= 1 {
- return
- } else {
- if permissionStr == "" {
- return
- } else {
- companyDetail, e := cygx.GetCompanyDetailById(user.CompanyId)
- if e != nil {
- err = errors.New("GetCompanyPermissionUpgrade, Err: " + e.Error())
- return
- }
- if companyDetail == nil {
- err = errors.New("客户不存在,uid:" + strconv.Itoa(int(user.UserId)) + "CompanyId:" + strconv.Itoa(user.CompanyId))
- return
- }
- companyDetailStatus = companyDetail.Status
- }
- }
-
- if activityInfo.ChartPermissionId == 1 {
- if activityInfo.IsLimitPeople > 0 {
- if strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) {
- havePower = true
- return
- }
- } else {
- havePower = true
- return
- }
- }
- if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3) && strings.Contains(permissionStr, "专家") && activityInfo.IsLimitPeople == 0 {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "正式" && strings.Contains(activityInfo.CustomerTypeIds, "4") {
- havePower = true
- } else if activityInfo.ActivityTypeId == 3 && strings.Contains(permissionStr, "专家") && companyDetailStatus == "试用" && strings.Contains(activityInfo.CustomerTypeIds, "5") {
- havePower = true
- } else if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3 || activityInfo.ActivityTypeId == 4 || activityInfo.ActivityTypeId == 5) && strings.Contains(permissionStr, "专家") {
- havePower = true
- }
- if strings.Contains(activityInfo.ChartPermissionName, "研选") || activityInfo.ChartPermissionName == "策略" {
- if strings.Contains(activityInfo.CustomerTypeIds, "5") {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- } else {
- if strings.Contains(permissionStrZhengShi, activityInfo.ChartPermissionName) {
- havePower = true
- return
- }
- }
- }
- permissionShengji, errs := cygx.GetCompanyPermissionByUserTrip(user.CompanyId)
- if errs != nil {
- err = errs
- return
- }
-
-
-
-
-
-
- if activityInfo.CustomerTypeIds != "" {
- if !strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) && userTypeStr != "8" {
- havePower = false
- if strings.Contains(permissionShengji, activityInfo.ChartPermissionName) && strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
- }
- }
- }
- if havePower && activityInfo.IsLimitPeople > 0 {
-
- noPower, e := GetShareNoPowe(activityInfo, permissionStr, userType)
- if e != nil {
- err = errors.New("GetShareNoPowe, Err: " + e.Error())
- return
- }
- if noPower {
- havePower = false
- }
- }
- return
- }
- func GetShareNoPoweNew(activityInfo *cygx.ActivityDetail, permissionStr string, userType int, user *models.WxUser) (noPower bool, err error) {
-
- if user.CompanyId == utils.HZ_COMPANY_ID {
- return
- }
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
-
- if userType == 8 {
- permissionShengji, errs := cygx.GetCompanyPermissionByUserZhengShiTrip(user.CompanyId)
- if errs != nil {
- err = errs
- return
- }
- if !strings.Contains(permissionShengji, activityInfo.ChartPermissionName) {
- noPower = true
- return
- }
- }
- if !noPower {
- noPower, err = CheckUserPowerByActivityChoose(user, activityInfo)
- }
- return
- }
- func CheckUserPowerByActivityChoose(user *models.WxUser, activityInfo *cygx.ActivityDetail) (noPower bool, err error) {
-
- if activityInfo.VisibleRange == 1 {
- adminIds, errAdmin := system.GetSelleridWhichGroup(user.CompanyId, 2)
- if errAdmin != nil {
- err = errAdmin
- return
- }
- sliceAdminIds := strings.Split(adminIds, ",")
- var haveAdminId bool
- for _, v := range sliceAdminIds {
- if v == strconv.Itoa(activityInfo.AdminId) {
- haveAdminId = true
- }
- }
- if !haveAdminId {
- noPower = true
- }
- }
-
- if activityInfo.IsMakerShow == 1 {
- if user.IsMaker == 0 {
- noPower = true
- }
- }
- return
- }
- func GetSpecialDetailUserPower(user *models.WxUser, activityInfo *cygx.ActivitySpecialDetail) (havePower bool, err error) {
- if user.CompanyId == utils.HZ_COMPANY_ID {
- havePower = true
- return
- }
- userType, _, permissionStr, _, e := GetUserType(user.CompanyId)
- if e != nil {
- err = errors.New("GetCompanyPermissionUpgrade, Err: " + e.Error())
- return
- }
- if userType == 0 {
- return
- }
- mapUserType, e := GetActivityCcustomerTypeList()
- if e != nil {
- err = e
- return
- }
- var userTypeStr string
- userTypeStr = mapUserType[userType]
-
- if userTypeStr == "1" || userTypeStr == "2" {
- if strings.Contains(activityInfo.CustomerTypeIds, userTypeStr) || strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
- return
- }
- }
- permissionShengji, errs := cygx.GetCompanyPermissionByUserTrip(user.CompanyId)
- if errs != nil {
- err = errs
- return
- }
-
- if permissionStr != "" {
- if activityInfo.ChartPermissionName == utils.CE_LUE_NAME {
- permissionShengji += "," + utils.CE_LUE_NAME
- }
- if activityInfo.ChartPermissionName == utils.GU_SHOU_NAME {
- permissionShengji += "," + utils.GU_SHOU_NAME
- }
- }
-
- if !strings.Contains(permissionShengji, activityInfo.ChartPermissionName) {
- return
- }
- var pars []interface{}
- var condition string
- var userTypes string
- condition += ` AND art.publish_status = 1 AND art.is_offline = 0 `
- userTypes = "%" + userTypeStr + "%"
- condition += ` AND art.customer_type_ids LIKE ? `
- pars = append(pars, userTypes)
- condition += ` AND art.activity_id = ? `
- pars = append(pars, activityInfo.ActivityId)
- total, e := cygx.GetActivitySpecialCount(condition, pars)
- if e != nil {
- err = errors.New("GetSpecialUserType, Err: " + e.Error())
- return
- }
- if total == 1 {
- havePower = true
- return
- }
- if strings.Contains(permissionShengji, activityInfo.ChartPermissionName) && strings.Contains(activityInfo.CustomerTypeIds, "8") {
- havePower = true
- return
- }
- return
- }
|