mirror of
https://gitee.com/dromara/mayfly-go
synced 2025-11-02 23:40:24 +08:00
* fix: 保存 LastResult 时截断字符串过长部分,以避免数据库报错 * refactor: 新增 entity.DbTaskBase 和 persistence.dbTaskBase, 用于实现数据库备份和恢复任务处理相关部分 * fix: aeskey变更后,解密密码出现数组越界访问错误 * fix: 时间属性为零值时,保存到 mysql 数据库报错 * refactor db.infrastructure.service.scheduler * feat: 实现立即备份功能 * refactor db.infrastructure.service.db_instance * refactor: 从数据库中获取数据库备份目录、mysql文件路径等配置信息 * fix: 数据库备份和恢复问题 * fix: 修改 .gitignore 文件,忽略数据库备份目录和数据库程序目录
53 lines
1.1 KiB
Go
53 lines
1.1 KiB
Go
package persistence
|
|
|
|
import (
|
|
"context"
|
|
"mayfly-go/internal/db/domain/entity"
|
|
"mayfly-go/pkg/base"
|
|
"mayfly-go/pkg/global"
|
|
"mayfly-go/pkg/gormx"
|
|
"mayfly-go/pkg/model"
|
|
)
|
|
|
|
type dbTaskBase[T model.ModelI] struct {
|
|
base.RepoImpl[T]
|
|
}
|
|
|
|
func (d *dbTaskBase[T]) UpdateEnabled(_ context.Context, taskId uint64, enabled bool) error {
|
|
cond := map[string]any{
|
|
"id": taskId,
|
|
}
|
|
return d.Updates(cond, map[string]any{
|
|
"enabled": enabled,
|
|
})
|
|
}
|
|
|
|
func (d *dbTaskBase[T]) UpdateTaskStatus(ctx context.Context, task T) error {
|
|
return d.UpdateById(ctx, task, "last_status", "last_result", "last_time")
|
|
}
|
|
|
|
func (d *dbTaskBase[T]) ListToDo() ([]T, error) {
|
|
var tasks []T
|
|
db := global.Db.Model(d.GetModel())
|
|
err := db.Where("enabled = ?", true).
|
|
Where(db.Where("repeated = ?", true).Or("last_status <> ?", entity.TaskSuccess)).
|
|
Scopes(gormx.UndeleteScope).
|
|
Find(&tasks).Error
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return tasks, nil
|
|
}
|
|
|
|
func (d *dbTaskBase[T]) ListRepeating() ([]T, error) {
|
|
cond := map[string]any{
|
|
"enabled": true,
|
|
"repeated": true,
|
|
}
|
|
var tasks []T
|
|
if err := d.ListByCond(cond, &tasks); err != nil {
|
|
return nil, err
|
|
}
|
|
return tasks, nil
|
|
}
|