wechat_article.go 9.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302
  1. package elastic
  2. import (
  3. "context"
  4. "encoding/json"
  5. "eta/eta_api/models/rag"
  6. "eta/eta_api/utils"
  7. "fmt"
  8. "github.com/olivere/elastic/v7"
  9. "time"
  10. )
  11. // WechatArticleAndPlatform
  12. // @Description: 存入ES的数据
  13. type WechatArticleAndPlatform struct {
  14. WechatArticleId int `gorm:"column:wechat_article_id;type:int(10) UNSIGNED;primaryKey;not null;" description:""`
  15. WechatPlatformId int `gorm:"column:wechat_platform_id;type:int(11);comment:归属公众号id;default:0;" description:"归属公众号id"`
  16. FakeId string `gorm:"column:fake_id;type:varchar(255);comment:公众号唯一id;" description:"公众号唯一id"`
  17. Title string `gorm:"column:title;type:varchar(255);comment:标题;" description:"标题"`
  18. Link string `gorm:"column:link;type:varchar(255);comment:链接;" description:"链接"`
  19. CoverUrl string `gorm:"column:cover_url;type:varchar(255);comment:公众号封面;" description:"公众号封面"`
  20. Description string `gorm:"column:description;type:varchar(255);comment:描述;" description:"描述"`
  21. Content string `gorm:"column:content;type:longtext;comment:报告详情;" description:"报告详情"`
  22. TextContent string `gorm:"column:text_content;type:text;comment:文本内容;" description:"文本内容"`
  23. //Abstract string `gorm:"column:abstract;type:text;comment:摘要;" description:"摘要"`
  24. Country string `gorm:"column:country;type:varchar(255);comment:国家;" description:"国家"`
  25. Province string `gorm:"column:province;type:varchar(255);comment:省;" description:"省"`
  26. City string `gorm:"column:city;type:varchar(255);comment:市;" description:"市"`
  27. ArticleCreateTime time.Time `gorm:"column:article_create_time;type:datetime;comment:报告创建时间;default:NULL;" description:"报告创建时间"`
  28. IsDeleted int `gorm:"column:is_deleted;type:tinyint(4);comment:是否删除,0:未删除,1: 已删除;default:0;" description:"是否删除,0:未删除,1: 已删除"`
  29. ModifyTime time.Time `gorm:"column:modify_time;type:datetime;comment:修改时间;default:NULL;" description:"修改时间"`
  30. CreateTime time.Time `gorm:"column:create_time;type:datetime;comment:入库时间;default:NULL;" description:"入库时间"`
  31. Nickname string `gorm:"column:nickname;type:varchar(255);comment:公众号名称;" description:"nickname"` // 公众号名称
  32. Alias string `gorm:"column:alias;type:varchar(255);comment:别名;" description:"alias"` // 别名
  33. RoundHeadImg string `gorm:"column:round_head_img;type:varchar(255);comment:头像;" description:"round_head_img"` // 头像
  34. }
  35. func (m *WechatArticleAndPlatform) ToView() rag.WechatArticleView {
  36. var articleCreateTime, modifyTime, createTime string
  37. if !m.ArticleCreateTime.IsZero() {
  38. articleCreateTime = m.ArticleCreateTime.Format(utils.FormatDateTime)
  39. }
  40. if !m.CreateTime.IsZero() {
  41. createTime = m.CreateTime.Format(utils.FormatDateTime)
  42. }
  43. if !m.ModifyTime.IsZero() {
  44. modifyTime = m.ModifyTime.Format(utils.FormatDateTime)
  45. }
  46. return rag.WechatArticleView{
  47. WechatArticleId: m.WechatArticleId,
  48. WechatPlatformId: m.WechatPlatformId,
  49. FakeId: m.FakeId,
  50. Title: m.Title,
  51. Link: m.Link,
  52. CoverUrl: m.CoverUrl,
  53. Description: m.Description,
  54. Content: m.Content,
  55. TextContent: m.TextContent,
  56. //Abstract: m.Abstract,
  57. Country: m.Country,
  58. Province: m.Province,
  59. City: m.City,
  60. ArticleCreateTime: articleCreateTime,
  61. ModifyTime: modifyTime,
  62. CreateTime: createTime,
  63. WechatPlatformName: m.Nickname,
  64. WechatPlatformRoundHeadImg: m.RoundHeadImg,
  65. }
  66. }
  67. func (m *WechatArticleAndPlatform) ArticleAndPlatformListToViewList(list []*WechatArticleAndPlatform) (wechatArticleViewList []rag.WechatArticleView) {
  68. wechatArticleViewList = make([]rag.WechatArticleView, 0)
  69. for _, v := range list {
  70. wechatArticleViewList = append(wechatArticleViewList, v.ToView())
  71. }
  72. return
  73. }
  74. // WechatArticleEsAddOrEdit
  75. // @Description: 新增/编辑微信文章
  76. // @author: Roc
  77. // @datetime 2025-03-13 10:24:05
  78. // @param docId string
  79. // @param item WechatArticleAndPlatform
  80. // @return err error
  81. func WechatArticleEsAddOrEdit(docId string, item WechatArticleAndPlatform) (err error) {
  82. if docId == "" {
  83. return
  84. }
  85. if utils.EsWechatArticleName == `` {
  86. return
  87. }
  88. defer func() {
  89. if err != nil {
  90. fmt.Println("WechatArticleEsAddOrEdit Err:", err.Error())
  91. }
  92. }()
  93. client := utils.EsClient
  94. resp, err := client.Index().Index(utils.EsWechatArticleName).Id(docId).BodyJson(item).Refresh("true").Do(context.Background())
  95. if err != nil {
  96. fmt.Println("新增失败:", err.Error())
  97. return err
  98. }
  99. if resp.Status == 0 {
  100. fmt.Println("新增成功", resp.Result)
  101. err = nil
  102. } else {
  103. fmt.Println("WechatArticleEsAddOrEdit", resp.Status, resp.Result)
  104. }
  105. return
  106. }
  107. // WechatArticleEsDel
  108. // @Description: 删除微信文章
  109. // @author: Roc
  110. // @datetime 2025-03-13 10:23:55
  111. // @param docId string
  112. // @return err error
  113. func WechatArticleEsDel(docId string) (err error) {
  114. if docId == "" {
  115. return
  116. }
  117. if utils.EsWechatArticleName == `` {
  118. return
  119. }
  120. defer func() {
  121. if err != nil {
  122. fmt.Println("EsDeleteEdbInfoData Err:", err.Error())
  123. }
  124. }()
  125. client := utils.EsClient
  126. resp, err := client.Delete().Index(utils.EsWechatArticleName).Id(docId).Refresh(`true`).Do(context.Background())
  127. if err != nil {
  128. return
  129. }
  130. if resp.Status == 0 {
  131. fmt.Println("删除成功")
  132. } else {
  133. fmt.Println("WechatArticleEsDel", resp.Status, resp.Result)
  134. }
  135. return
  136. }
  137. func WechatArticleEsSearch(keywordStr string, wechatPlatformId, from, size int, sortMap map[string]string) (total int64, list []*WechatArticleAndPlatform, err error) {
  138. indexName := utils.EsWechatArticleName
  139. list = make([]*WechatArticleAndPlatform, 0)
  140. defer func() {
  141. if err != nil {
  142. fmt.Println("SearchEdbInfoData Err:", err.Error())
  143. }
  144. }()
  145. query := elastic.NewBoolQuery()
  146. if wechatPlatformId > 0 {
  147. query = query.Must(elastic.NewTermQuery("WechatPlatformId", wechatPlatformId))
  148. }
  149. // 名字匹配
  150. if keywordStr != `` {
  151. query = query.Must(elastic.NewMultiMatchQuery(keywordStr, "Title"))
  152. }
  153. // 排序
  154. sortList := make([]*elastic.FieldSort, 0)
  155. // 如果没有关键字,那么就走指标id倒序
  156. for orderKey, orderType := range sortMap {
  157. switch orderType {
  158. case "asc":
  159. sortList = append(sortList, elastic.NewFieldSort(orderKey).Asc())
  160. case "desc":
  161. sortList = append(sortList, elastic.NewFieldSort(orderKey).Desc())
  162. }
  163. }
  164. return searchWechatArticle(indexName, query, sortList, from, size)
  165. }
  166. // searchEdbInfoDataV2 查询es中的数据
  167. func searchWechatArticle(indexName string, query elastic.Query, sortList []*elastic.FieldSort, from, size int) (total int64, list []*WechatArticleAndPlatform, err error) {
  168. total, err = searchWechatArticleTotal(indexName, query)
  169. if err != nil {
  170. return
  171. }
  172. // 获取列表数据
  173. list, err = searchWechatArticleList(indexName, query, sortList, from, size)
  174. if err != nil {
  175. return
  176. }
  177. return
  178. }
  179. // searchEdbInfoDataTotal
  180. // @Description: 查询es中的数量
  181. // @author: Roc
  182. // @datetime 2024-12-23 11:19:04
  183. // @param indexName string
  184. // @param query elastic.Query
  185. // @return total int64
  186. // @return err error
  187. func searchWechatArticleTotal(indexName string, query elastic.Query) (total int64, err error) {
  188. defer func() {
  189. if err != nil {
  190. fmt.Println("searchEdbInfoDataTotal Err:", err.Error())
  191. }
  192. }()
  193. client := utils.EsClient
  194. //根据条件数量统计
  195. requestTotalHits := client.Count(indexName).Query(query)
  196. total, err = requestTotalHits.Do(context.Background())
  197. if err != nil {
  198. return
  199. }
  200. return
  201. }
  202. // searchEdbInfoDataList
  203. // @Description: 查询es中的明细数据
  204. // @author: Roc
  205. // @datetime 2024-12-23 11:18:48
  206. // @param indexName string
  207. // @param query elastic.Query
  208. // @param sortList []*elastic.FieldSort
  209. // @param from int
  210. // @param size int
  211. // @return list []*data_manage.EdbInfoList
  212. // @return err error
  213. func searchWechatArticleList(indexName string, query elastic.Query, sortList []*elastic.FieldSort, from, size int) (list []*WechatArticleAndPlatform, err error) {
  214. list = make([]*WechatArticleAndPlatform, 0)
  215. defer func() {
  216. if err != nil {
  217. fmt.Println("searchEdbInfoDataList Err:", err.Error())
  218. }
  219. }()
  220. client := utils.EsClient
  221. // 高亮
  222. highlight := elastic.NewHighlight()
  223. highlight = highlight.Fields(elastic.NewHighlighterField("Title"))
  224. highlight = highlight.PreTags("<font color='red'>").PostTags("</font>")
  225. //request := client.Search(indexName).Highlight(highlight).From(from).Size(size) // sets the JSON request
  226. request := client.Search(indexName).From(from).Size(size) // sets the JSON request
  227. // 如果有指定排序,那么就按照排序来
  228. if len(sortList) > 0 {
  229. for _, v := range sortList {
  230. request = request.SortBy(v)
  231. }
  232. }
  233. searchMap := make(map[string]string)
  234. searchResp, err := request.Query(query).Do(context.Background())
  235. if err != nil {
  236. return
  237. }
  238. //fmt.Println(searchResp)
  239. //fmt.Println(searchResp.Status)
  240. if searchResp.Status != 0 {
  241. return
  242. }
  243. //total = searchResp.TotalHits()
  244. if searchResp.Hits != nil {
  245. for _, v := range searchResp.Hits.Hits {
  246. if _, ok := searchMap[v.Id]; !ok {
  247. itemJson, tmpErr := v.Source.MarshalJSON()
  248. if tmpErr != nil {
  249. err = tmpErr
  250. fmt.Println("movieJson err:", err)
  251. return
  252. }
  253. item := new(WechatArticleAndPlatform)
  254. tmpErr = json.Unmarshal(itemJson, &item)
  255. if tmpErr != nil {
  256. fmt.Println("json.Unmarshal movieJson err:", tmpErr)
  257. err = tmpErr
  258. return
  259. }
  260. if len(v.Highlight["Title"]) > 0 {
  261. item.Title = v.Highlight["Title"][0]
  262. }
  263. list = append(list, item)
  264. searchMap[v.Id] = v.Id
  265. }
  266. }
  267. }
  268. return
  269. }