mirror of
https://github.com/eryajf/chatgpt-dingtalk.git
synced 2025-10-05 00:02:42 +08:00
fix: 兼容当 SenderStaffId 字段为空的场景 (#152)
This commit is contained in:
@@ -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
|
||||||
|
@@ -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))
|
||||||
|
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user