Files
go_process_manager/internal/app/repository/task.go
2025-06-16 16:46:46 +08:00

69 lines
2.2 KiB
Go

package repository
import (
"errors"
"github.com/lzh-1625/go_process_manager/internal/app/constants"
"github.com/lzh-1625/go_process_manager/internal/app/model"
"github.com/lzh-1625/go_process_manager/internal/app/repository/query"
"gorm.io/gorm"
)
type taskRepository struct{}
var TaskRepository = new(taskRepository)
func (t *taskRepository) GetAllTask() (result []model.Task) {
db.Find(&result)
return
}
func (t *taskRepository) GetTaskById(id int) (result model.Task, err error) {
err = db.Model(&model.Task{}).Where(&model.Task{Id: int(id)}).First(&result).Error
return
}
func (t *taskRepository) GetTaskByKey(key string) (result model.Task, err error) {
err = db.Model(&model.Task{}).Where(&model.Task{Key: &key, ApiEnable: true}).First(&result).Error
return
}
func (t *taskRepository) AddTask(data model.Task) (taskId int, err error) {
err = db.Create(&data).Error
taskId = data.Id
return
}
func (t *taskRepository) DeleteTask(id int) (err error) {
err = db.Delete(&model.Task{Id: id}).Error
return
}
func (t *taskRepository) EditTask(data model.Task) (err error) {
err = db.Model(&model.Task{}).Where(&model.Task{Id: data.Id}).First(&model.Task{}).Error
if errors.Is(err, gorm.ErrRecordNotFound) {
return err
}
err = db.Model(&model.Task{}).Where(&model.Task{Id: data.Id}).Save(data).Error
return
}
func (t *taskRepository) EditTaskEnable(id int, enable bool) (err error) {
_, err = query.Task.Where(query.Task.Id.Eq(id)).Update(query.Task.Enable, enable)
return
}
func (t *taskRepository) GetAllTaskWithProcessName() (result []model.TaskVo) {
db.Raw(`SELECT t.*, p.name AS process_name, p2.name AS target_name,p3.name AS trigger_name
FROM task t LEFT JOIN process p ON t.process_id = p.uuid LEFT JOIN process p2 ON t.operation_target = p2.uuid LEFT JOIN process p3 ON t.trigger_target = p3.uuid`).Scan(&result)
return
}
func (t *taskRepository) GetTriggerTask(processName string, event constants.ProcessState) []model.Task {
result := []model.Task{}
query.Task.Select(query.Task.ALL).LeftJoin(query.Process, query.Process.Uuid.EqCol(query.Task.TriggerTarget)).Where(query.Process.Name.Eq(processName)).Where(query.Task.TriggerEvent.Eq(int32(event))).Scan(result)
return result
}