refactor: 重构ss输出,重构url解析
This commit is contained in:
@@ -3,6 +3,7 @@ package scoresaber
|
||||
import (
|
||||
"log"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"git.lxtend.com/qqbot/handler"
|
||||
"git.lxtend.com/qqbot/model"
|
||||
@@ -10,7 +11,7 @@ import (
|
||||
)
|
||||
|
||||
func init() {
|
||||
handler.RegisterHandler("查ss", getMySS)
|
||||
handler.RegisterHandler("查ss", getSSProfile)
|
||||
handler.RegisterHelpInform("查ss", "查看您的最新分数")
|
||||
handler.RegisterHandler("绑定ss", bindSS)
|
||||
handler.RegisterHelpInform("绑定ss", "绑定您的scoresaber账号")
|
||||
@@ -25,17 +26,40 @@ func init() {
|
||||
handler.RegisterHelpInform("截ss/jss", "scoresaber主页截图")
|
||||
}
|
||||
|
||||
func getMySS(msg model.Message) (reply model.Reply) {
|
||||
func getSSProfile(msg model.Message) (reply model.Reply) {
|
||||
var (
|
||||
resultStr string
|
||||
err error
|
||||
maxRetries = 3 // 最大重试次数
|
||||
maxRetries = 5 // 最大重试次数
|
||||
attempts = 0
|
||||
noUpdate = false
|
||||
)
|
||||
var ssId string
|
||||
if len(msg.RawMsg) > len("查ss ") {
|
||||
// ssId = msg.RawMsg[len("查ss "):]
|
||||
ssId = strings.Split(msg.RawMsg, " ")[1]
|
||||
noUpdate = true
|
||||
}
|
||||
|
||||
userIdStr := strconv.Itoa(int(msg.UserId))
|
||||
for attempts < maxRetries {
|
||||
resultStr, err = scoresaber.SSQuery.GetScore(userIdStr)
|
||||
err = nil
|
||||
if ssId == "" {
|
||||
ssId, err = scoresaber.GetSSID(userIdStr)
|
||||
}
|
||||
if err != nil {
|
||||
// return "您未绑定ss账号,输入\"绑定ss [ssId]\"绑定", nil
|
||||
return model.Reply{
|
||||
ReplyMsg: "您未绑定ss账号,输入\"绑定ss [ssId]\"绑定",
|
||||
ReferOriginMsg: true,
|
||||
FromMsg: msg,
|
||||
}
|
||||
}
|
||||
if !noUpdate {
|
||||
resultStr, err = scoresaber.SSQuery.GetScore(ssId)
|
||||
} else {
|
||||
resultStr, err = scoresaber.SSQuery.GetScoreWithoutUpdate(ssId)
|
||||
}
|
||||
if err == nil {
|
||||
break // 成功时退出循环
|
||||
}
|
||||
@@ -45,7 +69,7 @@ func getMySS(msg model.Message) (reply model.Reply) {
|
||||
|
||||
// 如果所有尝试都失败,返回适当的错误消息
|
||||
if err != nil {
|
||||
resultStr = "获取您的分数时出现问题,请稍后重试。"
|
||||
resultStr = "获取您的分数时出现问题,请稍后重试。" + err.Error()
|
||||
}
|
||||
|
||||
return model.Reply{
|
||||
|
||||
Reference in New Issue
Block a user