mirror of
https://github.com/krau/SaveAny-Bot.git
synced 2026-05-12 02:49:42 +08:00
refactor: use MTP API
This commit is contained in:
67
core/core.go
67
core/core.go
@@ -3,64 +3,37 @@ package core
|
||||
import (
|
||||
"context"
|
||||
"errors"
|
||||
"fmt"
|
||||
"time"
|
||||
|
||||
"github.com/imroc/req/v3"
|
||||
"github.com/amarnathcjd/gogram/telegram"
|
||||
"github.com/krau/SaveAny-Bot/bot"
|
||||
"github.com/krau/SaveAny-Bot/common"
|
||||
"github.com/krau/SaveAny-Bot/config"
|
||||
"github.com/krau/SaveAny-Bot/dao"
|
||||
"github.com/krau/SaveAny-Bot/logger"
|
||||
"github.com/krau/SaveAny-Bot/queue"
|
||||
"github.com/krau/SaveAny-Bot/storage"
|
||||
"github.com/krau/SaveAny-Bot/types"
|
||||
"github.com/mymmrac/telego"
|
||||
"github.com/mymmrac/telego/telegoutil"
|
||||
)
|
||||
|
||||
func processPendingTask(task types.Task) error {
|
||||
fileRecord, err := dao.GetReceivedFileByFileID(task.FileID)
|
||||
message, err := bot.Client.GetMessageByID(task.ChatID, task.MessageID)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
fileRecord.Processing = true
|
||||
if err := dao.UpdateReceivedFile(fileRecord); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
_, err = common.ReqClient.R().SetOutputFile(task.FileName).SetDownloadCallbackWithInterval(func(info req.DownloadInfo) {
|
||||
if info.Response == nil || info.Response.Response == nil || info.Response.Response.StatusCode != 200 {
|
||||
return
|
||||
}
|
||||
process := fmt.Sprintf("%.2f%%", float64(info.DownloadedSize)/float64(info.Response.ContentLength)*100.0)
|
||||
bot.Bot.EditMessageText(&telego.EditMessageTextParams{
|
||||
ChatID: telegoutil.ID(task.ChatID),
|
||||
MessageID: task.ReplyMessageID,
|
||||
Text: "正在下载文件: " + process,
|
||||
})
|
||||
}, time.Second*time.Duration(3*func() int {
|
||||
if queue.Len() > 0 {
|
||||
return queue.Len()
|
||||
}
|
||||
return 1
|
||||
}())).Get(bot.FileDownloadURL(task.FilePath))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
bot.Bot.EditMessageText(&telego.EditMessageTextParams{
|
||||
ChatID: telegoutil.ID(task.ChatID),
|
||||
MessageID: task.ReplyMessageID,
|
||||
Text: "下载完成, 正在转存...",
|
||||
logger.L.Debugf("Start downloading file: %s", task.FileName)
|
||||
dest, err := message.Download(&telegram.DownloadOptions{
|
||||
FileName: common.GetCacheFilePath(task.FileName),
|
||||
// ProgressCallback: func(totalBytes, downloadedBytes int64) {},
|
||||
})
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
defer func() {
|
||||
if config.Cfg.Temp.CacheTTL > 0 {
|
||||
common.PurgeFileAfter(common.GetDownloadedFilePath(task.FileName),
|
||||
time.Duration(config.Cfg.Temp.CacheTTL)*time.Second)
|
||||
common.PurgeFileAfter(dest, time.Duration(config.Cfg.Temp.CacheTTL)*time.Second)
|
||||
} else {
|
||||
if err := common.PurgeFile(common.GetDownloadedFilePath(task.FileName)); err != nil {
|
||||
if err := common.PurgeFile(dest); err != nil {
|
||||
logger.L.Errorf("Failed to purge file: %s", err)
|
||||
}
|
||||
}
|
||||
@@ -69,7 +42,7 @@ func processPendingTask(task types.Task) error {
|
||||
task.StoragePath = task.FileName
|
||||
}
|
||||
|
||||
if err := storage.Save(task.Storage, task.Ctx, common.GetDownloadedFilePath(task.FileName), task.StoragePath); err != nil {
|
||||
if err := storage.Save(task.Storage, task.Ctx, dest, task.StoragePath); err != nil {
|
||||
return err
|
||||
}
|
||||
return nil
|
||||
@@ -98,24 +71,8 @@ func worker(queue *queue.TaskQueue, semaphore chan struct{}) {
|
||||
queue.AddTask(task)
|
||||
case types.Succeeded:
|
||||
logger.L.Infof("Task succeeded: %s", task.String())
|
||||
bot.Bot.EditMessageText(&telego.EditMessageTextParams{
|
||||
ChatID: telegoutil.ID(task.ChatID),
|
||||
MessageID: task.ReplyMessageID,
|
||||
Text: "文件转存完成",
|
||||
})
|
||||
if err := dao.DeleteReceivedFileByFileID(task.FileID); err != nil {
|
||||
logger.L.Errorf("Failed to delete received file: %s", err)
|
||||
}
|
||||
case types.Failed:
|
||||
logger.L.Errorf("Task failed: %s", task.String())
|
||||
bot.Bot.EditMessageText(&telego.EditMessageTextParams{
|
||||
ChatID: telegoutil.ID(task.ChatID),
|
||||
MessageID: task.ReplyMessageID,
|
||||
Text: "文件转存失败:" + "\n" + task.Error.Error(),
|
||||
})
|
||||
if err := dao.DeleteReceivedFileByFileID(task.FileID); err != nil {
|
||||
logger.L.Errorf("Failed to delete received file: %s", err)
|
||||
}
|
||||
case types.Canceled:
|
||||
logger.L.Infof("Task canceled: %s", task.String())
|
||||
default:
|
||||
|
||||
Reference in New Issue
Block a user