public.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. package public
  2. import (
  3. "fmt"
  4. "strings"
  5. "github.com/eryajf/chatgpt-dingtalk/config"
  6. "github.com/eryajf/chatgpt-dingtalk/pkg/cache"
  7. "github.com/eryajf/chatgpt-dingtalk/pkg/dingbot"
  8. "github.com/eryajf/chatgpt-dingtalk/pkg/logger"
  9. )
  10. var UserService cache.UserServiceInterface
  11. var Config *config.Configuration
  12. var Prompt *[]config.Prompt
  13. func InitSvc() {
  14. Config = config.LoadConfig()
  15. Prompt = config.LoadPrompt()
  16. UserService = cache.NewUserService()
  17. // 暂时不在初始化时获取余额
  18. // if Config.Model == openai.GPT3Dot5Turbo0301 || Config.Model == openai.GPT3Dot5Turbo {
  19. // _, _ = GetBalance()
  20. // }
  21. }
  22. func FirstCheck(rmsg *dingbot.ReceiveMsg) bool {
  23. lc := UserService.GetUserMode(rmsg.SenderStaffId)
  24. if lc == "" {
  25. if Config.DefaultMode == "串聊" {
  26. return true
  27. } else {
  28. return false
  29. }
  30. }
  31. if lc != "" && strings.Contains(lc, "串聊") {
  32. return true
  33. }
  34. return false
  35. }
  36. // ProcessRequest 分析处理请求逻辑
  37. // 主要提供单日请求限额的功能
  38. func CheckRequest(rmsg *dingbot.ReceiveMsg) bool {
  39. if Config.MaxRequest == 0 {
  40. return true
  41. }
  42. count := UserService.GetUseRequestCount(rmsg.SenderStaffId)
  43. // 判断访问次数是否超过限制
  44. if count >= Config.MaxRequest {
  45. logger.Info(fmt.Sprintf("亲爱的: %s,您今日请求次数已达上限,请明天再来,交互发问资源有限,请务必斟酌您的问题,给您带来不便,敬请谅解!", rmsg.SenderNick))
  46. _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("一个好的问题,胜过十个好的答案!\n亲爱的: %s,您今日请求次数已达上限,请明天再来,交互发问资源有限,请务必斟酌您的问题,给您带来不便,敬请谅解!", rmsg.SenderNick))
  47. if err != nil {
  48. logger.Warning(fmt.Errorf("send message error: %v", err))
  49. }
  50. return false
  51. }
  52. // 访问次数未超过限制,将计数加1
  53. UserService.SetUseRequestCount(rmsg.SenderStaffId, count+1)
  54. return true
  55. }
  56. var Welcome string = `# 发送信息
  57. 若您想给机器人发送信息,有如下两种方式:
  58. 1. 在本机器人所在群里@机器人;
  59. 2. 点击机器人的头像后,再点击"发消息"。
  60. 机器人收到您的信息后,默认会交给chatgpt进行处理。除非,您发送的内容是如下**系统指令**之一。
  61. -----
  62. # 系统指令
  63. 系统指令是一些特殊的词语,当您向机器人发送这些词语时,会触发对应的功能:
  64. **单聊**:每条消息都是单独的对话,不包含上下文
  65. **串聊**:对话会携带上下文,除非您主动重置对话或对话长度超过限制
  66. **重置**:重置上下文
  67. **余额**:查询机器人所用OpenAI账号的余额
  68. **模板**:查询机器人内置的快捷模板
  69. **图片**:查看如何根据提示词生成图片
  70. **帮助**:重新获取帮助信息
  71. -----
  72. # 友情提示
  73. 使用"串聊模式"会显著加快机器人所用账号的余额消耗速度。
  74. 因此,若无保留上下文的需求,建议使用"单聊模式"。
  75. 即使有保留上下文的需求,也应适时使用"重置"指令来重置上下文。
  76. -----
  77. # 项目地址
  78. 本项目已在GitHub开源,[查看源代码](https://github.com/eryajf/chatgpt-dingtalk)。
  79. `