1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057 |
- package services
- import (
- "context"
- "fmt"
- "github.com/tealeg/xlsx"
- "hongze/hongze_cygx/models"
- "hongze/hongze_cygx/utils"
- "os"
- "path/filepath"
- "strconv"
- "strings"
- "time"
- )
- //修改活动状态
- func UpdateActivitySattus(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("同步失败,Err:", err.Error())
- }
- }()
- go models.UpdateActivitySattusToHaveInHand()
- go models.UpdateActivitySattusToComplete()
- return
- }
- //推送会议开始消息提醒60分钟前
- func SendActivityBeginMsg(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error())
- }
- }()
- endDate := time.Now().Add(+time.Minute * 60).Format(utils.FormatDateTime)
- listActivity, err := models.GetActivitySendMsgListAll(endDate)
- fmt.Println(len(listActivity))
- if err != nil {
- fmt.Println("GetActivitySendMsgListAll Err:", err.Error())
- return
- }
- if len(listActivity) == 0 {
- return
- }
- var remark = "点击查看活动详情"
- var signupIds string
- for _, v := range listActivity {
- signupIds += strconv.Itoa(v.Id) + ","
- var reserveResults string
- var first string
- openIdItem := new(models.OpenIdList)
- openIdItem.OpenId = v.OpenId
- openIdList := make([]*models.OpenIdList, 0)
- openIdList = append(openIdList, openIdItem)
- //if v.FailType == 0 {
- // reserveResults = "成功"
- //} else if v.FailType == 1 {
- // reserveResults = "失败(总人数已满)"
- //} else if v.FailType == 2 {
- // reserveResults = "失败(单机构超限制)"
- //} else if v.FailType == 3 {
- // reserveResults = "失败(爽约次数超限)"
- //}
- reserveResults = "--"
- first = "您有一场【" + v.ActivityTypeName + "】将在1小时后开始"
- SendWxMsgWithFrequency(first, v.ActivityName, reserveResults, v.ActivityTime, v.Address, remark, openIdList, v.ActivityId)
- }
- if len(signupIds) == 0 {
- return
- }
- signupIds = strings.TrimRight(signupIds, ",")
- err = models.UPdateSendedMsgStatus(signupIds)
- if err != nil {
- var msg string
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- return
- }
- //推送会议开始消息提醒15分钟前
- func SendActivityBeginMsgMeeting(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error())
- }
- }()
- endDate := time.Now().Add(+time.Minute * 15).Format(utils.FormatDateTime)
- listActivity, err := models.GetActivitySendMsgListAllMeeting(endDate)
- if err != nil {
- fmt.Println("GetActivitySendMsgListAll Err:", err.Error())
- return
- }
- if len(listActivity) == 0 {
- return
- }
- var signupIds string
- var remark = "点击查看活动详情"
- for _, v := range listActivity {
- signupIds += strconv.Itoa(v.Id) + ","
- var reserveResults string
- var first string
- openIdItem := new(models.OpenIdList)
- openIdItem.OpenId = v.OpenId
- openIdList := make([]*models.OpenIdList, 0)
- openIdList = append(openIdList, openIdItem)
- reserveResults = "--"
- first = "您有一场【" + v.ActivityTypeName + "】将在15分钟后开始"
- SendWxMsgWithFrequency(first, v.ActivityName, reserveResults, v.ActivityTime, "--", remark, openIdList, v.ActivityId)
- }
- if len(signupIds) == 0 {
- return
- }
- signupIds = strings.TrimRight(signupIds, ",")
- err = models.UPdateSendedMsgMeetingStatus(signupIds)
- if err != nil {
- var msg string
- go utils.SendEmail("发送模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送模版消息失败,Err:%s", err.Error())
- }
- return
- }
- //预约外呼名单,会前1小时自动发送邮件给专家组
- func SendEmailFileToExpert(cont context.Context) (err error) {
- var msg string
- var touser string
- defer func() {
- if err != nil {
- fmt.Println("err:", err)
- go utils.SendEmail("发送附件模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送附件模版消息失败,Err:%s", err.Error())
- }
- if msg != "" {
- fmt.Println(msg)
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- endDate := time.Now().Add(+time.Minute * 30).Format(utils.FormatDateTime)
- total, err := models.GetCountActivityIdToSendFile(endDate)
- if total == 0 {
- fmt.Println("发送附件完成0")
- return nil
- }
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- listActivity, err := models.GetActivityIdToSendFile(endDate)
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- for _, v := range listActivity {
- activityInfo, _ := models.GetAddActivityInfoById(v.ActivityId)
- if activityInfo == nil {
- msg = "活动不存在,Err:activityId:" + strconv.Itoa(v.ActivityId)
- return
- }
- list, errFile := models.GetSignupExport(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- //创建excel
- dir, errFile := os.Executable()
- exPath := filepath.Dir(dir)
- downLoadnFilePath := exPath + "/" + time.Now().Format(utils.FormatDateTimeUnSpace) + utils.GetRandDigit(5) + ".xlsx"
- xlsxFile := xlsx.NewFile()
- if errFile != nil {
- msg = "生成文件失败Err:" + errFile.Error()
- return
- }
- style := xlsx.NewStyle()
- alignment := xlsx.Alignment{
- Horizontal: "center",
- Vertical: "center",
- WrapText: true,
- }
- style.Alignment = alignment
- style.ApplyAlignment = true
- sheet, errFile := xlsxFile.AddSheet("外呼名单")
- if errFile != nil {
- msg = "新增Sheet失败,Err:" + errFile.Error()
- return
- }
- //设置宽度
- _ = sheet.SetColWidth(1, 1, 15)
- _ = sheet.SetColWidth(3, 3, 30)
- //标头
- rowTitle := sheet.AddRow()
- cellA := rowTitle.AddCell()
- cellA.Value = "姓名"
- cellB := rowTitle.AddCell()
- cellB.Value = "外呼号码"
- cellC := rowTitle.AddCell()
- cellC.Value = "国际代码"
- cellD := rowTitle.AddCell()
- cellD.Value = "公司名称"
- cellE := rowTitle.AddCell()
- cellE.Value = "所属销售"
- for _, item := range list {
- row := sheet.AddRow()
- cellA := row.AddCell()
- cellA.Value = item.RealName
- cellB := row.AddCell()
- cellB.Value = item.OutboundMobile
- cellC := row.AddCell()
- if item.CountryCode == "" {
- cellC.Value = "86"
- } else {
- cellC.Value = item.CountryCode
- }
- cellD := row.AddCell()
- cellD.Value = item.CompanyName
- cellE := row.AddCell()
- cellE.Value = item.SellerName
- }
- errFile = xlsxFile.Save(downLoadnFilePath)
- if errFile != nil {
- msg = "保存文件失败Err:" + errFile.Error()
- return
- }
- title := activityInfo.ActivityName + "外呼名单"
- content := "外呼名单详情"
- fileName := downLoadnFilePath
- if activityInfo.ChartPermissionName == "科技" {
- touser = utils.EmailTechnology
- } else if activityInfo.ChartPermissionName == "医药" {
- touser = utils.EmailMedicine
- } else if activityInfo.ChartPermissionName == "消费" {
- touser = utils.EmailConsumption
- } else if activityInfo.ChartPermissionName == "智造" {
- touser = utils.EmailZhizao
- } else if activityInfo.ChartPermissionName == "策略" {
- touser = utils.EmailStrategy
- } else if activityInfo.ChartPermissionName == "研选" {
- touser = utils.EmailExpert
- }
- sendResult := utils.SendEmailByHongze(title, content, touser, fileName, title+".xlsx")
- if sendResult {
- errFile = models.UPdateActivityIdToSendFile(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- os.Remove(downLoadnFilePath)
- } else {
- go utils.SendEmail("发送附件模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+activityInfo.ActivityName, utils.EmailSendToUsers)
- utils.FileLog.Info("发送附件模版消息失败,Err:%s", activityInfo.ActivityName)
- }
- }
- return
- }
- func EditOutboundMobile(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error())
- }
- }()
- list, err := models.GetActivitySignupListAll()
- if err != nil {
- fmt.Println("GetActivitySendMsgListAll Err:", err.Error())
- return
- }
- for _, v := range list {
- err = models.UPdateSignup(v)
- fmt.Println("修改:", strconv.Itoa(v.Id))
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error()+strconv.Itoa(v.Id))
- }
- }
- fmt.Println("修改完成")
- return
- }
- //同步用户绑定手机号以及区号
- func EditUserOutboundMobile(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error())
- }
- }()
- list, err := models.GetUserListAll()
- if err != nil {
- fmt.Println("GetActivitySendMsgListAll Err:", err.Error())
- return
- }
- for _, v := range list {
- err = models.UPdateUserCountryCode(v)
- fmt.Println("修改:", strconv.Itoa(v.UserId))
- if err != nil {
- fmt.Println("发送失败,Err:", err.Error()+strconv.Itoa(v.UserId))
- }
- }
- fmt.Println("修改完成")
- return
- }
- //获取 用户类型 //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户
- func GetUserType(companyId int) (userType int, permissionStrnew string, err error) {
- var permissionStr, permissionZhegnshiStr string
- if companyId <= 1 {
- userType = 0
- } else {
- total, errs := models.GetCountCompanyDetailByIdGroup(companyId)
- if errs != nil {
- err = errs
- return
- }
- if total == 0 {
- userType = 0
- } else {
- companyDetail, errs := models.GetCompanyDetailByIdGroup(companyId)
- if errs != nil {
- err = errs
- return
- }
- permissionStr, errs = models.GetCompanyPermissionByUser(companyId)
- if errs != nil {
- err = errs
- return
- }
- permissionZhegnshiStr, errs = models.GetCompanyPermissionByUserZhengShi(companyId)
- if errs != nil {
- err = errs
- return
- }
- //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户
- if companyDetail.Status == "永续" {
- userType = 1
- } else if companyDetail.Status == "试用" {
- userType = 5
- } else if companyDetail.Status == "正式" {
- if permissionStr == "专家" {
- userType = 4
- } else if strings.Count(permissionZhegnshiStr, "医药") == 2 && strings.Count(permissionZhegnshiStr, "消费") == 2 && strings.Count(permissionZhegnshiStr, "科技") == 2 && strings.Count(permissionZhegnshiStr, "智造") == 2 {
- userType = 2
- } else {
- userType = 3
- }
- if userType == 3 {
- if !strings.Contains(permissionStr, "医药") && !strings.Contains(permissionStr, "消费") && !strings.Contains(permissionStr, "科技") && !strings.Contains(permissionStr, "智造") {
- userType = 4
- }
- }
- }
- }
- }
- permissionStrnew = permissionStr
- return
- }
- // 校验被分享的用户是否有查看详情的权限
- func GetShareNoPowe(activityInfo *models.ActivityDetail, permissionStr string, userType int) (noPower bool, err error) {
- //var noPower bool
- if (userType == 1 || userType == 4 || userType == 5) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(userType)) {
- noPower = true
- }
- //1、永续客户 //2、大套餐客户(4个行业全开通的正式客户) //3、分行业套餐客户(开通对应行业的正式客户) //4、仅开通专家套餐的正式客户 //5、开通对应行业套餐或专家套餐的试用客户
- if userType == 2 && strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(2)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(4)) {
- noPower = true
- }
- if userType == 2 && !strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(2)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) {
- noPower = true
- }
- if userType == 3 && strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(4)) {
- noPower = true
- }
- if userType == 3 && !strings.Contains(permissionStr, "专家") && !strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(3)) {
- noPower = true
- }
- return
- }
- // 校验用户报名的权限
- func GetHavePower(activityInfo *models.ActivityDetail, permissionStr, companyDetailStatus string, userType int) (havePower bool, err error) {
- if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3) && strings.Contains(permissionStr, "专家") && activityInfo.LimitPeopleNum == 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 strings.Contains(permissionStr, activityInfo.ChartPermissionName) && strings.Contains(activityInfo.CustomerTypeIds, strconv.Itoa(userType)) {
- // havePower = true
- //} else if strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- // havePower = true
- } else if (activityInfo.ActivityTypeId == 1 || activityInfo.ActivityTypeId == 3 || activityInfo.ActivityTypeId == 4 || activityInfo.ActivityTypeId == 5) && strings.Contains(permissionStr, "专家") {
- havePower = true
- }
- if activityInfo.ActivityTypeId == 2 || activityInfo.ActivityTypeId == 6 {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(主观)") {
- havePower = true
- }
- } else {
- if strings.Contains(permissionStr, activityInfo.ChartPermissionName+"(客观)") {
- havePower = true
- }
- }
- if (activityInfo.ChartPermissionName == "研选" || activityInfo.ChartPermissionName == "策略") && strings.Contains(permissionStr, activityInfo.ChartPermissionName) {
- havePower = true
- }
- return
- }
- //研选系列专家电话会,会前1小时将问题列表发送给邮箱
- func SendEmailFileForAskMsgResearch(cont context.Context) (err error) {
- var msg string
- //var touser string
- defer func() {
- if err != nil {
- fmt.Println("err:", err)
- go utils.SendEmail("发送附件模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送附件模版消息失败,Err:%s", err.Error())
- }
- if msg != "" {
- fmt.Println(msg)
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- endDate := time.Now().Add(+time.Minute * 60).Format(utils.FormatDateTime)
- condition := `AND a.activity_type_id = 1 AND a.chart_permission_name = '研选' `
- total, err := models.GetCountActivityResearchToSendFile(condition, endDate)
- if total == 0 {
- fmt.Println("发送附件完成0")
- return nil
- }
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- listActivity, err := models.GetActivityResearchToSendFile(condition, endDate)
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- for _, v := range listActivity {
- activityInfo, _ := models.GetAddActivityInfoById(v.ActivityId)
- if activityInfo == nil {
- msg = "活动不存在,Err:activityId:" + strconv.Itoa(v.ActivityId)
- return
- }
- list, errFile := models.GetActivityMsgExport(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- for _, v2 := range list {
- user, err := models.GetWxUserItemByUserId(v2.UserId)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return err
- }
- //获取销售信息
- sellerItem, err := models.GetSellerByCompanyIdCheckFicc(v2.CompanyId, 2)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return err
- }
- //给研究员推送消息
- if sellerItem != nil {
- openIpItem, _ := models.GetUserRecordByMobile(4, utils.ActSendMsgMobile)
- if openIpItem != nil && openIpItem.OpenId != "" {
- SendActivityAskApplyTemplateMsg(user.RealName+"——"+user.CompanyName+"(所属销售:"+sellerItem.RealName+")", v2.CreateTime, v2.Content, activityInfo.ActivityName, openIpItem.OpenId, activityInfo.ActivityId)
- }
- }
- //给所属销售推送消息
- if sellerItem != nil {
- openIpItem, _ := models.GetUserRecordByMobile(4, sellerItem.Mobile)
- if openIpItem != nil && openIpItem.OpenId != "" {
- SendActivityAskApplyTemplateMsg(user.RealName+"——"+user.CompanyName+"(所属销售:"+sellerItem.RealName+")", v2.CreateTime, v2.Content, activityInfo.ActivityName, openIpItem.OpenId, activityInfo.ActivityId)
- }
- }
- }
- errFile = models.UPdateActivityMsgToSendFile(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- }
- return
- }
- //非研选系列专家电话会,根据主持人姓名,会前15分钟将问题列表发送给至该主持人对应邮箱
- func SendEmailFileForAskMsg(cont context.Context) (err error) {
- var msg string
- //var touser string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送附件模版消息失败"+"【"+utils.APPNAME+"】"+time.Now().Format(utils.FormatDateTime), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- utils.FileLog.Info("发送附件模版消息失败,Err:%s", err.Error())
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- endDate := time.Now().Add(+time.Minute * 15).Format(utils.FormatDateTime)
- condition := `AND a.activity_type_id = 1 AND a.chart_permission_name != '研选' `
- total, err := models.GetCountActivityResearchToSendFile(condition, endDate)
- if total == 0 {
- fmt.Println("发送附件完成0")
- return nil
- }
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- listActivity, err := models.GetActivityResearchToSendFile(condition, endDate)
- if err != nil {
- msg = "发送附件模版消息失败 Err:" + err.Error()
- return
- }
- listEmail, errEmail := models.GetAskEmail()
- if errEmail != nil {
- msg = "获取失败,Err:" + errEmail.Error()
- return
- }
- for _, v := range listActivity {
- activityInfo, _ := models.GetAddActivityInfoById(v.ActivityId)
- if activityInfo == nil {
- msg = "活动不存在,Err:activityId:" + strconv.Itoa(v.ActivityId)
- return
- }
- list, errFile := models.GetActivityMsgExport(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- for _, v2 := range list {
- user, err := models.GetWxUserItemByUserId(v2.UserId)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return err
- }
- var sendMobile string
- for _, vEmail := range listEmail {
- if strings.Index(activityInfo.Host, vEmail.Name) > 0 {
- sendMobile = vEmail.Mobile
- }
- }
- //获取销售信息
- sellerItem, err := models.GetSellerByCompanyIdCheckFicc(v2.CompanyId, 2)
- if err != nil && err.Error() != utils.ErrNoRow() {
- return err
- }
- //给研究员推送模板消息
- if sellerItem != nil {
- openIpItem, _ := models.GetUserRecordByMobile(4, sendMobile)
- if openIpItem != nil && openIpItem.OpenId != "" {
- SendActivityAskApplyTemplateMsg(user.RealName+"——"+user.CompanyName+"(所属销售:"+sellerItem.RealName+")", v2.CreateTime, v2.Content, activityInfo.ActivityName, openIpItem.OpenId, activityInfo.ActivityId)
- }
- }
- //给销售推送模板消息
- if sellerItem != nil {
- openIpItem, _ := models.GetUserRecordByMobile(4, sellerItem.Mobile)
- if openIpItem != nil && openIpItem.OpenId != "" {
- SendActivityAskApplyTemplateMsg(user.RealName+"——"+user.CompanyName+"(所属销售:"+sellerItem.RealName+")", v2.CreateTime, v2.Content, activityInfo.ActivityName, openIpItem.OpenId, activityInfo.ActivityId)
- }
- }
- }
- errFile = models.UPdateActivityMsgToSendFile(v.ActivityId)
- if errFile != nil {
- msg = "获取失败,Err:" + errFile.Error()
- return
- }
- }
- return
- }
- //活动标签字符串处理
- func LabelStr(label string) (labelNew string) {
- slicebr := strings.Split(label, "-")
- if len(slicebr) < 2 {
- labelNew = label
- } else {
- labelNew = slicebr[1]
- }
- return labelNew
- }
- //5.3版本活动标签字符串处理
- func LabelStrV5(label string, isShowSubjectName int) (labelNew string) {
- slicebr := strings.Split(label, "-")
- if len(slicebr) < 2 || isShowSubjectName == 0 {
- labelNew = label
- } else {
- labelNew = slicebr[1]
- }
- return labelNew
- }
- func ActivityAttendanceDetail(cont context.Context) (err error) {
- defer func() {
- if err != nil {
- fmt.Println("ActivityAttendanceDetail Err:" + err.Error())
- go utils.SendEmail(utils.APPNAME+"【"+utils.RunMode+"】"+"失败提醒", "ActivityAttendanceDetail ErrMsg:"+err.Error(), utils.EmailSendToUsers)
- }
- }()
- var activityIds string
- fmt.Println("开始同步")
- dateTime := time.Now().AddDate(0, 0, -14).Format(utils.FormatDate)
- dateNow := time.Now().AddDate(0, 0, 0).Format(utils.FormatDate)
- startDate := dateTime + " 00:00:00"
- endDate := dateNow + " 23:59:59"
- //获取进门财经需要处理的活动
- listActivityRoadshow, err := models.GetRoadshowDataListByDateTime(startDate, endDate)
- if err != nil {
- fmt.Println("GetRoadshowDataListByDateTime Err:", err.Error())
- return err
- }
- for _, vAct := range listActivityRoadshow {
- doTime := utils.TimeRemoveHms2(vAct.RoadshowBeginTime)
- findStartDate := doTime + " 00:00:00"
- findEndDate := doTime + " 23:59:59"
- var roadshowTitle string
- roadshowTitle = vAct.RoadshowTitle
- vAct.RoadshowTitle = strings.Replace(vAct.RoadshowTitle, "【", "", -1)
- vAct.RoadshowTitle = strings.Replace(vAct.RoadshowTitle, "】", "", -1)
- vAct.RoadshowTitle = strings.Replace(vAct.RoadshowTitle, " ", "", -1)
- vAct.RoadshowTitle = strings.Replace(vAct.RoadshowTitle, "-", "", -1)
- vAct.RoadshowTitle = strings.Replace(vAct.RoadshowTitle, ":", "", -1)
- nameSlice := strings.Split(vAct.RoadshowTitle, "|")
- //fmt.Println(timeSlice[0])
- //对于手动匹配到的活动数据也要更新
- var activityName string
- if len(nameSlice) > 1 {
- //if vAct.JmcjRoadshowTitle != "" {
- // activityName = vAct.JmcjRoadshowTitle
- //} else {
- // activityName = nameSlice[len(nameSlice)-1]
- //}
- activityName = nameSlice[len(nameSlice)-1]
- if activityName != "" {
- //通过名称去找匹配的活动
- activityDetail, _ := models.GetAddActivityInfoByTitle(activityName, findStartDate, findEndDate)
- if activityDetail == nil {
- continue
- } else {
- activityIds += strconv.Itoa(activityDetail.ActivityId) + ","
- }
- list, err := models.GetRoadshowDataList(roadshowTitle, findStartDate, findEndDate)
- if err != nil {
- fmt.Println("GetTacticsList Err:", err.Error())
- return err
- }
- needAddAttendanc := make([]*models.CygxActivityAttendanceDetail, 0)
- var mobileStr string
- if len(list) > 0 {
- fmt.Println("原来的", vAct.RoadshowTitle)
- fmt.Println("处理的", activityName)
- for _, v := range list {
- if v.UserPhone != "" {
- item := new(models.CygxActivityAttendanceDetail)
- item.ActivityId = activityDetail.ActivityId
- item.RealName = v.UserName
- item.Mobile = v.UserPhone
- item.CompanyName = v.Company
- //item.SellerName = sellerName
- item.FirstMeetingTime = v.FirstWatchTime
- item.LastMeetingTime = v.LastWatchTime
- item.Duration = utils.GetAttendanceDetailSeconds(v.JoinTime)
- if v.JoinType == 1 {
- item.MeetingTypeStr = "网络"
- } else {
- item.MeetingTypeStr = "电话"
- }
- item.MeetingAuthentication = v.AuthInfo
- if v.DataType == 1 {
- item.MeetingStatusStr = "直播"
- } else {
- item.MeetingStatusStr = "回放"
- }
- item.Position = v.Occupation
- item.UseridEntity = v.UseridEntity
- item.CreateTime = time.Now()
- mobileStr += "'" + v.UserPhone + "'" + ","
- needAddAttendanc = append(needAddAttendanc, item)
- }
- }
- mobileStr = strings.TrimRight(mobileStr, ",")
- if mobileStr == "" {
- mobileStr = "1"
- }
- listUser, err := models.GetWxUserOutboundMobile(mobileStr)
- if err != nil {
- fmt.Println("GetWxUserOutboundMobile Err:", err.Error())
- return err
- }
- for k, v := range needAddAttendanc {
- for _, v2 := range listUser {
- if v2.OutboundMobile == v.Mobile {
- needAddAttendanc[k].CompanyId = v2.CompanyId
- needAddAttendanc[k].SellerName = v2.SellerName
- needAddAttendanc[k].CompanyName = v2.CompanyName
- needAddAttendanc[k].IsMeetingStr = 1
- }
- }
- }
- //fmt.Println(mobileStr)
- //参会记录
- err = models.AddAttendancDetail(needAddAttendanc, activityDetail.ActivityId, mobileStr)
- if err != nil {
- fmt.Println("AddAttendancDetail Err:", err.Error())
- return err
- }
- ////处理是否限制报名
- err = AddCygxActivityRestrictSignupByAdmin(activityDetail.ActivityId)
- if err != nil {
- fmt.Println("AddCygxActivityRestrictSignupByAdmin Err:", err.Error())
- return err
- }
- }
- }
- }
- }
- //获取需要处理的活动
- listActivity, err := models.GetActivityListByDateTime(startDate, endDate, activityIds)
- if err != nil {
- fmt.Println("GetTacticsList Err:", err.Error())
- return err
- }
- //通过本地去找进门财经的数据
- for _, vAct := range listActivity {
- doTime := utils.TimeRemoveHms2(vAct.ActivityTime)
- findStartDate := doTime + " 00:00:00"
- findEndDate := doTime + " 23:59:59"
- nameSlice := strings.Split(vAct.ActivityName, "】")
- //对于手动匹配到的活动数据也要更新
- var activityName string
- if len(nameSlice) > 1 {
- if vAct.JmcjRoadshowTitle != "" {
- activityName = vAct.JmcjRoadshowTitle
- } else {
- activityName = nameSlice[len(nameSlice)-1]
- }
- //activityName = nameSlice[len(nameSlice)-1]
- if activityName != "" {
- list, err := models.GetRoadshowDataList(activityName, findStartDate, findEndDate)
- if err != nil {
- fmt.Println("GetTacticsList Err:", err.Error())
- return err
- }
- needAddAttendanc := make([]*models.CygxActivityAttendanceDetail, 0)
- var mobileStr string
- if len(list) > 0 {
- fmt.Println("原来的1", vAct.ActivityName)
- fmt.Println("处理的2", activityName)
- for _, v := range list {
- if v.UserPhone != "" {
- item := new(models.CygxActivityAttendanceDetail)
- item.ActivityId = vAct.ActivityId
- item.RealName = v.UserName
- item.Mobile = v.UserPhone
- item.CompanyName = v.Company
- //item.SellerName = sellerName
- item.FirstMeetingTime = v.FirstWatchTime
- item.LastMeetingTime = v.LastWatchTime
- item.Duration = utils.GetAttendanceDetailSeconds(v.JoinTime)
- if v.JoinType == 1 {
- item.MeetingTypeStr = "网络"
- } else {
- item.MeetingTypeStr = "电话"
- }
- item.MeetingAuthentication = v.AuthInfo
- if v.DataType == 1 {
- item.MeetingStatusStr = "直播"
- } else {
- item.MeetingStatusStr = "回放"
- }
- item.Position = v.Occupation
- item.UseridEntity = v.UseridEntity
- item.CreateTime = time.Now()
- mobileStr += "'" + v.UserPhone + "'" + ","
- needAddAttendanc = append(needAddAttendanc, item)
- }
- }
- mobileStr = strings.TrimRight(mobileStr, ",")
- if mobileStr == "" {
- mobileStr = "1"
- }
- listUser, err := models.GetWxUserOutboundMobile(mobileStr)
- if err != nil {
- fmt.Println("GetWxUserOutboundMobile Err:", err.Error())
- return err
- }
- for k, v := range needAddAttendanc {
- for _, v2 := range listUser {
- if v2.OutboundMobile == v.Mobile {
- needAddAttendanc[k].CompanyId = v2.CompanyId
- needAddAttendanc[k].SellerName = v2.SellerName
- needAddAttendanc[k].CompanyName = v2.CompanyName
- needAddAttendanc[k].IsMeetingStr = 1
- }
- }
- }
- //参会记录
- err = models.AddAttendancDetail(needAddAttendanc, vAct.ActivityId, mobileStr)
- if err != nil {
- fmt.Println("AddAttendancDetail Err:", err.Error())
- return err
- }
- ////处理是否限制报名
- err = AddCygxActivityRestrictSignupByAdmin(vAct.ActivityId)
- if err != nil {
- fmt.Println("AddCygxActivityRestrictSignupByAdmin Err:", err.Error())
- return err
- }
- activityIds += strconv.Itoa(vAct.ActivityId) + ","
- }
- }
- }
- }
- activityIds = strings.TrimRight(activityIds, ",")
- if activityIds != "" {
- detailList, err := models.GetActivityAttendanceDetailList(activityIds)
- if err != nil {
- fmt.Println("GetActivityAttendanceDetailList Err:", err.Error())
- return err
- }
- //添加报名日志 (下载使用)
- err = models.AddCygxActivityMeetDetailLogOnlineByList(detailList, activityIds)
- if err != nil {
- fmt.Println("AddCygxActivityMeetDetailLogOnline Err:", err.Error())
- return err
- }
- }
- fmt.Println("结束路演同步")
- return
- }
- //判断是否加入黑名单
- func AddCygxActivityRestrictSignupByAdmin(activityId int) (err error) {
- total, err := models.GetActivitySignupNomeetingCount(activityId)
- if err != nil {
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- fmt.Println(" Err:", err.Error())
- return err
- }
- if total == 0 {
- return err
- }
- mobileList, _ := models.GetUserMeetingMobile(activityId)
- if len(mobileList) >= 0 {
- for _, v := range mobileList {
- totalRestrict, err := models.GetRestrictSignupCountByUid(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- totalNomeet, err := models.GetActivitySignupNomeetingCountByUid(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- if totalRestrict > 0 && totalNomeet < 3 {
- err = models.DeleteCygxActivityRestrictSignup(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- }
- }
- }
- list, err := models.GetActivitySignupNomeetingCountList(activityId)
- if err != nil {
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- fmt.Println(" 用户限制报名失败 Err:", err.Error())
- return err
- }
- for _, v := range list {
- totalRestrict, err := models.GetRestrictSignupCountByUid(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- totalNomeet, err := models.GetActivitySignupNomeetingCountByUid(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- if totalNomeet >= 3 {
- if totalRestrict == 0 {
- infoUser, err := models.GetUserAndCompanyNameList(v.UserId)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- if infoUser != nil {
- item := new(models.CygxActivityRestrictSignup)
- item.UserId = infoUser.UserId
- item.CreateTime = time.Now()
- item.Mobile = infoUser.Mobile
- item.Email = infoUser.Email
- item.CompanyId = infoUser.CompanyId
- item.CompanyName = infoUser.CompanyName
- item.IsRestrict = 1
- err = models.AddCygxActivityRestrictSignup(item)
- if err != nil {
- fmt.Println(" Err:", err.Error())
- utils.FileLog.Info("用户限制报名失败,Err:%s,%s", err.Error())
- return err
- }
- }
- }
- }
- }
- return
- }
- //活动带问提醒
- func SendActivityAskApplyTemplateMsg(applyName, applyTime, askContent, activityName, openId string, activityId int) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- var accessToken string
- if utils.RunMode == "release" {
- accessToken, err = models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- } else {
- accessToken, err = models.GetWxAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- first := "有新的客户提问"
- keyword1 := applyName
- keyword2 := "-"
- keyword3 := applyTime
- keyword4 := askContent
- remark := activityName
- fontColor := "#D9001B"
- sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
- sendData["remark"] = map[string]interface{}{"value": remark, "color": fontColor}
- if utils.RunMode == "release" {
- sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
- } else {
- sendMap["template_id"] = utils.WxMsgTemplateIdApply
- }
- sendMap["miniprogram"] = map[string]interface{}{"appid": utils.WxAppId, "pagepath": "activityPages/activityDetail/activityDetail?id=" + strconv.Itoa(activityId)}
- sendMap["data"] = sendData
- sendTemplateMsg(sendUrl, openId, sendMap)
- fmt.Println("send end")
- return
- }
- //专项产业调研模板消息推送
- func SendSpecialTemplateMsg(applyName, applyTime, mobile, activityName, openId, resource string) (err error) {
- var msg string
- defer func() {
- if err != nil {
- go utils.SendEmail("发送模版消息失败"+time.Now().Format("2006-01-02 15:04:05"), msg+";Err:"+err.Error(), utils.EmailSendToUsers)
- }
- if msg != "" {
- utils.FileLog.Info("发送模版消息失败,msg:%s", msg)
- }
- }()
- var accessToken string
- if utils.RunMode == "release" {
- accessToken, err = models.GetWxAccessTokenByXzs()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- } else {
- accessToken, err = models.GetWxAccessToken()
- if err != nil {
- msg = "GetWxAccessToken Err:" + err.Error()
- return
- }
- if accessToken == "" {
- msg = "accessToken is empty"
- return
- }
- }
- sendUrl := "https://api.weixin.qq.com/cgi-bin/message/template/send?access_token=" + accessToken
- sendMap := make(map[string]interface{})
- sendData := make(map[string]interface{})
- var first string
- if resource == "sale" {
- first = "有客户对专项调研感兴趣"
- } else {
- first = "有5家公司预报名专项调研"
- }
- keyword1 := applyName
- keyword2 := mobile
- keyword3 := applyTime
- keyword4 := activityName
- fontColor := "#D9001B"
- sendData["first"] = map[string]interface{}{"value": first, "color": fontColor}
- sendData["keyword1"] = map[string]interface{}{"value": keyword1, "color": fontColor}
- sendData["keyword2"] = map[string]interface{}{"value": keyword2, "color": fontColor}
- sendData["keyword3"] = map[string]interface{}{"value": keyword3, "color": fontColor}
- sendData["keyword4"] = map[string]interface{}{"value": keyword4, "color": fontColor}
- if utils.RunMode == "release" {
- sendMap["template_id"] = utils.WxMsgTemplateIdApplyXzs
- } else {
- sendMap["template_id"] = utils.WxMsgTemplateIdApply
- }
- sendMap["data"] = sendData
- sendTemplateMsg(sendUrl, openId, sendMap)
- return
- }
|