mirror of
https://github.com/krau/SaveAny-Bot.git
synced 2026-05-11 18:10:01 +08:00
* refactor: a big refactor. wip * refactor: port handle file * refactor: place all handlers * fix: task info nil pointer * feat: enhance task progress tracking and context management * feat: cancel task * feat: stream mode * feat: silent mode * feat: dir cmd * refactor: remove unused old file * feat: rule cmd * feat: handle silent mode * feat: batch task * fix: batch task progress and temp file cleanup * refactor: update file creation and cleanup methods for better resource management * feat: add save command with silent mode handling * feat: message link * feat: update message prompts to include file count in storage selection * feat: slient save links * refactor: reduce dup code * feat: rule type * feat: chose dir * feat: refactor file handling and storage rules, improve error handling and logging * feat: rule mode * feat: telegraph pics * fix: tphpics nil pointer and inaccurate dirpath * feat: silent save telegraph * feat: add suffix to avoid file overwrite * feat: new storage telegram * chore: tidy go mod
153 lines
5.4 KiB
Go
153 lines
5.4 KiB
Go
package shortcut
|
|
|
|
import (
|
|
"fmt"
|
|
"path"
|
|
|
|
"github.com/celestix/gotgproto/dispatcher"
|
|
"github.com/celestix/gotgproto/ext"
|
|
"github.com/charmbracelet/log"
|
|
"github.com/gotd/td/tg"
|
|
"github.com/krau/SaveAny-Bot/client/bot/handlers/utils/msgelem"
|
|
"github.com/krau/SaveAny-Bot/client/bot/handlers/utils/ruleutil"
|
|
"github.com/krau/SaveAny-Bot/common/utils/tgutil"
|
|
"github.com/krau/SaveAny-Bot/core"
|
|
"github.com/krau/SaveAny-Bot/core/batchtftask"
|
|
"github.com/krau/SaveAny-Bot/core/tftask"
|
|
"github.com/krau/SaveAny-Bot/database"
|
|
"github.com/krau/SaveAny-Bot/pkg/tfile"
|
|
"github.com/krau/SaveAny-Bot/storage"
|
|
"github.com/rs/xid"
|
|
)
|
|
|
|
// 创建一个 tftask.TGFileTask 并添加到任务队列中, 以编辑消息的方式反馈结果
|
|
func CreateAndAddTGFileTaskWithEdit(ctx *ext.Context, userID int64, stor storage.Storage, dirPath string, file tfile.TGFileMessage, trackMsgID int) error {
|
|
logger := log.FromContext(ctx)
|
|
user, err := database.GetUserByChatID(ctx, userID)
|
|
if err != nil {
|
|
logger.Errorf("Failed to get user by chat ID: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "获取用户失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
if user.ApplyRule && user.Rules != nil {
|
|
matchedStorageName, matchedDirPath := ruleutil.ApplyRule(ctx, user.Rules, ruleutil.NewInput(file))
|
|
dirPath = matchedDirPath
|
|
if matchedStorageName.IsValid() {
|
|
stor, err = storage.GetStorageByUserIDAndName(ctx, user.ChatID, matchedStorageName.String())
|
|
if err != nil {
|
|
logger.Errorf("Failed to get storage by user ID and name: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "获取存储失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
}
|
|
}
|
|
|
|
storagePath := stor.JoinStoragePath(path.Join(dirPath, file.Name()))
|
|
injectCtx := tgutil.ExtWithContext(ctx.Context, ctx)
|
|
taskid := xid.New().String()
|
|
task, err := tftask.NewTGFileTask(taskid, injectCtx, file, ctx.Raw, stor, storagePath,
|
|
tftask.NewProgressTrack(
|
|
trackMsgID,
|
|
userID))
|
|
if err != nil {
|
|
logger.Errorf("create task failed: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "创建任务失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
if err := core.AddTask(injectCtx, task); err != nil {
|
|
logger.Errorf("add task failed: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "添加任务失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
text, entities := msgelem.BuildTaskAddedEntities(ctx, file.Name(), core.GetLength(injectCtx))
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: text,
|
|
Entities: entities,
|
|
})
|
|
|
|
return dispatcher.EndGroups
|
|
}
|
|
|
|
// 创建一个 batchtftask.BatchTGFileTask 并添加到任务队列中, 以编辑消息的方式反馈结果
|
|
func CreateAndAddBatchTGFileTaskWithEdit(ctx *ext.Context, userID int64, stor storage.Storage, dirPath string, files []tfile.TGFileMessage, trackMsgID int) error {
|
|
logger := log.FromContext(ctx)
|
|
user, err := database.GetUserByChatID(ctx, userID)
|
|
if err != nil {
|
|
logger.Errorf("Failed to get user by chat ID: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "获取用户失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
useRule := user.ApplyRule && user.Rules != nil
|
|
applyRule := func(file tfile.TGFileMessage) (string, string) {
|
|
if !useRule {
|
|
return stor.Name(), dirPath
|
|
}
|
|
storName, dirP := ruleutil.ApplyRule(ctx, user.Rules, ruleutil.NewInput(file))
|
|
if !storName.IsValid() {
|
|
return stor.Name(), dirP
|
|
}
|
|
return storName.String(), dirP
|
|
}
|
|
|
|
elems := make([]batchtftask.TaskElement, 0, len(files))
|
|
for _, file := range files {
|
|
storName, dirPath := applyRule(file)
|
|
fileStor := stor
|
|
if storName != stor.Name() && storName != "" {
|
|
fileStor, err = storage.GetStorageByUserIDAndName(ctx, user.ChatID, storName)
|
|
if err != nil {
|
|
logger.Errorf("Failed to get storage by user ID and name: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "获取存储失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
}
|
|
storPath := fileStor.JoinStoragePath(path.Join(dirPath, file.Name()))
|
|
elem, err := batchtftask.NewTaskElement(fileStor, storPath, file)
|
|
if err != nil {
|
|
logger.Errorf("Failed to create task element: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "任务创建失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
elems = append(elems, *elem)
|
|
}
|
|
injectCtx := tgutil.ExtWithContext(ctx.Context, ctx)
|
|
taskid := xid.New().String()
|
|
task := batchtftask.NewBatchTGFileTask(taskid, injectCtx, elems, ctx.Raw, batchtftask.NewProgressTracker(trackMsgID, userID), true)
|
|
if err := core.AddTask(injectCtx, task); err != nil {
|
|
logger.Errorf("Failed to add batch task: %s", err)
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: "批量任务添加失败: " + err.Error(),
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|
|
ctx.EditMessage(userID, &tg.MessagesEditMessageRequest{
|
|
ID: trackMsgID,
|
|
Message: fmt.Sprintf("已添加批量任务, 共 %d 个文件", len(files)),
|
|
ReplyMarkup: nil,
|
|
})
|
|
return dispatcher.EndGroups
|
|
}
|