question.go 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241
  1. package llm
  2. import (
  3. "encoding/json"
  4. "eta/eta_api/controllers"
  5. "eta/eta_api/models"
  6. "eta/eta_api/models/rag"
  7. "eta/eta_api/models/rag/request"
  8. "eta/eta_api/models/rag/response"
  9. "eta/eta_api/utils"
  10. "fmt"
  11. "github.com/rdlucklib/rdluck_tools/paging"
  12. "strings"
  13. "time"
  14. )
  15. // QuestionController
  16. // @Description: 问题库管理
  17. type QuestionController struct {
  18. controllers.BaseAuthController
  19. }
  20. // List
  21. // @Title 列表
  22. // @Description 列表
  23. // @Param PageSize query int true "每页数据条数"
  24. // @Param CurrentIndex query int true "当前页页码,从1开始"
  25. // @Param KeyWord query string true "搜索关键词"
  26. // @Success 200 {object} []*rag.QuestionListListResp
  27. // @router /question/list [get]
  28. func (c *QuestionController) List() {
  29. br := new(models.BaseResponse).Init()
  30. defer func() {
  31. c.Data["json"] = br
  32. c.ServeJSON()
  33. }()
  34. sysUser := c.SysUser
  35. if sysUser == nil {
  36. br.Msg = "请登录"
  37. br.ErrMsg = "请登录,SysUser Is Empty"
  38. return
  39. }
  40. pageSize, _ := c.GetInt("PageSize")
  41. currentIndex, _ := c.GetInt("CurrentIndex")
  42. keyWord := c.GetString("KeyWord")
  43. var startSize int
  44. if pageSize <= 0 {
  45. pageSize = utils.PageSize20
  46. }
  47. if currentIndex <= 0 {
  48. currentIndex = 1
  49. }
  50. startSize = utils.StartIndex(currentIndex, pageSize)
  51. var condition string
  52. var pars []interface{}
  53. if keyWord != "" {
  54. condition += fmt.Sprintf(` AND %s like ?`, rag.QuestionColumns.QuestionContent)
  55. pars = append(pars, `%`+keyWord+`%`)
  56. }
  57. obj := new(rag.Question)
  58. total, list, err := obj.GetPageListByCondition(condition, pars, startSize, pageSize)
  59. if err != nil {
  60. br.Msg = "获取失败"
  61. br.ErrMsg = "获取失败,Err:" + err.Error()
  62. return
  63. }
  64. viewList := obj.ListToViewList(list)
  65. page := paging.GetPaging(currentIndex, pageSize, total)
  66. resp := response.QuestionListListResp{
  67. List: viewList,
  68. Paging: page,
  69. }
  70. br.Ret = 200
  71. br.Success = true
  72. br.Msg = "获取成功"
  73. br.Data = resp
  74. }
  75. // Add
  76. // @Title 新增问题
  77. // @Description 新增问题
  78. // @Param request body request.AddQuestionReq true "type json string"
  79. // @Success 200 Ret=200 新增成功
  80. // @router /question/add [post]
  81. func (c *QuestionController) Add() {
  82. br := new(models.BaseResponse).Init()
  83. defer func() {
  84. c.Data["json"] = br
  85. c.ServeJSON()
  86. }()
  87. var req request.AddQuestionReq
  88. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  89. if err != nil {
  90. br.Msg = "参数解析异常!"
  91. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  92. return
  93. }
  94. req.Content = strings.TrimSpace(req.Content)
  95. if req.Content == "" {
  96. br.Msg = "请输入问题"
  97. br.IsSendEmail = false
  98. return
  99. }
  100. obj := rag.Question{}
  101. _, err = obj.GetByCondition(` AND question_content = ? `, []interface{}{req.Content})
  102. if err == nil {
  103. br.Msg = "问题已入库,请不要重复添加"
  104. br.IsSendEmail = false
  105. return
  106. }
  107. item := &rag.Question{
  108. QuestionId: 0,
  109. QuestionContent: req.Content,
  110. Sort: 0,
  111. ModifyTime: time.Now(),
  112. CreateTime: time.Now(),
  113. }
  114. err = item.Create()
  115. if err != nil {
  116. br.Msg = "添加失败"
  117. br.ErrMsg = "添加失败,Err:" + err.Error()
  118. return
  119. }
  120. br.Ret = 200
  121. br.Success = true
  122. br.Msg = `添加成功`
  123. }
  124. // Edit
  125. // @Title 编辑问题
  126. // @Description 编辑问题
  127. // @Param request body request.EditQuestionReq true "type json string"
  128. // @Success 200 Ret=200 新增成功
  129. // @router /question/edit [post]
  130. func (c *QuestionController) Edit() {
  131. br := new(models.BaseResponse).Init()
  132. defer func() {
  133. c.Data["json"] = br
  134. c.ServeJSON()
  135. }()
  136. var req request.EditQuestionReq
  137. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  138. if err != nil {
  139. br.Msg = "参数解析异常!"
  140. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  141. return
  142. }
  143. if req.QuestionId <= 0 {
  144. br.Msg = "问题id不能为空"
  145. br.IsSendEmail = false
  146. return
  147. }
  148. req.Content = strings.TrimSpace(req.Content)
  149. if req.Content == "" {
  150. br.Msg = "请输入问题"
  151. br.IsSendEmail = false
  152. return
  153. }
  154. obj := rag.Question{}
  155. item, err := obj.GetByID(req.QuestionId)
  156. if err != nil {
  157. br.Msg = "修改失败"
  158. br.ErrMsg = "修改失败,查找问题失败,Err:" + err.Error()
  159. if utils.IsErrNoRow(err) {
  160. br.Msg = "问题不存在"
  161. br.IsSendEmail = false
  162. }
  163. return
  164. }
  165. item.QuestionContent = req.Content
  166. item.ModifyTime = time.Now()
  167. err = item.Update([]string{"question_content", "modify_time"})
  168. if err != nil {
  169. br.Msg = "修改失败"
  170. br.ErrMsg = "修改失败,Err:" + err.Error()
  171. return
  172. }
  173. br.Ret = 200
  174. br.Success = true
  175. br.Msg = `添加成功`
  176. }
  177. // Del
  178. // @Title 删除问题
  179. // @Description 删除问题
  180. // @Param request body request.EditQuestionReq true "type json string"
  181. // @Success 200 Ret=200 新增成功
  182. // @router /question/del [post]
  183. func (c *QuestionController) Del() {
  184. br := new(models.BaseResponse).Init()
  185. defer func() {
  186. c.Data["json"] = br
  187. c.ServeJSON()
  188. }()
  189. var req request.EditQuestionReq
  190. err := json.Unmarshal(c.Ctx.Input.RequestBody, &req)
  191. if err != nil {
  192. br.Msg = "参数解析异常!"
  193. br.ErrMsg = "参数解析失败,Err:" + err.Error()
  194. return
  195. }
  196. if req.QuestionId <= 0 {
  197. br.Msg = "问题id不能为空"
  198. br.IsSendEmail = false
  199. return
  200. }
  201. obj := rag.Question{}
  202. item, err := obj.GetByID(req.QuestionId)
  203. if err != nil {
  204. br.Msg = "修改失败"
  205. br.ErrMsg = "修改失败,查找问题失败,Err:" + err.Error()
  206. if utils.IsErrNoRow(err) {
  207. br.Msg = "问题不存在"
  208. br.IsSendEmail = false
  209. }
  210. return
  211. }
  212. err = item.Del()
  213. if err != nil {
  214. br.Msg = "删除失败"
  215. br.ErrMsg = "删除失败,Err:" + err.Error()
  216. return
  217. }
  218. br.Ret = 200
  219. br.Success = true
  220. br.Msg = `删除成功`
  221. }