From 43630c4ff034994312612fd9e8d7d0fab9e3cca8 Mon Sep 17 00:00:00 2001 From: Jeff Erbrecht Date: Wed, 3 Jul 2024 13:38:33 -0400 Subject: [PATCH] Print all arguments passed to service Previously we were only printing the service start arguments (which we don't populate) and not the actual command-line arguments (which we do populate). Also remove a line that was printing garbage. --- .../main_windows.go | 11 +++++------ cmd/ops_agent_windows/run_windows.go | 10 +++++----- 2 files changed, 10 insertions(+), 11 deletions(-) diff --git a/cmd/google_cloud_ops_agent_diagnostics/main_windows.go b/cmd/google_cloud_ops_agent_diagnostics/main_windows.go index deb373893f..62952cb3b9 100644 --- a/cmd/google_cloud_ops_agent_diagnostics/main_windows.go +++ b/cmd/google_cloud_ops_agent_diagnostics/main_windows.go @@ -72,7 +72,10 @@ func (s *service) Execute(args []string, r <-chan svc.ChangeRequest, changes cha const cmdsAccepted = svc.AcceptStop | svc.AcceptShutdown changes <- svc.Status{State: svc.StartPending} - if err := s.parseFlags(args); err != nil { + + allArgs := append([]string{}, os.Args[1:]...) + allArgs = append(allArgs, args[1:]...) + if err := s.parseFlags(allArgs); err != nil { s.log.Error(DiagnosticsEventID, fmt.Sprintf("failed to parse arguments: %v", err)) return false, ERROR_INVALID_PARAMETER } @@ -122,9 +125,5 @@ func (s *service) parseFlags(args []string) error { s.log.Info(DiagnosticsEventID, fmt.Sprintf("args: %#v", args)) var fs flag.FlagSet fs.StringVar(&s.userConf, "config", "", "path to the user specified agent config") - s.log.Info(DiagnosticsEventID, s.userConf) - - allArgs := append([]string{}, os.Args[1:]...) - allArgs = append(allArgs, args[1:]...) - return fs.Parse(allArgs) + return fs.Parse(args) } diff --git a/cmd/ops_agent_windows/run_windows.go b/cmd/ops_agent_windows/run_windows.go index a106f4495f..8f2fe7480a 100644 --- a/cmd/ops_agent_windows/run_windows.go +++ b/cmd/ops_agent_windows/run_windows.go @@ -59,7 +59,10 @@ func (s *service) Execute(args []string, r <-chan svc.ChangeRequest, changes cha defer cancel() const cmdsAccepted = svc.AcceptStop | svc.AcceptShutdown changes <- svc.Status{State: svc.StartPending} - if err := s.parseFlags(args); err != nil { + + allArgs := append([]string{}, os.Args[1:]...) + allArgs = append(allArgs, args[1:]...) + if err := s.parseFlags(allArgs); err != nil { s.log.Error(EngineEventID, fmt.Sprintf("failed to parse arguments: %v", err)) // ERROR_INVALID_ARGUMENT return false, 0x00000057 @@ -104,10 +107,7 @@ func (s *service) parseFlags(args []string) error { var fs flag.FlagSet fs.StringVar(&s.userConf, "in", "", "path to the user specified agent config") fs.StringVar(&s.outDirectory, "out", "", "directory to write generated configuration files to") - - allArgs := append([]string{}, os.Args[1:]...) - allArgs = append(allArgs, args[1:]...) - return fs.Parse(allArgs) + return fs.Parse(args) } func (s *service) checkForStandaloneAgents(unified *confgenerator.UnifiedConfig) error {