diff --git a/devops/.vscode/settings.json b/devops/.vscode/settings.json new file mode 100644 index 0000000..1458126 --- /dev/null +++ b/devops/.vscode/settings.json @@ -0,0 +1,5 @@ +{ + "go.testEnvVars": { + "workspaceFolder": "${workspaceFolder}", + } +} \ No newline at end of file diff --git a/devops/agent/README.md b/devops/agent/README.md index f515b6a..16fe8ee 100644 --- a/devops/agent/README.md +++ b/devops/agent/README.md @@ -6,3 +6,94 @@ 4. 任务需要有任务名称, 与 任务参数 这些基础信息 +## 开发脚本执行引擎 + +1. 构造单元测试的环境(ioc), 被测试的对象在ioc里面, 名字叫: script_excutor, 运行单元测试的时候,需要ioc容器启动,并且完成初始化 +```go +package test + +import ( + "os" + + "github.com/infraboard/mcube/v2/ioc" +) + +// 用于设置测试环境的函数,比如初始化日志系统,配置环境变量等 +func Setup() { + // 配置文件的逻辑 + // 和我们本地运行时的保存一致, etc/application.toml, 这是一个相对路径(工程名称) + // 点击单元测试的时候, 单元测试的运行目录是变化的,因此这里需要给绝对逻辑 + ioc.DevelopmentSetupWithPaths(os.Getenv("workspaceFolder") + "/agent/etc/application.toml") +} +``` + + + + +## 注册脚本执行引擎 + +1. 注册 +```go +// 把ScriptExcutor 托管给IOC管理 +func init() { + ioc.Controller().Registry(&ScriptExcutor{ + WorkDirPrefix: "workspace", + ScriptDirPrefix: "scripts", + IsVerifyScriptIntegrity: false, + }) +} +``` + +2. 初始化 +```go +func (e *ScriptExcutor) Init() error { + // 初始化日志记录器 + e.log = log.Sub(e.Name()) + // 初始化脚本完整性管理器 + e.integrityManager = NewScriptIntegrityManager(e.ScriptDirPrefix, e.IsVerifyScriptIntegrity) + return nil +} + +func (e *ScriptExcutor) Name() string { + return APP_NAME +} +``` + +## 服务启动 + +1. 服务配置 +```toml +[app] +name = "devops_agent" + +[http] +port = 8848 + +[script_excutor] +work_dir_prefix = "workspace" +script_dir_prefix = "scripts" +is_verify_script_integrity = false +``` + +2. 服务启动 +```go +import ( + "github.com/infraboard/mcube/v2/ioc/server/cmd" + + // 工程引用到的一些通用工具(API) + // 这些接口 不是用来做功能实现, 提供健康检查,性能,等额外信息 + // 健康检查 + _ "github.com/infraboard/mcube/v2/ioc/apps/health/restful" + + // 非业务模块 + _ "github.com/infraboard/mcube/v2/ioc/apps/metric/restful" + + // 开启API Doc + _ "github.com/infraboard/mcube/v2/ioc/apps/apidoc/restful" +) + +func main() { + // 启动服务(ioc) + cmd.Start() +} +``` diff --git a/devops/agent/etc/application.toml b/devops/agent/etc/application.toml new file mode 100644 index 0000000..e7a4908 --- /dev/null +++ b/devops/agent/etc/application.toml @@ -0,0 +1,10 @@ +[app] +name = "devops_agent" + +[http] +port = 8848 + +[script_excutor] +work_dir_prefix = "/Users/yumaojun/Projects/go-course/go20/devops/agent/workspace" +script_dir_prefix = "/Users/yumaojun/Projects/go-course/go20/devops/agent/shells" +is_verify_script_integrity = false diff --git a/devops/agent/main.go b/devops/agent/main.go new file mode 100644 index 0000000..eb19ee0 --- /dev/null +++ b/devops/agent/main.go @@ -0,0 +1,21 @@ +package main + +import ( + "github.com/infraboard/mcube/v2/ioc/server/cmd" + + // 工程引用到的一些通用工具(API) + // 这些接口 不是用来做功能实现, 提供健康检查,性能,等额外信息 + // 健康检查 + _ "github.com/infraboard/mcube/v2/ioc/apps/health/restful" + + // 非业务模块 + _ "github.com/infraboard/mcube/v2/ioc/apps/metric/restful" + + // 开启API Doc + _ "github.com/infraboard/mcube/v2/ioc/apps/apidoc/restful" +) + +func main() { + // 启动服务(ioc) + cmd.Start() +} diff --git a/devops/agent/script/interface.go b/devops/agent/script/interface.go index 218f4ae..b1a5fe6 100644 --- a/devops/agent/script/interface.go +++ b/devops/agent/script/interface.go @@ -1,13 +1,41 @@ package script import ( + "context" "fmt" + "io" "os" "os/exec" + "path/filepath" "strings" "time" + + "github.com/infraboard/mcube/v2/ioc" ) +const ( + APP_NAME = "script_excutor" +) + +// ExecuteScript 执行脚本的接口函数 +// 当前这个脚本引擎对象,别托管到ioc里了,直接暴露一个全局函数就好了, +// 毕竟这个函数是我们对外提供的接口,没必要让调用者关心它是怎么实现的 +func ExecuteScript(ctx context.Context, in *ExecuteScriptRequest) (*ExecutionResult, error) { + // 从IOC容器中获取ScriptExcutor实例 + executor := ioc.Controller().Get(APP_NAME).(*ScriptExcutor) + return executor.ExecuteScript(ctx, in) +} + +func NewExecuteScriptRequest(scriptPath string, args []string) *ExecuteScriptRequest { + return &ExecuteScriptRequest{ + ScriptPath: scriptPath, + Args: args, + envVars: make(map[string]string), + createProcessGroup: true, // 默认启用进程组管理 + useProcessGroupKill: true, // 默认使用进程组杀死方式 + } +} + // ExecuteScriptRequest 定义了执行脚本所需的参数和配置 type ExecuteScriptRequest struct { ScriptPath string @@ -44,6 +72,38 @@ type ExecuteScriptRequest struct { cmd *exec.Cmd } +func (s *ExecuteScriptRequest) SetWorkDir(dir string) { + s.workDir = dir + if s.metadata != nil { + s.metadata.WorkDir = dir + } +} + +// GetResultFilePath 获取结果文件路径 +func (s *ExecuteScriptRequest) GetResultFilePath() string { + if filepath.IsAbs(s.resultFile) { + return s.resultFile + } + return filepath.Join(s.workDir, s.resultFile) +} + +// SetTimeout 设置脚本执行超时时间 +func (s *ExecuteScriptRequest) SetTimeout(timeout time.Duration) { + s.timeout = timeout + if s.metadata != nil { + s.metadata.Timeout = timeout + } +} + +// SetLogFile 设置脚本执行日志文件路径 +func (s *ExecuteScriptRequest) SetLogFile(path string) { + s.logFile = path +} + +func (s *ExecuteScriptRequest) SetLogCallback(callback func(string)) { + s.logCallback = callback +} + // SetEnv 设置环境变量, key会被强制转换为大写 func (s *ExecuteScriptRequest) SetEnv(key, value string) { key = strings.ToUpper(strings.TrimSpace(key)) @@ -53,6 +113,16 @@ func (s *ExecuteScriptRequest) SetEnv(key, value string) { } } +// SetDebugScript 设置是否启用调试脚本 +// 通过环境变量 DEBUG_SCRIPT 控制 (值为 true 或 1 时启用) +func (s *ExecuteScriptRequest) SetDebugScript(v bool) { + if v { + s.envVars["DEBUG_SCRIPT"] = "true" + } else { + s.envVars["DEBUG_SCRIPT"] = "false" + } +} + // buildEnv 构建环境变量, 将请求中的环境变量与系统环境变量合并,返回一个新的环境变量列表 func (s *ExecuteScriptRequest) buildEnv() []string { env := os.Environ() // 获取系统环境变量 @@ -82,6 +152,60 @@ func (r *ExecuteScriptRequest) WithWorkspacePrefix(workDirPrefix string) *Execut return r } +// getLogWriter 获取日志文件写入器 +// 如果指定了日志回调函数,会创建一个多路写入器,将日志同时写入文件和回调函数 +func (s *ExecuteScriptRequest) getLogWriter() (io.Writer, error) { + logPath := s.logFile + if !filepath.IsAbs(logPath) { + logPath = filepath.Join(s.workDir, logPath) + } + + // 如果文件存在, 清空文件内容 + if _, err := os.Stat(logPath); err == nil { + if err := os.Truncate(logPath, 0); err != nil { + return nil, fmt.Errorf("清空日志文件失败: %v", err) + } + } + + var logWriter io.Writer + // 如果文件不存在,创建目录和文件, 存在则直接打开 + if _, err := os.Stat(logPath); os.IsNotExist(err) { + if err := os.MkdirAll(filepath.Dir(logPath), 0755); err != nil { + return nil, fmt.Errorf("创建日志目录失败: %v", err) + } + file, err := os.Create(logPath) + if err != nil { + return nil, fmt.Errorf("创建日志文件失败: %v", err) + } + logWriter = file + } else { + file, err := os.OpenFile(logPath, os.O_CREATE|os.O_WRONLY|os.O_APPEND, 0644) + if err != nil { + return nil, fmt.Errorf("打开日志文件失败: %v", err) + } + logWriter = file + } + + // 如果有回调函数,创建一个多路写入器 + if s.logCallback != nil { + return io.MultiWriter(logWriter, &callbackWriter{callback: s.logCallback}), nil + } + + return logWriter, nil +} + +// callbackWriter 实现 io.Writer 接口的回调写入器 +type callbackWriter struct { + callback func(string) +} + +func (c *callbackWriter) Write(p []byte) (n int, err error) { + if c.callback != nil { + c.callback(string(p)) + } + return len(p), nil +} + // CommandMetadata 命令元数据 type CommandMetadata struct { ID string `json:"id"` // 命令唯一ID @@ -96,6 +220,13 @@ type CommandMetadata struct { RefTask string `json:"ref_task,omitempty"` // 关联的任务 } +func (s *CommandMetadata) String() string { + return fmt.Sprintf("ID=%s, Name=%s, CreatedBy=%s, CreatedAt=%s, Timeout=%s, WorkDir=%s", + s.ID, s.Name, s.CreatedBy, s.CreatedAt.Format("2006-01-02 15:04:05"), s.Timeout.String(), s.WorkDir) +} + +// VerifyScriptIntegrity 校验脚本完整性 + // ExecutionResult 命令执行结果 type ExecutionResult struct { // 命令 diff --git a/devops/agent/script/response.go b/devops/agent/script/response.go new file mode 100644 index 0000000..9b2e955 --- /dev/null +++ b/devops/agent/script/response.go @@ -0,0 +1,58 @@ +package script + +import ( + "fmt" + "os" + "strings" +) + +// ParseOutputParams 解析脚本输出参数文件(output.env) +// 支持标准的 key=value 格式,自动处理注释、空行、引号等 +func ParseOutputParams(filePath string) (map[string]string, error) { + data, err := os.ReadFile(filePath) + if err != nil { + return nil, err + } + + params := make(map[string]string) + lines := strings.Split(string(data), "\n") + + for lineNum, line := range lines { + // 去除首尾空白 + line = strings.TrimSpace(line) + + // 跳过空行和注释 + if line == "" || strings.HasPrefix(line, "#") { + continue + } + + // 查找第一个 = 号 + parts := strings.SplitN(line, "=", 2) + if len(parts) != 2 { + // 格式不正确,记录警告但继续处理 + fmt.Printf("[WARN] output.env line %d: invalid format, skipping: %s\n", lineNum+1, line) + continue + } + + key := strings.TrimSpace(parts[0]) + value := strings.TrimSpace(parts[1]) + + // 移除值两端的引号(支持单引号和双引号) + if len(value) >= 2 { + if (value[0] == '"' && value[len(value)-1] == '"') || + (value[0] == '\'' && value[len(value)-1] == '\'') { + value = value[1 : len(value)-1] + } + } + + // 验证 key 不为空 + if key == "" { + fmt.Printf("[WARN] output.env line %d: empty key, skipping\n", lineNum+1) + continue + } + + params[key] = value + } + + return params, nil +} diff --git a/devops/agent/script/response_test.go b/devops/agent/script/response_test.go new file mode 100644 index 0000000..d914cf0 --- /dev/null +++ b/devops/agent/script/response_test.go @@ -0,0 +1,19 @@ +package script_test + +import ( + "devops/agent/script" + "testing" +) + +func TestParseOutputParams(t *testing.T) { + outputParams, err := script.ParseOutputParams("testdata/output.env") + if err != nil { + t.Fatal(err) + } + + t.Log(outputParams) + if outputParams["key"] != "value" { + t.Errorf("expected key=value, got %s", outputParams["key"]) + } + +} diff --git a/devops/agent/script/runner.go b/devops/agent/script/runner.go index 970d8fa..c275038 100644 --- a/devops/agent/script/runner.go +++ b/devops/agent/script/runner.go @@ -2,7 +2,9 @@ package script import ( "context" + "encoding/json" "fmt" + "io" "os" "os/exec" "path/filepath" @@ -10,30 +12,53 @@ import ( "syscall" "time" + "github.com/infraboard/mcube/v2/ioc" + "github.com/infraboard/mcube/v2/ioc/config/log" "github.com/rs/zerolog" ) +// 把ScriptExcutor 托管给IOC管理 +func init() { + ioc.Controller().Registry(&ScriptExcutor{ + WorkDirPrefix: "workspace", + ScriptDirPrefix: "shells", + IsVerifyScriptIntegrity: false, + runningCommands: make(map[string]*ExecuteScriptRequest), + }) +} + // ScriptExcutor 脚本执行器,负责制定脚本的执行逻辑,比如准备环境变量、执行脚本、处理输出等 type ScriptExcutor struct { + ioc.ObjectImpl + // 工作目录前缀,用于确保脚本执行在指定的目录下 - WorkDirPrefix string + WorkDirPrefix string `toml:"work_dir_prefix" json:"work_dir_prefix" yaml:"work_dir_prefix"` // 脚本目录前缀,用于确保脚本路径在指定的目录下, 避免执行不安全的脚本 - ScriptDirPrefix string + ScriptDirPrefix string `toml:"script_dir_prefix" json:"script_dir_prefix" yaml:"script_dir_prefix"` // 是否启用脚本完整性校验, 通过编译时嵌入的脚本 hash 来校验脚本的完整性, 防止脚本被篡改 - IsVerifyScriptIntegrity bool + IsVerifyScriptIntegrity bool `toml:"is_verify_script_integrity" json:"is_verify_script_integrity" yaml:"is_verify_script_integrity"` // 日志记录器,用于记录脚本执行的日志信息 log *zerolog.Logger // 脚本完整性管理器,用于校验脚本的完整性 integrityManager *ScriptIntegrityManager + + // 当前正在执行中的命令列表,key为工作目录,value为执行请求 + runningCommands map[string]*ExecuteScriptRequest } func (e *ScriptExcutor) Init() error { + // 初始化日志记录器 + e.log = log.Sub(e.Name()) // 初始化脚本完整性管理器 e.integrityManager = NewScriptIntegrityManager(e.ScriptDirPrefix, e.IsVerifyScriptIntegrity) return nil } +func (e *ScriptExcutor) Name() string { + return APP_NAME +} + // ExecuteScript 执行脚本的核心方法,接受一个 ExecuteScriptRequest 请求,返回一个 ExecutionResult 结果 func (e *ScriptExcutor) ExecuteScript(ctx context.Context, in *ExecuteScriptRequest) (*ExecutionResult, error) { // 确保工作目录前缀, 避免脚本执行在不安全的目录下, 同时也方便清理执行结果 @@ -128,7 +153,128 @@ func (e *ScriptExcutor) ExecuteScript(ctx context.Context, in *ExecuteScriptRequ } } - return nil, nil + // 执行脚本,并且把结果写到输出到文件里面 + // 开始执行命令 + + // 添加到运行中的命令列表中 + e.runningCommands[in.workDir] = in + defer delete(e.runningCommands, in.workDir) + + taskId := "unknown" + if in.metadata != nil { + taskId = in.metadata.ID + } + + // 获取日志写入器 + logWriter, err := in.getLogWriter() + if err != nil { + e.log.Error().Str("task_id", taskId).Err(err).Msg("创建日志写入器失败") + return nil, err + } + defer func() { + if closer, ok := logWriter.(io.Closer); ok { + closer.Close() + } + }() + + // 命令的日志输出到制定的地方 + in.cmd.Stdout = logWriter + in.cmd.Stderr = logWriter + + // 记录执行开始, 包括时间、工作目录、脚本路径和元数据等信息 + startTime := time.Now() + logHeader := fmt.Sprintf("\n=== Execution Started ===\nTime: %s\nWorkDir: %s\nScript: %s\nMetadata: %s\n", + startTime.Format("2006-01-02 15:04:05"), + in.workDir, + fullScriptPath, + in.metadata.String(), + ) + fmt.Fprint(logWriter, logHeader) + fmt.Fprint(logWriter, "\n") + + // 执行命令 + e.log.Info().Str("task_id", taskId).Msg("开始执行命令") + err = in.cmd.Run() + endTime := time.Now() + duration := endTime.Sub(startTime) + + // 构建执行结果 + result := &ExecutionResult{ + Command: fullScriptPath, + StartTime: startTime, + EndTime: &endTime, + Duration: duration, + Success: err == nil, + Metadata: in.metadata, + } + + if err != nil { + // 判断是否为超时错误 + if in.cmd.ProcessState != nil && in.cmd.ProcessState.ExitCode() == -1 { + e.log.Error().Str("task_id", taskId).Dur("duration", duration).Dur("timeout", in.timeout).Err(err).Msg("命令执行超时") + } else { + e.log.Error().Str("task_id", taskId).Dur("duration", duration).Err(err).Msg("命令执行失败") + } + + // 错误信息 + result.Error = err.Error() + if in.cmd.ProcessState != nil { + result.ExitCode = in.cmd.ProcessState.ExitCode() + } else { + result.ExitCode = -1 + } + } else { + e.log.Info().Str("task_id", taskId).Dur("duration", duration).Msg("命令执行成功") + } + + // 解析脚本输出参数(无论成功或失败都收集) + outputFile := filepath.Join(in.workDir, "output.env") + if outputParams, parseErr := ParseOutputParams(outputFile); parseErr == nil && len(outputParams) > 0 { + result.OutputParams = outputParams + e.log.Info().Str("task_id", taskId).Bool("success", result.Success).Int("param_count", len(outputParams)).Msg("成功解析脚本输出参数") + } else if parseErr != nil && !os.IsNotExist(parseErr) { + e.log.Warn().Str("task_id", taskId).Str("output_file", outputFile).Err(parseErr).Msg("解析输出参数文件失败") + } + + // 保存执行结果(无论成功或失败都保存结果,方便后续查询和调试) + e.log.Debug().Str("task_id", taskId).Str("result_file", in.GetResultFilePath()).Msg("准备保存执行结果") + if saveErr := in.saveResult(result); saveErr != nil { + e.log.Error().Str("task_id", taskId).Err(saveErr).Msg("保存执行结果失败") + } + + // 记录执行结束 + logFooter := fmt.Sprintf("\n=== Execution Finished ===\nTime: %s\nDuration: %v\nSuccess: %t\nExitCode: %d\nError: %v\n", + endTime.Format("2006-01-02 15:04:05"), + duration, + result.Success, + result.ExitCode, + err, + ) + fmt.Fprint(logWriter, logFooter) + return result, err +} + +// saveResult 保存执行结果到文件 +func (s *ExecuteScriptRequest) saveResult(result *ExecutionResult) error { + if result == nil { + return nil + } + + resultPath := s.resultFile + if !filepath.IsAbs(resultPath) { + resultPath = filepath.Join(s.workDir, resultPath) + } + + // 美化输出JSON + data, err := json.MarshalIndent(result, "", " ") + if err != nil { + return fmt.Errorf("failed to marshal result: %v", err) + } + + if err := os.WriteFile(resultPath, data, 0644); err != nil { + return fmt.Errorf("failed to save result file: %v", err) + } + return nil } func (e *ScriptExcutor) InjectEnv(in *ExecuteScriptRequest) { diff --git a/devops/agent/script/runner_test.go b/devops/agent/script/runner_test.go new file mode 100644 index 0000000..30d5dae --- /dev/null +++ b/devops/agent/script/runner_test.go @@ -0,0 +1,32 @@ +package script_test + +import ( + "devops/agent/script" + "devops/agent/test" + "fmt" + "testing" + "time" +) + +func TestScriptExcutor_ExecuteScript(t *testing.T) { + // 直接使用单元测试的上下文, 方便取消 + req := script.NewExecuteScriptRequest("task_debug.sh", []string{}) + req.SetWorkDir("task-01") + req.SetTimeout(30 * time.Second) + req.SetDebugScript(true) + req.SetLogFile("stdout.txt") + req.SetLogCallback(func(s string) { + fmt.Print(s) + }) + + resp, err := script.ExecuteScript(t.Context(), req) + if err != nil { + t.Fatalf("failed to execute script: %v", err) + } + t.Logf("script execution result: %+v", resp) +} + +func init() { + // 设置测试环境 + test.Setup() +} diff --git a/devops/agent/script/testdata/output.env b/devops/agent/script/testdata/output.env new file mode 100644 index 0000000..fbb03fa --- /dev/null +++ b/devops/agent/script/testdata/output.env @@ -0,0 +1,3 @@ +a=b +c=d +key=value \ No newline at end of file diff --git a/devops/agent/shells/task_debug.sh b/devops/agent/shells/task_debug.sh old mode 100644 new mode 100755 diff --git a/devops/agent/test/setup.go b/devops/agent/test/setup.go new file mode 100644 index 0000000..924dafb --- /dev/null +++ b/devops/agent/test/setup.go @@ -0,0 +1,15 @@ +package test + +import ( + "os" + + "github.com/infraboard/mcube/v2/ioc" +) + +// 用于设置测试环境的函数,比如初始化日志系统,配置环境变量等 +func Setup() { + // 配置文件的逻辑 + // 和我们本地运行时的保存一致, etc/application.toml, 这是一个相对路径(工程名称) + // 点击单元测试的时候, 单元测试的运行目录是变化的,因此这里需要给绝对逻辑 + ioc.DevelopmentSetupWithPaths(os.Getenv("workspaceFolder") + "/agent/etc/application.toml") +} diff --git a/devops/agent/workspace/output.env b/devops/agent/workspace/output.env new file mode 100644 index 0000000..e69de29 diff --git a/devops/agent/workspace/task-01/debug.sh b/devops/agent/workspace/task-01/debug.sh new file mode 100755 index 0000000..21283f0 --- /dev/null +++ b/devops/agent/workspace/task-01/debug.sh @@ -0,0 +1,18 @@ +#!/bin/bash +# ========== 调试脚本 (自动生成) ========== +# 警告: 此脚本可能包含敏感信息,请勿提交到版本控制系统 +# 生成时间: 2026-03-15 15:58:16 +# 工作目录: /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +# 脚本路径: /Users/yumaojun/Projects/go-course/go20/devops/agent/shells/task_debug.sh +# ========================================== + +set -e + +# 设置环境变量 +export DEBUG_SCRIPT='true' +export OUTPUT_ENV_FILE='/Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01/output.env' +export SCRIPT_DIR='/Users/yumaojun/Projects/go-course/go20/devops/agent/shells' +export WORKSPACE='/Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01' + +# 执行脚本 +exec /Users/yumaojun/Projects/go-course/go20/devops/agent/shells/task_debug.sh diff --git a/devops/agent/workspace/task-01/output.env b/devops/agent/workspace/task-01/output.env new file mode 100644 index 0000000..e69de29 diff --git a/devops/agent/workspace/task-01/stdout.txt b/devops/agent/workspace/task-01/stdout.txt new file mode 100644 index 0000000..c6b11dd --- /dev/null +++ b/devops/agent/workspace/task-01/stdout.txt @@ -0,0 +1,240 @@ + +=== Execution Started === +Time: 2026-03-15 15:58:16 +WorkDir: /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +Script: /Users/yumaojun/Projects/go-course/go20/devops/agent/shells/task_debug.sh +Metadata: ID=cmd_1773561496254114000, Name=, CreatedBy=yumaojun, CreatedAt=2026-03-15 15:58:16, Timeout=30s, WorkDir=/Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 + +[HINT] 2026-03-15 15:58:16 - 开始任务调试信息输出 +[INFO] 2026-03-15 15:58:16 - ======================================== + 任务基本信息 +[INFO] 2026-03-15 15:58:16 - ======================================== +任务ID : 未设置 +任务名称 : 未设置 +任务类型 : 未设置 +任务状态 : 未设置 +任务描述 : 未设置 +执行者 : 未设置 +Agent 环境 : 未设置 +调度的 Agent : 未设置 + +[INFO] 2026-03-15 15:58:16 - ======================================== + 标准环境变量 +[INFO] 2026-03-15 15:58:16 - ======================================== +工作目录 : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +脚本目录 : /Users/yumaojun/Projects/go-course/go20/devops/agent/shells +用户 : yumaojun +主机名 : oldfishmpb-9.local +PWD : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +HOME : /Users/yumaojun +SHELL : /bin/zsh + +[INFO] 2026-03-15 15:58:16 - ======================================== + 任务参数 (PARAM_*) +[INFO] 2026-03-15 15:58:16 - ======================================== + (无任务参数) + +[INFO] 2026-03-15 15:58:16 - ======================================== + 任务定义 (DEFINE_*) +[INFO] 2026-03-15 15:58:16 - ======================================== + (无任务定义) + +[INFO] 2026-03-15 15:58:16 - ======================================== + 所有环境变量 +[INFO] 2026-03-15 15:58:16 - ======================================== +APPLICATIONINSIGHTS_CONFIGURATION_CONTENT : {} +APPLICATION_INSIGHTS_NO_DIAGNOSTIC_CHANNEL : 1 +APPLICATION_INSIGHTS_NO_STATSBEAT : true +BUNDLED_DEBUGPY_PATH : /Users/yumaojun/.vscode/extensions/ms-python.debugpy-2025.18.0-darwin-arm64/bundled/libs/debugpy +COLORTERM : truecolor +COMMAND_MODE : unix2003 +DEBUG_SCRIPT : true +ELECTRON_NO_ATTACH_CONSOLE : 1 +ELECTRON_RUN_AS_NODE : 1 +GIT_ASKPASS : /Applications/Visual Studio Code.app/Contents/Resources/app/extensions/git/dist/askpass.sh +GOMODCACHE : /Users/yumaojun/go/pkg/mod +GOPATH : /Users/yumaojun/go +GOPROXY : https://goproxy.cn,direct +GOTELEMETRY_GOPLS_CLIENT_START_TIME : 1706263009 +GOTELEMETRY_GOPLS_CLIENT_TOKEN : 92 +HOME : /Users/yumaojun +HOMEBREW_CELLAR : /opt/homebrew/Cellar +HOMEBREW_PREFIX : /opt/homebrew +HOMEBREW_REPOSITORY : /opt/homebrew +HTTPS_PROXY : http://localhost:8001 +HTTP_PROXY : http://localhost:8001 +INFOPATH : /opt/homebrew/share/info:/opt/homebrew/share/info: +JAVA_HOME : /Users/yumaojun/.sdkman/candidates/java/current +LANG : C.UTF-8 +LESS : -R +LOGNAME : yumaojun +LSCOLORS : Gxfxcxdxbxegedabagacad +LS_COLORS : di=1;36:ln=35:so=32:pi=33:ex=31:bd=34;46:cd=34;43:su=30;41:sg=30;46:tw=30;42:ow=30;43 +MACH_PORT_RENDEZVOUS_PEER_VALDATION : 0 +MAVEN_HOME : /Users/yumaojun/.sdkman/candidates/maven/current +MallocNanoZone : 0 +NODE_TLS_REJECT_UNAUTHORIZED : undefined +OSLogRateLimit : 64 +OTEL_SERVICE_NAME : devops_agent +OUTPUT_ENV_FILE : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01/output.env +PAGER : less +PATH : /usr/local/go/bin:/Users/yumaojun/bin:/usr/local/bin:/Users/yumaojun/go/bin:/Users/yumaojun/Library/... (truncated) +PWD : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +PYDEVD_DISABLE_FILE_VALIDATION : 1 +PYTHONSTARTUP : /Users/yumaojun/Library/Application Support/Code/User/workspaceStorage/1109ca5f32ed51b417f544c694efb... (truncated) +PYTHON_BASIC_REPL : 1 +RUSTUP_DIST_SERVER : https://rsproxy.cn +RUSTUP_UPDATE_ROOT : https://rsproxy.cn/rustup +SCRIPT_DIR : /Users/yumaojun/Projects/go-course/go20/devops/agent/shells +SDKMAN_CANDIDATES_API : https://api.sdkman.io/2 +SDKMAN_CANDIDATES_DIR : /Users/yumaojun/.sdkman/candidates +SDKMAN_DIR : /Users/yumaojun/.sdkman +SDKMAN_PLATFORM : darwinarm64 +SHELL : /bin/zsh +SHLVL : 4 +SSH_AUTH_SOCK : /private/tmp/com.apple.launchd.lh9fi1XbLE/Listeners +TERM : xterm-256color +TERM_PROGRAM : vscode +TERM_PROGRAM_VERSION : 1.111.0 +TMPDIR : /var/folders/51/dnfr1hzd53x03k3fxnnyd4qc0000gn/T/ +USER : yumaojun +USER_ZDOTDIR : /Users/yumaojun +VSCEXT_ENABLE_PYTHON_BEST_EFFORTS_INSTALLATION : false +VSCEXT_MATCH_MANIFEST_VERSIONS : true +VSCEXT_PROXY_URL : http://localhost:8001 +VSCEXT_STACK_ANALYSIS_COMMAND : rhda.stackAnalysis +VSCEXT_TELEMETRY_ID : 5d2072f3-115e-4c18-a6a6-c1ab0dbc96c6 +VSCEXT_TRACK_RECOMMENDATION_ACCEPTANCE_COMMAND : rhda.trackRecommendationAcceptance +VSCEXT_TRUSTIFY_DA_BACKEND_URL : https://rhda.rhcloud.com +VSCEXT_TRUSTIFY_DA_DOCKER_PATH : docker +VSCEXT_TRUSTIFY_DA_GO_PATH : go +VSCEXT_TRUSTIFY_DA_GRADLE_PATH : gradle +VSCEXT_TRUSTIFY_DA_IMAGE_PLATFORM : +VSCEXT_TRUSTIFY_DA_MVN_ARGS : [] +VSCEXT_TRUSTIFY_DA_MVN_PATH : mvn +VSCEXT_TRUSTIFY_DA_NPM_PATH : npm +VSCEXT_TRUSTIFY_DA_PIP3_PATH : pip3 +VSCEXT_TRUSTIFY_DA_PIP_PATH : pip +VSCEXT_TRUSTIFY_DA_PNPM_PATH : pnpm +VSCEXT_TRUSTIFY_DA_PODMAN_PATH : podman +VSCEXT_TRUSTIFY_DA_PREFER_GRADLEW : true +VSCEXT_TRUSTIFY_DA_PREFER_MVNW : true +VSCEXT_TRUSTIFY_DA_PYTHON3_PATH : python3 +VSCEXT_TRUSTIFY_DA_PYTHON_PATH : python +VSCEXT_TRUSTIFY_DA_SKOPEO_CONFIG_PATH : +VSCEXT_TRUSTIFY_DA_SKOPEO_PATH : skopeo +VSCEXT_TRUSTIFY_DA_SYFT_CONFIG_PATH : +VSCEXT_TRUSTIFY_DA_SYFT_PATH : syft +VSCEXT_TRUSTIFY_DA_YARN_PATH : yarn +VSCEXT_USE_GO_MVS : false +VSCEXT_USE_PIP_DEP_TREE : false +VSCEXT_USE_PYTHON_VIRTUAL_ENVIRONMENT : false +VSCEXT_UTM_SOURCE : vscode +VSCEXT_VULNERABILITY_ALERT_SEVERITY : Error +VSCODE_CLI : 1 +VSCODE_CODE_CACHE_PATH : /Users/yumaojun/Library/Application Support/Code/CachedData/ce099c1ed25d9eb3076c11e4a280f3eb52b4fbeb +VSCODE_CRASH_REPORTER_PROCESS_TYPE : extensionHost +VSCODE_CWD : /Users/yumaojun/Projects/go-course/go20/devops +VSCODE_DEBUGPY_ADAPTER_ENDPOINTS : /Users/yumaojun/.vscode/extensions/ms-python.debugpy-2025.18.0-darwin-arm64/.noConfigDebugAdapterEnd... (truncated) +VSCODE_DOTNET_INSTALL_TOOL_ORIGINAL_HOME : /Users/yumaojun +VSCODE_ESM_ENTRYPOINT : vs/workbench/api/node/extensionHostProcess +VSCODE_GIT_ASKPASS_MAIN : /Applications/Visual Studio Code.app/Contents/Resources/app/extensions/git/dist/askpass-main.js +VSCODE_GIT_ASKPASS_NODE : /Applications/Visual Studio Code.app/Contents/Frameworks/Code Helper (Plugin).app/Contents/MacOS/Cod... (truncated) +VSCODE_GIT_IPC_HANDLE : /var/folders/51/dnfr1hzd53x03k3fxnnyd4qc0000gn/T/vscode-git-da870cf1eb.sock +VSCODE_HANDLES_UNCAUGHT_ERRORS : true +VSCODE_INJECTION : 1 +VSCODE_IPC_HOOK : /Users/yumaojun/Library/Application Support/Code/1.11-main.sock +VSCODE_L10N_BUNDLE_LOCATION : file:///Users/yumaojun/.vscode/extensions/ms-ceintl.vscode-language-pack-zh-hans-1.110.2026031109/tr... (truncated) +VSCODE_NLS_CONFIG : {"userLocale":"zh-cn","osLocale":"zh-cn","resolvedLanguage":"zh-cn","defaultMessagesFile":"/Applicat... (truncated) +VSCODE_PID : 28877 +VSCODE_PROFILE_INITIALIZED : 1 +VSCODE_PYTHON_AUTOACTIVATE_GUARD : 1 +WORKSPACE : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 +XPC_FLAGS : 0x0 +XPC_SERVICE_NAME : 0 +ZDOTDIR : /Users/yumaojun +ZSH : /Users/yumaojun/.oh-my-zsh +_ : /usr/bin/env +__CFBundleIdentifier : com.microsoft.VSCode +__CF_USER_TEXT_ENCODING : 0x1F5:0x19:0x34 +http_proxy : http://localhost:8001 +https_proxy : http://localhost:8001 +workspaceFolder : /Users/yumaojun/Projects/go-course/go20/devops + +[INFO] 2026-03-15 15:58:16 - ======================================== + 系统信息 +[INFO] 2026-03-15 15:58:16 - ======================================== +操作系统 : Darwin +内核版本 : 25.3.0 +架构 : arm64 +磁盘使用 : 523Gi/1.8Ti (29% used) +CPU 核心数 : unknown +当前时间 : 2026-03-15 15:58:16 CST + +[INFO] 2026-03-15 15:58:16 - ======================================== + 工作目录内容 +[INFO] 2026-03-15 15:58:16 - ======================================== +工作目录路径 : /Users/yumaojun/Projects/go-course/go20/devops/agent/workspace/task-01 + +文件列表: + -rwxr-xr-x 1 yumaojun staff 831B Mar 15 15:58 debug.sh + -rw-r--r-- 1 yumaojun staff 0B Mar 15 15:58 output.env + -rw-r--r-- 1 yumaojun staff 9.6K Mar 15 15:58 stdout.txt + +[INFO] 2026-03-15 15:58:16 - ======================================== + 网络信息 +[INFO] 2026-03-15 15:58:16 - ======================================== +IP 地址: + inet 127.0.0.1 netmask 0xff000000 + inet6 ::1 prefixlen 128 + inet6 fe80::1%lo0 prefixlen 64 scopeid 0x1 + inet6 fe80::4fe:9546:f301:c912%en0 prefixlen 64 secured scopeid 0xe + inet 192.168.10.38 netmask 0xffffff00 broadcast 192.168.10.255 + inet6 2409:8a55:2e75:9ee1:14ea:6bfb:6c38:5558 prefixlen 64 autoconf secured + inet6 2409:8a55:2e75:9ee1:f0fb:2d8e:30b8:f36e prefixlen 64 deprecated autoconf temporary + inet6 2409:8a55:2e75:9ee1::a0c prefixlen 64 dynamic + inet6 2409:8a55:2e75:9ee1:7d95:f17f:244c:7f69 prefixlen 64 deprecated autoconf temporary + inet6 2409:8a55:2e75:9ee1:9c3b:28fb:41e2:f670 prefixlen 64 autoconf temporary + inet6 fe80::e076:f5ff:fe6c:bb23%awdl0 prefixlen 64 scopeid 0x10 + inet6 fe80::e076:f5ff:fe6c:bb23%llw0 prefixlen 64 scopeid 0x11 + inet6 fe80::2aaa:254b:5496:fcd7%utun0 prefixlen 64 scopeid 0x12 + inet6 fe80::3a94:3e19:56f2:7729%utun1 prefixlen 64 scopeid 0x13 + inet6 fe80::3a73:5c32:f0b4:764c%utun2 prefixlen 64 scopeid 0x14 + inet6 fe80::ce81:b1c:bd2c:69e%utun3 prefixlen 64 scopeid 0x15 + +[INFO] 2026-03-15 15:58:16 - ======================================== + Docker 信息 +[INFO] 2026-03-15 15:58:16 - ======================================== +Docker 版本 : 29.2.1 +运行中的容器 : 2 +总容器数 : 18 +镜像数量 : 44 + +[INFO] 2026-03-15 15:58:16 - ======================================== + 进程信息 +[INFO] 2026-03-15 15:58:16 - ======================================== +当前进程 PID : 31646 +父进程 PID : 31637 + +当前进程树: + +[INFO] 2026-03-15 15:58:16 - ======================================== + 环境变量统计 +[INFO] 2026-03-15 15:58:16 - ======================================== +总环境变量数 : 118 +任务参数数 (PARAM_*) : 0 +0 +任务定义数 (DEFINE_*) : 0 +0 +任务信息数 (TASK_*) : 0 +0 + +[INFO] 2026-03-15 15:58:16 - ======================================== +[SUCCESS] 2026-03-15 15:58:16 - 任务调试信息输出完成 + +=== Execution Finished === +Time: 2026-03-15 15:58:16 +Duration: 398.239625ms +Success: true +ExitCode: 0 +Error: diff --git a/devops/docs/agent.drawio b/devops/docs/agent.drawio index 677284a..272f230 100644 --- a/devops/docs/agent.drawio +++ b/devops/docs/agent.drawio @@ -1,39 +1,78 @@ - + - - + + - + - + - + - + - + - + - + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/devops/go.mod b/devops/go.mod index b80ccd7..ce81c2d 100644 --- a/devops/go.mod +++ b/devops/go.mod @@ -4,22 +4,63 @@ go 1.25.6 require ( github.com/infraboard/mcube v1.9.29 - github.com/infraboard/mcube/v2 v2.1.3 + github.com/infraboard/mcube/v2 v2.1.4 github.com/rs/zerolog v1.34.0 ) require ( github.com/BurntSushi/toml v1.5.0 // indirect + github.com/beorn7/perks v1.0.1 // indirect github.com/caarlos0/env/v6 v6.10.1 // indirect + github.com/cenkalti/backoff/v5 v5.0.3 // indirect + github.com/cespare/xxhash/v2 v2.3.0 // indirect + github.com/dustin/go-humanize v1.0.1 // indirect + github.com/emicklei/go-restful-openapi/v2 v2.11.0 // indirect + github.com/emicklei/go-restful/v3 v3.13.0 // indirect + github.com/go-logr/logr v1.4.3 // indirect + github.com/go-logr/stdr v1.2.2 // indirect + github.com/go-openapi/jsonpointer v0.21.0 // indirect + github.com/go-openapi/jsonreference v0.21.0 // indirect + github.com/go-openapi/spec v0.21.0 // indirect + github.com/go-openapi/swag v0.23.0 // indirect + github.com/google/uuid v1.6.0 // indirect + github.com/grafana/regexp v0.0.0-20240518133315-a468a5bfb3bc // indirect + github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.2 // indirect + github.com/inconshreveable/mousetrap v1.1.0 // indirect + github.com/josharian/intern v1.0.0 // indirect + github.com/mailru/easyjson v0.7.7 // indirect github.com/mattn/go-colorable v0.1.13 // indirect github.com/mattn/go-isatty v0.0.20 // indirect github.com/mitchellh/mapstructure v1.5.0 // indirect + github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 // indirect github.com/pkg/errors v0.9.1 // indirect + github.com/prometheus/client_golang v1.23.1 // indirect + github.com/prometheus/client_model v0.6.2 // indirect + github.com/prometheus/common v0.66.0 // indirect + github.com/prometheus/procfs v0.16.1 // indirect + github.com/spf13/cobra v1.10.1 // indirect + github.com/spf13/pflag v1.0.9 // indirect + go.opentelemetry.io/auto/sdk v1.1.0 // indirect + go.opentelemetry.io/contrib/instrumentation/github.com/emicklei/go-restful/otelrestful v0.62.0 // indirect + go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.62.0 // indirect go.opentelemetry.io/otel v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0 // indirect + go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0 // indirect + go.opentelemetry.io/otel/metric v1.38.0 // indirect + go.opentelemetry.io/otel/sdk v1.38.0 // indirect go.opentelemetry.io/otel/trace v1.38.0 // indirect + go.opentelemetry.io/proto/otlp v1.7.1 // indirect go.yaml.in/yaml/v2 v2.4.2 // indirect + golang.org/x/net v0.43.0 // indirect golang.org/x/sys v0.35.0 // indirect + golang.org/x/text v0.28.0 // indirect + google.golang.org/genproto/googleapis/api v0.0.0-20250825161204-c5933d9347a5 // indirect + google.golang.org/genproto/googleapis/rpc v0.0.0-20250825161204-c5933d9347a5 // indirect + google.golang.org/grpc v1.75.0 // indirect + google.golang.org/protobuf v1.36.8 // indirect gopkg.in/natefinch/lumberjack.v2 v2.2.1 // indirect + gopkg.in/yaml.v2 v2.4.0 // indirect gopkg.in/yaml.v3 v3.0.1 // indirect sigs.k8s.io/yaml v1.6.0 // indirect ) diff --git a/devops/go.sum b/devops/go.sum index 2fd6380..64fae97 100644 --- a/devops/go.sum +++ b/devops/go.sum @@ -1,17 +1,82 @@ github.com/BurntSushi/toml v1.5.0 h1:W5quZX/G/csjUnuI8SUYlsHs9M38FC7znL0lIO+DvMg= github.com/BurntSushi/toml v1.5.0/go.mod h1:ukJfTF/6rtPPRCnwkur4qwRxa8vTRFBF0uk2lLoLwho= +github.com/beorn7/perks v1.0.1 h1:VlbKKnNfV8bJzeqoa4cOKqO6bYr3WgKZxO8Z16+hsOM= +github.com/beorn7/perks v1.0.1/go.mod h1:G2ZrVWU2WbWT9wwq4/hrbKbnv/1ERSJQ0ibhJ6rlkpw= github.com/caarlos0/env/v6 v6.10.1 h1:t1mPSxNpei6M5yAeu1qtRdPAK29Nbcf/n3G7x+b3/II= github.com/caarlos0/env/v6 v6.10.1/go.mod h1:hvp/ryKXKipEkcuYjs9mI4bBCg+UI0Yhgm5Zu0ddvwc= +github.com/cenkalti/backoff/v5 v5.0.3 h1:ZN+IMa753KfX5hd8vVaMixjnqRZ3y8CuJKRKj1xcsSM= +github.com/cenkalti/backoff/v5 v5.0.3/go.mod h1:rkhZdG3JZukswDf7f0cwqPNk4K0sa+F97BxZthm/crw= +github.com/cespare/xxhash/v2 v2.3.0 h1:UL815xU9SqsFlibzuggzjXhog7bL6oX9BbNZnL2UFvs= +github.com/cespare/xxhash/v2 v2.3.0/go.mod h1:VGX0DQ3Q6kWi7AoAeZDth3/j3BFtOZR5XLFGgcrjCOs= github.com/coreos/go-systemd/v22 v22.5.0/go.mod h1:Y58oyj3AT4RCenI/lSvhwexgC+NSVTIJ3seZv2GcEnc= +github.com/cpuguy83/go-md2man/v2 v2.0.6/go.mod h1:oOW0eioCTA6cOiMLiUPZOpcVxMig6NIQQ7OS05n1F4g= +github.com/creack/pty v1.1.9/go.mod h1:oKZEueFk5CKHvIhNR5MUki03XCEU+Q6VDXinZuGJ33E= +github.com/davecgh/go-spew v1.1.0/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= github.com/davecgh/go-spew v1.1.1 h1:vj9j/u1bqnvCEfJOwUhtlOARqs3+rkHYY13jYWTU97c= github.com/davecgh/go-spew v1.1.1/go.mod h1:J7Y8YcW2NihsgmVo/mv3lAwl/skON4iLHjSsI+c5H38= +github.com/dustin/go-humanize v1.0.1 h1:GzkhY7T5VNhEkwH0PVJgjz+fX1rhBrR7pRT3mDkpeCY= +github.com/dustin/go-humanize v1.0.1/go.mod h1:Mu1zIs6XwVuF/gI1OepvI0qD18qycQx+mFykh5fBlto= +github.com/emicklei/go-restful-openapi/v2 v2.11.0 h1:Ur+yGxoOH/7KRmcj/UoMFqC3VeNc9VOe+/XidumxTvk= +github.com/emicklei/go-restful-openapi/v2 v2.11.0/go.mod h1:4CTuOXHFg3jkvCpnXN+Wkw5prVUnP8hIACssJTYorWo= +github.com/emicklei/go-restful/v3 v3.11.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/emicklei/go-restful/v3 v3.13.0 h1:C4Bl2xDndpU6nJ4bc1jXd+uTmYPVUwkD6bFY/oTyCes= +github.com/emicklei/go-restful/v3 v3.13.0/go.mod h1:6n3XBCmQQb25CM2LCACGz8ukIrRry+4bhvbpWn3mrbc= +github.com/go-logr/logr v1.2.2/go.mod h1:jdQByPbusPIv2/zmleS9BjJVeZ6kBagPoEUsqbVz/1A= +github.com/go-logr/logr v1.4.3 h1:CjnDlHq8ikf6E492q6eKboGOC0T8CDaOvkHCIg8idEI= +github.com/go-logr/logr v1.4.3/go.mod h1:9T104GzyrTigFIr8wt5mBrctHMim0Nb2HLGrmQ40KvY= +github.com/go-logr/stdr v1.2.2 h1:hSWxHoqTgW2S2qGc0LTAI563KZ5YKYRhT3MFKZMbjag= +github.com/go-logr/stdr v1.2.2/go.mod h1:mMo/vtBO5dYbehREoey6XUKy/eSumjCCveDpRre4VKE= +github.com/go-openapi/jsonpointer v0.19.3/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= +github.com/go-openapi/jsonpointer v0.19.5/go.mod h1:Pl9vOtqEWErmShwVjC8pYs9cog34VGT37dQOVbmoatg= +github.com/go-openapi/jsonpointer v0.21.0 h1:YgdVicSA9vH5RiHs9TZW5oyafXZFc6+2Vc1rr/O9oNQ= +github.com/go-openapi/jsonpointer v0.21.0/go.mod h1:IUyH9l/+uyhIYQ/PXVA41Rexl+kOkAPDdXEYns6fzUY= +github.com/go-openapi/jsonreference v0.20.0/go.mod h1:Ag74Ico3lPc+zR+qjn4XBUmXymS4zJbYVCZmcgkasdo= +github.com/go-openapi/jsonreference v0.21.0 h1:Rs+Y7hSXT83Jacb7kFyjn4ijOuVGSvOdF2+tg1TRrwQ= +github.com/go-openapi/jsonreference v0.21.0/go.mod h1:LmZmgsrTkVg9LG4EaHeY8cBDslNPMo06cago5JNLkm4= +github.com/go-openapi/spec v0.20.9/go.mod h1:2OpW+JddWPrpXSCIX8eOx7lZ5iyuWj3RYR6VaaBKcWA= +github.com/go-openapi/spec v0.21.0 h1:LTVzPc3p/RzRnkQqLRndbAzjY0d0BCL72A6j3CdL9ZY= +github.com/go-openapi/spec v0.21.0/go.mod h1:78u6VdPw81XU44qEWGhtr982gJ5BWg2c0I5XwVMotYk= +github.com/go-openapi/swag v0.19.5/go.mod h1:POnQmlKehdgb5mhVOsnJFsivZCEZ/vjK9gh66Z9tfKk= +github.com/go-openapi/swag v0.19.15/go.mod h1:QYRuS/SOXUCsnplDa677K7+DxSOj6IPNl/eQntq43wQ= +github.com/go-openapi/swag v0.23.0 h1:vsEVJDUo2hPJ2tu0/Xc+4noaxyEffXNIs3cOULZ+GrE= +github.com/go-openapi/swag v0.23.0/go.mod h1:esZ8ITTYEsH1V2trKHjAN8Ai7xHb8RV+YSZ577vPjgQ= github.com/godbus/dbus/v5 v5.0.4/go.mod h1:xhWf0FNVPg57R7Z0UbKHbJfkEywrmjJnf7w5xrFpKfA= +github.com/golang/protobuf v1.5.4 h1:i7eJL8qZTpSEXOPTxNKhASYpMn+8e5Q6AdndVa1dWek= +github.com/golang/protobuf v1.5.4/go.mod h1:lnTiLA8Wa4RWRcIUkrtSVa5nRhsEGBg48fD6rSs7xps= github.com/google/go-cmp v0.7.0 h1:wk8382ETsv4JYUZwIsn6YpYiWiBsYLSJiTsyBybVuN8= github.com/google/go-cmp v0.7.0/go.mod h1:pXiqmnSA92OHEEa9HXL2W4E7lf9JzCmGVUdgjX3N/iU= +github.com/google/gofuzz v1.0.0/go.mod h1:dBl0BpW6vV/+mYPU4Po3pmUjxk6FQPldtuIdl/M65Eg= +github.com/google/uuid v1.6.0 h1:NIvaJDMOsjHA8n1jAhLSgzrAzy1Hgr+hNrb57e+94F0= +github.com/google/uuid v1.6.0/go.mod h1:TIyPZe4MgqvfeYDBFedMoGGpEw/LqOeaOT+nhxU+yHo= +github.com/grafana/regexp v0.0.0-20240518133315-a468a5bfb3bc h1:GN2Lv3MGO7AS6PrRoT6yV5+wkrOpcszoIsO4+4ds248= +github.com/grafana/regexp v0.0.0-20240518133315-a468a5bfb3bc/go.mod h1:+JKpmjMGhpgPL+rXZ5nsZieVzvarn86asRlBg4uNGnk= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.2 h1:8Tjv8EJ+pM1xP8mK6egEbD1OgnVTyacbefKhmbLhIhU= +github.com/grpc-ecosystem/grpc-gateway/v2 v2.27.2/go.mod h1:pkJQ2tZHJ0aFOVEEot6oZmaVEZcRme73eIFmhiVuRWs= +github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= +github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= github.com/infraboard/mcube v1.9.29 h1:sta2Ca+H83sXaQFaTKAX2uVwsXKhAbFbbUr5m1El3UE= github.com/infraboard/mcube v1.9.29/go.mod h1:5VqpDng1zHVoLF9WXYelO/jV0WkxSURooVSHzMznx0U= -github.com/infraboard/mcube/v2 v2.1.3 h1:2UCceLoMkcjxp7btEZQgajyBW/Tzf7meB4OwEA8Hzs4= -github.com/infraboard/mcube/v2 v2.1.3/go.mod h1:M/UxG9LsdiBVdMKnoCnDOzr3CR7PNBXsygTbB5U6Ibg= +github.com/infraboard/mcube/v2 v2.1.4 h1:45j82fDgLnGdnuQisob8N84UikWit/NMn0aq5ErJOI0= +github.com/infraboard/mcube/v2 v2.1.4/go.mod h1:M/UxG9LsdiBVdMKnoCnDOzr3CR7PNBXsygTbB5U6Ibg= +github.com/josharian/intern v1.0.0 h1:vlS4z54oSdjm0bgjRigI+G1HpF+tI+9rE5LLzOg8HmY= +github.com/josharian/intern v1.0.0/go.mod h1:5DoeVV0s6jJacbCEi61lwdGj/aVlrQvzHFFd8Hwg//Y= +github.com/json-iterator/go v1.1.12/go.mod h1:e30LSqwooZae/UwlEbR2852Gd8hjQvJoHmT4TnhNGBo= +github.com/klauspost/compress v1.18.0 h1:c/Cqfb0r+Yi+JtIEq73FWXVkRonBlf0CRNYc8Zttxdo= +github.com/klauspost/compress v1.18.0/go.mod h1:2Pp+KzxcywXVXMr50+X0Q/Lsb43OQHYWRCY2AiWywWQ= +github.com/kr/pretty v0.1.0/go.mod h1:dAy3ld7l9f0ibDNOQOHHMYYIIbhfbHSm3C4ZsoJORNo= +github.com/kr/pretty v0.3.1 h1:flRD4NNwYAUpkphVc1HcthR4KEIFJ65n8Mw5qdRn3LE= +github.com/kr/pretty v0.3.1/go.mod h1:hoEshYVHaxMs3cyo3Yncou5ZscifuDolrwPKZanG3xk= +github.com/kr/pty v1.1.1/go.mod h1:pFQYn66WHrOpPYNljwOMqo10TkYh1fy3cYio2l3bCsQ= +github.com/kr/text v0.1.0/go.mod h1:4Jbv+DJW3UT/LiOwJeYQe1efqtUx/iVham/4vfdArNI= +github.com/kr/text v0.2.0 h1:5Nx0Ya0ZqY2ygV366QzturHI13Jq95ApcVaJBhpS+AY= +github.com/kr/text v0.2.0/go.mod h1:eLer722TekiGuMkidMxC/pM04lWEeraHUUmBw8l2grE= +github.com/kylelemons/godebug v1.1.0 h1:RPNrshWIDI6G2gRW9EHilWtl7Z6Sb1BR0xunSBf0SNc= +github.com/kylelemons/godebug v1.1.0/go.mod h1:9/0rRGxNHcop5bhtWyNeEfOS8JIWk580+fNqagV/RAw= +github.com/mailru/easyjson v0.0.0-20190614124828-94de47d64c63/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= +github.com/mailru/easyjson v0.0.0-20190626092158-b2ccc519800e/go.mod h1:C1wdFJiN94OJF2b5HbByQZoLdCWB1Yqtg26g4irojpc= +github.com/mailru/easyjson v0.7.6/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= +github.com/mailru/easyjson v0.7.7 h1:UGYAvKxe3sBsEDzO8ZeWOSlIQfWFlxbzLZe7hwFURr0= +github.com/mailru/easyjson v0.7.7/go.mod h1:xzfreul335JAWq5oZzymOObrkdz5UnU4kGfJJLY9Nlc= github.com/mattn/go-colorable v0.1.13 h1:fFA4WZxdEF4tXPZVKMLwD8oUnCTTo08duU7wxecdEvA= github.com/mattn/go-colorable v0.1.13/go.mod h1:7S9/ev0klgBDR4GtXTXX8a3vIGJpMovkB8vQcUbaXHg= github.com/mattn/go-isatty v0.0.16/go.mod h1:kYGgaQfpe5nmfYZH+SKPsOc2e4SrIfOl2e/yFXSvRLM= @@ -20,32 +85,101 @@ github.com/mattn/go-isatty v0.0.20 h1:xfD0iDuEKnDkl03q4limB+vH+GxLEtL/jb4xVJSWWE github.com/mattn/go-isatty v0.0.20/go.mod h1:W+V8PltTTMOvKvAeJH7IuucS94S2C6jfK/D7dTCTo3Y= github.com/mitchellh/mapstructure v1.5.0 h1:jeMsZIYE/09sWLaz43PL7Gy6RuMjD2eJVyuac5Z2hdY= github.com/mitchellh/mapstructure v1.5.0/go.mod h1:bFUtVrKA4DC2yAKiSyO/QUcy7e+RRV2QTWOzhPopBRo= +github.com/modern-go/concurrent v0.0.0-20180228061459-e0a39a4cb421/go.mod h1:6dJC0mAP4ikYIbvyc7fijjWJddQyLn8Ig3JB5CqoB9Q= +github.com/modern-go/reflect2 v1.0.2/go.mod h1:yWuevngMOJpCy52FWWMvUC8ws7m/LJsjYzDa0/r8luk= +github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822 h1:C3w9PqII01/Oq1c1nUAm88MOHcQC9l5mIlSMApZMrHA= +github.com/munnerz/goautoneg v0.0.0-20191010083416-a7dc8b61c822/go.mod h1:+n7T8mK8HuQTcFwEeznm/DIxMOiR9yIdICNftLE1DvQ= +github.com/niemeyer/pretty v0.0.0-20200227124842-a10e7caefd8e/go.mod h1:zD1mROLANZcx1PVRCS0qkT7pwLkGfwJo4zjcN/Tysno= github.com/pkg/errors v0.9.1 h1:FEBLx1zS214owpjy7qsBeixbURkuhQAwrK5UwLGTwt4= github.com/pkg/errors v0.9.1/go.mod h1:bwawxfHBFNV+L2hUp1rHADufV3IMtnDRdf1r5NINEl0= github.com/pmezard/go-difflib v1.0.0 h1:4DBwDE0NGyQoBHbLQYPwSUPoCMWR5BEzIk/f1lZbAQM= github.com/pmezard/go-difflib v1.0.0/go.mod h1:iKH77koFhYxTK1pcRnkKkqfTogsbg7gZNVY4sRDYZ/4= +github.com/prometheus/client_golang v1.23.1 h1:w6gXMLQGgd0jXXlote9lRHMe0nG01EbnJT+C0EJru2Y= +github.com/prometheus/client_golang v1.23.1/go.mod h1:br8j//v2eg2K5Vvna5klK8Ku5pcU5r4ll73v6ik5dIQ= +github.com/prometheus/client_model v0.6.2 h1:oBsgwpGs7iVziMvrGhE53c/GrLUsZdHnqNwqPLxwZyk= +github.com/prometheus/client_model v0.6.2/go.mod h1:y3m2F6Gdpfy6Ut/GBsUqTWZqCUvMVzSfMLjcu6wAwpE= +github.com/prometheus/common v0.66.0 h1:K/rJPHrG3+AoQs50r2+0t7zMnMzek2Vbv31OFVsMeVY= +github.com/prometheus/common v0.66.0/go.mod h1:Ux6NtV1B4LatamKE63tJBntoxD++xmtI/lK0VtEplN4= +github.com/prometheus/procfs v0.16.1 h1:hZ15bTNuirocR6u0JZ6BAHHmwS1p8B4P6MRqxtzMyRg= +github.com/prometheus/procfs v0.16.1/go.mod h1:teAbpZRB1iIAJYREa1LsoWUXykVXA1KlTmWl8x/U+Is= +github.com/rogpeppe/go-internal v1.13.1 h1:KvO1DLK/DRN07sQ1LQKScxyZJuNnedQ5/wKSR38lUII= +github.com/rogpeppe/go-internal v1.13.1/go.mod h1:uMEvuHeurkdAXX61udpOXGD/AzZDWNMNyH2VO9fmH0o= github.com/rs/xid v1.6.0/go.mod h1:7XoLgs4eV+QndskICGsho+ADou8ySMSjJKDIan90Nz0= github.com/rs/zerolog v1.34.0 h1:k43nTLIwcTVQAncfCw4KZ2VY6ukYoZaBPNOE8txlOeY= github.com/rs/zerolog v1.34.0/go.mod h1:bJsvje4Z08ROH4Nhs5iH600c3IkWhwp44iRc54W6wYQ= +github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= +github.com/spf13/cobra v1.10.1 h1:lJeBwCfmrnXthfAupyUTzJ/J4Nc1RsHC/mSRU2dll/s= +github.com/spf13/cobra v1.10.1/go.mod h1:7SmJGaTHFVBY0jW4NXGluQoLvhqFQM+6XSKD+P4XaB0= +github.com/spf13/pflag v1.0.9 h1:9exaQaMOCwffKiiiYk6/BndUBv+iRViNW+4lEMi0PvY= +github.com/spf13/pflag v1.0.9/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= +github.com/stretchr/objx v0.1.0/go.mod h1:HFkY916IF+rwdDfMAkV7OtwuqBVzrE8GR6GFx+wExME= +github.com/stretchr/testify v1.3.0/go.mod h1:M5WIy9Dh21IEIfnGCwXGc5bZfKNJtfHm1UVUgZn+9EI= +github.com/stretchr/testify v1.6.1/go.mod h1:6Fq8oRcR53rry900zMqJjRRixrwX3KX962/h/Wwjteg= github.com/stretchr/testify v1.11.1 h1:7s2iGBzp5EwR7/aIZr8ao5+dra3wiQyKjjFuvgVKu7U= github.com/stretchr/testify v1.11.1/go.mod h1:wZwfW3scLgRK+23gO65QZefKpKQRnfz6sD981Nm4B6U= +go.opentelemetry.io/auto/sdk v1.1.0 h1:cH53jehLUN6UFLY71z+NDOiNJqDdPRaXzTel0sJySYA= +go.opentelemetry.io/auto/sdk v1.1.0/go.mod h1:3wSPjt5PWp2RhlCcmmOial7AvC4DQqZb7a7wCow3W8A= +go.opentelemetry.io/contrib/instrumentation/github.com/emicklei/go-restful/otelrestful v0.62.0 h1:9LdRsKTxvzNkWbp99PX7BlLpw6FnybDjjwmUNLFehdY= +go.opentelemetry.io/contrib/instrumentation/github.com/emicklei/go-restful/otelrestful v0.62.0/go.mod h1:AyBa73p8qKi4lrBfVV8KPv3GhwqMsm3pahKetIHScQ0= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.62.0 h1:rbRJ8BBoVMsQShESYZ0FkvcITu8X8QNwJogcLUmDNNw= +go.opentelemetry.io/contrib/instrumentation/google.golang.org/grpc/otelgrpc v0.62.0/go.mod h1:ru6KHrNtNHxM4nD/vd6QrLVWgKhxPYgblq4VAtNawTQ= +go.opentelemetry.io/contrib/propagators/b3 v1.37.0 h1:0aGKdIuVhy5l4GClAjl72ntkZJhijf2wg1S7b5oLoYA= +go.opentelemetry.io/contrib/propagators/b3 v1.37.0/go.mod h1:nhyrxEJEOQdwR15zXrCKI6+cJK60PXAkJ/jRyfhr2mg= go.opentelemetry.io/otel v1.38.0 h1:RkfdswUDRimDg0m2Az18RKOsnI8UDzppJAtj01/Ymk8= go.opentelemetry.io/otel v1.38.0/go.mod h1:zcmtmQ1+YmQM9wrNsTGV/q/uyusom3P8RxwExxkZhjM= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0 h1:GqRJVj7UmLjCVyVJ3ZFLdPRmhDUp2zFmQe3RHIOsw24= +go.opentelemetry.io/otel/exporters/otlp/otlptrace v1.38.0/go.mod h1:ri3aaHSmCTVYu2AWv44YMauwAQc0aqI9gHKIcSbI1pU= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0 h1:lwI4Dc5leUqENgGuQImwLo4WnuXFPetmPpkLi2IrX54= +go.opentelemetry.io/otel/exporters/otlp/otlptrace/otlptracegrpc v1.38.0/go.mod h1:Kz/oCE7z5wuyhPxsXDuaPteSWqjSBD5YaSdbxZYGbGk= +go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0 h1:kJxSDN4SgWWTjG/hPp3O7LCGLcHXFlvS2/FFOrwL+SE= +go.opentelemetry.io/otel/exporters/stdout/stdouttrace v1.38.0/go.mod h1:mgIOzS7iZeKJdeB8/NYHrJ48fdGc71Llo5bJ1J4DWUE= +go.opentelemetry.io/otel/metric v1.38.0 h1:Kl6lzIYGAh5M159u9NgiRkmoMKjvbsKtYRwgfrA6WpA= +go.opentelemetry.io/otel/metric v1.38.0/go.mod h1:kB5n/QoRM8YwmUahxvI3bO34eVtQf2i4utNVLr9gEmI= +go.opentelemetry.io/otel/sdk v1.38.0 h1:l48sr5YbNf2hpCUj/FoGhW9yDkl+Ma+LrVl8qaM5b+E= +go.opentelemetry.io/otel/sdk v1.38.0/go.mod h1:ghmNdGlVemJI3+ZB5iDEuk4bWA3GkTpW+DOoZMYBVVg= +go.opentelemetry.io/otel/sdk/metric v1.38.0 h1:aSH66iL0aZqo//xXzQLYozmWrXxyFkBJ6qT5wthqPoM= +go.opentelemetry.io/otel/sdk/metric v1.38.0/go.mod h1:dg9PBnW9XdQ1Hd6ZnRz689CbtrUp0wMMs9iPcgT9EZA= go.opentelemetry.io/otel/trace v1.38.0 h1:Fxk5bKrDZJUH+AMyyIXGcFAPah0oRcT+LuNtJrmcNLE= go.opentelemetry.io/otel/trace v1.38.0/go.mod h1:j1P9ivuFsTceSWe1oY+EeW3sc+Pp42sO++GHkg4wwhs= +go.opentelemetry.io/proto/otlp v1.7.1 h1:gTOMpGDb0WTBOP8JaO72iL3auEZhVmAQg4ipjOVAtj4= +go.opentelemetry.io/proto/otlp v1.7.1/go.mod h1:b2rVh6rfI/s2pHWNlB7ILJcRALpcNDzKhACevjI+ZnE= +go.uber.org/goleak v1.3.0 h1:2K3zAYmnTNqV73imy9J1T3WC+gmCePx2hEGkimedGto= +go.uber.org/goleak v1.3.0/go.mod h1:CoHD4mav9JJNrW/WLlf7HGZPjdw8EucARQHekz1X6bE= go.yaml.in/yaml/v2 v2.4.2 h1:DzmwEr2rDGHl7lsFgAHxmNz/1NlQ7xLIrlN2h5d1eGI= go.yaml.in/yaml/v2 v2.4.2/go.mod h1:081UH+NErpNdqlCXm3TtEran0rJZGxAYx9hb/ELlsPU= -go.yaml.in/yaml/v3 v3.0.3 h1:bXOww4E/J3f66rav3pX3m8w6jDE4knZjGOw8b5Y6iNE= -go.yaml.in/yaml/v3 v3.0.3/go.mod h1:tBHosrYAkRZjRAOREWbDnBXUf08JOwYq++0QNwQiWzI= +go.yaml.in/yaml/v3 v3.0.4 h1:tfq32ie2Jv2UxXFdLJdh3jXuOzWiL1fo0bu/FbuKpbc= +go.yaml.in/yaml/v3 v3.0.4/go.mod h1:DhzuOOF2ATzADvBadXxruRBLzYTpT36CKvDb3+aBEFg= +golang.org/x/net v0.43.0 h1:lat02VYK2j4aLzMzecihNvTlJNQUq316m2Mr9rnM6YE= +golang.org/x/net v0.43.0/go.mod h1:vhO1fvI4dGsIjh73sWfUVjj3N7CA9WkKJNQm2svM6Jg= golang.org/x/sys v0.0.0-20220811171246-fbc7d0a398ab/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.6.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.12.0/go.mod h1:oPkhp1MJrh7nUepCBck5+mAzfO9JrbApNNgaTdGDITg= golang.org/x/sys v0.35.0 h1:vz1N37gP5bs89s7He8XuIYXpyY0+QlsKmzipCbUtyxI= golang.org/x/sys v0.35.0/go.mod h1:BJP2sWEmIv4KK5OTEluFJCKSidICx8ciO85XgH3Ak8k= -gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405 h1:yhCVgyC4o1eVCa2tZl7eS0r+SDo693bJlVdllGtEeKM= +golang.org/x/text v0.28.0 h1:rhazDwis8INMIwQ4tpjLDzUhx6RlXqZNPEM0huQojng= +golang.org/x/text v0.28.0/go.mod h1:U8nCwOR8jO/marOQ0QbDiOngZVEBB7MAiitBuMjXiNU= +gonum.org/v1/gonum v0.16.0 h1:5+ul4Swaf3ESvrOnidPp4GZbzf0mxVQpDCYUQE7OJfk= +gonum.org/v1/gonum v0.16.0/go.mod h1:fef3am4MQ93R2HHpKnLk4/Tbh/s0+wqD5nfa6Pnwy4E= +google.golang.org/genproto/googleapis/api v0.0.0-20250825161204-c5933d9347a5 h1:BIRfGDEjiHRrk0QKZe3Xv2ieMhtgRGeLcZQ0mIVn4EY= +google.golang.org/genproto/googleapis/api v0.0.0-20250825161204-c5933d9347a5/go.mod h1:j3QtIyytwqGr1JUDtYXwtMXWPKsEa5LtzIFN1Wn5WvE= +google.golang.org/genproto/googleapis/rpc v0.0.0-20250825161204-c5933d9347a5 h1:eaY8u2EuxbRv7c3NiGK0/NedzVsCcV6hDuU5qPX5EGE= +google.golang.org/genproto/googleapis/rpc v0.0.0-20250825161204-c5933d9347a5/go.mod h1:M4/wBTSeyLxupu3W3tJtOgB14jILAS/XWPSSa3TAlJc= +google.golang.org/grpc v1.75.0 h1:+TW+dqTd2Biwe6KKfhE5JpiYIBWq865PhKGSXiivqt4= +google.golang.org/grpc v1.75.0/go.mod h1:JtPAzKiq4v1xcAB2hydNlWI2RnF85XXcV0mhKXr2ecQ= +google.golang.org/protobuf v1.36.8 h1:xHScyCOEuuwZEc6UtSOvPbAT4zRh0xcNRYekJwfqyMc= +google.golang.org/protobuf v1.36.8/go.mod h1:fuxRtAxBytpl4zzqUh6/eyUujkJdNiuEkXntxiD/uRU= gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20180628173108-788fd7840127/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20200227125254-8fa46927fb4f/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c h1:Hei/4ADfdWqJk1ZMxUNpqntNwaWcugrBjAiHlqqRiVk= +gopkg.in/check.v1 v1.0.0-20201130134442-10cb98267c6c/go.mod h1:JHkPIbrfpd72SG/EVd6muEfDQjcINNoR0C8j2r3qZ4Q= gopkg.in/natefinch/lumberjack.v2 v2.2.1 h1:bBRl1b0OH9s/DuPhuXpNl+VtCaJXFZ5/uEFST95x9zc= gopkg.in/natefinch/lumberjack.v2 v2.2.1/go.mod h1:YD8tP3GAjkrDg1eZH7EGmyESg/lsYskCTPBJVb9jqSc= +gopkg.in/yaml.v2 v2.2.2/go.mod h1:hI93XBmqTisBFMUTm0b8Fm+jr3Dg1NNxqwp+5A1VGuI= +gopkg.in/yaml.v2 v2.4.0 h1:D8xgwECY7CYvx+Y2n4sBz93Jn9JRvxdiyyo8CTfuKaY= +gopkg.in/yaml.v2 v2.4.0/go.mod h1:RDklbk79AGWmwhnvt/jBztapEOGDOx6ZbXqjP6csGnQ= +gopkg.in/yaml.v3 v3.0.0-20200313102051-9f266ea9e77c/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= +gopkg.in/yaml.v3 v3.0.0-20200615113413-eeeca48fe776/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= gopkg.in/yaml.v3 v3.0.1 h1:fxVm/GzAzEWqLHuvctI91KS9hhNmmWOoWu0XTYJS7CA= gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM= sigs.k8s.io/yaml v1.6.0 h1:G8fkbMSAFqgEFgh4b1wmtzDnioxFCUgTZhlbj5P9QYs=