process_request.go 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package process
  2. import (
  3. "fmt"
  4. "strings"
  5. "time"
  6. "github.com/eryajf/chatgpt-dingtalk/pkg/dingbot"
  7. "github.com/eryajf/chatgpt-dingtalk/pkg/logger"
  8. "github.com/eryajf/chatgpt-dingtalk/public"
  9. "github.com/solywsh/chatgpt"
  10. )
  11. // ProcessRequest 分析处理请求逻辑
  12. func ProcessRequest(rmsg *dingbot.ReceiveMsg) error {
  13. if public.CheckRequest(rmsg) {
  14. content := strings.TrimSpace(rmsg.Text.Content)
  15. switch content {
  16. case "单聊":
  17. public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), content)
  18. _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈单聊的模式 =====", rmsg.SenderNick))
  19. if err != nil {
  20. logger.Warning(fmt.Errorf("send message error: %v", err))
  21. }
  22. case "串聊":
  23. public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), content)
  24. _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈串聊的模式 =====", rmsg.SenderNick))
  25. if err != nil {
  26. logger.Warning(fmt.Errorf("send message error: %v", err))
  27. }
  28. case "重置":
  29. public.UserService.ClearUserMode(rmsg.GetSenderIdentifier())
  30. public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
  31. _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====已重置与👉%s👈的对话模式,可以开始新的对话=====", rmsg.SenderNick))
  32. if err != nil {
  33. logger.Warning(fmt.Errorf("send message error: %v", err))
  34. }
  35. case "模板":
  36. var title string
  37. for _, v := range *public.Prompt {
  38. title = title + v.Title + " | "
  39. }
  40. _, err := rmsg.ReplyToDingtalk(string(dingbot.MARKDOWN), fmt.Sprintf("%s 您好,当前程序内置集成了这些提示词:\n\n-----\n\n| %s \n\n-----\n\n您可以选择某个提示词作为对话内容的开头。\n\n以周报为例,可发送\"#周报 我本周用Go写了一个钉钉集成ChatGPT的聊天应用\",可将工作内容填充为一篇完整的周报。\n\n-----\n\n若您不清楚某个提示词的所代表的含义,您可以直接发送提示词,例如直接发送\"#周报\"", rmsg.SenderNick, title))
  41. if err != nil {
  42. logger.Warning(fmt.Errorf("send message error: %v", err))
  43. }
  44. case "图片":
  45. _, err := rmsg.ReplyToDingtalk(string(dingbot.MARKDOWN), "发送以 **#图片** 开头的内容,将会触发绘画能力,图片生成之后,将会保存在程序根目录下的 **images目录** \n 如果你绘图没有思路,可以在这两个网站寻找灵感。\n - [https://lexica.art/](https://lexica.art/)\n- [https://www.clickprompt.org/zh-CN/](https://www.clickprompt.org/zh-CN/)")
  46. if err != nil {
  47. logger.Warning(fmt.Errorf("send message error: %v", err))
  48. }
  49. case "余额":
  50. cacheMsg := public.UserService.GetUserMode("system_balance")
  51. if cacheMsg == "" {
  52. rst, err := public.GetBalance()
  53. if err != nil {
  54. logger.Warning(fmt.Errorf("get balance error: %v", err))
  55. return err
  56. }
  57. t1 := time.Unix(int64(rst.Grants.Data[0].EffectiveAt), 0)
  58. t2 := time.Unix(int64(rst.Grants.Data[0].ExpiresAt), 0)
  59. 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"))
  60. }
  61. _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), cacheMsg)
  62. if err != nil {
  63. logger.Warning(fmt.Errorf("send message error: %v", err))
  64. }
  65. default:
  66. if public.FirstCheck(rmsg) {
  67. return Do("串聊", rmsg)
  68. } else {
  69. return Do("单聊", rmsg)
  70. }
  71. }
  72. }
  73. return nil
  74. }
  75. // 执行处理请求
  76. func Do(mode string, rmsg *dingbot.ReceiveMsg) error {
  77. // 先把模式注入
  78. public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), mode)
  79. switch mode {
  80. case "单聊":
  81. reply, err := chatgpt.SingleQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
  82. if err != nil {
  83. logger.Info(fmt.Errorf("gpt request error: %v", err))
  84. if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
  85. public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
  86. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了,错误信息:%v,看起来是超过最大对话限制了,已自动重置您的对话", err))
  87. if err != nil {
  88. logger.Warning(fmt.Errorf("send message error: %v", err))
  89. return err
  90. }
  91. } else {
  92. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了,错误信息:%v", err))
  93. if err != nil {
  94. logger.Warning(fmt.Errorf("send message error: %v", err))
  95. return err
  96. }
  97. }
  98. }
  99. if reply == "" {
  100. logger.Warning(fmt.Errorf("get gpt result falied: %v", err))
  101. return nil
  102. } else {
  103. reply = strings.TrimSpace(reply)
  104. reply = strings.Trim(reply, "\n")
  105. // 回复@我的用户
  106. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), reply)
  107. if err != nil {
  108. logger.Warning(fmt.Errorf("send message error: %v", err))
  109. return err
  110. }
  111. }
  112. case "串聊":
  113. cli, reply, err := chatgpt.ContextQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
  114. if err != nil {
  115. logger.Info(fmt.Sprintf("gpt request error: %v", err))
  116. if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
  117. public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
  118. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了,错误信息:%v,看起来是超过最大对话限制了,已自动重置您的对话", err))
  119. if err != nil {
  120. logger.Warning(fmt.Errorf("send message error: %v", err))
  121. return err
  122. }
  123. } else {
  124. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了,错误信息:%v", err))
  125. if err != nil {
  126. logger.Warning(fmt.Errorf("send message error: %v", err))
  127. return err
  128. }
  129. }
  130. }
  131. if reply == "" {
  132. logger.Warning(fmt.Errorf("get gpt result falied: %v", err))
  133. return nil
  134. } else {
  135. reply = strings.TrimSpace(reply)
  136. reply = strings.Trim(reply, "\n")
  137. // 回复@我的用户
  138. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), reply)
  139. if err != nil {
  140. logger.Warning(fmt.Errorf("send message error: %v", err))
  141. return err
  142. }
  143. _ = cli.ChatContext.SaveConversation(rmsg.GetSenderIdentifier())
  144. }
  145. default:
  146. }
  147. return nil
  148. }
  149. func ImageGenerate(rmsg *dingbot.ReceiveMsg) error {
  150. reply, err := chatgpt.ImageQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
  151. if err != nil {
  152. logger.Info(fmt.Errorf("gpt request error: %v", err))
  153. _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了,错误信息:%v", err))
  154. if err != nil {
  155. logger.Warning(fmt.Errorf("send message error: %v", err))
  156. return err
  157. }
  158. }
  159. if reply == "" {
  160. logger.Warning(fmt.Errorf("get gpt result falied: %v", err))
  161. return nil
  162. } else {
  163. reply = strings.TrimSpace(reply)
  164. reply = strings.Trim(reply, "\n")
  165. // 回复@我的用户
  166. _, err = rmsg.ReplyToDingtalk(string(dingbot.MARKDOWN), fmt.Sprintf(">点击图片可旋转或放大。\n![](%s)", reply))
  167. if err != nil {
  168. logger.Warning(fmt.Errorf("send message error: %v", err))
  169. return err
  170. }
  171. }
  172. return nil
  173. }