fix: 兼容当 SenderStaffId 字段为空的场景 (#152)

This commit is contained in:
Mao Mao
2023-04-01 16:05:16 +08:00
committed by GitHub
parent e2a4960c33
commit 093f0efea8
3 changed files with 23 additions and 14 deletions

View File

@@ -68,6 +68,15 @@ type At struct {
IsAtAll bool `json:"isAtAll"` IsAtAll bool `json:"isAtAll"`
} }
// 获取用户标识,兼容当 SenderStaffId 字段为空的场景
func (r ReceiveMsg) GetSenderIdentifier() string {
if r.SenderStaffId != "" {
return r.SenderStaffId
} else {
return r.SenderNick
}
}
// 发消息给钉钉 // 发消息给钉钉
func (r ReceiveMsg) ReplyToDingtalk(msgType, msg string) (statuscode int, err error) { func (r ReceiveMsg) ReplyToDingtalk(msgType, msg string) (statuscode int, err error) {
atUser := r.SenderStaffId atUser := r.SenderStaffId

View File

@@ -17,20 +17,20 @@ func ProcessRequest(rmsg *dingbot.ReceiveMsg) error {
content := strings.TrimSpace(rmsg.Text.Content) content := strings.TrimSpace(rmsg.Text.Content)
switch content { switch content {
case "单聊": case "单聊":
public.UserService.SetUserMode(rmsg.SenderStaffId, content) public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), content)
_, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈单聊的模式 =====", rmsg.SenderNick)) _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈单聊的模式 =====", rmsg.SenderNick))
if err != nil { if err != nil {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
} }
case "串聊": case "串聊":
public.UserService.SetUserMode(rmsg.SenderStaffId, content) public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), content)
_, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈串聊的模式 =====", rmsg.SenderNick)) _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====现在进入与👉%s👈串聊的模式 =====", rmsg.SenderNick))
if err != nil { if err != nil {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
} }
case "重置": case "重置":
public.UserService.ClearUserMode(rmsg.SenderStaffId) public.UserService.ClearUserMode(rmsg.GetSenderIdentifier())
public.UserService.ClearUserSessionContext(rmsg.SenderStaffId) public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
_, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====已重置与👉%s👈的对话模式可以开始新的对话=====", rmsg.SenderNick)) _, err := rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("=====已重置与👉%s👈的对话模式可以开始新的对话=====", rmsg.SenderNick))
if err != nil { if err != nil {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
@@ -80,14 +80,14 @@ func ProcessRequest(rmsg *dingbot.ReceiveMsg) error {
// 执行处理请求 // 执行处理请求
func Do(mode string, rmsg *dingbot.ReceiveMsg) error { func Do(mode string, rmsg *dingbot.ReceiveMsg) error {
// 先把模式注入 // 先把模式注入
public.UserService.SetUserMode(rmsg.SenderStaffId, mode) public.UserService.SetUserMode(rmsg.GetSenderIdentifier(), mode)
switch mode { switch mode {
case "单聊": case "单聊":
reply, err := chatgpt.SingleQa(rmsg.Text.Content, rmsg.SenderStaffId) reply, err := chatgpt.SingleQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
if err != nil { if err != nil {
logger.Info(fmt.Errorf("gpt request error: %v", err)) logger.Info(fmt.Errorf("gpt request error: %v", err))
if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") { if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
public.UserService.ClearUserSessionContext(rmsg.SenderStaffId) public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
_, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v看起来是超过最大对话限制了已自动重置您的对话", err)) _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v看起来是超过最大对话限制了已自动重置您的对话", err))
if err != nil { if err != nil {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
@@ -115,11 +115,11 @@ func Do(mode string, rmsg *dingbot.ReceiveMsg) error {
} }
} }
case "串聊": case "串聊":
cli, reply, err := chatgpt.ContextQa(rmsg.Text.Content, rmsg.SenderStaffId) cli, reply, err := chatgpt.ContextQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
if err != nil { if err != nil {
logger.Info(fmt.Sprintf("gpt request error: %v", err)) logger.Info(fmt.Sprintf("gpt request error: %v", err))
if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") { if strings.Contains(fmt.Sprintf("%v", err), "maximum text length exceeded") {
public.UserService.ClearUserSessionContext(rmsg.SenderStaffId) public.UserService.ClearUserSessionContext(rmsg.GetSenderIdentifier())
_, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v看起来是超过最大对话限制了已自动重置您的对话", err)) _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v看起来是超过最大对话限制了已自动重置您的对话", err))
if err != nil { if err != nil {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
@@ -145,7 +145,7 @@ func Do(mode string, rmsg *dingbot.ReceiveMsg) error {
logger.Warning(fmt.Errorf("send message error: %v", err)) logger.Warning(fmt.Errorf("send message error: %v", err))
return err return err
} }
_ = cli.ChatContext.SaveConversation(rmsg.SenderStaffId) _ = cli.ChatContext.SaveConversation(rmsg.GetSenderIdentifier())
} }
default: default:
@@ -154,7 +154,7 @@ func Do(mode string, rmsg *dingbot.ReceiveMsg) error {
} }
func ImageGenerate(rmsg *dingbot.ReceiveMsg) error { func ImageGenerate(rmsg *dingbot.ReceiveMsg) error {
reply, err := chatgpt.ImageQa(rmsg.Text.Content, rmsg.SenderStaffId) reply, err := chatgpt.ImageQa(rmsg.Text.Content, rmsg.GetSenderIdentifier())
if err != nil { if err != nil {
logger.Info(fmt.Errorf("gpt request error: %v", err)) logger.Info(fmt.Errorf("gpt request error: %v", err))
_, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v", err)) _, err = rmsg.ReplyToDingtalk(string(dingbot.TEXT), fmt.Sprintf("请求openai失败了错误信息%v", err))

View File

@@ -25,7 +25,7 @@ func InitSvc() {
} }
func FirstCheck(rmsg *dingbot.ReceiveMsg) bool { func FirstCheck(rmsg *dingbot.ReceiveMsg) bool {
lc := UserService.GetUserMode(rmsg.SenderStaffId) lc := UserService.GetUserMode(rmsg.GetSenderIdentifier())
if lc == "" { if lc == "" {
if Config.DefaultMode == "串聊" { if Config.DefaultMode == "串聊" {
return true return true
@@ -45,7 +45,7 @@ func CheckRequest(rmsg *dingbot.ReceiveMsg) bool {
if Config.MaxRequest == 0 { if Config.MaxRequest == 0 {
return true return true
} }
count := UserService.GetUseRequestCount(rmsg.SenderStaffId) count := UserService.GetUseRequestCount(rmsg.GetSenderIdentifier())
// 判断访问次数是否超过限制 // 判断访问次数是否超过限制
if count >= Config.MaxRequest { if count >= Config.MaxRequest {
logger.Info(fmt.Sprintf("亲爱的: %s您今日请求次数已达上限请明天再来交互发问资源有限请务必斟酌您的问题给您带来不便敬请谅解!", rmsg.SenderNick)) logger.Info(fmt.Sprintf("亲爱的: %s您今日请求次数已达上限请明天再来交互发问资源有限请务必斟酌您的问题给您带来不便敬请谅解!", rmsg.SenderNick))
@@ -56,7 +56,7 @@ func CheckRequest(rmsg *dingbot.ReceiveMsg) bool {
return false return false
} }
// 访问次数未超过限制将计数加1 // 访问次数未超过限制将计数加1
UserService.SetUseRequestCount(rmsg.SenderStaffId, count+1) UserService.SetUseRequestCount(rmsg.GetSenderIdentifier(), count+1)
return true return true
} }