From b0bbf8721c215a37c2fdaa4a5a4552817f0e0893 Mon Sep 17 00:00:00 2001 From: faiq Date: Wed, 16 Oct 2024 18:00:43 -0700 Subject: [PATCH] fix: pass os Interupt to child process --- cmd/konvoy-image-wrapper/cmd/wrapper.go | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/cmd/konvoy-image-wrapper/cmd/wrapper.go b/cmd/konvoy-image-wrapper/cmd/wrapper.go index de02750b3..49ca893cc 100644 --- a/cmd/konvoy-image-wrapper/cmd/wrapper.go +++ b/cmd/konvoy-image-wrapper/cmd/wrapper.go @@ -369,17 +369,25 @@ func (r *Runner) dockerRun(args []string) error { cmd.Args = append(cmd.Args, args...) cmd.Stdout = os.Stdout cmd.Stderr = os.Stderr + subStdin, err := cmd.StdinPipe() + if err != nil { + return fmt.Errorf("failed to make pipe %w", err) + } + defer subStdin.Close() + cmd.SysProcAttr = &syscall.SysProcAttr{ + Setsid: true, + Pdeathsig: syscall.SIGKILL, + } c := make(chan os.Signal, 1) signal.Notify(c, syscall.SIGINT, syscall.SIGTERM) defer signal.Stop(c) go func() { sig := <-c - if signalErr := cmd.Process.Signal(sig); signalErr != nil { + if signalErr := cmd.Process.Signal(os.Interrupt); signalErr != nil { fmt.Fprintf(cmd.Stderr, "failed to relay signal %s %v\n", sig.String(), signalErr) } }() - - err := cmd.Run() + err = cmd.Run() if err != nil { return fmt.Errorf("cmd failed %w", err) }