1
0
mirror of https://github.com/fumiama/ReiBot.git synced 2026-06-10 04:50:27 +08:00

add 响应通知主人 & 按顺序打印服务

This commit is contained in:
源文雨
2022-10-06 21:13:47 +08:00
parent 3d4c3d447f
commit 4bf573933b
7 changed files with 175 additions and 51 deletions

4
cd.go
View File

@@ -26,7 +26,7 @@ func init() {
startTime = time.Now().Unix() startTime = time.Now().Unix()
msg, err := ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "●cd"+tok)) msg, err := ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "●cd"+tok))
if err != nil { if err != nil {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "ERROR: "+err.Error())) _, _ = ctx.SendPlainMessage(false, "ERROR: ", err)
return return
} }
process.SleepAbout1sTo2s() process.SleepAbout1sTo2s()
@@ -54,7 +54,7 @@ func init() {
msg, err := ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, binutils.BytesToString(my))) msg, err := ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, binutils.BytesToString(my)))
cl() cl()
if err != nil { if err != nil {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "ERROR: "+err.Error())) _, _ = ctx.SendPlainMessage(false, "ERROR: ", err)
return return
} }
process.SleepAbout1sTo2s() process.SleepAbout1sTo2s()

View File

@@ -477,6 +477,11 @@ func (e *Engine) OnCallbackQueryKeywordGroup(keywords []string, rules ...Rule) *
return StoreMatcher(matcher) return StoreMatcher(matcher)
} }
// OnCallbackQueryPrefixGroup 前缀触发器组
func OnCallbackQueryPrefixGroup(prefix []string, rules ...Rule) *Matcher {
return defaultEngine.OnCallbackQueryPrefixGroup(prefix, rules...)
}
// OnCallbackQueryPrefixGroup 前缀触发器组 // OnCallbackQueryPrefixGroup 前缀触发器组
func (e *Engine) OnCallbackQueryPrefixGroup(prefix []string, rules ...Rule) *Matcher { func (e *Engine) OnCallbackQueryPrefixGroup(prefix []string, rules ...Rule) *Matcher {
matcher := &Matcher{ matcher := &Matcher{

View File

@@ -3,7 +3,6 @@ package echo
import ( import (
ctrl "github.com/FloatTech/zbpctrl" ctrl "github.com/FloatTech/zbpctrl"
rei "github.com/fumiama/ReiBot" rei "github.com/fumiama/ReiBot"
tgba "github.com/go-telegram-bot-api/telegram-bot-api/v5"
) )
func init() { func init() {
@@ -16,6 +15,6 @@ func init() {
if args == "" { if args == "" {
return return
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, args)) _, _ = ctx.SendPlainMessage(false, args)
}) })
} }

View File

@@ -10,7 +10,7 @@ import (
func main() { func main() {
rei.OnMessageFullMatch("help").SetBlock(true). rei.OnMessageFullMatch("help").SetBlock(true).
Handle(func(ctx *rei.Ctx) { Handle(func(ctx *rei.Ctx) {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "echo string")) _, _ = ctx.SendPlainMessage(false, "echo string")
}) })
rei.Run(rei.Bot{ rei.Run(rei.Bot{
Token: "", Token: "",

View File

@@ -3,6 +3,7 @@ package rei
import ( import (
"fmt" "fmt"
"os" "os"
"sort"
"sync/atomic" "sync/atomic"
"unicode" "unicode"
@@ -81,3 +82,25 @@ func Delete(service string) {
} }
} }
} }
// ForEachByPrio iterates through managers by their priority.
func ForEachByPrio(iterator func(i int, manager *ctrl.Control[*Ctx]) bool) {
for i, v := range cpmp2lstbyprio() {
if !iterator(i, v) {
return
}
}
}
func cpmp2lstbyprio() []*ctrl.Control[*Ctx] {
m.RLock()
defer m.RUnlock()
ret := make([]*ctrl.Control[*Ctx], 0, len(m.M))
for _, v := range m.M {
ret = append(ret, v)
}
sort.SliceStable(ret, func(i, j int) bool {
return enmap[ret[i].Service].prio < enmap[ret[j].Service].prio
})
return ret
}

187
rule.go
View File

@@ -4,12 +4,14 @@ import (
"fmt" "fmt"
"strconv" "strconv"
"strings" "strings"
"time"
"unsafe" "unsafe"
"github.com/FloatTech/floatbox/process" "github.com/FloatTech/floatbox/process"
ctrl "github.com/FloatTech/zbpctrl" ctrl "github.com/FloatTech/zbpctrl"
tgba "github.com/go-telegram-bot-api/telegram-bot-api/v5" tgba "github.com/go-telegram-bot-api/telegram-bot-api/v5"
"github.com/wdvxdr1123/ZeroBot/extension" "github.com/wdvxdr1123/ZeroBot/extension"
"github.com/wdvxdr1123/ZeroBot/extension/rate"
) )
func newctrl(service string, o *ctrl.Options[*Ctx]) Rule { func newctrl(service string, o *ctrl.Options[*Ctx]) Rule {
@@ -24,22 +26,66 @@ func Lookup(service string) (*ctrl.Control[*Ctx], bool) {
return m.Lookup(service) return m.Lookup(service)
} }
// respLimiterManager 请求响应限速器管理
//
// 每 1d 1次触发
var respLimiterManager = rate.NewManager[int64](time.Hour*24, 1)
func init() { func init() {
process.NewCustomOnce(&m).Do(func() { process.NewCustomOnce(&m).Do(func() {
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
"响应", "response", "沉默", "silence", "响应", "response", "沉默", "silence",
}, UserOrGrpAdmin).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) { }, UserOrGrpAdmin).SetBlock(true).Limit(func(ctx *Ctx) *rate.Limiter {
return respLimiterManager.Load(ctx.Message.Chat.ID)
}).secondPriority().Handle(func(ctx *Ctx) {
grp := ctx.Message.Chat.ID grp := ctx.Message.Chat.ID
msg := "" msg := ""
switch ctx.State["command"] { switch ctx.State["command"] {
case "响应", "response": case "响应", "response":
err := m.Response(grp) if m.CanResponse(grp) {
if err == nil { msg = ctx.Caller.Self.String() + "已经在工作了哦~"
msg = ctx.Caller.Self.String() + "将开始在此工作啦~" break
} else {
msg = "ERROR: " + err.Error()
} }
if SuperUserPermission(ctx) {
err := m.Response(grp)
if err == nil {
msg = ctx.Caller.Self.String() + "将开始在此工作啦~"
} else {
msg = "ERROR: " + err.Error()
}
break
}
notify := &tgba.PhotoConfig{
BaseFile: tgba.BaseFile{
BaseChat: tgba.BaseChat{
ReplyMarkup: tgba.NewInlineKeyboardMarkup(
tgba.NewInlineKeyboardRow(
tgba.NewInlineKeyboardButtonData(
"同意",
"respermit"+fmt.Sprintf("%016x", uint64(grp)),
),
tgba.NewInlineKeyboardButtonData(
"拒绝",
"resrefuse"+fmt.Sprintf("%016x", uint64(grp)),
),
),
),
},
File: tgba.FileID(ctx.Message.Chat.Photo.BigFileID),
},
Caption: "主人, @" + ctx.Message.From.String() + " 请求响应~\n*ChatType*: " + ctx.Message.Chat.Type + "\n*ChatUserName*: " + ctx.Message.Chat.UserName + "\n*ChatID*: " + strconv.FormatInt(ctx.Message.Chat.ID, 10) + "\n*ChatTitle*: " + ctx.Message.Chat.Title + "\n*ChatDescription*: " + ctx.Message.Chat.Description,
ParseMode: "Markdown",
}
for _, id := range ctx.Caller.b.SuperUsers {
notify.ChatID = id
_, _ = ctx.Caller.Send(notify)
}
msg = "已将响应请求发给主人了, 请耐心等待回应哦~"
case "沉默", "silence": case "沉默", "silence":
if !m.CanResponse(grp) {
msg = ctx.Caller.Self.String() + "已经在休息了哦~"
break
}
err := m.Silence(grp) err := m.Silence(grp)
if err == nil { if err == nil {
msg = ctx.Caller.Self.String() + "将开始休息啦~" msg = ctx.Caller.Self.String() + "将开始休息啦~"
@@ -49,7 +95,52 @@ func init() {
default: default:
msg = "ERROR: bad command\"" + fmt.Sprint(ctx.State["command"]) + "\"" msg = "ERROR: bad command\"" + fmt.Sprint(ctx.State["command"]) + "\""
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, msg)) _, _ = ctx.SendPlainMessage(false, msg)
})
OnCallbackQueryRegex(`^respermit([0-9a-f]{16})$`, SuperUserPermission).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) {
grp, err := strconv.ParseUint(ctx.State["regex_matched"].([]string)[1], 16, 64)
if err != nil {
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "ERROR: "+err.Error()))
return
}
msg := ""
err = m.Response(int64(grp))
if err == nil {
msg = ctx.Caller.Self.String() + "将开始在此工作啦~"
} else {
msg = "ERROR: " + err.Error()
}
_, err = ctx.Caller.Send(&tgba.MessageConfig{
BaseChat: tgba.BaseChat{
ChatID: int64(grp),
},
Text: msg,
})
if err != nil {
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "ERROR: "+err.Error()))
return
}
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "已发送"))
})
OnCallbackQueryRegex(`^resrefuse([0-9a-f]{16})$`, SuperUserPermission).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) {
grp, err := strconv.ParseUint(ctx.State["regex_matched"].([]string)[1], 16, 64)
if err != nil {
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "ERROR: "+err.Error()))
return
}
_, err = ctx.Caller.Send(&tgba.MessageConfig{
BaseChat: tgba.BaseChat{
ChatID: int64(grp),
},
Text: "很遗憾, 因为各种原因, 您暂时未获使用权限呢",
})
if err != nil {
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "ERROR: "+err.Error()))
return
}
_, _ = ctx.Caller.Send(tgba.NewCallbackWithAlert(ctx.Value.(*tgba.CallbackQuery).ID, "已发送"))
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
@@ -75,33 +166,36 @@ func init() {
default: default:
msg = "ERROR: bad command\"" + cmd + "\"" msg = "ERROR: bad command\"" + cmd + "\""
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, msg)) _, _ = ctx.SendPlainMessage(false, msg)
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
"启用", "enable", "禁用", "disable", "启用", "enable", "禁用", "disable",
}, UserOrGrpAdmin).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) { }, UserOrGrpAdmin).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) {
grp := ctx.Message.Chat.ID
if !m.CanResponse(grp) {
return
}
model := extension.CommandModel{} model := extension.CommandModel{}
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
service, ok := Lookup(model.Args) service, ok := Lookup(model.Args)
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
grp := ctx.Message.Chat.ID
if strings.Contains(model.Command, "启用") || strings.Contains(model.Command, "enable") { if strings.Contains(model.Command, "启用") || strings.Contains(model.Command, "enable") {
service.Enable(grp) service.Enable(grp)
if service.Options.OnEnable != nil { if service.Options.OnEnable != nil {
service.Options.OnEnable(ctx) service.Options.OnEnable(ctx)
} else { } else {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已启用服务: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已启用服务: ", model.Args)
} }
} else { } else {
service.Disable(grp) service.Disable(grp)
if service.Options.OnDisable != nil { if service.Options.OnDisable != nil {
service.Options.OnDisable(ctx) service.Options.OnDisable(ctx)
} else { } else {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已禁用服务: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已禁用服务: ", model.Args)
} }
} }
}) })
@@ -113,45 +207,52 @@ func init() {
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
service, ok := Lookup(model.Args) service, ok := Lookup(model.Args)
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
if strings.Contains(model.Command, "启用") || strings.Contains(model.Command, "enable") { if strings.Contains(model.Command, "启用") || strings.Contains(model.Command, "enable") {
service.Enable(0) service.Enable(0)
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已全局启用服务: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已全局启用服务: ", model.Args)
} else { } else {
service.Disable(0) service.Disable(0)
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已全局禁用服务: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已全局禁用服务: ", model.Args)
} }
}) })
OnMessageCommandGroup([]string{"还原", "reset"}, UserOrGrpAdmin).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) { OnMessageCommandGroup([]string{"还原", "reset"}, UserOrGrpAdmin).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) {
grp := ctx.Message.Chat.ID
if !m.CanResponse(grp) {
return
}
model := extension.CommandModel{} model := extension.CommandModel{}
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
service, ok := Lookup(model.Args) service, ok := Lookup(model.Args)
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
grp := ctx.Message.Chat.ID
service.Reset(grp) service.Reset(grp)
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已还原服务的默认启用状态: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已还原服务的默认启用状态: ", model.Args)
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
"禁止", "ban", "允许", "permit", "禁止", "ban", "允许", "permit",
}, AdminPermission).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) { }, AdminPermission).SetBlock(true).secondPriority().Handle(func(ctx *Ctx) {
grp := ctx.Message.Chat.ID
if !m.CanResponse(grp) {
return
}
model := extension.CommandModel{} model := extension.CommandModel{}
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
args := strings.Split(model.Args, " ") args := strings.Split(model.Args, " ")
if len(args) >= 2 { if len(args) >= 2 {
service, ok := Lookup(args[0]) service, ok := Lookup(args[0])
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
grp := ctx.Message.Chat.ID grp := ctx.Message.Chat.ID
msg := "**" + args[0] + "报告**" msg := "*" + args[0] + "报告*"
issu := SuperUserPermission(ctx) issu := SuperUserPermission(ctx)
if strings.Contains(model.Command, "允许") || strings.Contains(model.Command, "permit") { if strings.Contains(model.Command, "允许") || strings.Contains(model.Command, "permit") {
for _, usr := range args[1:] { for _, usr := range args[1:] {
@@ -190,10 +291,10 @@ func init() {
} }
} }
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, msg)) _, _ = ctx.SendPlainMessage(false, msg)
return return
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "参数错误!")) _, _ = ctx.SendPlainMessage(false, "参数错误!")
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
@@ -205,10 +306,10 @@ func init() {
if len(args) >= 2 { if len(args) >= 2 {
service, ok := Lookup(args[0]) service, ok := Lookup(args[0])
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
msg := "**" + args[0] + "全局报告**" msg := "*" + args[0] + "全局报告*"
if strings.Contains(model.Command, "允许") || strings.Contains(model.Command, "permit") { if strings.Contains(model.Command, "允许") || strings.Contains(model.Command, "permit") {
for _, usr := range args[1:] { for _, usr := range args[1:] {
uid, err := strconv.ParseInt(usr, 10, 64) uid, err := strconv.ParseInt(usr, 10, 64)
@@ -226,10 +327,10 @@ func init() {
} }
} }
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, msg)) _, _ = ctx.SendPlainMessage(false, msg)
return return
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "参数错误!")) _, _ = ctx.SendPlainMessage(false, "参数错误!")
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
@@ -239,7 +340,7 @@ func init() {
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
args := strings.Split(model.Args, " ") args := strings.Split(model.Args, " ")
if len(args) >= 1 { if len(args) >= 1 {
msg := "**报告**" msg := "*报告*"
if strings.Contains(model.Command, "解") || strings.Contains(model.Command, "un") { if strings.Contains(model.Command, "解") || strings.Contains(model.Command, "un") {
for _, usr := range args { for _, usr := range args {
uid, err := strconv.ParseInt(usr, 10, 64) uid, err := strconv.ParseInt(usr, 10, 64)
@@ -259,10 +360,10 @@ func init() {
} }
} }
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, msg)) _, _ = ctx.SendPlainMessage(false, msg)
return return
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "参数错误!")) _, _ = ctx.SendPlainMessage(false, "参数错误!")
}) })
OnMessageCommandGroup([]string{ OnMessageCommandGroup([]string{
@@ -272,15 +373,15 @@ func init() {
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
service, ok := Lookup(model.Args) service, ok := Lookup(model.Args)
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
err := service.Flip() err := service.Flip()
if err != nil { if err != nil {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "ERROR: "+err.Error())) _, _ = ctx.SendPlainMessage(false, "ERROR: ", err)
return return
} }
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "已改变全局默认启用状态: "+model.Args)) _, _ = ctx.SendPlainMessage(false, "已改变全局默认启用状态: ", model.Args)
}) })
OnMessageCommandGroup([]string{"用法", "usage"}, UserOrGrpAdmin).SetBlock(true).secondPriority(). OnMessageCommandGroup([]string{"用法", "usage"}, UserOrGrpAdmin).SetBlock(true).secondPriority().
@@ -289,47 +390,43 @@ func init() {
_ = ctx.Parse(&model) _ = ctx.Parse(&model)
service, ok := Lookup(model.Args) service, ok := Lookup(model.Args)
if !ok { if !ok {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "没有找到指定服务!")) _, _ = ctx.SendPlainMessage(false, "没有找到指定服务!")
return return
} }
if service.Options.Help != "" { if service.Options.Help != "" {
gid := ctx.Message.Chat.ID gid := ctx.Message.Chat.ID
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, service.EnableMarkIn(gid).String()+" "+service.String())) _, _ = ctx.SendPlainMessage(false, service.EnableMarkIn(gid), " ", service)
} else { } else {
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, "该服务无帮助!")) _, _ = ctx.SendPlainMessage(false, "该服务无帮助!")
} }
}) })
OnMessageCommandGroup([]string{"服务列表", "service_list"}, UserOrGrpAdmin).SetBlock(true).secondPriority(). OnMessageCommandGroup([]string{"服务列表", "service_list"}, UserOrGrpAdmin).SetBlock(true).secondPriority().
Handle(func(ctx *Ctx) { Handle(func(ctx *Ctx) {
i := 0
gid := ctx.Message.Chat.ID gid := ctx.Message.Chat.ID
m.RLock() m.RLock()
msg := make([]any, 1, len(m.M)*4+1) msg := make([]any, 1, len(m.M)*4+1)
m.RUnlock() m.RUnlock()
msg[0] = "--------服务列表--------\n发送\"/用法 name\"查看详情\n发送\"/响应\"启用会话" msg[0] = "--------服务列表--------\n发送\"/用法 name\"查看详情\n发送\"/响应\"启用会话"
m.ForEach(func(key string, manager *ctrl.Control[*Ctx]) bool { ForEachByPrio(func(i int, service *ctrl.Control[*Ctx]) bool {
i++ msg = append(msg, "\n", i+1, ": ", service.EnableMarkIn(gid), service.Service)
msg = append(msg, "\n", i, ": ", manager.EnableMarkIn(gid), key)
return true return true
}) })
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, fmt.Sprint(msg...))) _, _ = ctx.SendPlainMessage(false, msg...)
}) })
OnMessageCommandGroup([]string{"服务详情", "service_detail"}, UserOrGrpAdmin).SetBlock(true).secondPriority(). OnMessageCommandGroup([]string{"服务详情", "service_detail"}, UserOrGrpAdmin).SetBlock(true).secondPriority().
Handle(func(ctx *Ctx) { Handle(func(ctx *Ctx) {
i := 0
gid := ctx.Message.Chat.ID gid := ctx.Message.Chat.ID
m.RLock() m.RLock()
msgs := make([]any, 1, len(m.M)*7+1) msgs := make([]any, 1, len(m.M)*7+1)
m.RUnlock() m.RUnlock()
msgs[0] = "---服务详情---\n" msgs[0] = "---服务详情---\n"
m.ForEach(func(key string, service *ctrl.Control[*Ctx]) bool { ForEachByPrio(func(i int, service *ctrl.Control[*Ctx]) bool {
i++ msgs = append(msgs, i+1, ": ", service.EnableMarkIn(gid), service.Service, "\n", service, "\n\n")
msgs = append(msgs, i, ": ", service.EnableMarkIn(gid), key, "\n", service, "\n\n")
return true return true
}) })
_, _ = ctx.Caller.Send(tgba.NewMessage(ctx.Message.Chat.ID, fmt.Sprint(msgs...))) _, _ = ctx.SendPlainMessage(false, msgs...)
}) })
}) })
} }

View File

@@ -529,7 +529,7 @@ func MustProvidePhoto(needphohint, failhint string) Rule {
select { select {
case <-time.After(time.Second * 120): case <-time.After(time.Second * 120):
if failhint != "" { if failhint != "" {
_, _ = ctx.Caller.Send(tgba.NewMessage(msg.Chat.ID, failhint)) _, _ = ctx.SendPlainMessage(true, failhint)
} }
return false return false
case newCtx := <-next: case newCtx := <-next: