process_request.go 6.8 KB

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