1
0
mirror of https://github.com/fumiama/NanoBot.git synced 2026-06-05 02:30:23 +08:00

fix: message delete

This commit is contained in:
源文雨
2023-10-18 15:17:30 +09:00
parent 88aede89dc
commit a6a961da65
4 changed files with 37 additions and 45 deletions

View File

@@ -1,5 +1,6 @@
emptyon:
- Message
- MessageDelete
- GuildCreate
- GuildUpdate
@@ -12,14 +13,14 @@ emptyon:
- GuildMemberUpdate
- GuildMemberRemove
- MessageCreate
- MessageDelete
#- MessageCreate
#- MessageDelete
- MessageReactionAdd
- MessageReactionRemove
- DirectMessageCreate
- DirectMessageDelete
#- DirectMessageCreate
#- DirectMessageDelete
- OpenForumThreadCreate
- OpenForumThreadUpdate
@@ -49,8 +50,8 @@ emptyon:
- AudioOnMic
- AudioOffMic
- AtMessageCreate
- PublicMessageDelete
#- AtMessageCreate
#- PublicMessageDelete
ruleon:
Message:

View File

@@ -8,6 +8,12 @@ func (e *Engine) OnMessage(rules ...Rule) *Matcher { return e.On("Message", rule
// OnMessage ...
func OnMessage(rules ...Rule) *Matcher { return On("Message", rules...) }
// OnMessageDelete ...
func (e *Engine) OnMessageDelete(rules ...Rule) *Matcher { return e.On("MessageDelete", rules...) }
// OnMessageDelete ...
func OnMessageDelete(rules ...Rule) *Matcher { return On("MessageDelete", rules...) }
// OnGuildCreate ...
func (e *Engine) OnGuildCreate(rules ...Rule) *Matcher { return e.On("GuildCreate", rules...) }
@@ -62,18 +68,6 @@ func (e *Engine) OnGuildMemberRemove(rules ...Rule) *Matcher { return e.On("Guil
// OnGuildMemberRemove ...
func OnGuildMemberRemove(rules ...Rule) *Matcher { return On("GuildMemberRemove", rules...) }
// OnMessageCreate ...
func (e *Engine) OnMessageCreate(rules ...Rule) *Matcher { return e.On("MessageCreate", rules...) }
// OnMessageCreate ...
func OnMessageCreate(rules ...Rule) *Matcher { return On("MessageCreate", rules...) }
// OnMessageDelete ...
func (e *Engine) OnMessageDelete(rules ...Rule) *Matcher { return e.On("MessageDelete", rules...) }
// OnMessageDelete ...
func OnMessageDelete(rules ...Rule) *Matcher { return On("MessageDelete", rules...) }
// OnMessageReactionAdd ...
func (e *Engine) OnMessageReactionAdd(rules ...Rule) *Matcher { return e.On("MessageReactionAdd", rules...) }
@@ -86,18 +80,6 @@ func (e *Engine) OnMessageReactionRemove(rules ...Rule) *Matcher { return e.On("
// OnMessageReactionRemove ...
func OnMessageReactionRemove(rules ...Rule) *Matcher { return On("MessageReactionRemove", rules...) }
// OnDirectMessageCreate ...
func (e *Engine) OnDirectMessageCreate(rules ...Rule) *Matcher { return e.On("DirectMessageCreate", rules...) }
// OnDirectMessageCreate ...
func OnDirectMessageCreate(rules ...Rule) *Matcher { return On("DirectMessageCreate", rules...) }
// OnDirectMessageDelete ...
func (e *Engine) OnDirectMessageDelete(rules ...Rule) *Matcher { return e.On("DirectMessageDelete", rules...) }
// OnDirectMessageDelete ...
func OnDirectMessageDelete(rules ...Rule) *Matcher { return On("DirectMessageDelete", rules...) }
// OnOpenForumThreadCreate ...
func (e *Engine) OnOpenForumThreadCreate(rules ...Rule) *Matcher { return e.On("OpenForumThreadCreate", rules...) }
@@ -236,18 +218,6 @@ func (e *Engine) OnAudioOffMic(rules ...Rule) *Matcher { return e.On("AudioOffMi
// OnAudioOffMic ...
func OnAudioOffMic(rules ...Rule) *Matcher { return On("AudioOffMic", rules...) }
// OnAtMessageCreate ...
func (e *Engine) OnAtMessageCreate(rules ...Rule) *Matcher { return e.On("AtMessageCreate", rules...) }
// OnAtMessageCreate ...
func OnAtMessageCreate(rules ...Rule) *Matcher { return On("AtMessageCreate", rules...) }
// OnPublicMessageDelete ...
func (e *Engine) OnPublicMessageDelete(rules ...Rule) *Matcher { return e.On("PublicMessageDelete", rules...) }
// OnPublicMessageDelete ...
func OnPublicMessageDelete(rules ...Rule) *Matcher { return On("PublicMessageDelete", rules...) }
// OnMessagePrefix ...
func OnMessagePrefix(prefix string, rules ...Rule) *Matcher {
return defaultEngine.OnMessagePrefix(prefix, rules...)

View File

@@ -52,6 +52,11 @@ func (bot *Bot) processEvent(payload *WebsocketPayload) {
fallthrough
case "MessageCreate", "AtMessageCreate":
tp = "Message"
case "DirectMessageDelete":
ctx.IsToMe = true
fallthrough
case "MessageDelete", "PublicMessageDelete":
tp = "MessageDelete"
}
matcherLock.RLock()
n := len(matcherMap[tp])
@@ -78,6 +83,19 @@ func (bot *Bot) processEvent(payload *WebsocketPayload) {
ctx.IsToMe = true
}
log.Infoln(getLogHeader(), "=>", ctx.Message)
case "MessageDelete":
mdl := (*MessageDelete)(x.UnsafePointer())
opmember, err := ctx.GetGuildMemberOf(mdl.Message.GuildID, mdl.OpUser.ID)
if err != nil {
log.Warnln(getLogHeader(), "获取撤回消息者详情错误:", err)
return
}
ctx.Message = (*MessageDelete)(x.UnsafePointer()).Message
ctx.Message.Member = &Member{
GuildID: mdl.Message.GuildID,
User: ctx.Message.Author,
}
ctx.Message.Author = opmember.User
}
go match(ctx, matchers)
}

View File

@@ -16,9 +16,12 @@ func newctrl(service string, o *ctrl.Options[*Ctx]) Rule {
c := m.NewControl(service, o)
return func(ctx *Ctx) bool {
ctx.State["manager"] = c
gid, _ := strconv.ParseUint(ctx.Message.ChannelID, 10, 64)
uid, _ := strconv.ParseUint(ctx.Message.Author.ID, 10, 64)
return c.Handler(int64(gid), int64(uid))
if ctx.Message != nil {
gid, _ := strconv.ParseUint(ctx.Message.ChannelID, 10, 64)
uid, _ := strconv.ParseUint(ctx.Message.Author.ID, 10, 64)
return c.Handler(int64(gid), int64(uid))
}
return false
}
}