feat: ⚠️ 批量导入课程接口支持冲突预检测与冲突提示 - 批量导入课程接口支持预先检测冲突 - 返回并展示具体发生冲突的课程信息 📚💥 - 补全此前规划的冲突提示功能(把大饼补上了 🍞) refactor: 🧱 使用工作单元模式管理 dao 层事务 - 引入工作单元模式(Unit of Work)统一管理 dao 层 - 新建全局事务,使跨 repo 的 gorm 事务管理更加方便 🔁 fix: 🐛 修复将任务块添加进日程接口的多个问题 - 修复核心逻辑 bug(费了老大劲 😵💫) - 补充并覆盖该接口的多种异常与错误场景测试 🧪
51 lines
1.4 KiB
Go
51 lines
1.4 KiB
Go
package service
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/LoveLosita/smartflow/backend/conv"
|
|
"github.com/LoveLosita/smartflow/backend/dao"
|
|
"github.com/LoveLosita/smartflow/backend/model"
|
|
"github.com/LoveLosita/smartflow/backend/respond"
|
|
)
|
|
|
|
type TaskService struct {
|
|
// 伸出手:准备接住 DAO
|
|
dao *dao.TaskDAO
|
|
}
|
|
|
|
// NewTaskService 创建 TaskService 实例
|
|
func NewTaskService(dao *dao.TaskDAO) *TaskService {
|
|
return &TaskService{
|
|
dao: dao,
|
|
}
|
|
}
|
|
|
|
func (ts *TaskService) AddTask(ctx context.Context, req *model.UserAddTaskRequest, userID int) (*model.UserAddTaskResponse, error) {
|
|
//1. 调用 conv 层进行转换
|
|
taskModel := conv.UserAddTaskRequestToModel(req, userID)
|
|
//2.检查优先级是否合法
|
|
if taskModel.Priority < 1 || taskModel.Priority >= 5 {
|
|
return nil, respond.InvalidPriority
|
|
}
|
|
//3. 调用 courseDAO 层进行数据持久化
|
|
createdTask, err := ts.dao.AddTask(taskModel)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
//4. 调用 conv 层进行响应转换
|
|
response := conv.ModelToUserAddTaskResponse(createdTask)
|
|
return response, nil
|
|
}
|
|
|
|
func (ts *TaskService) GetUserTasks(ctx context.Context, userID int) ([]model.GetUserTaskResp, error) {
|
|
//1. 调用 courseDAO 层获取数据
|
|
tasks, err := ts.dao.GetTasksByUserID(userID)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
//2. 调用 conv 层进行响应转换
|
|
response := conv.ModelToGetUserTasksResp(tasks)
|
|
return response, nil
|
|
}
|