knowledgeService.go 9.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264
  1. package service
  2. import (
  3. cm "app.yhyue.com/moapp/jybase/common"
  4. . "app.yhyue.com/moapp/jybase/encrypt"
  5. elastic "app.yhyue.com/moapp/jybase/esv1"
  6. . "bp.jydev.jianyu360.cn/SocialPlatform/knowledgeBase/entity"
  7. "bp.jydev.jianyu360.cn/SocialPlatform/knowledgeBase/rpc/knowledge/knowledgeclient"
  8. "bp.jydev.jianyu360.cn/SocialPlatform/knowledgeBase/rpc/knowledge/util"
  9. "database/sql"
  10. "fmt"
  11. "github.com/zeromicro/go-zero/core/logx"
  12. "log"
  13. "strconv"
  14. "time"
  15. )
  16. type KnowledgeService struct{}
  17. var (
  18. Index = "smart_new"
  19. Type = "smart"
  20. )
  21. // KnowledgeAdd 添加问题
  22. func (k *KnowledgeService) KnowledgeAdd(param *knowledgeclient.AddRequest, segment string) (bool, string) {
  23. //先查找知识库Id
  24. query := map[string]interface{}{"status": 1, "appid": param.AppId, "ent_id": param.EntId}
  25. datalist := Mysql.Find(util.KNOWLEDGE, query, "id", "", -1, -1)
  26. if datalist != nil && *datalist != nil && len(*datalist) > 0 {
  27. //问题进行分词
  28. keywords := ""
  29. keywordsArr := util.HanlpGetNormalWords(param.Question, segment)
  30. if len(keywordsArr) != 0 {
  31. for _, val := range keywordsArr {
  32. keywords += val + " "
  33. }
  34. }
  35. if keywords == "" {
  36. keywords = param.Question
  37. }
  38. createPerson := param.EntUserId
  39. var answerId int64
  40. nowTime := time.Now().Local().Format(util.DateFullLayout)
  41. fool := Mysql.ExecTx("添加知识", func(tx *sql.Tx) bool {
  42. //插入答案
  43. answerData := map[string]interface{}{
  44. "knowledge_id": (*datalist)[0]["id"],
  45. "status": 1,
  46. "create_time": nowTime,
  47. "update_time": nowTime,
  48. "create_person": createPerson,
  49. "content": param.Answer,
  50. }
  51. answerId = Mysql.Insert(util.ANSWER, answerData)
  52. //插入问题
  53. questionData := map[string]interface{}{
  54. "answer_id": answerId,
  55. "content": param.Question,
  56. "keywords": keywords,
  57. }
  58. questionId := Mysql.Insert(util.QUESTION, questionData)
  59. return answerId > 0 && questionId > 0
  60. })
  61. if fool {
  62. //插入es
  63. knowledge := map[string]interface{}{
  64. "knowledgeId": (*datalist)[0]["id"],
  65. "status": 1,
  66. "createTime": time.Now().Unix(),
  67. "createPerson": createPerson,
  68. "answer": param.Answer,
  69. "question": param.Question,
  70. "keywords": keywords,
  71. "answerId": answerId,
  72. "entId": param.EntId,
  73. }
  74. b := elastic.Save(Index, Type, knowledge)
  75. return b, ""
  76. }
  77. return fool, "插入mysql出错"
  78. }
  79. return false, "租户不存在"
  80. }
  81. // KnowledgeEdit 编辑问题
  82. func (k *KnowledgeService) KnowledgeEdit(param *knowledgeclient.KnowledgeEditReq, segment string) (ok bool) {
  83. ok = false
  84. //获取问题分词
  85. keywords := ""
  86. keywordsArr := util.HanlpGetNormalWords(param.Question, segment)
  87. logx.Info("keywordsArr", keywordsArr)
  88. if len(keywordsArr) != 0 {
  89. for _, val := range keywordsArr {
  90. keywords += val + " "
  91. }
  92. }
  93. if keywords == "" {
  94. keywords = param.Question
  95. }
  96. //通过entUserId获取创建人名称
  97. /*req := &usercenter.EntUserReq{
  98. EntId: param.EntId,
  99. EntUserId: param.EntUserId,
  100. AppId: param.AppId,
  101. }
  102. resp, err := UserCenterLib.GetEntUserInfo(context.Background(), req)
  103. if resp.ErrorCode != 0 {
  104. logx.Info("查询用户中台创建人信息失败", param.EntId, param.EntUserId, "err:", err)
  105. return ok
  106. }*/
  107. createPerson := param.EntUserId
  108. fool := Mysql.ExecTx("编辑问题、答案", func(tx *sql.Tx) bool {
  109. //修改答案
  110. answerUpdate := map[string]interface{}{
  111. "update_time": time.Now().Local().Format(util.DateFullLayout),
  112. "content": param.Answer,
  113. }
  114. ok1 := Mysql.UpdateByTx(tx, util.ANSWER, map[string]interface{}{"id": param.AnswerId}, answerUpdate)
  115. //修改问题
  116. questionUpdate := map[string]interface{}{
  117. "content": param.Question,
  118. "keywords": keywords,
  119. }
  120. ok2 := Mysql.UpdateByTx(tx, util.QUESTION, map[string]interface{}{"answer_id": param.AnswerId}, questionUpdate)
  121. return ok1 && ok2
  122. })
  123. if fool {
  124. query := `{"query":{"bool":{"must":[{"term":{"answerId":"` + strconv.Itoa(int(param.AnswerId)) + `"}}],"must_not":[],"should":[]}},"from":0,"size":10,"sort":[],"facets":{}}`
  125. //修改es数据
  126. newKnowledge := map[string]interface{}{
  127. "knowledgeId": param.KnowledgeId,
  128. "status": 1,
  129. "createTime": time.Now().Unix(),
  130. "createPerson": createPerson,
  131. "answer": param.Answer,
  132. "question": param.Question,
  133. "keywords": keywords,
  134. "answerId": param.AnswerId,
  135. "entId": param.EntId,
  136. }
  137. ok1 := elastic.Del(Index, Type, query)
  138. ok2 := elastic.Save(Index, Type, newKnowledge)
  139. return ok1 && ok2
  140. }
  141. return ok
  142. }
  143. // KnowledgeList 问题列表
  144. func (k *KnowledgeService) KnowledgeList(param *knowledgeclient.ListRequest) *knowledgeclient.ListData {
  145. var knowledgeList knowledgeclient.ListData
  146. var data []*knowledgeclient.KnowledgeEntity
  147. countSql := fmt.Sprintf("SELECT COUNT(b.id) FROM %s a LEFT JOIN %s b ON a.id = b.knowledge_id LEFT JOIN %s c ON b.id = c.answer_id WHERE b.`status` =1 and a.ent_id=%d", util.KNOWLEDGE, util.ANSWER, util.QUESTION, param.EntId)
  148. count := Mysql.CountBySql(countSql)
  149. if count > 0 {
  150. //列表数据
  151. sql1 := fmt.Sprintf("SELECT b.content as answer,c.content as question,b.id,b.knowledge_id FROM %s a LEFT JOIN %s b ON a.id = b.knowledge_id LEFT JOIN %s c ON b.id = c.answer_id WHERE b.`status` =1 and a.ent_id=? order by b.update_time desc limit ?,?", util.KNOWLEDGE, util.ANSWER, util.QUESTION)
  152. datalist := Mysql.SelectBySql(sql1, param.EntId, (param.PageIndex-1)*param.PageSize, param.PageSize)
  153. if datalist != nil && *datalist != nil && len(*datalist) > 0 {
  154. for _, value := range *datalist {
  155. knowledge := knowledgeclient.KnowledgeEntity{}
  156. knowledge.Answer = cm.ObjToString(value["answer"])
  157. knowledge.Question = cm.ObjToString(value["question"])
  158. knowledge.AnswerId = cm.Int64All(value["id"])
  159. knowledge.KnowledgeId = cm.Int64All(value["knowledge_id"])
  160. data = append(data, &knowledge)
  161. }
  162. }
  163. knowledgeList.Total = count
  164. knowledgeList.Data = data
  165. }
  166. return &knowledgeList
  167. }
  168. // KnowledgeInfo 问题详情
  169. func (k *KnowledgeService) KnowledgeInfo(answerId int64) (data *knowledgeclient.KnowledgeEntity, ok bool) {
  170. //util.ANSWER,util.QUESTION
  171. sql1 := fmt.Sprintf("SELECT b.content as answer,c.content as question,b.id,b.knowledge_id FROM %s b LEFT JOIN %s c ON b.id = c.answer_id WHERE b.`status` =1 AND b.id = %d", util.ANSWER, util.QUESTION, answerId)
  172. datalist := Mysql.SelectBySql(sql1)
  173. if datalist != nil && *datalist != nil && len(*datalist) > 0 {
  174. knowledge := knowledgeclient.KnowledgeEntity{}
  175. knowledge.Answer = cm.ObjToString((*datalist)[0]["answer"])
  176. knowledge.Question = cm.ObjToString((*datalist)[0]["question"])
  177. knowledge.AnswerId = cm.Int64All((*datalist)[0]["id"])
  178. knowledge.KnowledgeId = cm.Int64All((*datalist)[0]["knowledge_id"])
  179. return &knowledge, true
  180. }
  181. return nil, false
  182. }
  183. // KnowledgeDel 删除问题
  184. func (k *KnowledgeService) KnowledgeDel(answerId int64) (ok bool) {
  185. ok = false
  186. //修改答案
  187. answerUpdate := map[string]interface{}{
  188. "update_time": time.Now().Local().Format(util.DateFullLayout),
  189. "status": 0,
  190. }
  191. fool := Mysql.Update(util.ANSWER, map[string]interface{}{"id": answerId}, answerUpdate)
  192. if fool {
  193. //删除es数据
  194. query := `{"query":{"bool":{"must":[{"term":{"answerId":"` + strconv.Itoa(int(answerId)) + `"}}],"must_not":[],"should":[]}},"from":0,"size":1,"sort":[],"facets":{}}`
  195. ok = elastic.Del(Index, Type, query)
  196. }
  197. return ok
  198. }
  199. // FindAnswer 根据问题推荐一个答案
  200. func (k *KnowledgeService) FindAnswer(param *knowledgeclient.FindAnswerReq, addr, index, segment string) *knowledgeclient.Question {
  201. var question knowledgeclient.Question
  202. robotEntId := SE.Decode4Hex(param.RobotEntId)
  203. //组装es query
  204. query := util.DSL4SmartResponse(param.Question, robotEntId, int(param.Type), addr, index, segment)
  205. logx.Info("query:", query)
  206. if query != "" {
  207. res := elastic.Get(Index, Type, query)
  208. if res != nil && len(*res) > 0 {
  209. data := (*res)[0]
  210. question.Answer = cm.ObjToString(data["answer"])
  211. question.Question = cm.ObjToString(data["question"])
  212. }
  213. }
  214. return &question
  215. }
  216. // RecommendAnswer 根据问题推荐三个答案
  217. func (k *KnowledgeService) RecommendAnswer(param *knowledgeclient.FindAnswerReq, segment string, recommendQuestionCount int) []*knowledgeclient.Question {
  218. var (
  219. keyWords = ""
  220. searchField = `"answer","question"`
  221. answers []*knowledgeclient.Question
  222. )
  223. //根据问题进行分词
  224. keywordsArr := util.HanlpGetNormalWords(param.Question, segment)
  225. logx.Info("keywordsArr", keywordsArr)
  226. if len(keywordsArr) != 0 {
  227. for _, val := range keywordsArr {
  228. keyWords += val + " "
  229. }
  230. }
  231. if keyWords == "" {
  232. keyWords = param.Question
  233. }
  234. //logx.Info("entId:", SE.Decode4Hex(param.RobotEntId))
  235. var query = util.DSL4SearchByKwsOrid(keyWords, param.RobotEntId, 0)
  236. limit := 3
  237. if param.ReqSource == 1 {
  238. limit = recommendQuestionCount
  239. }
  240. res := elastic.GetAllByNgram(Index, Type, query, "", "", searchField, 0, limit, 0, false)
  241. if res != nil && len(*res) > 0 {
  242. for _, val := range *res {
  243. answers = append(answers, &knowledgeclient.Question{
  244. Question: cm.ObjToString(val["question"]),
  245. Answer: cm.ObjToString(val["answer"]),
  246. })
  247. }
  248. log.Println("推荐答案:", answers)
  249. }
  250. return answers
  251. }