everything.go 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985
  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]string{} //根据留资维表:tidb/Jianyu_subjectdb/d_saleleads_code
  340. saleSource := TiDb.SelectBySql(`SELECT source,name FROM d_saleleads_code WHERE department LIKE '%大客户%' AND is_delete = 1`)
  341. if saleSource != nil && len(*saleSource) > 0 {
  342. for _, v := range *saleSource {
  343. source := common.ObjToString(v["source"])
  344. name := common.ObjToString(v["name"])
  345. for _, s := range filterArr {
  346. name = strings.ReplaceAll(name, s, "")
  347. }
  348. sourceMap[source] = name
  349. }
  350. }
  351. nowTime := time.Now().Format(date.Date_Full_Layout)
  352. bigSaleTime := cfg.BigSaleTime
  353. bigOrderTime := cfg.BigOrderTime
  354. if bigSaleTime == 0 {
  355. bigSaleTime = time.Now().Unix()
  356. }
  357. if bigOrderTime == "" {
  358. bigOrderTime = nowTime
  359. }
  360. data := FindBatchData("dk")
  361. saleleadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"createtime": map[string]interface{}{"$gte": bigSaleTime}}, `{"phone":1,"createtime":1}`, nil, false, -1, -1)
  362. if ok && saleleadsData != nil && len(*saleleadsData) > 0 {
  363. for _, v := range *saleleadsData {
  364. sources := common.ObjToString(v["source"])
  365. userid := common.ObjToString(v["userid"])
  366. uid := ""
  367. if !mongodb.IsObjectIdHex(userid) {
  368. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userid}, "", "")
  369. if userMapping != nil && len(*userMapping) > 0 {
  370. userid = common.ObjToString((*userMapping)["userid"])
  371. uid = common.ObjToString((*userMapping)["uid"])
  372. }
  373. }
  374. if sourceMap[sources] != "" {
  375. source := sourceMap[sources]
  376. phone := common.ObjToString(v["phone"])
  377. if IsInternal(phone) {
  378. continue
  379. }
  380. key := fmt.Sprintf("%s_%s", source, phone)
  381. if _, ok := data[key]; ok {
  382. continue
  383. }
  384. data[key] = true
  385. company := common.ObjToString(v["company"])
  386. job := common.ObjToString(v["position"])
  387. username := common.ObjToString(v["name"])
  388. email := common.ObjToString(v["mail"])
  389. interest := common.ObjToString(v["interest"])
  390. data_requirement := common.ObjToString(v["data_requirement"])
  391. belongTo, usernickname := "大客户", ""
  392. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{"uid": uid}, "", "")
  393. if userData != nil {
  394. usernickname = common.ObjToString((*userData)["nickname"])
  395. bt := common.ObjToString((*userData)["belong_to"])
  396. if strings.HasPrefix(bt, "03") || bt == "0102" {
  397. continue
  398. }
  399. }
  400. dataArr = append(dataArr, map[string]interface{}{
  401. "createTime": nowTime,
  402. "lastUpdateTime": nowTime,
  403. "uid": uid,
  404. "userid": userid,
  405. "username": username,
  406. "usernickname": usernickname,
  407. "company": company,
  408. "job": job,
  409. "phone": phone,
  410. "email": email,
  411. "source": source,
  412. "belongTo": belongTo,
  413. "interest": interest,
  414. "data_requirement": data_requirement,
  415. })
  416. }
  417. if gconv.Int64(v["createtime"]) > bigSaleTime {
  418. bigSaleTime = gconv.Int64(v["createtime"])
  419. }
  420. }
  421. }
  422. cfg.BigSaleTime = bigSaleTime
  423. 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`)
  424. if orderData != nil && len(*orderData) > 0 {
  425. for _, v := range *orderData {
  426. phone := common.ObjToString(v["user_phone"])
  427. order_status := common.IntAll(v["order_status"])
  428. product_type := common.ObjToString(v["product_type"])
  429. orderUserId := gconv.String(v["user_id"])
  430. query := map[string]interface{}{}
  431. if !mongodb.IsObjectIdHex(orderUserId) {
  432. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": orderUserId}, "", "")
  433. if userMapping != nil && len(*userMapping) > 0 {
  434. uid := common.ObjToString((*userMapping)["uid"])
  435. query["uid"] = uid
  436. }
  437. } else {
  438. query["userid"] = orderUserId
  439. }
  440. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", query, "", "")
  441. username, usernickname, userid, uid, source, payorderinfo, unpayorderinfo := "", "", "", "", "", "", ""
  442. if userData != nil {
  443. if phone == "" {
  444. phone = common.ObjToString((*userData)["phone"])
  445. }
  446. if IsInternal(phone) {
  447. continue
  448. }
  449. username = common.ObjToString((*userData)["name"])
  450. usernickname = common.ObjToString((*userData)["nickname"])
  451. uid = common.ObjToString((*userData)["uid"])
  452. userid = common.ObjToString((*userData)["userid"])
  453. bt := common.ObjToString((*userData)["belong_to"])
  454. if strings.HasPrefix(bt, "03") || bt == "0102" {
  455. continue
  456. }
  457. }
  458. if product_type == "历史数据" {
  459. if order_status == 0 {
  460. source = "线上历史数据导出未支付订单"
  461. unpayorderinfo = "历史数据"
  462. } else {
  463. source = "线上历史数据导出已支付订单"
  464. payorderinfo = "历史数据" + fmt.Sprint(common.IntAll(v["pay_money"])/100)
  465. }
  466. } else {
  467. if order_status == 0 {
  468. source = "线上数据流量包未支付订单"
  469. unpayorderinfo = "数据流量包"
  470. } else {
  471. source = "线上数据流量包已支付订单"
  472. payorderinfo = "数据流量包" + fmt.Sprint(common.IntAll(v["pay_money"])/100)
  473. }
  474. }
  475. key := fmt.Sprintf("%s_%s", source, phone)
  476. if _, ok := data[key]; ok {
  477. continue
  478. }
  479. data[key] = true
  480. dataArr = append(dataArr, map[string]interface{}{
  481. "createTime": nowTime,
  482. "lastUpdateTime": nowTime,
  483. "phone": phone,
  484. "username": username,
  485. "usernickname": usernickname,
  486. "uid": uid,
  487. "userid": userid,
  488. "company": v["company_name"],
  489. "email": v["user_mail"],
  490. "belongTo": "大客户",
  491. "source": source,
  492. "data_count": v["data_count"],
  493. "unpayorderinfo": unpayorderinfo,
  494. "payorderinfo": payorderinfo, //增加客户需求
  495. })
  496. bigOrderTime = gconv.Time(gconv.String(v["create_time"])).Format(date.Date_Full_Layout)
  497. }
  498. cfg.BigOrderTime = bigOrderTime
  499. }
  500. xlsxArr := []string{"用户昵称", "姓名", "公司名称", "职位", "联系人电话", "购买条数", "用户邮箱", "已支付订单信息", "未支付订单类型", "销售线索来源", "具体来源", "数据需求"}
  501. if len(dataArr) > 0 {
  502. keyContent := fmt.Sprintf("data_%s_%s", time.Now().Format("2006-01-02"), "dk")
  503. redis.Put("newother", keyContent, data, 86400)
  504. bigData := TiDb.SelectBySql("select * from dwd_f_crm_clue_big_autodraw_record")
  505. if bigData != nil && len(*bigData) > 0 {
  506. cdata := *bigData
  507. bigArr := map[string][]map[string]interface{}{}
  508. for _, v := range dataArr {
  509. mincount := common.IntAll(cdata[0]["count"])
  510. minindex := 0
  511. minemail := ""
  512. for kk, vv := range cdata {
  513. vcount := common.IntAll(vv["count"])
  514. vemail := common.ObjToString(vv["email"])
  515. if vcount <= mincount {
  516. minindex = kk
  517. mincount = vcount
  518. minemail = vemail
  519. }
  520. }
  521. bigArr[minemail] = append(bigArr[minemail], v)
  522. cdata[minindex]["count"] = mincount + 1
  523. name := common.ObjToString(cdata[minindex]["name"])
  524. TiDb.UpdateOrDeleteBySql(`update dwd_f_crm_clue_big_autodraw_record set count = count + 1 where name = ?`, name)
  525. }
  526. for k, vb := range bigArr {
  527. batch := FindBatch("dk")
  528. fileName, detailName := time.Now().Format(date.Date_Short_Layout)+"-"+batch+"大客户销售线索", ""
  529. xf := xlsx.NewFile()
  530. style := xlsx.NewStyle()
  531. style.Font.Size = 12
  532. style.Font.Bold = true
  533. style.Alignment.Vertical = "center"
  534. style.Alignment.Horizontal = "center"
  535. detailName = time.Now().Format(date.Date_Short_Layout) + "数据详情请查看附件"
  536. sh, _ := xf.AddSheet("线索数据")
  537. row1 := sh.AddRow()
  538. for _, x := range xlsxArr {
  539. cell := row1.AddCell()
  540. cell.SetString(x)
  541. cell.SetStyle(style)
  542. }
  543. for _, v := range vb {
  544. row := sh.AddRow()
  545. row.AddCell().SetString(common.ObjToString(v["usernickname"]))
  546. row.AddCell().SetString(common.ObjToString(v["username"]))
  547. row.AddCell().SetString(common.ObjToString(v["company"]))
  548. row.AddCell().SetString(common.ObjToString(v["job"]))
  549. row.AddCell().SetString(common.ObjToString(v["phone"]))
  550. row.AddCell().SetValue(common.IntAll(v["data_count"]))
  551. row.AddCell().SetString(common.ObjToString(v["email"]))
  552. row.AddCell().SetString(common.ObjToString(v["payorderinfo"]))
  553. row.AddCell().SetString(common.ObjToString(v["unpayorderinfo"]))
  554. row.AddCell().SetString(common.ObjToString(v["source"]))
  555. row.AddCell().SetString(common.ObjToString(v["interest"]))
  556. row.AddCell().SetString(common.ObjToString(v["data_requirement"]))
  557. //增加客户需求
  558. }
  559. email := k
  560. //email = "wanghao@jianyu360.com"
  561. dir := "./xlsx/dk/" + fileName + ".xlsx"
  562. err := xf.Save(dir)
  563. if err != nil {
  564. log.Println("xls error", err, dir)
  565. } else {
  566. gmail := &mail.GmailAuth{
  567. SmtpHost: "smtp.exmail.qq.com",
  568. SmtpPort: 465,
  569. User: "public03@topnet.net.cn",
  570. Pwd: "ue9Rg9Sf4CVtdm5a",
  571. }
  572. status := mail.GSendMail_q("剑鱼标讯", email, "", "", fileName, detailName, dir, fileName+".xlsx", gmail)
  573. if status {
  574. log.Println("send mail success", fileName, email)
  575. }
  576. }
  577. }
  578. }
  579. }
  580. common.WriteSysConfig(&cfg)
  581. log.Println("大客户线索定时任务结束")
  582. }
  583. func IsInternal(phone string) bool {
  584. if DataAnalysisService.Count("dwd_f_userbase_insider", map[string]interface{}{
  585. "mobile": phone,
  586. }) > 0 {
  587. return true
  588. }
  589. return false
  590. }
  591. // 咨询组线索
  592. func AdvisoryCommittee() {
  593. runOk := getRunOk()
  594. if !runOk {
  595. log.Println("不是工作日,任务暂停")
  596. return
  597. }
  598. log.Println("咨询部线索定时任务开始")
  599. dataArr := []map[string]interface{}{}
  600. filterArr := []string{"-pc", "-app", "-wx", "-h5"}
  601. sourceMap := map[string]string{} //根据留资维表:tidb/Jianyu_subjectdb/d_saleleads_code
  602. saleSource := TiDb.SelectBySql(`SELECT source,name FROM d_saleleads_code WHERE department LIKE '%咨询组%' AND is_delete = 1`)
  603. if saleSource != nil && len(*saleSource) > 0 {
  604. for _, v := range *saleSource {
  605. source := common.ObjToString(v["source"])
  606. name := common.ObjToString(v["name"])
  607. for _, s := range filterArr {
  608. name = strings.ReplaceAll(name, s, "")
  609. }
  610. sourceMap[source] = name
  611. }
  612. }
  613. nowTime := time.Now().Format(date.Date_Full_Layout)
  614. advisoryCommitteeTime := cfg.AdvisoryCommitteeTime
  615. if advisoryCommitteeTime == 0 {
  616. advisoryCommitteeTime = time.Now().Unix()
  617. }
  618. saleleadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"createtime": map[string]interface{}{"$gte": advisoryCommitteeTime}}, `{"phone":1,"createtime":1}`, nil, false, -1, -1)
  619. if ok && saleleadsData != nil && len(*saleleadsData) > 0 {
  620. data := FindBatchData("zx")
  621. for _, v := range *saleleadsData {
  622. sources := common.ObjToString(v["source"])
  623. userid := common.ObjToString(v["userid"])
  624. uid := ""
  625. if !mongodb.IsObjectIdHex(userid) {
  626. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userid}, "", "")
  627. if userMapping != nil && len(*userMapping) > 0 {
  628. userid = common.ObjToString((*userMapping)["userid"])
  629. uid = common.ObjToString((*userMapping)["uid"])
  630. }
  631. }
  632. if sourceMap[sources] != "" {
  633. company := common.ObjToString(v["company"])
  634. phone := common.ObjToString(v["phone"])
  635. if IsInternal(phone) {
  636. continue
  637. }
  638. username := common.ObjToString(v["name"])
  639. email := common.ObjToString(v["mail"])
  640. interest := common.ObjToString(v["interest"])
  641. data_requirement := common.ObjToString(v["data_requirement"])
  642. source := sourceMap[sources]
  643. belongTo := "咨询组"
  644. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{"uid": uid}, "", "")
  645. if userData != nil {
  646. bt := common.ObjToString((*userData)["belong_to"])
  647. if strings.HasPrefix(bt, "03") || bt == "0102" {
  648. continue
  649. }
  650. }
  651. key := fmt.Sprintf("%s_%s_%s", source, phone, interest)
  652. if _, ok := data[key]; ok {
  653. continue
  654. }
  655. data[key] = true
  656. dataArr = append(dataArr, map[string]interface{}{
  657. "createTime": nowTime,
  658. "createtime": v["createtime"],
  659. "username": username,
  660. "company": company,
  661. "phone": phone,
  662. "source": source,
  663. "belongTo": belongTo,
  664. "interest": interest,
  665. "data_requirement": data_requirement,
  666. "branch": v["branch"],
  667. "email": email,
  668. })
  669. }
  670. if gconv.Int64(v["createtime"]) > advisoryCommitteeTime {
  671. advisoryCommitteeTime = gconv.Int64(v["createtime"])
  672. }
  673. }
  674. keyContent := fmt.Sprintf("data_%s_%s", time.Now().Format("2006-01-02"), "zx")
  675. redis.Put("newother", keyContent, data, 86400)
  676. }
  677. cfg.AdvisoryCommitteeTime = advisoryCommitteeTime
  678. xlsxArr := []string{"姓名", "联系方式", "邮箱", "公司名称", "咨询需求", "销售线索来源", "具体来源", "留资时间"}
  679. if len(dataArr) > 0 {
  680. //排序:首先按照“联系方式”排序,即同1个用户的留资放在一起,其次按照留资时间正序排序。
  681. batch := FindBatch("zx")
  682. fileName, detailName := "咨询服务销售线索 "+time.Now().Format(date.Date_Short_Layout)+"-"+batch, ""
  683. xf := xlsx.NewFile()
  684. style := xlsx.NewStyle()
  685. style.Font.Size = 12
  686. style.Font.Bold = true
  687. style.Alignment.Vertical = "center"
  688. style.Alignment.Horizontal = "center"
  689. detailName = "今日新增咨询服务销售线索,请查收附件,及时跟进。"
  690. sh, _ := xf.AddSheet("线索数据")
  691. row1 := sh.AddRow()
  692. for _, x := range xlsxArr {
  693. cell := row1.AddCell()
  694. cell.SetString(x)
  695. cell.SetStyle(style)
  696. }
  697. for _, v := range dataArr {
  698. row := sh.AddRow()
  699. row.AddCell().SetString(common.ObjToString(v["username"]))
  700. row.AddCell().SetString(common.ObjToString(v["phone"]))
  701. row.AddCell().SetString(common.ObjToString(v["email"]))
  702. row.AddCell().SetString(common.ObjToString(v["company"]))
  703. row.AddCell().SetString(common.ObjToString(v["data_requirement"]))
  704. row.AddCell().SetString(common.ObjToString(v["source"]))
  705. row.AddCell().SetString(common.ObjToString(v["interest"]))
  706. row.AddCell().SetString(gconv.Time(gconv.Int64(v["createtime"])).Format(date.Date_Full_Layout))
  707. //增加客户需求
  708. }
  709. email := db.AdvisoryCommitteeMail
  710. dir := "./xlsx/zx/" + fileName + ".xlsx"
  711. err := xf.Save(dir)
  712. if err != nil {
  713. log.Println("xls error", err, dir)
  714. } else {
  715. gmail := &mail.GmailAuth{
  716. SmtpHost: "smtp.exmail.qq.com",
  717. SmtpPort: 465,
  718. User: "public03@topnet.net.cn",
  719. Pwd: "ue9Rg9Sf4CVtdm5a",
  720. }
  721. for _, v := range email {
  722. status := mail.GSendMail_q("剑鱼标讯", v, "", "", fileName, detailName, dir, fileName+".xlsx", gmail)
  723. if status {
  724. log.Println("send mail success", fileName, v)
  725. }
  726. }
  727. }
  728. }
  729. common.WriteSysConfig(&cfg)
  730. log.Println("咨询部线索定时任务结束")
  731. }
  732. // 市场部线索
  733. func marketCustomer() {
  734. runOk := getRunOk()
  735. if !runOk {
  736. log.Println("不是工作日,任务暂停")
  737. return
  738. }
  739. log.Println("市场部线索定时任务开始")
  740. dataArr := []map[string]interface{}{}
  741. filterArr := []string{"-pc", "-app", "-wx", "-h5"}
  742. sourceMap := map[string]string{} //根据留资维表:tidb/Jianyu_subjectdb/d_saleleads_code
  743. saleSource := TiDb.SelectBySql(`SELECT source,name FROM d_saleleads_code WHERE department LIKE '%市场组%' AND is_delete = 1`)
  744. if saleSource != nil && len(*saleSource) > 0 {
  745. for _, v := range *saleSource {
  746. source := common.ObjToString(v["source"])
  747. name := common.ObjToString(v["name"])
  748. for _, s := range filterArr {
  749. name = strings.ReplaceAll(name, s, "")
  750. }
  751. sourceMap[source] = name
  752. }
  753. }
  754. nowTime := time.Now().Format(date.Date_Full_Layout)
  755. marketSaleTime := cfg.MarketSaleTime
  756. if marketSaleTime == 0 {
  757. marketSaleTime = time.Now().Unix()
  758. }
  759. saleleadsData, ok := Mgo.Find("saleLeads", map[string]interface{}{"createtime": map[string]interface{}{"$gte": marketSaleTime}}, `{"phone":1,"createtime":1}`, nil, false, -1, -1)
  760. if ok && saleleadsData != nil && len(*saleleadsData) > 0 {
  761. data := FindBatchData("sc")
  762. for _, v := range *saleleadsData {
  763. sources := common.ObjToString(v["source"])
  764. userid := common.ObjToString(v["userid"])
  765. uid := ""
  766. if !mongodb.IsObjectIdHex(userid) {
  767. userMapping := TiDb.FindOne("dwd_f_userbase_id_mapping", map[string]interface{}{"position_id": userid}, "", "")
  768. if userMapping != nil && len(*userMapping) > 0 {
  769. userid = common.ObjToString((*userMapping)["userid"])
  770. uid = common.ObjToString((*userMapping)["uid"])
  771. }
  772. }
  773. if sourceMap[sources] != "" {
  774. company := common.ObjToString(v["company"])
  775. phone := common.ObjToString(v["phone"])
  776. if IsInternal(phone) {
  777. continue
  778. }
  779. job := common.ObjToString(v["position"])
  780. username := common.ObjToString(v["name"])
  781. email := common.ObjToString(v["mail"])
  782. interest := common.ObjToString(v["interest"])
  783. data_requirement := common.ObjToString(v["data_requirement"])
  784. source := sourceMap[sources]
  785. belongTo, usernickname := "市场组", ""
  786. userData := TiDb.FindOne("dwd_f_userbase_baseinfo", map[string]interface{}{"uid": uid}, "", "")
  787. if userData != nil {
  788. usernickname = common.ObjToString((*userData)["nickname"])
  789. bt := common.ObjToString((*userData)["belong_to"])
  790. if strings.HasPrefix(bt, "03") || bt == "0102" {
  791. continue
  792. }
  793. }
  794. key := fmt.Sprintf("%s_%s", source, phone)
  795. if _, ok := data[key]; ok {
  796. continue
  797. }
  798. data[key] = true
  799. dataArr = append(dataArr, map[string]interface{}{
  800. "createTime": nowTime,
  801. "lastUpdateTime": nowTime,
  802. "createtime": v["createtime"],
  803. "uid": uid,
  804. "userid": userid,
  805. "username": username,
  806. "usernickname": usernickname,
  807. "company": company,
  808. "job": job,
  809. "phone": phone,
  810. "email": email,
  811. "source": source,
  812. "belongTo": belongTo,
  813. "interest": interest,
  814. "data_requirement": data_requirement,
  815. "branch": v["branch"],
  816. })
  817. }
  818. if gconv.Int64(v["createtime"]) > marketSaleTime {
  819. marketSaleTime = gconv.Int64(v["createtime"])
  820. }
  821. }
  822. keyContent := fmt.Sprintf("data_%s_%s", time.Now().Format("2006-01-02"), "sc")
  823. redis.Put("newother", keyContent, data, 86400)
  824. }
  825. cfg.MarketSaleTime = marketSaleTime
  826. xlsxArr := []string{"姓名", "联系人电话", "公司名称", "职位", "部门", "销售线索来源", "留资时间"}
  827. if len(dataArr) > 0 {
  828. //排序:首先按照“联系方式”排序,即同1个用户的留资放在一起,其次按照留资时间正序排序。
  829. batch := FindBatch("sc")
  830. fileName, detailName := "商务合作销售线索 "+time.Now().Format(date.Date_Short_Layout)+"-"+batch, ""
  831. xf := xlsx.NewFile()
  832. style := xlsx.NewStyle()
  833. style.Font.Size = 12
  834. style.Font.Bold = true
  835. style.Alignment.Vertical = "center"
  836. style.Alignment.Horizontal = "center"
  837. detailName = "今日新增商务合作销售线索,请查收附件,及时跟进。"
  838. sh, _ := xf.AddSheet("线索数据")
  839. row1 := sh.AddRow()
  840. for _, x := range xlsxArr {
  841. cell := row1.AddCell()
  842. cell.SetString(x)
  843. cell.SetStyle(style)
  844. }
  845. for _, v := range dataArr {
  846. row := sh.AddRow()
  847. row.AddCell().SetString(common.ObjToString(v["username"]))
  848. row.AddCell().SetString(common.ObjToString(v["phone"]))
  849. row.AddCell().SetString(common.ObjToString(v["company"]))
  850. row.AddCell().SetString(common.ObjToString(v["job"]))
  851. row.AddCell().SetString(common.ObjToString(v["branch"]))
  852. row.AddCell().SetString(common.ObjToString(v["source"]))
  853. row.AddCell().SetString(gconv.Time(gconv.Int64(v["createtime"])).Format(date.Date_Full_Layout))
  854. //增加客户需求
  855. }
  856. email := db.MarketSaleMail
  857. dir := "./xlsx/sc/" + fileName + ".xlsx"
  858. err := xf.Save(dir)
  859. if err != nil {
  860. log.Println("xls error", err, dir)
  861. } else {
  862. gmail := &mail.GmailAuth{
  863. SmtpHost: "smtp.exmail.qq.com",
  864. SmtpPort: 465,
  865. User: "public03@topnet.net.cn",
  866. Pwd: "ue9Rg9Sf4CVtdm5a",
  867. }
  868. status := mail.GSendMail_q("剑鱼标讯", email, "", "", fileName, detailName, dir, fileName+".xlsx", gmail)
  869. if status {
  870. log.Println("send mail success", fileName, email)
  871. }
  872. }
  873. }
  874. common.WriteSysConfig(&cfg)
  875. log.Println("大客户线索定时任务结束")
  876. }
  877. func eventReg() {
  878. lastEventRegTime := cfg.LastEventRegTime
  879. sql := fmt.Sprintf(`select * from exhibition_sign_up where is_del = 0 and update_time > "%s" order by update_time asc`, lastEventRegTime)
  880. log.Println("活动报名表定时任务开始", sql)
  881. data := Jyactivities.SelectBySql(sql)
  882. if data != nil && *data != nil && len(*data) > 0 {
  883. for _, v := range *data {
  884. ok1, ok2 := FormatData(v, "eventReg")
  885. if !ok1 {
  886. common.WriteSysConfig(&cfg)
  887. log.Println("线索卡点", "eventReg", v, lastEventRegTime)
  888. break
  889. } else {
  890. if !ok2 {
  891. log.Println("用户分配已达上限", "eventReg", v, lastEventRegTime)
  892. common.WriteSysConfig(&cfg)
  893. break
  894. }
  895. }
  896. cfg.LastEventRegTime = common.ObjToString(v["update_time"])
  897. }
  898. }
  899. common.WriteSysConfig(&cfg)
  900. log.Println("活动报名表定时任务结束")
  901. }
  902. func saveHlyj(belong_to, item, phone, name, sourceName, cluename, position, nowTime string, isGroup, isCommerce int) {
  903. if strings.HasPrefix(belong_to, "02") && item == "eventReg" {
  904. saveMap := map[string]interface{}{
  905. "unique_id": phone,
  906. "phone": phone,
  907. "username": name,
  908. "source": sourceName,
  909. "status999": "status5",
  910. "company": cluename,
  911. "job": position,
  912. "belongTo": "市场部",
  913. "createTime": nowTime,
  914. "lastUpdateTime": nowTime,
  915. }
  916. token := getToken()
  917. updateData := map[string]interface{}{
  918. "dbType": "0001",
  919. "customerList": []map[string]interface{}{saveMap},
  920. }
  921. dataByte, _ := json.Marshal(&updateData)
  922. url := `https://a1.7x24cc.com/commonInte?flag=1007&account=N000000029739&accessToken=` + token + `&json=` + url.QueryEscape(string(dataByte))
  923. bs, err := doGet(url)
  924. if err != nil {
  925. log.Println("调用接口失败")
  926. } else {
  927. resMap := common.StringToMap(string(bs))
  928. if resMap["success"] != nil && resMap["success"].(bool) {
  929. saveMap["company_nature"] = isGroup
  930. saveMap["company_verification"] = isCommerce
  931. TiDbData.Insert("customer", saveMap)
  932. } else {
  933. log.Println("新增线索失败")
  934. }
  935. }
  936. }
  937. }
  938. func FindBatch(moudle string) string {
  939. now := time.Now().Format("2006-01-02")
  940. key := fmt.Sprintf("batch_%s_%s", now, moudle)
  941. yesterday := time.Now().AddDate(0, 0, -1).Format("2006-01-02")
  942. yesterdayKey := fmt.Sprintf("batch_%s_%s", yesterday, moudle)
  943. if ok, _ := redis.Exists("newother", yesterdayKey); ok {
  944. //删除之前数据
  945. redis.Del("newother", yesterdayKey)
  946. }
  947. batch := redis.Incr("newother", key)
  948. return fmt.Sprintf("%04d", batch)
  949. }
  950. func FindBatchData(moudle string) map[string]interface{} {
  951. now := time.Now().Format("2006-01-02")
  952. //数据提取
  953. keyContent := fmt.Sprintf("data_%s_%s", now, moudle)
  954. data := redis.Get("newother", keyContent)
  955. if data == nil {
  956. return make(map[string]interface{})
  957. } else {
  958. return gconv.Map(data)
  959. }
  960. }