inline: clean inactive tasks for memory usage
This commit is contained in:
parent
15db8ea6df
commit
285d7eb4aa
1 changed files with 46 additions and 2 deletions
|
@ -5,6 +5,7 @@ import (
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"sync"
|
"sync"
|
||||||
|
"time"
|
||||||
|
|
||||||
"github.com/google/uuid"
|
"github.com/google/uuid"
|
||||||
"github.com/pkg/errors"
|
"github.com/pkg/errors"
|
||||||
|
@ -18,24 +19,67 @@ import (
|
||||||
"github.com/PaulSonOfLars/gotgbot/v2/ext"
|
"github.com/PaulSonOfLars/gotgbot/v2/ext"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
type TaskEntry struct {
|
||||||
|
Task *models.DownloadContext
|
||||||
|
CreatedAt time.Time
|
||||||
|
}
|
||||||
|
|
||||||
var InlineTasks sync.Map
|
var InlineTasks sync.Map
|
||||||
|
var cleanupActive sync.Once
|
||||||
|
|
||||||
|
const taskTimeout = 5 * time.Minute
|
||||||
|
|
||||||
func GetTask(id string) (*models.DownloadContext, bool) {
|
func GetTask(id string) (*models.DownloadContext, bool) {
|
||||||
value, ok := InlineTasks.Load(id)
|
value, ok := InlineTasks.Load(id)
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, false
|
return nil, false
|
||||||
}
|
}
|
||||||
return value.(*models.DownloadContext), true
|
entry, ok := value.(TaskEntry)
|
||||||
|
if !ok {
|
||||||
|
return nil, false
|
||||||
|
}
|
||||||
|
return entry.Task, true
|
||||||
}
|
}
|
||||||
|
|
||||||
func SetTask(id string, task *models.DownloadContext) {
|
func SetTask(id string, task *models.DownloadContext) {
|
||||||
InlineTasks.Store(id, task)
|
InlineTasks.Store(id, TaskEntry{
|
||||||
|
Task: task,
|
||||||
|
CreatedAt: time.Now(),
|
||||||
|
})
|
||||||
|
cleanupActive.Do(startTasksCleanup)
|
||||||
}
|
}
|
||||||
|
|
||||||
func DeleteTask(id string) {
|
func DeleteTask(id string) {
|
||||||
InlineTasks.Delete(id)
|
InlineTasks.Delete(id)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func startTasksCleanup() {
|
||||||
|
go func() {
|
||||||
|
ticker := time.NewTicker(1 * time.Minute)
|
||||||
|
defer ticker.Stop()
|
||||||
|
|
||||||
|
for range ticker.C {
|
||||||
|
cleanupStaleTasks()
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
}
|
||||||
|
|
||||||
|
func cleanupStaleTasks() {
|
||||||
|
now := time.Now()
|
||||||
|
InlineTasks.Range(func(key, value interface{}) bool {
|
||||||
|
entry, ok := value.(TaskEntry)
|
||||||
|
if !ok {
|
||||||
|
InlineTasks.Delete(key)
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
if now.Sub(entry.CreatedAt) > taskTimeout {
|
||||||
|
InlineTasks.Delete(key)
|
||||||
|
}
|
||||||
|
return true
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func HandleInline(
|
func HandleInline(
|
||||||
bot *gotgbot.Bot,
|
bot *gotgbot.Bot,
|
||||||
ctx *ext.Context,
|
ctx *ext.Context,
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue