From 8c1ed7254f63e19dad015c2f7b71788a02df101b Mon Sep 17 00:00:00 2001 From: Magnus Gule Date: Sat, 11 Jan 2025 20:40:25 +0100 Subject: [PATCH] fix closing some custom commands on Windows (#3981) * Bugfix: Rewrote addProcessToGroup. Fixed possible invalid process handle by using windows.OpenProcess instead. Fixes issue: 3980 * run gofumpt --------- Co-authored-by: aler9 <46489434+aler9@users.noreply.github.com> --- internal/externalcmd/cmd_win.go | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/internal/externalcmd/cmd_win.go b/internal/externalcmd/cmd_win.go index e424d49d806..5c6d2df02fa 100644 --- a/internal/externalcmd/cmd_win.go +++ b/internal/externalcmd/cmd_win.go @@ -44,13 +44,21 @@ func closeProcessGroup(h windows.Handle) error { } func addProcessToGroup(h windows.Handle, p *os.Process) error { - type process struct { - Pid int - Handle uintptr + // Combine the required access rights + access := uint32(windows.PROCESS_SET_QUOTA | windows.PROCESS_TERMINATE) + + processHandle, err := windows.OpenProcess(access, false, uint32(p.Pid)) + if err != nil { + return fmt.Errorf("failed to open process: %v", err) + } + defer windows.CloseHandle(processHandle) + + err = windows.AssignProcessToJobObject(h, processHandle) + if err != nil { + return fmt.Errorf("failed to assign process to job object: %v", err) } - return windows.AssignProcessToJobObject(h, - windows.Handle((*process)(unsafe.Pointer(p)).Handle)) + return nil } func (e *Cmd) runOSSpecific(env []string) error {