everything.go 36 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024
  1. package main
  2. import (
  3. "app.yhyue.com/moapp/jybase/redis"
  4. "encoding/json"
  5. "fmt"
  6. "github.com/gogf/gf/util/gconv"
  7. "log"
  8. "net/url"
  9. "strings"
  10. "time"
  11. "app.yhyue.com/moapp/jybase/mail"
  12. "github.com/tealeg/xlsx"
  13. "app.yhyue.com/moapp/jybase/date"
  14. dates "app.yhyue.com/moapp/jybase/date"
  15. "app.yhyue.com/moapp/jybase/mongodb"
  16. "app.yhyue.com/moapp/jybase/common"
  17. )
  18. func everythingSync() {
  19. lastEverythingTime := cfg.LastEverythingTime
  20. nowTime := time.Now().Format(dates.Date_Full_Layout)
  21. sql := fmt.Sprintf(`select * from user_source where channel_code = "JyChCoopA" and create_time > "%s" order by create_time asc`, lastEverythingTime)
  22. log.Println("三方渠道数据定时任务开始", sql)
  23. data := ThirdParty.SelectBySql(sql)
  24. if data != nil && *data != nil && len(*data) > 0 {
  25. for _, v := range *data {
  26. user_id := common.ObjToString(v["user_id"])
  27. position_id := common.Int64All(v["position_id"])
  28. phone := common.ObjToString(v["phone"])
  29. state := common.IntAll(v["state"])
  30. user_mold, is_assign, is_transfer, last_login_time, registe_time, mailbox, source, clueId, order_type := 4, 0, 0, "", "", "", "", int64(0), ""
  31. owner, sales_lead_phone, sales_ent_name, sales_position, sales_dep, data_request, unique_id, belongTo, sales_leads_source := "", "", "", "", "", "", "", "", ""
  32. cData := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"phone": phone}, "", "")
  33. if cData != nil {
  34. is_assign = common.IntAll((*cData)["is_assign"])
  35. is_transfer = common.IntAll((*cData)["is_transfer"])
  36. clueId = common.Int64All((*cData)["id"])
  37. }
  38. //
  39. udata := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{"userid": user_id}, "", "")
  40. if udata != nil {
  41. userSource := common.ObjToString((*udata)["source"])
  42. if userSource == "0102" {
  43. continue
  44. }
  45. }
  46. //
  47. /*cuData := TiDbData.FindOne("customer", map[string]interface{}{"phone": phone}, "", "")
  48. if cuData != nil {
  49. owner = common.ObjToString((*cuData)["owner"])
  50. unique_id = common.ObjToString((*cuData)["unique_id"])
  51. belongTo = common.ObjToString((*cuData)["belongTo"])
  52. }*/
  53. vData := TiDb.FindOne("dwd_f_userbase_visit_info", map[string]interface{}{"userid": user_id}, "", "")
  54. if vData != nil {
  55. last_login_time = common.ObjToString((*vData)["date"])
  56. }
  57. dData := Mysql.Find("dataexport_order", map[string]interface{}{"user_id": user_id}, "", "", -1, -1)
  58. if dData != nil && len(*dData) > 0 {
  59. pMap := map[string]string{}
  60. pArr := []string{}
  61. for _, v := range *dData {
  62. product_type := common.ObjToString(v["product_type"])
  63. pMap[product_type] = "1"
  64. }
  65. for k := range pMap {
  66. pArr = append(pArr, k)
  67. }
  68. if len(pArr) > 0 {
  69. order_type = strings.Join(pArr, ",")
  70. }
  71. }
  72. uData, ok := Mgo.FindOne("user", map[string]interface{}{"_id": mongodb.StringTOBsonId(user_id)})
  73. if ok && uData != nil {
  74. l_registedate := common.Int64All((*uData)["l_registedate"])
  75. registe_time = time.Unix(l_registedate, 0).Format(dates.Date_Full_Layout)
  76. }
  77. sData, oks := Mgo.Find("saleLeads", map[string]interface{}{"userid": user_id}, `{"_id":-1}`, nil, false, 0, 1)
  78. if oks && sData != nil {
  79. if len(*sData) > 0 {
  80. sDatas := (*sData)[0]
  81. sales_lead_phone = common.ObjToString(sDatas["phone"])
  82. sales_position = common.ObjToString(sDatas["position"])
  83. sales_ent_name = common.ObjToString(sDatas["company"])
  84. sales_dep = common.ObjToString(sDatas["branch"])
  85. if sales_dep == "" {
  86. sales_dep = common.ObjToString(sDatas["department"])
  87. }
  88. data_request = common.ObjToString(sDatas["data_requirement"])
  89. mailbox = common.ObjToString(sDatas["mail"])
  90. source = common.ObjToString(sDatas["interest"])
  91. }
  92. }
  93. if state == 1 {
  94. sales_leads_source = "一切都好登录"
  95. if is_assign == 1 || is_transfer == 1 || owner != "" {
  96. user_mold = 1
  97. } else {
  98. user_mold = 2
  99. }
  100. } else if state == 2 {
  101. sales_leads_source = "一切都好注册"
  102. if is_assign == 1 || is_transfer == 1 || owner != "" {
  103. user_mold = 3
  104. } else {
  105. user_mold = 4
  106. }
  107. }
  108. if owner == "" && unique_id != "" && belongTo == "市场部" {
  109. token := getToken()
  110. if token != "" {
  111. sss := url.QueryEscape("合作渠道一切都好")
  112. urls := `https://a1.7x24cc.com/commonInte?flag=1008&account=N000000029739&accessToken=` + token + `&cusObj={"unique_id":"` + unique_id + `","empNo":"8049","owner":"8049","source":"` + sss + `"}&dbType=0001`
  113. bs, err := doGet(urls)
  114. if err != nil {
  115. log.Println("调用接口失败", unique_id, err)
  116. }
  117. resMap := common.StringToMap(string(bs))
  118. if resMap["success"] != nil && resMap["success"].(bool) {
  119. /*ok := TiDbData.Update("customer", map[string]interface{}{"unique_id": unique_id}, map[string]interface{}{"empNo": "8049", "owner": "8049", "source": "合作渠道一切都好"})
  120. if ok {
  121. log.Println("更新成功", unique_id)
  122. } else {
  123. log.Println("更新失败", unique_id)
  124. }*/
  125. } else {
  126. log.Println("调用接口失败!!", unique_id)
  127. }
  128. }
  129. }
  130. if ThirdParty.Count("user_channel_info", map[string]interface{}{"user_id": user_id}) > 0 {
  131. ThirdParty.Update("user_channel_info", map[string]interface{}{"user_id": user_id}, map[string]interface{}{
  132. "user_mold": user_mold,
  133. "last_login_time": common.If(last_login_time != "", last_login_time, nil),
  134. "sales_lead_phone": sales_lead_phone,
  135. "sales_ent_name": sales_ent_name,
  136. "sales_position": sales_position,
  137. "sales_dep": sales_dep,
  138. "sales_leads_source": sales_leads_source,
  139. "mailbox": mailbox,
  140. "order_type": order_type,
  141. "data_request": data_request,
  142. "source": source,
  143. "update_time": nowTime,
  144. })
  145. } else {
  146. ThirdParty.Insert("user_channel_info", map[string]interface{}{
  147. "user_id": user_id,
  148. "registe_time": registe_time,
  149. "phone": phone,
  150. "user_mold": user_mold,
  151. "last_login_time": common.If(last_login_time != "", last_login_time, nil),
  152. "sales_lead_phone": sales_lead_phone,
  153. "sales_ent_name": sales_ent_name,
  154. "sales_position": sales_position,
  155. "sales_dep": sales_dep,
  156. "sales_leads_source": sales_leads_source,
  157. "order_type": order_type,
  158. "mailbox": mailbox,
  159. "data_request": data_request,
  160. "source": source,
  161. "update_time": nowTime,
  162. })
  163. }
  164. if clueId > 0 && is_assign != 1 && is_transfer != 1 {
  165. TiDb.Update("dwd_f_userbase_baseinfo", map[string]interface{}{"userid": user_id}, map[string]interface{}{"belong_to": "0301"})
  166. TiDb.Update("dwd_f_crm_clue_info", map[string]interface{}{"phone": phone}, map[string]interface{}{"is_assign": -1})
  167. TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
  168. "clue_id": clueId,
  169. "position_id": common.If(position_id > 0, position_id, -1),
  170. "change_type": "退出公海",
  171. "new_value": "通过合作渠道一切就好" + fmt.Sprint(common.If(user_mold == 1 || user_mold == 2, "登录", "注册")),
  172. "createtime": nowTime,
  173. "BCPCID": common.GetRandom(32),
  174. "operator_id": -1,
  175. })
  176. }
  177. }
  178. cfg.LastEverythingTime = common.ObjToString((*data)[len(*data)-1]["create_time"])
  179. }
  180. common.WriteSysConfig(&cfg)
  181. log.Println("三方渠道数据定时任务结束")
  182. }
  183. func saveEverything(user_id, phone, item, sourceName, sourceCode string) bool {
  184. nowTime, isOk := time.Now().Format(dates.Date_Full_Layout), false
  185. user_mold, is_assign, is_transfer, last_login_time, registe_time, mailbox, source, order_type, sales_leads_source := 4, 0, 0, "", "", "", "", "", ""
  186. owner, sales_lead_phone, sales_ent_name, sales_position, sales_dep, data_request, unique_id, belongTo, clueId, position_id := "", "", "", "", "", "", "", "", int64(0), int64(0)
  187. cData := TiDb.FindOne("dwd_f_crm_clue_info", map[string]interface{}{"phone": phone}, "", "")
  188. if cData != nil {
  189. is_assign = common.IntAll((*cData)["is_assign"])
  190. is_transfer = common.IntAll((*cData)["is_transfer"])
  191. clueId = common.Int64All((*cData)["is_transfer"])
  192. position_id = common.Int64All((*cData)["position_id"])
  193. }
  194. /*cuData := TiDbData.FindOne("customer", map[string]interface{}{"phone": phone}, "", "")
  195. if cuData != nil {
  196. unique_id = common.ObjToString((*cuData)["unique_id"])
  197. owner = common.ObjToString((*cuData)["owner"])
  198. }*/
  199. dData := Mysql.Find("dataexport_order", map[string]interface{}{"user_id": user_id}, "", "", -1, -1)
  200. if dData != nil && len(*dData) > 0 {
  201. pMap := map[string]string{}
  202. pArr := []string{}
  203. for _, v := range *dData {
  204. product_type := common.ObjToString(v["product_type"])
  205. pMap[product_type] = "1"
  206. }
  207. for k := range pMap {
  208. pArr = append(pArr, k)
  209. }
  210. if len(pArr) > 0 {
  211. order_type = strings.Join(pArr, ",")
  212. }
  213. }
  214. vData := TiDb.FindOne("dwd_f_userbase_visit_info", map[string]interface{}{"userid": user_id}, "", "")
  215. if vData != nil {
  216. last_login_time = common.ObjToString((*vData)["date"])
  217. }
  218. uData, ok := Mgo.FindOne("user", map[string]interface{}{"_id": mongodb.StringTOBsonId(user_id)})
  219. if ok && uData != nil {
  220. l_registedate := common.Int64All((*uData)["l_registedate"])
  221. registe_time = time.Unix(l_registedate, 0).Format(dates.Date_Full_Layout)
  222. }
  223. if item == "orders" {
  224. sales_leads_source = "订单未支付"
  225. } else if item == "users" || item == "xcxusers" {
  226. return false
  227. } else if item == "saleLeads" {
  228. sales_leads_source = sourceName
  229. } else {
  230. sales_leads_source = "用户留资"
  231. }
  232. query := map[string]interface{}{"userid": user_id}
  233. if sourceCode != "" {
  234. query["source"] = sourceCode
  235. }
  236. sData, oks := Mgo.Find("saleLeads", query, `{"_id":-1}`, nil, false, 0, 1)
  237. if oks && sData != nil {
  238. if len(*sData) > 0 {
  239. sDatas := (*sData)[0]
  240. sales_lead_phone = common.ObjToString(sDatas["phone"])
  241. sales_position = common.ObjToString(sDatas["position"])
  242. sales_ent_name = common.ObjToString(sDatas["company"])
  243. sales_dep = common.ObjToString(sDatas["branch"])
  244. if sales_dep == "" {
  245. sales_dep = common.ObjToString(sDatas["department"])
  246. }
  247. data_request = common.ObjToString(sDatas["data_requirement"])
  248. mailbox = common.ObjToString(sDatas["mail"])
  249. source = common.ObjToString(sDatas["interest"])
  250. }
  251. }
  252. if is_assign == 1 || is_transfer == 1 || owner != "" {
  253. user_mold = 1
  254. } else {
  255. user_mold = 2
  256. }
  257. if owner == "" && unique_id != "" && belongTo == "市场部" {
  258. token := getToken()
  259. if token != "" {
  260. sss := url.QueryEscape("合作渠道一切都好")
  261. urls := `https://a1.7x24cc.com/commonInte?flag=1008&account=N000000029739&accessToken=` + token + `&cusObj={"unique_id":"` + unique_id + `","empNo":"8049","owner":"8049","source":"` + sss + `"}&dbType=0001`
  262. bs, err := doGet(urls)
  263. if err != nil {
  264. log.Println("调用接口失败", unique_id, err)
  265. }
  266. resMap := common.StringToMap(string(bs))
  267. if resMap["success"] != nil && resMap["success"].(bool) {
  268. ok := TiDbData.Update("customer", map[string]interface{}{"unique_id": unique_id}, map[string]interface{}{"empNo": "8049", "owner": "8049", "source": "合作渠道一切都好"})
  269. if ok {
  270. log.Println("更新成功", unique_id)
  271. } else {
  272. log.Println("更新失败", unique_id)
  273. }
  274. } else {
  275. log.Println("调用接口失败!!", unique_id)
  276. }
  277. }
  278. }
  279. if ThirdParty.Count("user_channel_info", map[string]interface{}{"user_id": user_id}) > 0 {
  280. ThirdParty.Update("user_channel_info", map[string]interface{}{"user_id": user_id}, map[string]interface{}{
  281. "user_mold": user_mold,
  282. "last_login_time": common.If(last_login_time != "", last_login_time, nil),
  283. "sales_lead_phone": sales_lead_phone,
  284. "sales_ent_name": sales_ent_name,
  285. "sales_position": sales_position,
  286. "sales_dep": sales_dep,
  287. "sales_leads_source": sales_leads_source,
  288. "mailbox": mailbox,
  289. "data_request": data_request,
  290. "source": source,
  291. "order_type": order_type,
  292. "update_time": nowTime,
  293. })
  294. } else {
  295. ThirdParty.Insert("user_channel_info", map[string]interface{}{
  296. "user_id": user_id,
  297. "registe_time": registe_time,
  298. "phone": phone,
  299. "user_mold": user_mold,
  300. "last_login_time": common.If(last_login_time != "", last_login_time, nil),
  301. "sales_lead_phone": sales_lead_phone,
  302. "sales_ent_name": sales_ent_name,
  303. "sales_position": sales_position,
  304. "sales_dep": sales_dep,
  305. "sales_leads_source": sales_leads_source,
  306. "mailbox": mailbox,
  307. "data_request": data_request,
  308. "order_type": order_type,
  309. "source": source,
  310. "update_time": nowTime,
  311. })
  312. }
  313. if clueId > 0 && is_assign != 1 && is_transfer != 1 {
  314. TiDb.Update("dwd_f_crm_clue_info", map[string]interface{}{"phone": phone}, map[string]interface{}{"is_assign": -1})
  315. TiDb.Insert("dwd_f_crm_clue_change_record", map[string]interface{}{
  316. "clue_id": clueId,
  317. "position_id": common.If(position_id > 0, position_id, -1),
  318. "change_type": "退出公海",
  319. "new_value": "通过合作渠道一切就好登录",
  320. "createtime": nowTime,
  321. "BCPCID": common.GetRandom(32),
  322. "operator_id": -1,
  323. })
  324. } else if is_assign == 1 || is_transfer == 1 {
  325. isOk = true
  326. }
  327. return isOk
  328. }
  329. // 大客户线索-发邮件
  330. func bigCustomer() {
  331. runOk := getRunOk()
  332. if !runOk {
  333. log.Println("不是工作日,任务暂停")
  334. return
  335. }
  336. log.Println("大客户线索定时任务开始")
  337. dataArr := []map[string]interface{}{}
  338. filterArr := []string{"-pc", "-app", "-wx", "-h5"}
  339. sourceMap := map[string]map[string]interface{}{} //根据留资维表:tidb/Jianyu_subjectdb/d_saleleads_code
  340. saleSource := TiDb.SelectBySql(`SELECT source,name,appoint_email FROM d_saleleads_code WHERE department LIKE '%大客户%' AND is_delete = 1`)
  341. if saleSource != nil && len(*saleSource) > 0 {
  342. for _, v := range *saleSource {
  343. saleSourceMap := v
  344. source := common.ObjToString(v["source"])
  345. name := common.ObjToString(v["name"])
  346. for _, s := range filterArr {
  347. name = strings.ReplaceAll(name, s, "")
  348. }
  349. saleSourceMap["name"] = name
  350. sourceMap[source] = saleSourceMap
  351. }
  352. }
  353. nowTime := time.Now().Format(date.Date_Full_Layout)
  354. bigSaleTime := cfg.BigSaleTime
  355. bigOrderTime := cfg.BigOrderTime
  356. if bigSaleTime == 0 {
  357. bigSaleTime = time.Now().Unix()
  358. }
  359. if bigOrderTime == "" {
  360. bigOrderTime = nowTime
  361. }
  362. data := FindBatchData("dk")
  363. saleleadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"createtime": map[string]interface{}{"$gt": bigSaleTime}}, `{"phone":1,"createtime":1}`, nil, false, -1, -1)
  364. if ok && saleleadsData != nil && len(*saleleadsData) > 0 {
  365. for _, v := range *saleleadsData {
  366. sources := common.ObjToString(v["source"])
  367. userid := common.ObjToString(v["userid"])
  368. uid := ""
  369. if !mongodb.IsObjectIdHex(userid) {
  370. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userid}, "", "")
  371. if userMapping != nil && len(*userMapping) > 0 {
  372. userid = common.ObjToString((*userMapping)["userid"])
  373. uid = common.ObjToString((*userMapping)["uid"])
  374. }
  375. } else {
  376. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"userid": userid}, "", "")
  377. if userMapping != nil && len(*userMapping) > 0 {
  378. userid = common.ObjToString((*userMapping)["userid"])
  379. uid = common.ObjToString((*userMapping)["uid"])
  380. }
  381. }
  382. if sourceMap[sources] != nil {
  383. sourceData := sourceMap[sources]
  384. source := sourceData["name"]
  385. phone := common.ObjToString(v["phone"])
  386. if IsInternal(phone) {
  387. continue
  388. }
  389. key := fmt.Sprintf("%s_%s", source, phone)
  390. if _, ok := data[key]; ok {
  391. continue
  392. }
  393. data[key] = true
  394. company := common.ObjToString(v["company"])
  395. job := common.ObjToString(v["position"])
  396. username := common.ObjToString(v["name"])
  397. email := common.ObjToString(v["mail"])
  398. interest := common.ObjToString(v["interest"])
  399. data_requirement := common.ObjToString(v["data_requirement"])
  400. belongTo, usernickname := "大客户", ""
  401. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{"uid": uid}, "", "")
  402. if userData != nil {
  403. usernickname = common.ObjToString((*userData)["nickname"])
  404. bt := common.ObjToString((*userData)["belong_to"])
  405. if strings.HasPrefix(bt, "03") || bt == "0102" {
  406. continue
  407. }
  408. }
  409. dataArr = append(dataArr, map[string]interface{}{
  410. "createTime": nowTime,
  411. "lastUpdateTime": nowTime,
  412. "uid": uid,
  413. "userid": userid,
  414. "username": username,
  415. "usernickname": usernickname,
  416. "company": company,
  417. "job": job,
  418. "phone": phone,
  419. "email": email,
  420. "source": source,
  421. "belongTo": belongTo,
  422. "interest": interest,
  423. "data_requirement": data_requirement,
  424. "appoint_email": sourceData["appoint_email"],
  425. })
  426. }
  427. if gconv.Int64(v["createtime"]) > bigSaleTime {
  428. bigSaleTime = gconv.Int64(v["createtime"])
  429. }
  430. }
  431. }
  432. cfg.BigSaleTime = bigSaleTime
  433. orderData := Mysql.SelectBySql(`SELECT * FROM dataexport_order WHERE create_time > "` + bigOrderTime + `" AND (product_type = '历史数据' or product_type = '数据流量包') AND order_status IN (0,1) AND salesperson IS NULL AND is_backstage_order = 0`)
  434. if orderData != nil && len(*orderData) > 0 {
  435. for _, v := range *orderData {
  436. bigOrderTime = gconv.Time(gconv.String(v["create_time"])).Format(date.Date_Full_Layout)
  437. phone := common.ObjToString(v["user_phone"])
  438. order_status := common.IntAll(v["order_status"])
  439. product_type := common.ObjToString(v["product_type"])
  440. orderUserId := gconv.String(v["user_id"])
  441. query := map[string]interface{}{}
  442. if !mongodb.IsObjectIdHex(orderUserId) {
  443. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": orderUserId}, "", "")
  444. if userMapping != nil && len(*userMapping) > 0 {
  445. uid := common.ObjToString((*userMapping)["uid"])
  446. query["uid"] = uid
  447. }
  448. } else {
  449. query["userid"] = orderUserId
  450. }
  451. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
  452. username, usernickname, userid, uid, source, payorderinfo, unpayorderinfo := "", "", "", "", "", "", ""
  453. if userData != nil {
  454. if phone == "" {
  455. phone = common.ObjToString((*userData)["phone"])
  456. }
  457. if IsInternal(phone) {
  458. continue
  459. }
  460. username = common.ObjToString((*userData)["name"])
  461. usernickname = common.ObjToString((*userData)["nickname"])
  462. uid = common.ObjToString((*userData)["uid"])
  463. userid = common.ObjToString((*userData)["userid"])
  464. bt := common.ObjToString((*userData)["belong_to"])
  465. if strings.HasPrefix(bt, "03") || bt == "0102" {
  466. continue
  467. }
  468. }
  469. if product_type == "历史数据" {
  470. if order_status == 0 {
  471. source = "线上历史数据导出未支付订单"
  472. unpayorderinfo = "历史数据"
  473. } else {
  474. source = "线上历史数据导出已支付订单"
  475. payorderinfo = "历史数据" + fmt.Sprint(common.IntAll(v["pay_money"])/100)
  476. }
  477. } else {
  478. if order_status == 0 {
  479. source = "线上数据流量包未支付订单"
  480. unpayorderinfo = "数据流量包"
  481. } else {
  482. source = "线上数据流量包已支付订单"
  483. payorderinfo = "数据流量包" + fmt.Sprint(common.IntAll(v["pay_money"])/100)
  484. }
  485. }
  486. key := fmt.Sprintf("%s_%s", source, phone)
  487. if _, ok := data[key]; ok {
  488. continue
  489. }
  490. data[key] = true
  491. dataArr = append(dataArr, map[string]interface{}{
  492. "createTime": nowTime,
  493. "lastUpdateTime": nowTime,
  494. "phone": phone,
  495. "username": username,
  496. "usernickname": usernickname,
  497. "uid": uid,
  498. "userid": userid,
  499. "company": v["company_name"],
  500. "email": v["user_mail"],
  501. "belongTo": "大客户",
  502. "source": source,
  503. "data_count": v["data_count"],
  504. "unpayorderinfo": unpayorderinfo,
  505. "payorderinfo": payorderinfo, //增加客户需求
  506. "appoint_email": "",
  507. })
  508. }
  509. cfg.BigOrderTime = bigOrderTime
  510. }
  511. saveDataToRedis(data, "dk")
  512. xlsxArr := []string{"用户昵称", "姓名", "公司名称", "职位", "联系人电话", "购买条数", "用户邮箱", "已支付订单信息", "未支付订单类型", "销售线索来源", "具体来源", "数据需求"}
  513. if len(dataArr) > 0 {
  514. bigArr := map[string][]map[string]interface{}{}
  515. for _, v := range dataArr {
  516. minemail := ""
  517. if gconv.String(v["appoint_email"]) == "" {
  518. minemail, _ = EmailSelect("dk", "")
  519. } else {
  520. minemail = gconv.String(v["appoint_email"])
  521. }
  522. bigArr[minemail] = append(bigArr[minemail], v)
  523. }
  524. for k, vb := range bigArr {
  525. batch := FindBatch("dk")
  526. fileName, detailName := time.Now().Format(date.Date_Short_Layout)+"-"+batch+"大客户销售线索", ""
  527. xf := xlsx.NewFile()
  528. style := xlsx.NewStyle()
  529. style.Font.Size = 12
  530. style.Font.Bold = true
  531. style.Alignment.Vertical = "center"
  532. style.Alignment.Horizontal = "center"
  533. detailName = time.Now().Format(date.Date_Short_Layout) + "数据详情请查看附件"
  534. sh, _ := xf.AddSheet("线索数据")
  535. row1 := sh.AddRow()
  536. for _, x := range xlsxArr {
  537. cell := row1.AddCell()
  538. cell.SetString(x)
  539. cell.SetStyle(style)
  540. }
  541. for _, v := range vb {
  542. row := sh.AddRow()
  543. row.AddCell().SetString(common.ObjToString(v["usernickname"]))
  544. row.AddCell().SetString(common.ObjToString(v["username"]))
  545. row.AddCell().SetString(common.ObjToString(v["company"]))
  546. row.AddCell().SetString(common.ObjToString(v["job"]))
  547. row.AddCell().SetString(common.ObjToString(v["phone"]))
  548. row.AddCell().SetValue(common.IntAll(v["data_count"]))
  549. row.AddCell().SetString(common.ObjToString(v["email"]))
  550. row.AddCell().SetString(common.ObjToString(v["payorderinfo"]))
  551. row.AddCell().SetString(common.ObjToString(v["unpayorderinfo"]))
  552. row.AddCell().SetString(common.ObjToString(v["source"]))
  553. row.AddCell().SetString(common.ObjToString(v["interest"]))
  554. row.AddCell().SetString(common.ObjToString(v["data_requirement"]))
  555. //增加客户需求
  556. }
  557. email := k
  558. //email = "wanghao@jianyu360.com"
  559. dir := "./xlsx/dk/" + fileName + ".xlsx"
  560. err := xf.Save(dir)
  561. if err != nil {
  562. log.Println("xls error", err, dir)
  563. } else {
  564. status := mail.GSendMail_q("剑鱼标讯", email, "", "", fileName, detailName, dir, fileName+".xlsx", &Gmail)
  565. if status {
  566. log.Println("send mail success", fileName, email)
  567. }
  568. }
  569. }
  570. }
  571. common.WriteSysConfig(&cfg)
  572. log.Println("大客户线索定时任务结束")
  573. }
  574. func IsInternal(phone string) bool {
  575. if DataAnalysisService.Count("dwd_f_userbase_insider", map[string]interface{}{
  576. "mobile": phone,
  577. }) > 0 {
  578. return true
  579. }
  580. return false
  581. }
  582. func eventReg() {
  583. lastEventRegTime := cfg.LastEventRegTime
  584. sql := fmt.Sprintf(`select * from exhibition_sign_up where is_del = 0 and update_time > "%s" order by update_time asc`, lastEventRegTime)
  585. log.Println("活动报名表定时任务开始", sql)
  586. data := Jyactivities.SelectBySql(sql)
  587. if data != nil && *data != nil && len(*data) > 0 {
  588. for _, v := range *data {
  589. ok1, ok2, _ := FormatData(v, "eventReg")
  590. if !ok1 {
  591. common.WriteSysConfig(&cfg)
  592. log.Println("线索卡点", "eventReg", v, lastEventRegTime)
  593. } else {
  594. if !ok2 {
  595. log.Println("用户分配已达上限", "eventReg", v, lastEventRegTime)
  596. common.WriteSysConfig(&cfg)
  597. }
  598. }
  599. cfg.LastEventRegTime = common.ObjToString(v["update_time"])
  600. }
  601. }
  602. common.WriteSysConfig(&cfg)
  603. log.Println("活动报名表定时任务结束")
  604. }
  605. func saveHlyj(belong_to, item, phone, name, sourceName, cluename, position, nowTime string, isGroup, isCommerce int) {
  606. if strings.HasPrefix(belong_to, "02") && item == "eventReg" {
  607. saveMap := map[string]interface{}{
  608. "unique_id": phone,
  609. "phone": phone,
  610. "username": name,
  611. "source": sourceName,
  612. "status999": "status5",
  613. "company": cluename,
  614. "job": position,
  615. "belongTo": "市场部",
  616. "createTime": nowTime,
  617. "lastUpdateTime": nowTime,
  618. }
  619. token := getToken()
  620. updateData := map[string]interface{}{
  621. "dbType": "0001",
  622. "customerList": []map[string]interface{}{saveMap},
  623. }
  624. dataByte, _ := json.Marshal(&updateData)
  625. url := `https://a1.7x24cc.com/commonInte?flag=1007&account=N000000029739&accessToken=` + token + `&json=` + url.QueryEscape(string(dataByte))
  626. bs, err := doGet(url)
  627. if err != nil {
  628. log.Println("调用接口失败")
  629. } else {
  630. resMap := common.StringToMap(string(bs))
  631. if resMap["success"] != nil && resMap["success"].(bool) {
  632. saveMap["company_nature"] = isGroup
  633. saveMap["company_verification"] = isCommerce
  634. TiDbData.Insert("customer", saveMap)
  635. } else {
  636. log.Println("新增线索失败")
  637. }
  638. }
  639. }
  640. }
  641. func FindBatch(moudle string) string {
  642. now := time.Now().Format("2006-01-02")
  643. key := fmt.Sprintf("batch_%s_%s", now, moudle)
  644. yesterday := time.Now().AddDate(0, 0, -1).Format("2006-01-02")
  645. yesterdayKey := fmt.Sprintf("batch_%s_%s", yesterday, moudle)
  646. if ok, _ := redis.Exists("newother", yesterdayKey); ok {
  647. //删除之前数据
  648. redis.Del("newother", yesterdayKey)
  649. }
  650. batch := redis.Incr("newother", key)
  651. return fmt.Sprintf("%04d", batch)
  652. }
  653. func FindBatchData(moudle string) map[string]interface{} {
  654. now := time.Now().Format("2006-01-02")
  655. //数据提取
  656. keyContent := fmt.Sprintf("data_%s_%s", now, moudle)
  657. data := redis.Get("newother", keyContent)
  658. if data == nil {
  659. return make(map[string]interface{})
  660. } else {
  661. return gconv.Map(data)
  662. }
  663. }
  664. // 咨询组线索
  665. func AdvisoryCommittee() {
  666. /*if !isRunning() {
  667. log.Println("不是工作日,任务暂停")
  668. return
  669. }
  670. log.Println("咨询部线索定时任务开始")
  671. sourceMap := buildSourceMap("咨询组")
  672. nowTime := time.Now().Format(date.Date_Full_Layout)
  673. startTime := getCommitteeTime(cfg.AdvisoryCommitteeTime)
  674. dataArr, endtime := processLeads("zx", startTime, sourceMap, nowTime)
  675. cfg.AdvisoryCommitteeTime = endtime
  676. exportToExcel(dataArr, "咨询服务销售线索", "zx")
  677. log.Println("咨询部线索定时任务结束")
  678. common.WriteSysConfig(&cfg)*/
  679. }
  680. // 运营部线索
  681. /*func SelectionDepartment() {
  682. if !isRunning() {
  683. log.Println("不是工作日,任务暂停")
  684. return
  685. }
  686. log.Println("运营部线索定时任务开始")
  687. sourceMap := buildSourceMap("运营部")
  688. nowTime := time.Now().Format(date.Date_Full_Layout)
  689. startTime := getCommitteeTime(cfg.SelectionDepartmentTime)
  690. dataArr, endtime := processLeads("yy", startTime, sourceMap, nowTime)
  691. cfg.SelectionDepartmentTime = endtime
  692. exportToExcel(dataArr, "运营部销售线索", "yy")
  693. log.Println("运营部线索定时任务结束")
  694. common.WriteSysConfig(&cfg)
  695. }
  696. */
  697. // 特殊留资
  698. func SpecialSaleLeads() {
  699. /*if !isRunning() {
  700. log.Println("不是工作日,任务暂停")
  701. return
  702. }*/
  703. saleLeadsConfig := TiDb.Find("saleLeads_config", map[string]interface{}{
  704. "status": 0,
  705. }, "", "", -1, -1)
  706. log.Println("特殊留资线索定时任务开始")
  707. for _, v := range *saleLeadsConfig {
  708. log.Println(fmt.Sprintf("%s留资线索定时任务开始", gconv.String(v["groupName"])))
  709. //留来源获取
  710. sourceMap := buildSourceMap(gconv.String(v["groupName"]))
  711. dataArr, endtime := processLeads(v, sourceMap)
  712. //最后一次数据修改
  713. TiDb.Update("saleLeads_config", map[string]interface{}{
  714. "id": gconv.Int64(v["id"]),
  715. }, map[string]interface{}{
  716. "lastTime": endtime,
  717. })
  718. exportToExcel(dataArr, gconv.String(v["title"]), gconv.String(v["groupCode"]), gconv.String(v["mail"]))
  719. log.Println(fmt.Sprintf("%s留资线索定时任务结束", gconv.String(v["groupName"])))
  720. }
  721. log.Println("特殊留资线索定时任务结束")
  722. }
  723. // 市场部线索
  724. func MarketCustomer() {
  725. /*if !isRunning() {
  726. log.Println("不是工作日,任务暂停")
  727. return
  728. }
  729. log.Println("市场部线索定时任务开始")
  730. sourceMap := buildSourceMap("市场组")
  731. nowTime := time.Now().Format(date.Date_Full_Layout)
  732. startTime := getCommitteeTime(cfg.MarketSaleTime)
  733. dataArr, endtime := processLeads("sc", startTime, sourceMap, nowTime)
  734. cfg.MarketSaleTime = endtime
  735. exportToExcel(dataArr, "商务合作销售线索", "sc")
  736. common.WriteSysConfig(&cfg)
  737. log.Println("市场部线索定时任务结束")*/
  738. }
  739. // 判断是否在工作日
  740. func isRunning() bool {
  741. return getRunOk()
  742. }
  743. // 从数据库构建来源映射
  744. func buildSourceMap(department string) map[string]map[string]interface{} {
  745. sourceMap := map[string]map[string]interface{}{}
  746. saleSource := TiDb.SelectBySql(fmt.Sprintf(`SELECT source,name,appoint_email FROM d_saleleads_code WHERE department LIKE '%%%s%%' AND is_delete = 1`, department))
  747. if saleSource != nil {
  748. for _, v := range *saleSource {
  749. source := common.ObjToString(v["source"])
  750. name := common.ObjToString(v["name"])
  751. name = filterSourceName(name)
  752. appointEmail := common.ObjToString(v["appoint_email"])
  753. sourceMap[source] = map[string]interface{}{
  754. "name": name,
  755. "appointEmail": appointEmail,
  756. }
  757. }
  758. }
  759. return sourceMap
  760. }
  761. // 过滤来源名称
  762. func filterSourceName(name string) string {
  763. filterArr := []string{"-pc", "-app", "-wx", "-h5"}
  764. for _, s := range filterArr {
  765. name = strings.ReplaceAll(name, s, "")
  766. }
  767. return name
  768. }
  769. // 获取最后一条数据时间
  770. func getCommitteeTime(cfgTime int64) int64 {
  771. if cfgTime == 0 {
  772. return time.Now().Unix()
  773. }
  774. return cfgTime
  775. }
  776. // 处理留资信息
  777. func processLeads(saleLeadsMap map[string]interface{}, sourceMap map[string]map[string]interface{}) ([]map[string]interface{}, int64) {
  778. batch := gconv.String(saleLeadsMap["groupCode"])
  779. lastTime := gconv.Int64(saleLeadsMap["lastTime"])
  780. dataArr := []map[string]interface{}{}
  781. endtime := int64(0)
  782. saleleadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"createtime": map[string]interface{}{"$gt": lastTime}}, `{"phone":1,"createtime":1}`, nil, false, -1, -1)
  783. if ok && saleleadsData != nil {
  784. data := FindBatchData(batch)
  785. for _, v := range *saleleadsData {
  786. lead := map[string]interface{}{}
  787. lead, endtime = processLead(v, sourceMap, lastTime, data)
  788. if lead != nil {
  789. dataArr = append(dataArr, lead)
  790. }
  791. }
  792. saveDataToRedis(data, batch)
  793. }
  794. return dataArr, endtime
  795. }
  796. // 处理单个留资信息
  797. func processLead(v map[string]interface{}, sourceMap map[string]map[string]interface{}, lastTime int64, data map[string]interface{}) (map[string]interface{}, int64) {
  798. nowTime := time.Now().Format(date.Date_Full_Layout)
  799. sources := common.ObjToString(v["source"])
  800. // 更新最后会时间
  801. if gconv.Int64(v["createtime"]) > lastTime {
  802. lastTime = gconv.Int64(v["createtime"])
  803. }
  804. sourceData, exist := sourceMap[sources]
  805. if !exist {
  806. return nil, lastTime
  807. }
  808. phone := common.ObjToString(v["phone"])
  809. if IsInternal(phone) {
  810. return nil, lastTime
  811. }
  812. // 获取用户信息
  813. userData := getUserData(v)
  814. if userData == nil || isUserInBlackList(userData) {
  815. return nil, lastTime
  816. }
  817. key := fmt.Sprintf("%s_%s_%s", sourceMap[sources], phone, common.ObjToString(v["interest"]))
  818. if _, exists := data[key]; exists {
  819. return nil, lastTime
  820. }
  821. data[key] = true
  822. return map[string]interface{}{
  823. "createTime": nowTime,
  824. "createtime": v["createtime"],
  825. "username": common.ObjToString(v["name"]),
  826. "company": common.ObjToString(v["company"]),
  827. "phone": phone,
  828. "source": gconv.String(sourceData["name"]),
  829. "interest": common.ObjToString(v["interest"]),
  830. "data_requirement": common.ObjToString(v["data_requirement"]),
  831. "branch": v["branch"],
  832. "job": v["position"],
  833. "email": common.ObjToString(v["mail"]),
  834. "appointEmail": gconv.String(sourceData["appointEmail"]),
  835. }, lastTime
  836. }
  837. // 获取用户数据
  838. func getUserData(v map[string]interface{}) map[string]interface{} {
  839. userid := common.ObjToString(v["userid"])
  840. userMapping := &map[string]interface{}{}
  841. if !mongodb.IsObjectIdHex(userid) {
  842. userMapping = TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userid}, "", "")
  843. } else {
  844. userMapping = TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"userid": userid}, "", "")
  845. }
  846. if userMapping != nil && len(*userMapping) > 0 {
  847. return *userMapping
  848. }
  849. return nil
  850. }
  851. // 判断用户是否在黑名单
  852. func isUserInBlackList(userData map[string]interface{}) bool {
  853. bt := common.ObjToString(userData["belong_to"])
  854. return strings.HasPrefix(bt, "03") || bt == "0102"
  855. }
  856. // 判断是否是安博会线索
  857. func isABHLead(lead map[string]interface{}) bool {
  858. s_sourceid := common.ObjToString(lead["s_sourceid"])
  859. return s_sourceid == db.Sourceid
  860. }
  861. // 导出到 Excel
  862. func exportToExcel(dataArr []map[string]interface{}, title, batch, mails string) {
  863. if len(dataArr) == 0 {
  864. return
  865. }
  866. bigArr := map[string][]map[string]interface{}{}
  867. for _, v := range dataArr {
  868. appointEmail := gconv.String(v["appointEmail"])
  869. if appointEmail == "" {
  870. appointEmail, _ = EmailSelect(batch, mails)
  871. }
  872. bigArr[appointEmail] = append(bigArr[appointEmail], v)
  873. }
  874. for email, arr := range bigArr {
  875. data := FindBatch(batch)
  876. xlsxArr := []string{"姓名", "联系方式", "职位", "部门", "邮箱", "公司名称", "咨询需求", "销售线索来源", "具体来源", "留资时间"}
  877. fileName, detailName := fmt.Sprintf("%s %s-%s", title, time.Now().Format(date.Date_Short_Layout), data), "今日新增销售线索,请查收附件,及时跟进。"
  878. xf := xlsx.NewFile()
  879. style := xlsx.NewStyle()
  880. style.Font.Size = 12
  881. style.Font.Bold = true
  882. style.Alignment.Vertical = "center"
  883. style.Alignment.Horizontal = "center"
  884. sh, _ := xf.AddSheet("线索数据")
  885. row1 := sh.AddRow()
  886. for _, x := range xlsxArr {
  887. cell := row1.AddCell()
  888. cell.SetString(x)
  889. cell.SetStyle(style)
  890. }
  891. for _, v := range arr {
  892. row := sh.AddRow()
  893. row.AddCell().SetString(common.ObjToString(v["username"]))
  894. row.AddCell().SetString(common.ObjToString(v["phone"]))
  895. row.AddCell().SetString(common.ObjToString(v["job"]))
  896. row.AddCell().SetString(common.ObjToString(v["branch"]))
  897. row.AddCell().SetString(common.ObjToString(v["email"]))
  898. row.AddCell().SetString(common.ObjToString(v["company"]))
  899. row.AddCell().SetString(common.ObjToString(v["data_requirement"]))
  900. row.AddCell().SetString(common.ObjToString(v["source"]))
  901. row.AddCell().SetString(common.ObjToString(v["interest"]))
  902. row.AddCell().SetString(gconv.Time(gconv.Int64(v["createtime"])).Format(date.Date_Full_Layout))
  903. }
  904. dir := fmt.Sprintf("./xlsx/%s/%s.xlsx", batch, fileName)
  905. if err := xf.Save(dir); err != nil {
  906. log.Println("xls error", err, dir)
  907. return
  908. }
  909. sendEmail(fileName, detailName, dir, email)
  910. }
  911. }
  912. // 发送邮件
  913. func sendEmail(fileName, detailName, dir, email string) {
  914. gmail := &mail.GmailAuth{
  915. SmtpHost: db.Mail.SmtpHost,
  916. SmtpPort: db.Mail.SmtpPort,
  917. User: db.Mail.User,
  918. Pwd: db.Mail.Pwd,
  919. }
  920. if status := mail.GSendMail_q("剑鱼标讯", email, "", "", fileName, detailName, dir, fileName+".xlsx", gmail); status {
  921. log.Println("send mail success", fileName, email)
  922. }
  923. }
  924. // 保存数据到 Redis
  925. func saveDataToRedis(data map[string]interface{}, batch string) {
  926. keyContent := fmt.Sprintf("data_%s_%s", time.Now().Format("2006-01-02"), batch)
  927. redis.Put("newother", keyContent, data, 86400)
  928. }
  929. // 邮箱选择处理
  930. func EmailSelect(batch, mailStr string) (string, string) {
  931. name := ""
  932. minemail := ""
  933. bigData := TiDb.SelectBySql("select * from dwd_f_crm_clue_big_autodraw_record where type =? ", batch)
  934. if bigData != nil && len(*bigData) > 0 {
  935. //查看有没有新增人员 人名-邮箱,邮箱|人名-邮箱,
  936. mailMap := map[string]string{}
  937. if mailStr != "" {
  938. for _, s := range strings.Split(mailStr, "|") {
  939. if len(strings.Split(s, "-")) > 1 {
  940. arr := strings.Split(s, "-")
  941. personName := arr[0]
  942. mailMap[personName] = arr[1]
  943. }
  944. }
  945. for personName, mailStr := range mailMap {
  946. isOk := false
  947. for _, m := range *bigData {
  948. tablePersonName := gconv.String(m["name"])
  949. if tablePersonName == personName {
  950. isOk = true
  951. }
  952. }
  953. if !isOk {
  954. rData := TiDb.FindOne("dwd_f_crm_clue_big_autodraw_record", map[string]interface{}{
  955. "type": batch,
  956. }, "", "count desc")
  957. //这是一个新人
  958. TiDb.Insert("dwd_f_crm_clue_big_autodraw_record", map[string]interface{}{
  959. "name": personName,
  960. "count": common.Int64All((*rData)["count"]),
  961. "email": mailStr,
  962. "type": batch,
  963. })
  964. return minemail, name
  965. }
  966. }
  967. }
  968. mincount := common.IntAll((*bigData)[0]["count"])
  969. for _, vv := range *bigData {
  970. vcount := common.IntAll(vv["count"])
  971. vemail := common.ObjToString(vv["email"])
  972. vName := common.ObjToString(vv["name"])
  973. if vcount <= mincount {
  974. mincount = vcount
  975. minemail = vemail
  976. name = vName
  977. }
  978. }
  979. }
  980. TiDb.UpdateOrDeleteBySql(`update dwd_f_crm_clue_big_autodraw_record set count = count + 1 where name = ? and type=?`, name, batch)
  981. return minemail, name
  982. }