mirror of
https://github.com/krau/SaveAny-Bot.git
synced 2026-05-11 18:39:42 +08:00
feat: parse message link via userbot, close #70
This commit is contained in:
@@ -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
|
||||
}
|
||||
|
||||
34
bot/utils.go
34
bot/utils.go
@@ -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
|
||||
|
||||
Reference in New Issue
Block a user