rag_question.go 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294
  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. // 问题索引
  12. var EsRagQuestionName = utils.EsRagQuestionName
  13. type RagQuestionItem struct {
  14. QuestionId int `gorm:"column:question_id;type:int(9) UNSIGNED;primaryKey;not null;" description:"question_id"`
  15. QuestionTitle string `gorm:"column:question_title;type:varchar(255);comment:问题标题;" description:"问题标题"`
  16. QuestionContent string `gorm:"column:question_content;type:varchar(255);comment:问题内容;" description:"问题内容"`
  17. Sort int `gorm:"column:sort;type:int(11);comment:排序;default:0;" description:"排序"`
  18. IsDefault int `gorm:"column:is_default;type:int(1);comment:是否默认提示词;default:NULL;" description:"是否默认提示词"`
  19. SysUserId int `gorm:"column:sys_user_id;type:int(11);comment:添加人id;default:0;" description:"添加人id"`
  20. SysUserRealName string `gorm:"column:sys_user_real_name;type:varchar(255);comment:添加人真实名称;" description:"添加人真实名称"`
  21. ModifyTime time.Time `gorm:"column:modify_time;type:datetime;default:NULL;" description:"modify_time"`
  22. CreateTime time.Time `gorm:"column:create_time;type:datetime;default:NULL;" description:"create_time"`
  23. }
  24. func (m *RagQuestionItem) ToView() rag.QuestionView {
  25. var modifyTime, createTime string
  26. if !m.CreateTime.IsZero() {
  27. createTime = m.CreateTime.Format(utils.FormatDateTime)
  28. }
  29. if !m.ModifyTime.IsZero() {
  30. modifyTime = m.ModifyTime.Format(utils.FormatDateTime)
  31. }
  32. return rag.QuestionView{
  33. QuestionId: m.QuestionId,
  34. QuestionTitle: m.QuestionTitle,
  35. QuestionContent: m.QuestionContent,
  36. Sort: m.Sort,
  37. IsDefault: m.IsDefault,
  38. SysUserId: m.SysUserId,
  39. SysUserRealName: m.SysUserRealName,
  40. ModifyTime: modifyTime,
  41. CreateTime: createTime,
  42. }
  43. }
  44. func (m *RagQuestionItem) ToViewList(list []*RagQuestionItem) (wechatArticleViewList []rag.QuestionView) {
  45. wechatArticleViewList = make([]rag.QuestionView, 0)
  46. for _, v := range list {
  47. wechatArticleViewList = append(wechatArticleViewList, v.ToView())
  48. }
  49. return
  50. }
  51. // RagQuestionEsAddOrEdit
  52. // @Description: 新增/编辑微信文章
  53. // @author: Roc
  54. // @datetime 2025-03-13 10:24:05
  55. // @param docId string
  56. // @param item WechatArticleAndPlatform
  57. // @return err error
  58. func RagQuestionEsAddOrEdit(docId string, item RagQuestionItem) (err error) {
  59. if docId == "" {
  60. return
  61. }
  62. if EsRagQuestionName == `` {
  63. return
  64. }
  65. defer func() {
  66. if err != nil {
  67. fmt.Println("WechatArticleEsAddOrEdit Err:", err.Error())
  68. }
  69. }()
  70. client := utils.EsClient
  71. resp, err := client.Index().Index(EsRagQuestionName).Id(docId).BodyJson(item).Refresh("true").Do(context.Background())
  72. if err != nil {
  73. fmt.Println("新增失败:", err.Error())
  74. return err
  75. }
  76. if resp.Status == 0 {
  77. fmt.Println("新增成功", resp.Result)
  78. err = nil
  79. } else {
  80. fmt.Println("WechatArticleEsAddOrEdit", resp.Status, resp.Result)
  81. }
  82. return
  83. }
  84. // WechatArticleEsDel
  85. // @Description: 删除微信文章
  86. // @author: Roc
  87. // @datetime 2025-03-13 10:23:55
  88. // @param docId string
  89. // @return err error
  90. func RagQuestionEsDel(docId string) (err error) {
  91. if docId == "" {
  92. return
  93. }
  94. if EsRagQuestionName == `` {
  95. return
  96. }
  97. defer func() {
  98. if err != nil {
  99. fmt.Println("EsDeleteEdbInfoData Err:", err.Error())
  100. }
  101. }()
  102. client := utils.EsClient
  103. resp, err := client.Delete().Index(EsRagQuestionName).Id(docId).Refresh(`true`).Do(context.Background())
  104. if err != nil {
  105. return
  106. }
  107. if resp.Status == 0 {
  108. fmt.Println("删除成功")
  109. } else {
  110. fmt.Println("WechatArticleEsDel", resp.Status, resp.Result)
  111. }
  112. return
  113. }
  114. // RagQuestionEsSearch
  115. // @Description: 搜索
  116. // @author: Roc
  117. // @datetime 2025-03-13 19:54:54
  118. // @param keywordStr string
  119. // @param tagIdList []int
  120. // @param platformIdList []int
  121. // @param from int
  122. // @param size int
  123. // @param sortMap map[string]string
  124. // @return total int64
  125. // @return list []*RagQuestionItem
  126. // @return err error
  127. func RagQuestionEsSearch(keywordStr string, isQueryDefault bool, from, size int, sortMap map[string]string) (total int64, list []*RagQuestionItem, err error) {
  128. indexName := EsRagQuestionName
  129. list = make([]*RagQuestionItem, 0)
  130. defer func() {
  131. if err != nil {
  132. fmt.Println("SearchEdbInfoData Err:", err.Error())
  133. }
  134. }()
  135. query := elastic.NewBoolQuery()
  136. // 名字匹配
  137. if keywordStr != `` {
  138. query = query.Must(elastic.NewMultiMatchQuery(keywordStr, "QuestionContent"))
  139. }
  140. if isQueryDefault {
  141. query = query.Must(elastic.NewTermQuery("IsDefault", 1))
  142. }
  143. // 排序
  144. sortList := make([]*elastic.FieldSort, 0)
  145. // 如果没有关键字,那么就走指标id倒序
  146. for orderKey, orderType := range sortMap {
  147. switch orderType {
  148. case "asc":
  149. sortList = append(sortList, elastic.NewFieldSort(orderKey).Asc())
  150. case "desc":
  151. sortList = append(sortList, elastic.NewFieldSort(orderKey).Desc())
  152. }
  153. }
  154. return searchRagQuestion(indexName, query, sortList, from, size)
  155. }
  156. // searchRagQuestion 查询es中的数据
  157. func searchRagQuestion(indexName string, query elastic.Query, sortList []*elastic.FieldSort, from, size int) (total int64, list []*RagQuestionItem, err error) {
  158. total, err = searchRagQuestionTotal(indexName, query)
  159. if err != nil {
  160. return
  161. }
  162. // 获取列表数据
  163. list, err = searchRagQuestionList(indexName, query, sortList, from, size)
  164. if err != nil {
  165. return
  166. }
  167. return
  168. }
  169. // searchEdbInfoDataTotal
  170. // @Description: 查询es中的数量
  171. // @author: Roc
  172. // @datetime 2024-12-23 11:19:04
  173. // @param indexName string
  174. // @param query elastic.Query
  175. // @return total int64
  176. // @return err error
  177. func searchRagQuestionTotal(indexName string, query elastic.Query) (total int64, err error) {
  178. defer func() {
  179. if err != nil {
  180. fmt.Println("searchEdbInfoDataTotal Err:", err.Error())
  181. }
  182. }()
  183. client := utils.EsClient
  184. //根据条件数量统计
  185. requestTotalHits := client.Count(indexName).Query(query)
  186. total, err = requestTotalHits.Do(context.Background())
  187. if err != nil {
  188. return
  189. }
  190. return
  191. }
  192. // searchEdbInfoDataList
  193. // @Description: 查询es中的明细数据
  194. // @author: Roc
  195. // @datetime 2024-12-23 11:18:48
  196. // @param indexName string
  197. // @param query elastic.Query
  198. // @param sortList []*elastic.FieldSort
  199. // @param from int
  200. // @param size int
  201. // @return list []*data_manage.EdbInfoList
  202. // @return err error
  203. func searchRagQuestionList(indexName string, query elastic.Query, sortList []*elastic.FieldSort, from, size int) (list []*RagQuestionItem, err error) {
  204. list = make([]*RagQuestionItem, 0)
  205. defer func() {
  206. if err != nil {
  207. fmt.Println("searchEdbInfoDataList Err:", err.Error())
  208. }
  209. }()
  210. client := utils.EsClient
  211. // 高亮
  212. highlight := elastic.NewHighlight()
  213. highlight = highlight.Fields(elastic.NewHighlighterField("Content"))
  214. highlight = highlight.PreTags("<font color='red'>").PostTags("</font>")
  215. //request := client.Search(indexName).Highlight(highlight).From(from).Size(size) // sets the JSON request
  216. request := client.Search(indexName).From(from).Size(size) // sets the JSON request
  217. // 如果有指定排序,那么就按照排序来
  218. if len(sortList) > 0 {
  219. for _, v := range sortList {
  220. request = request.SortBy(v)
  221. }
  222. }
  223. searchMap := make(map[string]string)
  224. searchResp, err := request.Query(query).Do(context.Background())
  225. if err != nil {
  226. return
  227. }
  228. //fmt.Println(searchResp)
  229. //fmt.Println(searchResp.Status)
  230. if searchResp.Status != 0 {
  231. return
  232. }
  233. //total = searchResp.TotalHits()
  234. if searchResp.Hits != nil {
  235. for _, v := range searchResp.Hits.Hits {
  236. if _, ok := searchMap[v.Id]; !ok {
  237. itemJson, tmpErr := v.Source.MarshalJSON()
  238. if tmpErr != nil {
  239. err = tmpErr
  240. fmt.Println("movieJson err:", err)
  241. return
  242. }
  243. item := new(RagQuestionItem)
  244. tmpErr = json.Unmarshal(itemJson, &item)
  245. if tmpErr != nil {
  246. fmt.Println("json.Unmarshal movieJson err:", tmpErr)
  247. err = tmpErr
  248. return
  249. }
  250. if len(v.Highlight["QuestionContent"]) > 0 {
  251. item.QuestionContent = v.Highlight["QuestionContent"][0]
  252. }
  253. list = append(list, item)
  254. searchMap[v.Id] = v.Id
  255. }
  256. }
  257. }
  258. return
  259. }