Merge pull request #3475 from stefanberger/gpg2-passphrase-via-file
ECI: gpg: Pass the passphrase to the gpg2 tool using a pipe
This commit is contained in:
commit
f0821348b4
@ -131,9 +131,24 @@ func (gc *gpgv2Client) GetGPGPrivateKey(keyid uint64, passphrase string) ([]byte
|
|||||||
args = append(args, []string{"--homedir", gc.gpgHomeDir}...)
|
args = append(args, []string{"--homedir", gc.gpgHomeDir}...)
|
||||||
}
|
}
|
||||||
|
|
||||||
args = append(args, []string{"--pinentry-mode", "loopback", "--batch", "--passphrase", passphrase, "--export-secret-key", fmt.Sprintf("0x%x", keyid)}...)
|
rfile, wfile, err := os.Pipe()
|
||||||
|
if err != nil {
|
||||||
|
return nil, errors.Wrapf(err, "could not create pipe")
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
rfile.Close()
|
||||||
|
wfile.Close()
|
||||||
|
}()
|
||||||
|
// fill pipe in background
|
||||||
|
go func(passphrase string) {
|
||||||
|
wfile.Write([]byte(passphrase))
|
||||||
|
wfile.Close()
|
||||||
|
}(passphrase)
|
||||||
|
|
||||||
|
args = append(args, []string{"--pinentry-mode", "loopback", "--batch", "--passphrase-fd", fmt.Sprintf("%d", 3), "--export-secret-key", fmt.Sprintf("0x%x", keyid)}...)
|
||||||
|
|
||||||
cmd := exec.Command("gpg2", args...)
|
cmd := exec.Command("gpg2", args...)
|
||||||
|
cmd.ExtraFiles = []*os.File{rfile}
|
||||||
|
|
||||||
return runGPGGetOutput(cmd)
|
return runGPGGetOutput(cmd)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user