process_request.go 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160
  1. package process
  2. import (
  3. "fmt"
  4. "strings"
  5. "time"
  6. "github.com/eryajf/chatgpt-dingtalk/public"
  7. "github.com/eryajf/chatgpt-dingtalk/public/logger"
  8. "github.com/solywsh/chatgpt"
  9. )
  10. // ProcessRequest 分析处理请求逻辑
  11. func ProcessRequest(rmsg public.ReceiveMsg) error {
  12. if CheckRequest(rmsg) {
  13. content := strings.TrimSpace(rmsg.Text.Content)
  14. switch content {
  15. case "单聊":
  16. public.UserService.SetUserMode(rmsg.SenderStaffId, content)
  17. _, err := rmsg.ReplyText(fmt.Sprintf("=====现在进入与👉%s👈单聊的模式 =====", rmsg.SenderNick), rmsg.SenderStaffId)
  18. if err != nil {
  19. logger.Warning(fmt.Errorf("send message error: %v", err))
  20. }
  21. case "串聊":
  22. public.UserService.SetUserMode(rmsg.SenderStaffId, content)
  23. _, err := rmsg.ReplyText(fmt.Sprintf("=====现在进入与👉%s👈串聊的模式 =====", rmsg.SenderNick), rmsg.SenderStaffId)
  24. if err != nil {
  25. logger.Warning(fmt.Errorf("send message error: %v", err))
  26. }
  27. case "重置":
  28. public.UserService.ClearUserMode(rmsg.SenderStaffId)
  29. public.UserService.ClearUserSessionContext(rmsg.SenderStaffId)
  30. _, err := rmsg.ReplyText(fmt.Sprintf("=====已重置与👉%s👈的对话模式,可以开始新的对话=====", rmsg.SenderNick), rmsg.SenderStaffId)
  31. if err != nil {
  32. logger.Warning(fmt.Errorf("send message error: %v", err))
  33. }
  34. case "余额":
  35. cacheMsg := public.UserService.GetUserMode("system_balance")
  36. if cacheMsg == "" {
  37. rst, err := public.GetBalance()
  38. if err != nil {
  39. logger.Warning(fmt.Errorf("get balance error: %v", err))
  40. return err
  41. }
  42. t1 := time.Unix(int64(rst.Grants.Data[0].EffectiveAt), 0)
  43. t2 := time.Unix(int64(rst.Grants.Data[0].ExpiresAt), 0)
  44. cacheMsg = fmt.Sprintf("💵 已用: 💲%v\n💵 剩余: 💲%v\n⏳ 有效时间: 从 %v 到 %v\n", fmt.Sprintf("%.2f", rst.TotalUsed), fmt.Sprintf("%.2f", rst.TotalAvailable), t1.Format("2006-01-02 15:04:05"), t2.Format("2006-01-02 15:04:05"))
  45. }
  46. _, err := rmsg.ReplyText(cacheMsg, rmsg.SenderStaffId)
  47. if err != nil {
  48. logger.Warning(fmt.Errorf("send message error: %v", err))
  49. }
  50. default:
  51. if public.FirstCheck(rmsg) {
  52. return Do("串聊", rmsg)
  53. } else {
  54. return Do("单聊", rmsg)
  55. }
  56. }
  57. }
  58. return nil
  59. }
  60. // 执行处理请求
  61. func Do(mode string, rmsg public.ReceiveMsg) error {
  62. // 先把模式注入
  63. public.UserService.SetUserMode(rmsg.SenderStaffId, mode)
  64. switch mode {
  65. case "单聊":
  66. reply, err := chatgpt.SingleQa(rmsg.Text.Content, rmsg.SenderStaffId)
  67. if err != nil {
  68. logger.Info(fmt.Errorf("gpt request error: %v", err))
  69. if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
  70. public.UserService.ClearUserSessionContext(rmsg.SenderStaffId)
  71. _, err = rmsg.ReplyText(fmt.Sprintf("请求openai失败了,错误信息:%v,看起来是超过最大对话限制了,已自动重置您的对话", err), rmsg.SenderStaffId)
  72. if err != nil {
  73. logger.Warning(fmt.Errorf("send message error: %v", err))
  74. return err
  75. }
  76. } else {
  77. _, err = rmsg.ReplyText(fmt.Sprintf("请求openai失败了,错误信息:%v", err), rmsg.SenderStaffId)
  78. if err != nil {
  79. logger.Warning(fmt.Errorf("send message error: %v", err))
  80. return err
  81. }
  82. }
  83. }
  84. if reply == "" {
  85. logger.Warning(fmt.Errorf("get gpt result falied: %v", err))
  86. return nil
  87. } else {
  88. reply = strings.TrimSpace(reply)
  89. reply = strings.Trim(reply, "\n")
  90. // 回复@我的用户
  91. // fmt.Println("单聊结果是:", reply)
  92. _, err = rmsg.ReplyText(reply, rmsg.SenderStaffId)
  93. if err != nil {
  94. logger.Warning(fmt.Errorf("send message error: %v", err))
  95. return err
  96. }
  97. }
  98. case "串聊":
  99. cli, reply, err := chatgpt.ContextQa(rmsg.Text.Content, rmsg.SenderStaffId)
  100. if err != nil {
  101. logger.Info(fmt.Sprintf("gpt request error: %v", err))
  102. if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
  103. public.UserService.ClearUserSessionContext(rmsg.SenderStaffId)
  104. _, err = rmsg.ReplyText(fmt.Sprintf("请求openai失败了,错误信息:%v,看起来是超过最大对话限制了,已自动重置您的对话", err), rmsg.SenderStaffId)
  105. if err != nil {
  106. logger.Warning(fmt.Errorf("send message error: %v", err))
  107. return err
  108. }
  109. } else {
  110. _, err = rmsg.ReplyText(fmt.Sprintf("请求openai失败了,错误信息:%v", err), rmsg.SenderStaffId)
  111. if err != nil {
  112. logger.Warning(fmt.Errorf("send message error: %v", err))
  113. return err
  114. }
  115. }
  116. }
  117. if reply == "" {
  118. logger.Warning(fmt.Errorf("get gpt result falied: %v", err))
  119. return nil
  120. } else {
  121. reply = strings.TrimSpace(reply)
  122. reply = strings.Trim(reply, "\n")
  123. // 回复@我的用户
  124. _, err = rmsg.ReplyText(reply, rmsg.SenderStaffId)
  125. if err != nil {
  126. logger.Warning(fmt.Errorf("send message error: %v", err))
  127. return err
  128. }
  129. _ = cli.ChatContext.SaveConversation(rmsg.SenderStaffId)
  130. }
  131. default:
  132. }
  133. return nil
  134. }
  135. // ProcessRequest 分析处理请求逻辑
  136. func CheckRequest(rmsg public.ReceiveMsg) bool {
  137. if public.Config.MaxRequest == 0 {
  138. return true
  139. }
  140. count := public.UserService.GetUseRequestCount(rmsg.SenderStaffId)
  141. // 判断访问次数是否超过限制
  142. if count >= public.Config.MaxRequest {
  143. logger.Info(fmt.Sprintf("亲爱的: %s,您今日请求次数已达上限,请明天再来,交互发问资源有限,请务必斟酌您的问题,给您带来不便,敬请谅解!", rmsg.SenderNick))
  144. _, err := rmsg.ReplyText(fmt.Sprintf("一个好的问题,胜过十个好的答案!\n亲爱的: %s,您今日请求次数已达上限,请明天再来,交互发问资源有限,请务必斟酌您的问题,给您带来不便,敬请谅解!", rmsg.SenderNick), rmsg.SenderStaffId)
  145. if err != nil {
  146. logger.Warning(fmt.Errorf("send message error: %v", err))
  147. }
  148. return false
  149. }
  150. // 访问次数未超过限制,将计数加1
  151. public.UserService.SetUseRequestCount(rmsg.SenderStaffId, count+1)
  152. return true
  153. }