package workflows import ( "sort" "time" "github.com/mentos1386/zdravko/internal/temporal" "go.temporal.io/sdk/workflow" ) func (w *Workflows) CheckWorkflowDefinition(ctx workflow.Context, param temporal.WorkflowCheckParam) (*temporal.WorkflowCheckResult, error) { workerGroupIds := param.WorkerGroupIds sort.Strings(workerGroupIds) targetsFilterResult := temporal.ActivityTargetsFilterResult{} err := workflow.ExecuteActivity( workflow.WithActivityOptions(ctx, workflow.ActivityOptions{ StartToCloseTimeout: 60 * time.Second, TaskQueue: temporal.TEMPORAL_SERVER_QUEUE, }), temporal.ActivityTargetsFilterName, temporal.ActivityTargetsFilterParam{ Filter: param.Filter, }, ).Get(ctx, &targetsFilterResult) if err != nil { return nil, err } for _, target := range targetsFilterResult.Targets { for _, workerGroupId := range workerGroupIds { var checkResult *temporal.ActivityCheckResult err := workflow.ExecuteActivity( workflow.WithActivityOptions(ctx, workflow.ActivityOptions{ StartToCloseTimeout: 60 * time.Second, TaskQueue: workerGroupId, }), temporal.ActivityCheckName, temporal.ActivityCheckParam{ Script: param.Script, Target: target, }, ).Get(ctx, &checkResult) if err != nil { return nil, err } status := temporal.AddTargetHistoryStatusFailure if checkResult.Success { status = temporal.AddTargetHistoryStatusSuccess } var addTargetHistoryResult *temporal.ActivityAddTargetHistoryResult err = workflow.ExecuteActivity( workflow.WithActivityOptions(ctx, workflow.ActivityOptions{ StartToCloseTimeout: 60 * time.Second, TaskQueue: temporal.TEMPORAL_SERVER_QUEUE, }), temporal.ActivityAddTargetHistoryName, &temporal.ActivityAddTargetHistoryParam{ Target: target, WorkerGroupId: workerGroupId, CheckId: param.CheckId, Status: status, Note: checkResult.Note, }, ).Get(ctx, &addTargetHistoryResult) if err != nil { return nil, err } } } return &temporal.WorkflowCheckResult{ Note: "Check workflow completed", }, nil }