main.go 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. package main
  2. import (
  3. "encoding/json"
  4. "fmt"
  5. "io/ioutil"
  6. "net/http"
  7. "strings"
  8. "github.com/eryajf/chatgpt-dingtalk/pkg/process"
  9. "github.com/eryajf/chatgpt-dingtalk/public"
  10. "github.com/eryajf/chatgpt-dingtalk/public/logger"
  11. )
  12. func init() {
  13. public.InitSvc()
  14. }
  15. func main() {
  16. Start()
  17. }
  18. var Welcome string = `Commands:
  19. =================================
  20. 🙋 单聊 👉 单独聊天
  21. 📣 串聊 👉 带上下文聊天
  22. 🔃 重置 👉 重置带上下文聊天
  23. 💵 余额 👉 查询剩余额度
  24. 🚀 帮助 👉 显示帮助信息
  25. =================================
  26. 🚜 例:@我发送 空 或 帮助 将返回此帮助信息
  27. 💪 Power By https://github.com/eryajf/chatgpt-dingtalk
  28. `
  29. // 💵 余额 👉 查看接口可调用额度
  30. func Start() {
  31. // 定义一个处理器函数
  32. handler := func(w http.ResponseWriter, r *http.Request) {
  33. data, err := ioutil.ReadAll(r.Body)
  34. if err != nil {
  35. http.Error(w, err.Error(), http.StatusBadRequest)
  36. logger.Warning(fmt.Sprintf("read request body failed: %v\n", err.Error()))
  37. return
  38. }
  39. if len(data) == 0 {
  40. logger.Warning("回调参数为空,以至于无法正常解析,请检查原因")
  41. return
  42. }
  43. var msgObj = new(public.ReceiveMsg)
  44. err = json.Unmarshal(data, &msgObj)
  45. if err != nil {
  46. logger.Warning(fmt.Errorf("unmarshal request body failed: %v", err))
  47. }
  48. if msgObj.Text.Content == "" || msgObj.ChatbotUserID == "" {
  49. logger.Warning("从钉钉回调过来的内容为空,根据过往的经验,或许重新创建一下机器人,能解决这个问题")
  50. return
  51. }
  52. // TODO: 校验请求
  53. if len(msgObj.Text.Content) == 1 || strings.TrimSpace(msgObj.Text.Content) == "帮助" {
  54. // 欢迎信息
  55. _, err := msgObj.ReplyText(Welcome, msgObj.SenderStaffId)
  56. if err != nil {
  57. logger.Warning(fmt.Errorf("send message error: %v", err))
  58. }
  59. } else {
  60. logger.Info(fmt.Sprintf("dingtalk callback parameters: %#v", msgObj))
  61. err = process.ProcessRequest(*msgObj)
  62. if err != nil {
  63. logger.Warning(fmt.Errorf("process request failed: %v", err))
  64. }
  65. }
  66. }
  67. // 创建一个新的 HTTP 服务器
  68. server := &http.Server{
  69. Addr: ":8090",
  70. Handler: http.HandlerFunc(handler),
  71. }
  72. // 启动服务器
  73. logger.Info("Start Listen On ", server.Addr)
  74. err := server.ListenAndServe()
  75. if err != nil {
  76. logger.Danger(err)
  77. }
  78. }