es_comprehensive.go 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528
  1. package elastic
  2. import (
  3. "context"
  4. "errors"
  5. "fmt"
  6. "github.com/PuerkitoBio/goquery"
  7. "github.com/olivere/elastic/v7"
  8. "hongze/hz_crm_api/models/cygx"
  9. "hongze/hz_crm_api/services/alarm_msg"
  10. "hongze/hz_crm_api/utils"
  11. "html"
  12. "strconv"
  13. "strings"
  14. )
  15. type ElasticComprehensiveDetail struct {
  16. SourceId int `description:"资源ID"`
  17. IsSummary int `description:"是否是纪要"`
  18. Source string `description:"资源类型 报告 :article 、图表 :newchart、微路演 :roadshow、活动 :activity、活动视频:activityvideo、活动音频:activityvoice、专项调研活动:activityspecial 、 本周研究汇总: researchsummary 、 上周纪要汇总 :minutessummary 、晨会精华 :meetingreviewchapt 、 产品内测:productinterior 、 产业资源包:industrialsource"`
  19. Title string `description:"标题"`
  20. BodyText string `description:"内容"`
  21. PublishDate string `description:"发布时间"`
  22. Abstract string `description:"摘要"`
  23. Annotation string `description:"核心观点"`
  24. IndustryName string `description:"产业名称"`
  25. SubjectNames string `description:"标的名称"`
  26. }
  27. // 新增和修改数据
  28. func EsAddOrEditComprehensiveData(item *ElasticComprehensiveDetail) (err error) {
  29. indexName := utils.IndexNameComprehensive // 避免调用错别的项目的索引 ,这里写死
  30. //return
  31. defer func() {
  32. if err != nil {
  33. go alarm_msg.SendAlarmMsg("更新综合页面数据Es失败"+err.Error()+fmt.Sprint(item), 2)
  34. }
  35. }()
  36. client, err := NewClient()
  37. if err != nil {
  38. fmt.Println(err, "err1")
  39. return
  40. }
  41. mustMap := make([]interface{}, 0)
  42. mustMap = append(mustMap, map[string]interface{}{
  43. "term": map[string]interface{}{
  44. "SourceId": item.SourceId,
  45. },
  46. })
  47. mustMap = append(mustMap, map[string]interface{}{
  48. "term": map[string]interface{}{
  49. "Source": item.Source,
  50. },
  51. })
  52. //fmt.Println(item.SourceId)
  53. queryMap := map[string]interface{}{
  54. "query": map[string]interface{}{
  55. "bool": map[string]interface{}{
  56. "must": mustMap,
  57. },
  58. },
  59. }
  60. requestTotalHits := client.Count(indexName).BodyJson(queryMap)
  61. total, e := requestTotalHits.Do(context.Background())
  62. if e != nil {
  63. err = errors.New("requestTotalHits.Do(context.Background()), Err: " + e.Error())
  64. return
  65. }
  66. //return
  67. //根据来源以及ID ,判断内容是否存在,如果存在就新增,如果不存在就修改
  68. if total == 0 {
  69. resp, e := client.Index().Index(indexName).BodyJson(item).Do(context.Background())
  70. if e != nil {
  71. err = errors.New("client.Index().Index(indexName).BodyJson(item).Do(context.Background()), Err: " + e.Error())
  72. return
  73. }
  74. if resp.Status == 0 && resp.Result == "created" {
  75. //fmt.Println("新增成功")
  76. //err = nil
  77. return
  78. } else {
  79. err = errors.New(fmt.Sprint(resp))
  80. return
  81. }
  82. } else {
  83. //拼接需要改动的前置条件
  84. bool_query := elastic.NewBoolQuery()
  85. bool_query.Must(elastic.NewTermQuery("SourceId", item.SourceId))
  86. bool_query.Must(elastic.NewTermQuery("Source", item.Source))
  87. //设置需要改动的内容
  88. var script string
  89. script += fmt.Sprint("ctx._source['SubjectNames'] = '", item.SubjectNames, "';")
  90. script += fmt.Sprint("ctx._source['PublishDate'] = '", item.PublishDate, "';")
  91. script += fmt.Sprint("ctx._source['IsSummary'] = ", item.IsSummary, ";")
  92. script += fmt.Sprint("ctx._source['Abstract'] = '", item.Abstract, "';")
  93. script += fmt.Sprint("ctx._source['Title'] = '", item.Title, "';")
  94. script += fmt.Sprint("ctx._source['BodyText'] = '", item.BodyText, "';")
  95. script += fmt.Sprint("ctx._source['Annotation'] = '", item.Annotation, "';")
  96. script += fmt.Sprint("ctx._source['IndustryName'] = '", item.IndustryName, "'")
  97. _, e := client.UpdateByQuery(indexName).
  98. Query(bool_query).
  99. Script(elastic.NewScriptInline(script)).
  100. Refresh("true").
  101. Do(context.Background())
  102. if e != nil {
  103. err = errors.New(" client.UpdateByQuery(indexName), Err: " + e.Error())
  104. return
  105. }
  106. }
  107. return
  108. }
  109. // 删除数据
  110. func EsDeleteComprehensiveData(item *ElasticComprehensiveDetail) (err error) {
  111. indexName := utils.IndexNameComprehensive // 避免调用错别的项目的索引 ,这里写死
  112. defer func() {
  113. if err != nil {
  114. fmt.Println(err)
  115. go alarm_msg.SendAlarmMsg("删除数据综合页面数据Es失败"+err.Error()+fmt.Sprint(item), 2)
  116. }
  117. }()
  118. fmt.Println("删除", item.SourceId)
  119. client, err := NewClient()
  120. //拼接需要删除的前置条件
  121. bool_query := elastic.NewBoolQuery()
  122. bool_query.Must(elastic.NewTermQuery("SourceId", item.SourceId))
  123. bool_query.Must(elastic.NewTermQuery("Source", item.Source))
  124. _, e := client.DeleteByQuery(indexName).
  125. Query(bool_query).
  126. Do(context.Background())
  127. if e != nil {
  128. err = errors.New(" client.DeleteByQuery(indexName), Err: " + e.Error())
  129. return
  130. }
  131. return
  132. }
  133. // ES添加文章:报告、纪要
  134. func AddComprehensiveArticle(sourceId int) {
  135. var err error
  136. defer func() {
  137. if err != nil {
  138. fmt.Println("err:", err)
  139. go alarm_msg.SendAlarmMsg("AddComprehensiveArticle,Err:"+err.Error(), 3)
  140. }
  141. }()
  142. v, e := cygx.GetArticleInfoOtherByArticleId(sourceId)
  143. if e != nil {
  144. err = errors.New("GetArticleInfoOtherByArticleId" + e.Error())
  145. return
  146. }
  147. content := html.UnescapeString(v.Body)
  148. doc, e := goquery.NewDocumentFromReader(strings.NewReader(content))
  149. if e != nil {
  150. err = errors.New("goquery.NewDocumentFromReader" + e.Error())
  151. return
  152. }
  153. bodyText := doc.Text()
  154. item := new(ElasticComprehensiveDetail)
  155. item.SourceId = v.ArticleId
  156. item.IsSummary = v.IsSummary
  157. item.Source = utils.CYGX_OBJ_ARTICLE
  158. item.Title = v.Title
  159. item.PublishDate = v.PublishDate.Format(utils.FormatDateTime)
  160. item.BodyText = bodyText
  161. item.Annotation = html.UnescapeString(v.Annotation)
  162. item.Abstract = html.UnescapeString(v.Abstract)
  163. if v.PublishStatus == 1 {
  164. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  165. } else {
  166. EsDeleteComprehensiveData(item) // 没有发布就删除
  167. }
  168. return
  169. }
  170. // Es添加活动
  171. func AddComprehensiveActivity(sourceId int) {
  172. var err error
  173. defer func() {
  174. if err != nil {
  175. fmt.Println("err:", err)
  176. go alarm_msg.SendAlarmMsg("AddComprehensiveActivity,Err:"+err.Error(), 3)
  177. }
  178. }()
  179. activityId := sourceId
  180. detail, e := cygx.GetAddActivityInfoById(sourceId)
  181. if e != nil {
  182. err = errors.New("GetAddActivityInfoById" + e.Error())
  183. return
  184. }
  185. mapActivityIndustrialManagement := make(map[int][]string)
  186. mapActivitySubject := make(map[int][]string)
  187. industrialList, e := cygx.GetIndustrialActivityGroupManagementList(activityId, 1)
  188. if e != nil && e.Error() != utils.ErrNoRow() {
  189. err = errors.New("GetIndustrialActivityGroupManagementList" + e.Error())
  190. return
  191. }
  192. if len(industrialList) > 0 {
  193. for _, v := range industrialList {
  194. mapActivityIndustrialManagement[activityId] = append(mapActivityIndustrialManagement[activityId], v.IndustryName)
  195. }
  196. subjectList, e := cygx.GetSubjectActivityGroupManagementList(activityId, 1)
  197. if e != nil && e.Error() != utils.ErrNoRow() {
  198. err = errors.New("GetSubjectActivityGroupManagementList" + e.Error())
  199. return
  200. }
  201. if len(subjectList) > 0 {
  202. for _, v := range subjectList {
  203. mapActivitySubject[activityId] = append(mapActivitySubject[activityId], v.SubjectName)
  204. }
  205. }
  206. }
  207. item := new(ElasticComprehensiveDetail)
  208. item.SourceId = detail.ActivityId
  209. item.Source = utils.CYGX_OBJ_ACTIVITY
  210. item.SubjectNames = strings.Join(mapActivitySubject[detail.ActivityId], ",")
  211. item.IndustryName = strings.Join(mapActivityIndustrialManagement[detail.ActivityId], ",")
  212. item.Title = detail.ActivityName
  213. item.PublishDate = detail.ActivityTime
  214. if detail.PublishStatus == 1 {
  215. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  216. } else {
  217. EsDeleteComprehensiveData(item) // 没有发布就删除
  218. }
  219. return
  220. }
  221. // Es添加专项调研活动
  222. func AddComprehensiveActivitySpecial(sourceId int) {
  223. var err error
  224. defer func() {
  225. if err != nil {
  226. fmt.Println("err:", err)
  227. go alarm_msg.SendAlarmMsg("AddComprehensiveActivitySpecial,Err:"+err.Error(), 3)
  228. }
  229. }()
  230. activityId := sourceId
  231. detail, e := cygx.GetAddActivityInfoSpecialById(sourceId)
  232. if e != nil {
  233. err = errors.New("GetAddActivityInfoSpecialById" + e.Error())
  234. return
  235. }
  236. mapActivityIndustrialManagement := make(map[int][]string)
  237. mapActivitySubject := make(map[int][]string)
  238. industrialList, e := cygx.GetIndustrialActivityGroupManagementList(activityId, 2)
  239. if e != nil && e.Error() != utils.ErrNoRow() {
  240. err = errors.New("GetIndustrialActivityGroupManagementList" + e.Error())
  241. return
  242. }
  243. if len(industrialList) > 0 {
  244. for _, v := range industrialList {
  245. mapActivityIndustrialManagement[activityId] = append(mapActivityIndustrialManagement[activityId], v.IndustryName)
  246. }
  247. subjectList, e := cygx.GetSubjectActivityGroupManagementList(activityId, 2)
  248. if e != nil && e.Error() != utils.ErrNoRow() {
  249. err = errors.New("GetSubjectActivityGroupManagementList" + e.Error())
  250. return
  251. }
  252. if len(subjectList) > 0 {
  253. for _, v := range subjectList {
  254. mapActivitySubject[activityId] = append(mapActivitySubject[activityId], v.SubjectName)
  255. }
  256. }
  257. }
  258. item := new(ElasticComprehensiveDetail)
  259. item.SourceId = detail.ActivityId
  260. item.Source = utils.CYGX_OBJ_ACTIVITYSPECIAL
  261. item.SubjectNames = strings.Join(mapActivitySubject[detail.ActivityId], ",")
  262. item.IndustryName = strings.Join(mapActivityIndustrialManagement[detail.ActivityId], ",")
  263. item.Title = detail.ResearchTheme
  264. if detail.ActivityTime == utils.EmptyDateTimeStr {
  265. item.PublishDate = detail.LastUpdatedTime.Format(utils.FormatDateTime)
  266. } else {
  267. item.PublishDate = detail.ActivityTime
  268. }
  269. if detail.PublishStatus == 1 {
  270. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  271. } else {
  272. EsDeleteComprehensiveData(item) // 没有发布就删除
  273. }
  274. return
  275. }
  276. // Es添加活动视频
  277. func AddComprehensiveActivityVideo(activityId int) {
  278. var err error
  279. defer func() {
  280. if err != nil {
  281. fmt.Println("err:", err)
  282. go alarm_msg.SendAlarmMsg("AddComprehensiveActivityVideo,Err:"+err.Error(), 3)
  283. }
  284. }()
  285. detailactivity, e := cygx.GetAddActivityInfoById(activityId)
  286. if e != nil {
  287. err = errors.New("GetAddActivityInfoById" + e.Error())
  288. return
  289. }
  290. detail, e := cygx.GetCygxActivityVideoReqDetail(activityId)
  291. if e != nil {
  292. err = errors.New("GetAddActivityInfoById" + e.Error())
  293. return
  294. }
  295. item := new(ElasticComprehensiveDetail)
  296. item.SourceId = detail.VideoId
  297. item.Source = utils.CYGX_OBJ_ACTIVITYVIDEO
  298. if detail == nil {
  299. EsDeleteComprehensiveData(item) //如果活动视频不存在 没有发布就删除
  300. }
  301. mapActivityIndustrialManagement := make(map[int][]string)
  302. mapActivitySubject := make(map[int][]string)
  303. industrialList, e := cygx.GetIndustrialActivityGroupManagementList(activityId, 1)
  304. if e != nil && e.Error() != utils.ErrNoRow() {
  305. err = errors.New("GetIndustrialActivityGroupManagementList" + e.Error())
  306. return
  307. }
  308. if len(industrialList) > 0 {
  309. for _, v := range industrialList {
  310. mapActivityIndustrialManagement[activityId] = append(mapActivityIndustrialManagement[activityId], v.IndustryName)
  311. }
  312. subjectList, e := cygx.GetSubjectActivityGroupManagementList(activityId, 1)
  313. if e != nil && e.Error() != utils.ErrNoRow() {
  314. err = errors.New("GetSubjectActivityGroupManagementList" + e.Error())
  315. return
  316. }
  317. if len(subjectList) > 0 {
  318. for _, v := range subjectList {
  319. mapActivitySubject[activityId] = append(mapActivitySubject[activityId], v.SubjectName)
  320. }
  321. }
  322. }
  323. item.SubjectNames = strings.Join(mapActivitySubject[detail.ActivityId], ",")
  324. item.IndustryName = strings.Join(mapActivityIndustrialManagement[detail.ActivityId], ",")
  325. item.Title = detail.VideoName
  326. item.BodyText = detailactivity.ActivityName
  327. item.PublishDate = detailactivity.ActivityTime
  328. EsAddOrEditComprehensiveData(item) //新增或者修改
  329. return
  330. }
  331. // Es添加活动音频
  332. func AddComprehensiveActivityVoice(activityId int) {
  333. var err error
  334. defer func() {
  335. if err != nil {
  336. fmt.Println("err:", err)
  337. go alarm_msg.SendAlarmMsg("AddComprehensiveActivityVoice,Err:"+err.Error(), 3)
  338. }
  339. }()
  340. detailactivity, e := cygx.GetAddActivityInfoById(activityId)
  341. if e != nil {
  342. err = errors.New("GetAddActivityInfoById" + e.Error())
  343. return
  344. }
  345. detail, e := cygx.GetCygxActivityVoiceReqDetail(activityId)
  346. if e != nil {
  347. err = errors.New("GetAddActivityInfoById" + e.Error())
  348. return
  349. }
  350. item := new(ElasticComprehensiveDetail)
  351. item.SourceId = detail.ActivityVoiceId
  352. item.Source = utils.CYGX_OBJ_ACTIVITYVOICE
  353. if detail == nil {
  354. EsDeleteComprehensiveData(item) //如果不存在就先删除
  355. }
  356. mapActivityIndustrialManagement := make(map[int][]string)
  357. mapActivitySubject := make(map[int][]string)
  358. industrialList, e := cygx.GetIndustrialActivityGroupManagementList(activityId, 1)
  359. if e != nil && e.Error() != utils.ErrNoRow() {
  360. err = errors.New("GetIndustrialActivityGroupManagementList" + e.Error())
  361. return
  362. }
  363. if len(industrialList) > 0 {
  364. for _, v := range industrialList {
  365. mapActivityIndustrialManagement[activityId] = append(mapActivityIndustrialManagement[activityId], v.IndustryName)
  366. }
  367. subjectList, e := cygx.GetSubjectActivityGroupManagementList(activityId, 1)
  368. if e != nil && e.Error() != utils.ErrNoRow() {
  369. err = errors.New("GetSubjectActivityGroupManagementList" + e.Error())
  370. return
  371. }
  372. if len(subjectList) > 0 {
  373. for _, v := range subjectList {
  374. mapActivitySubject[activityId] = append(mapActivitySubject[activityId], v.SubjectName)
  375. }
  376. }
  377. }
  378. item.SubjectNames = strings.Join(mapActivitySubject[detail.ActivityId], ",")
  379. item.IndustryName = strings.Join(mapActivityIndustrialManagement[detail.ActivityId], ",")
  380. item.Title = detail.VoiceName
  381. item.BodyText = detailactivity.ActivityName
  382. item.PublishDate = detailactivity.ActivityTime
  383. EsAddOrEditComprehensiveData(item) //新增或者修改
  384. return
  385. }
  386. // Es添加微路演
  387. func AddComprehensiveRoadshow(sourceId int) {
  388. var err error
  389. defer func() {
  390. if err != nil {
  391. fmt.Println("err:", err)
  392. go alarm_msg.SendAlarmMsg("AddComprehensiveActivityVoice,Err:"+err.Error(), 3)
  393. }
  394. }()
  395. v, e := cygx.GetMicroRoadshowVideoByVideoId(sourceId)
  396. if e != nil {
  397. err = errors.New("GetMicroRoadshowVideoByVideoId" + e.Error())
  398. return
  399. }
  400. item := new(ElasticComprehensiveDetail)
  401. item.SourceId = v.VideoId
  402. item.Source = utils.CYGX_OBJ_ROADSHOW
  403. item.IndustryName = v.IndustryName
  404. item.Title = v.VideoName
  405. item.PublishDate = v.PublishDate.Format(utils.FormatDateTime)
  406. if v.PublishStatus == 1 {
  407. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  408. } else {
  409. EsDeleteComprehensiveData(item) // 没有发布就删除
  410. }
  411. return
  412. }
  413. // Es添加晨会精华
  414. func AddComprehensiveMeetingreviewchapt(sourceId int) {
  415. var err error
  416. defer func() {
  417. if err != nil {
  418. fmt.Println("err:", err)
  419. go alarm_msg.SendAlarmMsg("AddComprehensiveMeetingreviewchapt,Err:"+err.Error(), 3)
  420. }
  421. }()
  422. v, e := cygx.GetCygxMorningMeetingReviewChapterDetail(sourceId)
  423. if e != nil {
  424. err = errors.New("GetCygxMorningMeetingReviewChapterDetail" + e.Error())
  425. return
  426. }
  427. content := html.UnescapeString(v.Content)
  428. doc, e := goquery.NewDocumentFromReader(strings.NewReader(content))
  429. if e != nil {
  430. err = errors.New("goquery.NewDocumentFromReader" + e.Error())
  431. return
  432. }
  433. bodyText := doc.Text()
  434. item := new(ElasticComprehensiveDetail)
  435. item.SourceId = sourceId
  436. item.Source = utils.CYGX_OBJ_MEETINGREVIEWCHAPT
  437. item.IndustryName = v.IndustryName
  438. item.PublishDate = v.MeetingTime.Format(utils.FormatDateTime)
  439. item.Abstract = bodyText
  440. EsAddOrEditComprehensiveData(item) //如果发布了就新增
  441. return
  442. }
  443. // Es删除晨会精华
  444. func DeleteComprehensiveMeetingreviewchapt(sourceId int) {
  445. var err error
  446. defer func() {
  447. if err != nil {
  448. fmt.Println("err:", err)
  449. go alarm_msg.SendAlarmMsg("AddComprehensiveMeetingreviewchapt,Err:"+err.Error(), 3)
  450. }
  451. }()
  452. item := new(ElasticComprehensiveDetail)
  453. item.SourceId = sourceId
  454. item.Source = utils.CYGX_OBJ_MEETINGREVIEWCHAPT
  455. EsDeleteComprehensiveData(item) //删除
  456. return
  457. }
  458. // 添加产业资源包
  459. func AddComprehensiveIndustrialSource(sourceType string, articleId int) {
  460. var err error
  461. defer func() {
  462. if err != nil {
  463. fmt.Println(err)
  464. go alarm_msg.SendAlarmMsg("AddComprehensiveIndustrialSource"+err.Error(), 2)
  465. }
  466. }()
  467. var condition string
  468. var pars []interface{}
  469. mapActivitySubject := make(map[int][]string, 0)
  470. listsubject, e := cygx.GetCygxIndustrialSubjectListCondition(condition, pars)
  471. if e != nil {
  472. err = errors.New("GetIndustrialManagementRepList, Err: " + e.Error())
  473. return
  474. }
  475. for _, v := range listsubject {
  476. mapActivitySubject[v.IndustrialManagementId] = append(mapActivitySubject[v.IndustrialManagementId], v.SubjectName)
  477. }
  478. var industrialsource string
  479. if sourceType == "Hz" {
  480. condition = " AND a.article_type_id = 0 " // 弘则资源包
  481. industrialsource = "industrialsourceHz"
  482. } else {
  483. condition = " AND a.article_type_id > 0 " //研选资源包
  484. industrialsource = "industrialsourceYx"
  485. }
  486. if articleId > 0 {
  487. condition += " AND a.article_id = " + strconv.Itoa(articleId)
  488. }
  489. list, err := cygx.GetSearchResourceList(0, condition, 0, 0)
  490. if err != nil {
  491. fmt.Println(err)
  492. return
  493. }
  494. if len(list) == 0 {
  495. return
  496. }
  497. for _, v := range list {
  498. item := new(ElasticComprehensiveDetail)
  499. item.SourceId = v.IndustrialManagementId
  500. item.Source = industrialsource
  501. item.IndustryName = v.IndustryName
  502. item.SubjectNames = strings.Join(mapActivitySubject[v.IndustrialManagementId], ",")
  503. item.PublishDate = v.PublishDate + " 00:00:00"
  504. EsAddOrEditComprehensiveData(item)
  505. }
  506. }