feat: parse message link via userbot, close #70

This commit is contained in:
krau
2025-06-09 14:33:40 +08:00
parent 95522d03f9
commit 56ea1d6f36
4 changed files with 56 additions and 6 deletions

View File

@@ -62,12 +62,19 @@ func tryFetchFileFromMessage(ctx *ext.Context, chatID int64, messageID int, file
if (strings.Contains(err.Error(), "peer not found") || strings.Contains(err.Error(), "unexpected message type")) && userclient.UC != nil {
common.Log.Warnf("无法获取文件 %d:%d, 尝试使用 userbot: %s", chatID, messageID, err)
uctx := userclient.GetCtx()
// TODO: 群组支持
file, err = FileFromMessage(uctx, chatID, messageID, fileName)
if err == nil {
return file, true, nil
peer := uctx.PeerStorage.GetInputPeerById(chatID)
if peer == nil {
return nil, true, fmt.Errorf("failed to get peer for chat %d: %w", chatID, err)
}
return nil, true, err
msg, err := GetSingleHistoryMessage(uctx, uctx.Raw, peer, messageID)
if err != nil {
return nil, true, err
}
file, err = FileFromMedia(msg.Media, fileName)
if err != nil {
return nil, true, fmt.Errorf("failed to get file from userbot message %d:%d: %w", chatID, messageID, err)
}
return file, true, nil
}
return nil, false, err
}

View File

@@ -1,6 +1,7 @@
package bot
import (
"context"
"errors"
"fmt"
"strconv"
@@ -12,6 +13,7 @@ import (
"github.com/gabriel-vasile/mimetype"
"github.com/gotd/td/telegram/message/entity"
"github.com/gotd/td/telegram/message/styling"
"github.com/gotd/td/telegram/query"
"github.com/gotd/td/tg"
"github.com/krau/SaveAny-Bot/common"
"github.com/krau/SaveAny-Bot/dao"
@@ -235,6 +237,38 @@ func GetTGMessage(ctx *ext.Context, chatId int64, messageID int) (*tg.Message, e
return tgMessage, nil
}
// https://github.com/iyear/tdl/blob/fbb396da774ba544e527c3ef41c44921ad74ee98/core/util/tutil/tutil.go#L174
func GetSingleHistoryMessage(ctx context.Context, client *tg.Client, peer tg.InputPeerClass, msg int) (*tg.Message, error) {
it := query.Messages(client).GetHistory(peer).OffsetID(msg + 1).BatchSize(1).Iter()
if !it.Next(ctx) {
return nil, fmt.Errorf("failed to get message %d from %s: %w", msg, peer, it.Err())
}
m, ok := it.Value().Msg.(*tg.Message)
if !ok {
return nil, fmt.Errorf("invalid message %d", msg)
}
if m.GetID() != msg {
return nil, fmt.Errorf("the message %d/%d may be deleted", GetInputPeerID(peer), msg)
}
return m, nil
}
func GetInputPeerID(peer tg.InputPeerClass) int64 {
switch p := peer.(type) {
case *tg.InputPeerUser:
return p.UserID
case *tg.InputPeerChat:
return p.ChatID
case *tg.InputPeerChannel:
return p.ChannelID
}
return 0
}
func ProvideSelectMessage(ctx *ext.Context, update *ext.Update, fileName string, chatID int64, fileMsgID, toEditMsgID int) error {
entityBuilder := entity.Builder{}
var entities []tg.MessageEntityClass