/* Copyright (c) [2023] [pcm] [pcm-coordinator] is licensed under Mulan PSL v2. You can use this software according to the terms and conditions of the Mulan PSL v2. You may obtain a copy of Mulan PSL v2 at: http://license.coscl.org.cn/MulanPSL2 THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND, EITHER EXPaRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT, MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE. See the Mulan PSL v2 for more details. */ package core import ( "context" "gitlink.org.cn/JointCloud/pcm-coordinator/pkg/constants" "gitlink.org.cn/JointCloud/pcm-coordinator/pkg/models" "k8s.io/apimachinery/pkg/util/json" "time" "gitlink.org.cn/JointCloud/pcm-coordinator/internal/svc" "gitlink.org.cn/JointCloud/pcm-coordinator/internal/types" "github.com/zeromicro/go-zero/core/logx" ) type ScheduleTaskByYamlLogic struct { logx.Logger ctx context.Context svcCtx *svc.ServiceContext } func NewScheduleTaskByYamlLogic(ctx context.Context, svcCtx *svc.ServiceContext) *ScheduleTaskByYamlLogic { return &ScheduleTaskByYamlLogic{ Logger: logx.WithContext(ctx), ctx: ctx, svcCtx: svcCtx, } } func (l *ScheduleTaskByYamlLogic) ScheduleTaskByYaml(req *types.ScheduleTaskByYamlReq) (resp *types.ScheduleTaskByYamlResp, err error) { resp = &types.ScheduleTaskByYamlResp{} bytes, err := json.Marshal(req) if err != nil { return nil, err } // 构建主任务结构体 taskModel := models.Task{ Status: constants.Saved, Description: req.Description, Name: req.Name, YamlString: string(bytes), CommitTime: time.Now(), NsID: req.NsID, } // 保存任务数据到数据库 tx := l.svcCtx.DbEngin.Create(&taskModel) if tx.Error != nil { return nil, tx.Error } // 遍历子任务放入任务队列中 for _, task := range req.Tasks { task.NsID = req.NsID task.TaskId = taskModel.Id // 将任务数据转换成消息体 reqMessage, err := json.Marshal(task) if err != nil { logx.Error(err) return nil, err } publish := l.svcCtx.RedisClient.Publish(context.Background(), task.TaskType, reqMessage) if publish.Err() != nil { return nil, publish.Err() } } resp.TaskId = taskModel.Id return resp, nil }